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

Contents of /branches/4.x/src/commands/automation/ScheduleCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (show annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months ago) by rakinar2
File MIME type: application/typescript
File size: 4540 byte(s)
chore: add old version archive branches (2.x to 9.x-dev)
1 /**
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 ScheduleMessageQueue from '../../queues/ScheduleMessageQueue';
28
29 export default class ScheduleCommand extends BaseCommand {
30 supportsInteractions = true;
31 permissions = [Permissions.FLAGS.MANAGE_MESSAGES];
32
33 constructor() {
34 super('schedule', '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 timeout = await setTimeoutv2('send', time, msg.guild!.id, `schedule ${time} ${text!} #${channel.name}`, text!, channel.id, msg.guild!.id);
97
98 const { id } = await client.queueManager.addQueue(ScheduleMessageQueue, {
99 data: {
100 guildID: msg.guild!.id,
101 channelID: msg.channel!.id,
102 content: text
103 },
104 runAt: new Date(Date.now() + time),
105 guild: msg.guild!.id,
106 });
107
108 await msg.reply({
109 embeds: [
110 new MessageEmbed()
111 .setDescription('A queue job has been added.')
112 .setFooter({
113 text: 'ID: ' + id // timeout.row.id
114 })
115 ],
116 ephemeral: true
117 });
118 }
119 catch(e) {
120 console.log(e);
121
122 await msg.reply({
123 embeds: [
124 new MessageEmbed()
125 .setColor('#f14a60')
126 .setDescription(`I don't have enough permission to send messages on this channel.`)
127 ]
128 });
129
130 return;
131 }
132
133 if (msg instanceof Message) {
134 await msg.react('⏰');
135 }
136 }
137 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26