/[sudobot]/branches/4.x/src/commands/moderation/ReportCommand.ts
ViewVC logotype

Contents of /branches/4.x/src/commands/moderation/ReportCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (show annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months, 1 week ago) by rakinar2
File MIME type: application/typescript
File size: 6410 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 { ModalSubmitInteraction } from 'discord-modals';
21 import { Message, Interaction, CacheType, MessageContextMenuInteraction, Modal, MessageActionRow, TextInputComponent, TextChannel, GuildMember } from 'discord.js';
22 import DiscordClient from '../../client/Client';
23 import MessageEmbed from '../../client/MessageEmbed';
24 import CommandOptions from '../../types/CommandOptions';
25 import InteractionOptions from '../../types/InteractionOptions';
26 import BaseCommand from '../../utils/structures/BaseCommand';
27
28 export default class ReportCommand extends BaseCommand {
29 name = "Report Message";
30 category = "moderation";
31 ids: { [randomId: string]: Message } = {};
32 supportsInteractions = true;
33 supportsContextMenu = true;
34
35 async modalSubmit(client: DiscordClient, interaction: ModalSubmitInteraction): Promise<void> {
36 if (!(await this.verify(client, interaction))) {
37 return;
38 }
39
40 const { customId, guild } = interaction;
41 const targetMessage = this.ids[customId];
42
43 if (!targetMessage) {
44 await interaction.reply({ content: "Whoops! Something unexpected happened here! Please try again", ephemeral: true });
45 return;
46 }
47
48 try {
49 const { logging_channel } = client.config.props[guild!.id] ?? {};
50 const channel = <TextChannel> await guild!.channels.fetch(logging_channel);
51
52 if (channel && channel.send) {
53 await channel.send({
54 embeds: [
55 new MessageEmbed({
56 author: {
57 name: targetMessage.author.tag,
58 iconURL: targetMessage.author.displayAvatarURL(),
59 },
60 description: targetMessage.content ?? '*No Content*',
61 title: 'Message Reported',
62 fields: [
63 {
64 name: "Reported by",
65 value: interaction.user!.tag
66 }
67 ],
68 footer: {
69 text: 'Report Received'
70 }
71 })
72 .setTimestamp()
73 .setColor('#f14a60')
74 ],
75 files: [...targetMessage.attachments.values()],
76 stickers: [...targetMessage.stickers.values()]
77 });
78 }
79 }
80 catch (e) {
81 console.log(e);
82 await interaction.reply({ content: "Could not report that message. An internal error has occurred.", ephemeral: true });
83 return;
84 }
85
86 try {
87 await targetMessage.delete();
88 }
89 catch (e) {
90 await interaction.reply({ content: "Could not remove that message. Probably the author has deleted it or I don't have enough permissions.", ephemeral: true });
91 return;
92 }
93
94 await interaction.reply({ content: "The message has been reported. Moderators will take action soon.", ephemeral: true });
95 }
96
97 async verify(client: DiscordClient, interaction: MessageContextMenuInteraction | ModalSubmitInteraction) {
98 const member = interaction.member as GuildMember;
99 const config = client.config.props[member.guild.id].reports;
100
101 if (!config.enabled) {
102 await interaction.reply({ ephemeral: true, content: "Message reports are disabled in this server." });
103 return false;
104 }
105
106 if (member.roles.cache.has(client.config.props[(interaction.member as GuildMember).guild.id].mod_role)) {
107 return true;
108 }
109
110 if (config.mod_only && !member.roles.cache.has(client.config.props[(interaction.member as GuildMember).guild.id].mod_role)) {
111 await interaction.reply({ ephemeral: true, content: "Only moderators can report messages." });
112 return false;
113 }
114
115 for (const roleID of config.reporter_roles) {
116 if (roleID === 'everyone') {
117 return true;
118 }
119
120 if (member.roles.cache.has(roleID)) {
121 return true;
122 }
123 }
124
125 if (config.reporters.includes(interaction.member!.user.id)) {
126 return true;
127 }
128
129 await interaction.reply({ ephemeral: true, content: "You're not permitted to report messages." });
130 return false;
131 }
132
133 async run(client: DiscordClient, interaction: MessageContextMenuInteraction, options: InteractionOptions): Promise<void> {
134 if (!(await this.verify(client, interaction))) {
135 return;
136 }
137
138 const randomId = 'report_modal_' + Math.round(Math.random() * 10000000);
139 const { targetMessage } = interaction;
140 const modal = new Modal()
141 .setCustomId(randomId)
142 .setTitle("Report Message")
143 .addComponents(
144 new MessageActionRow<TextInputComponent>()
145 .addComponents(
146 new TextInputComponent()
147 .setCustomId('reason')
148 .setLabel("Reason")
149 .setPlaceholder("Why are you reporting this message?")
150 .setMinLength(1)
151 .setRequired(true)
152 .setStyle('PARAGRAPH')
153 )
154 );
155
156 await interaction.showModal(modal);
157 this.ids[randomId] = targetMessage as Message;
158 }
159 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26