/[sudobot]/branches/3.x/src/events/message/MessageCreateEvent.ts
ViewVC logotype

Contents of /branches/3.x/src/events/message/MessageCreateEvent.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: 4037 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 BaseEvent from '../../utils/structures/BaseEvent';
21 import { FileOptions, Message } from 'discord.js';
22 import DiscordClient from '../../client/Client';
23 import CommandOptions from '../../types/CommandOptions';
24 import path from 'path';
25 import MessageEmbed from '../../client/MessageEmbed';
26
27 export default class MessageCreateEvent extends BaseEvent {
28 constructor() {
29 super('messageCreate');
30 }
31
32 async run(client: DiscordClient, message: Message) {
33 if (message.author.bot || !message.guild || message.channel.type === 'DM')
34 return;
35
36 await client.setMessage(message);
37
38 await client.spamFilter.start(message);
39 await client.messageFilter.start(message);
40
41 if (message.content.startsWith(client.config.get('prefix'))) {
42 const [cmdName, ...args] = await message.content
43 .slice(client.config.get('prefix').length)
44 .trim()
45 .split(/ +/);
46
47 const command = await client.commands.get(cmdName);
48
49 if (command && command.supportsLegacy) {
50 const allowed = await client.auth.verify(message.member!, command);
51
52 if (allowed) {
53 if (!(await client.cooldown.onMessageCreate(message, command))) {
54 console.log(`Skipping execution of command \'${cmdName}\' - Cooldown`);
55 return;
56 }
57
58 const options = {
59 cmdName,
60 args,
61 argv: [cmdName, ...args],
62 normalArgs: args.filter(a => a[0] !== '-'),
63 options: args.filter(a => a[0] === '-'),
64 isInteraction: false
65 } as CommandOptions;
66
67 await command.execute(client, message, options);
68 }
69 else {
70 await message.reply({
71 embeds: [
72 new MessageEmbed()
73 .setColor('#f14a60')
74 .setDescription(":x: You don't have permission to run this command.")
75 ]
76 });
77 }
78
79 return;
80 }
81
82 const snippet = await client.snippetManager.getParsed(message.guild!.id, cmdName);
83
84 if (snippet) {
85 try {
86 await message.channel.send({
87 content: snippet.content.trim() === '' ? undefined : snippet.content,
88 files: snippet.files.map(name => {
89 return {
90 name,
91 attachment: path.resolve(process.env.SUDO_PREFIX ?? path.join(__dirname, '../../..'), 'storage', name)
92 } as FileOptions
93 }),
94 embeds: snippet.embeds
95 });
96 }
97 catch (e) {
98 console.log(e);
99 }
100
101 return;
102 }
103 }
104
105 await client.afkEngine.start(message);
106 }
107 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26