/[sudobot]/branches/5.x/src/commands/automation/ScheduleAndExpireCommand.ts
ViewVC logotype

Contents of /branches/5.x/src/commands/automation/ScheduleAndExpireCommand.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: 6031 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-2023 OSN Developers.
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 { Message, PermissionsBitField, SlashCommandBuilder, TextBasedChannel } from "discord.js";
21 import path from "path";
22 import Command, { ArgumentType, BasicCommandContext, CommandMessage, CommandReturn, ValidationRule } from "../../core/Command";
23 import QueueEntry from "../../utils/QueueEntry";
24 import { stringToTimeInterval } from "../../utils/datetime";
25 import { logError } from "../../utils/logger";
26
27 export default class ScheduleAndExpireCommand extends Command {
28 public readonly name = "scheduleandexpire";
29 public readonly validationRules: ValidationRule[] = [
30 {
31 types: [ArgumentType.TimeInterval],
32 minValue: 1,
33 minMaxErrorMessage: "Please specify a valid time interval!",
34 requiredErrorMessage: "Please specify after how long the message should be sent!",
35 typeErrorMessage: "Please specify a valid time interval!",
36 timeMilliseconds: true,
37 name: "time_interval_send"
38 },
39 {
40 types: [ArgumentType.TimeInterval],
41 minValue: 1,
42 minMaxErrorMessage: "Please specify a valid deletion time interval!",
43 requiredErrorMessage: "Please specify after how long the message should be deleted!",
44 typeErrorMessage: "Please specify a valid deletion time interval!",
45 timeMilliseconds: true,
46 name: "time_interval_remove"
47 },
48 {
49 types: [ArgumentType.StringRest],
50 optional: true,
51 requiredErrorMessage: "Please specify a message content!",
52 typeErrorMessage: "Please specify a valid message content!",
53 name: "content"
54 }
55 ];
56 public readonly permissions = [PermissionsBitField.Flags.ManageMessages];
57 public readonly aliases = ["expiresc", "scex", "schedulexp"];
58
59 public readonly description = "Sends a message and deletes it after the given primary and secondary timeframe, respectively.";
60 public readonly argumentSyntaxes = ["<send_after> <expire_after> [content]"];
61 public readonly slashCommandBuilder = new SlashCommandBuilder()
62 .addStringOption(option => option.setName("content").setDescription("The message content").setRequired(true))
63 .addStringOption(option =>
64 option
65 .setName("send_after")
66 .setDescription("Specify the time after the bot should send the message")
67 .setRequired(true)
68 )
69 .addStringOption(option =>
70 option
71 .setName("expire_after")
72 .setDescription("Specify the time after the bot should remove the message")
73 .setRequired(true)
74 )
75 .addChannelOption(option =>
76 option
77 .setName("channel")
78 .setDescription("The channel where the message will be sent, defaults to the current channel")
79 );
80
81 async execute(message: CommandMessage, context: BasicCommandContext): Promise<CommandReturn> {
82 await this.deferIfInteraction(message);
83
84 let timeIntervalSend = context.isLegacy
85 ? context.parsedNamedArgs.time_interval_send
86 : context.options.getString("send_after", true);
87
88 if (!context.isLegacy) {
89 const { error, result } = stringToTimeInterval(timeIntervalSend, {
90 milliseconds: true
91 });
92
93 if (error) {
94 await this.error(message, error);
95 return;
96 }
97
98 timeIntervalSend = result;
99 }
100
101 let timeIntervalRemove = context.isLegacy
102 ? context.parsedNamedArgs.time_interval_remove
103 : context.options.getString("expire_after", true);
104
105 if (!context.isLegacy) {
106 const { error, result } = stringToTimeInterval(timeIntervalRemove, {
107 milliseconds: true
108 });
109
110 if (error) {
111 await this.error(message, error);
112 return;
113 }
114
115 timeIntervalRemove = result;
116 }
117
118 const content: string = context.isLegacy ? context.parsedNamedArgs.content : context.options.getString("content");
119 const channel = (
120 context.isLegacy ? message.channel! : context.options.getChannel("channel") ?? message.channel!
121 ) as TextBasedChannel;
122
123 if (!channel.isTextBased()) {
124 await this.error(message, "Cannot send messages to a non-text based channel!");
125 return;
126 }
127
128 await this.client.queueManager.add(
129 new QueueEntry({
130 args: [channel.id, timeIntervalRemove.toString(), content],
131 client: this.client,
132 createdAt: new Date(),
133 filePath: path.resolve(__dirname, "../../queues/ScheduleAndExpireMessageQueue"),
134 guild: message.guild!,
135 name: "ScheduleAndExpireMessageQueue",
136 userId: message.member!.user.id,
137 willRunAt: new Date(Date.now() + timeIntervalSend)
138 })
139 );
140
141 if (message instanceof Message) {
142 await message.react(this.emoji("check")).catch(logError);
143 } else {
144 await this.success(message, "Successfully scheduled message.");
145 }
146 }
147 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26