/[sudobot]/branches/4.x/src/commands/automation/ExpireCommand.ts
ViewVC logotype

Annotation of /branches/4.x/src/commands/automation/ExpireCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (hide annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months, 1 week ago) by rakinar2
File MIME type: application/typescript
File size: 4656 byte(s)
chore: add old version archive branches (2.x to 9.x-dev)
1 rakinar2 577 /**
2     * This file is part of SudoBot.
3     *
4     * Copyright (C) 2021-2022 OSN Inc.
5     *
6     * SudoBot is free software; you can redistribute it and/or modify it
7     * under the terms of the GNU Affero General Public License as published by
8     * the Free Software Foundation, either version 3 of the License, or
9     * (at your option) any later version.
10     *
11     * SudoBot is distributed in the hope that it will be useful, but
12     * WITHOUT ANY WARRANTY; without even the implied warranty of
13     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14     * GNU Affero General Public License for more details.
15     *
16     * You should have received a copy of the GNU Affero General Public License
17     * along with SudoBot. If not, see <https://www.gnu.org/licenses/>.
18     */
19    
20     import { CommandInteraction, Message, Permissions, TextChannel } from 'discord.js';
21     import BaseCommand from '../../utils/structures/BaseCommand';
22     import DiscordClient from '../../client/Client';
23     import CommandOptions from '../../types/CommandOptions';
24     import InteractionOptions from '../../types/InteractionOptions';
25     import MessageEmbed from '../../client/MessageEmbed';
26     import ms from 'ms';
27     import ExpireMessageQueue from '../../queues/ExpireMessageQueue';
28    
29     export default class ExpireCommand extends BaseCommand {
30     permissions = [Permissions.FLAGS.MANAGE_MESSAGES];
31     supportsInteractions = true;
32    
33     constructor() {
34     super('expire', 'automation', []);
35     }
36    
37     async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
38     if (!options.isInteraction && options.args[1] === undefined) {
39     await msg.reply({
40     embeds: [
41     new MessageEmbed()
42     .setColor('#f14a60')
43     .setDescription(`This command requires at least two arguments.`)
44     ]
45     });
46    
47     return;
48     }
49    
50     const time = ms(options.isInteraction ? <string> await options.options.getString('time') : options.args[0]);
51    
52     if (!time) {
53     await msg.reply({
54     embeds: [
55     new MessageEmbed()
56     .setColor('#f14a60')
57     .setDescription(`Invalid time interval given.`)
58     ]
59     });
60    
61     return;
62     }
63    
64     let channel: TextChannel = <TextChannel> msg.channel;
65     let text: string;
66    
67     if (options.isInteraction) {
68     if (options.options.getChannel('channel')) {
69     channel = <TextChannel> await options.options.getChannel('channel');
70     }
71    
72     text = <string> await options.options.getString('content');
73     }
74     else if (msg instanceof Message) {
75     const args = [...options.args];
76     args.shift();
77    
78     if (msg.mentions.channels.last()) {
79     channel = await <TextChannel> msg.mentions.channels.last();
80     args.pop();
81     }
82    
83     text = args.join(' ');
84     }
85    
86     if (!channel.send) {
87     await msg.reply({
88     content: 'Invalid text channel.',
89     ephemeral: true
90     });
91    
92     return;
93     }
94    
95     try {
96     const message = await channel.send({
97     content: text!
98     });
99    
100     //const timeout = await setTimeoutv2('expire', time, msg.guild!.id, `expire ${time} ${text!} #${channel.name}`, message.id, channel.id, msg.guild!.id);
101    
102     const { id } = await client.queueManager.addQueue(ExpireMessageQueue, {
103     data: {
104     messageID: message.id,
105     guildID: message.guild!.id,
106     channelID: message.channel.id
107     },
108     runAt: new Date(Date.now() + time),
109     guild: message.guild!.id
110     });
111    
112     await msg.reply({
113     embeds: [
114     new MessageEmbed()
115     .setDescription('A queue job has been added.')
116     .setFooter({
117     text: `ID: ${id}` // timeout.row.id
118     })
119     ],
120     ephemeral: true
121     });
122     }
123     catch(e) {
124     console.log(e);
125    
126     await msg.reply({
127     embeds: [
128     new MessageEmbed()
129     .setColor('#f14a60')
130     .setDescription(`I don't have enough permission to send messages on this channel.`)
131     ]
132     });
133    
134     return;
135     }
136    
137     if (msg instanceof Message) {
138     await msg.react('⏰');
139     }
140     }
141     }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26