/[sudobot]/branches/3.x/src/commands/utils/AddsnippetCommand.ts
ViewVC logotype

Contents of /branches/3.x/src/commands/utils/AddsnippetCommand.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: 3926 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, MessageAttachment } 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 { download } from '../../utils/util';
27 import path from 'path';
28 import { fetchEmoji } from '../../utils/Emoji';
29
30 export default class AddsnippetCommand extends BaseCommand {
31 constructor() {
32 super('addsnippet', 'utils', []);
33 }
34
35 async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
36 if (!options.isInteraction && options.args[1] === undefined) {
37 await msg.reply({
38 embeds: [
39 new MessageEmbed()
40 .setColor('#f14a60')
41 .setDescription(`This command requires at least two arguments.`)
42 ]
43 });
44
45 return;
46 }
47
48 let name: string;
49 let content: string;
50 let files: MessageAttachment[] = [];
51 let filenames: string[] = [];
52
53 if (options.isInteraction) {
54 await (msg as CommandInteraction).deferReply();
55 name = <string> await options.options.getString('name');
56 content = <string> await options.options.getString('content');
57
58 if (options.options.getAttachment('file'))
59 files.push(await options.options.getAttachment('file')!);
60 }
61 else {
62 name = options.args[0];
63 options.args.shift();
64 content = options.args.join(' ');
65
66 if ((msg as Message).attachments.first()) {
67 files = (msg as Message).attachments.map(a => {
68 return {
69 name: a.name,
70 url: a.proxyURL
71 } as MessageAttachment;
72 });
73 }
74 }
75
76 if (client.snippetManager.get(msg.guild!.id, name)) {
77 await this.deferReply(msg, {
78 embeds: [
79 new MessageEmbed()
80 .setColor('#f14a60')
81 .setDescription("A snippet already exists with that name.")
82 ]
83 });
84
85 return;
86 }
87
88 for await (const file of files) {
89 try {
90 let filename = Math.round(Math.random() * 1000000) + '_' + file.name!;
91 filenames.push(filename);
92 await download(file.url, path.resolve(process.env.SUDO_PREFIX ?? path.join(__dirname, '../../..'), 'storage', filename));
93 }
94 catch (e) {
95 console.log(e);
96 }
97 }
98
99 await client.snippetManager.set(msg.guild!.id, name, content, filenames);
100 await client.snippetManager.write();
101
102 await this.deferReply(msg, {
103 embeds: [
104 new MessageEmbed()
105 .setDescription((await fetchEmoji('check'))!.toString() + " Snippet created")
106 ]
107 });
108 }
109 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26