/[sudobot]/trunk/src/commands/moderation/KickCommand.ts
ViewVC logotype

Diff of /trunk/src/commands/moderation/KickCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 86 by rakin, Mon Jul 29 17:28:32 2024 UTC revision 393 by rakin, Mon Jul 29 17:29:59 2024 UTC
# Line 1  Line 1 
1  import { BanOptions, CommandInteraction, GuildMember, Interaction, Message, User } from 'discord.js';  /**
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, ContextMenuInteraction, GuildMember, Message, Permissions, User } from 'discord.js';
21  import BaseCommand from '../../utils/structures/BaseCommand';  import BaseCommand from '../../utils/structures/BaseCommand';
22  import DiscordClient from '../../client/Client';  import DiscordClient from '../../client/Client';
23  import CommandOptions from '../../types/CommandOptions';  import CommandOptions from '../../types/CommandOptions';
24  import InteractionOptions from '../../types/InteractionOptions';  import InteractionOptions from '../../types/InteractionOptions';
25  import MessageEmbed from '../../client/MessageEmbed';  import MessageEmbed from '../../client/MessageEmbed';
 import getUser from '../../utils/getUser';  
26  import getMember from '../../utils/getMember';  import getMember from '../../utils/getMember';
 import History from '../../automod/History';  
27  import Punishment from '../../models/Punishment';  import Punishment from '../../models/Punishment';
28  import PunishmentType from '../../types/PunishmentType';  import PunishmentType from '../../types/PunishmentType';
29    import { hasPermission, shouldNotModerate } from '../../utils/util';
30    
31  export default class KickCommand extends BaseCommand {  export default class KickCommand extends BaseCommand {
32      supportsInteractions: boolean = true;      supportsInteractions: boolean = true;
33        supportsContextMenu: boolean = true;
34        
35        permissions = [Permissions.FLAGS.KICK_MEMBERS];
36    
37      constructor() {      constructor() {
38          super('kick', 'moderation', []);          super('kick', 'moderation', ['Kick']);
39      }      }
40    
41      async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {      async run(client: DiscordClient, msg: Message | CommandInteraction | ContextMenuInteraction, options: CommandOptions | InteractionOptions) {
42          if (!options.isInteraction && typeof options.args[0] === 'undefined') {          if (!options.isInteraction && typeof options.args[0] === 'undefined') {
43              await msg.reply({              await msg.reply({
44                  embeds: [                  embeds: [
# Line 34  export default class KickCommand extends Line 55  export default class KickCommand extends
55          let reason: string | undefined;          let reason: string | undefined;
56    
57          if (options.isInteraction) {          if (options.isInteraction) {
58              user = await <GuildMember> options.options.getMember('member');              user = await <GuildMember> (msg instanceof ContextMenuInteraction ? options.options.getMember('user') : options.options.getMember('member'));
59    
60              if (!user) {              if (!user) {
61                  await msg.reply({                  await msg.reply({
# Line 84  export default class KickCommand extends Line 105  export default class KickCommand extends
105          }          }
106    
107          try {          try {
108              if (!user.kickable)              if (!(await hasPermission(client, user, msg, null, "You don't have permission to kick this user."))) {
109                    return;
110                }
111                
112                if (!user.kickable || shouldNotModerate(client, user))
113                  throw new Error('User not kickable');                  throw new Error('User not kickable');
114                            
115              await user.kick(reason);              await user.kick(reason);
# Line 95  export default class KickCommand extends Line 120  export default class KickCommand extends
120                  guild_id: msg.guild!.id,                  guild_id: msg.guild!.id,
121                  mod_id: msg.member!.user.id,                  mod_id: msg.member!.user.id,
122                  mod_tag: (msg.member!.user as User).tag,                  mod_tag: (msg.member!.user as User).tag,
123                  reason                  reason,
124                    createdAt: new Date()
125              });              });
126    
127              await History.create(user.id, msg.guild!, 'kick', msg.member!.user.id, typeof reason === 'undefined' ? null : reason);              // await History.create(user.id, msg.guild!, 'kick', msg.member!.user.id, typeof reason === 'undefined' ? null : reason);
128          }          }
129          catch (e) {          catch (e) {
130              await msg.reply({              await msg.reply({
# Line 133  export default class KickCommand extends Line 159  export default class KickCommand extends
159              ]              ]
160          });          });
161      }      }
 }  
162    }

Legend:
Removed from v.86  
changed lines
  Added in v.393

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26