mirror of
https://github.com/veganhacktivists/arabot.git
synced 2025-05-19 10:34:16 +02:00
feat(arabot): add temp ban command
This commit is contained in:
parent
48125ba896
commit
cd8ecd527b
205
src/commands/mod/ban/tempBan.ts
Normal file
205
src/commands/mod/ban/tempBan.ts
Normal file
@ -0,0 +1,205 @@
|
|||||||
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
/*
|
||||||
|
Animal Rights Advocates Discord Bot
|
||||||
|
Copyright (C) 2023 Anthony Berg
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { Command, RegisterBehavior } from '@sapphire/framework';
|
||||||
|
import { Duration, DurationFormatter } from '@sapphire/time-utilities';
|
||||||
|
import type {
|
||||||
|
User,
|
||||||
|
Snowflake,
|
||||||
|
TextChannel,
|
||||||
|
Guild,
|
||||||
|
} from 'discord.js';
|
||||||
|
import { EmbedBuilder } from 'discord.js';
|
||||||
|
import IDs from '#utils/ids';
|
||||||
|
import { addTempBan, checkTempBan } from '#utils/database/tempBan';
|
||||||
|
import { addEmptyUser, updateUser, userExists } from '#utils/database/dbExistingUser';
|
||||||
|
|
||||||
|
export class TempBanCommand extends Command {
|
||||||
|
public constructor(context: Command.Context, options: Command.Options) {
|
||||||
|
super(context, {
|
||||||
|
...options,
|
||||||
|
name: 'tempban',
|
||||||
|
description: 'Bans a user for a certain amount of time',
|
||||||
|
preconditions: ['RestrictedAccessOnly'],
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Registers that this is a slash command
|
||||||
|
public override registerApplicationCommands(registry: Command.Registry) {
|
||||||
|
registry.registerChatInputCommand(
|
||||||
|
(builder) => builder
|
||||||
|
.setName(this.name)
|
||||||
|
.setDescription(this.description)
|
||||||
|
.addUserOption((option) => option.setName('user')
|
||||||
|
.setDescription('User to ban')
|
||||||
|
.setRequired(true))
|
||||||
|
.addStringOption((option) => option.setName('duration')
|
||||||
|
.setDescription('How long to ban the user for')
|
||||||
|
.setRequired(true))
|
||||||
|
.addStringOption((option) => option.setName('reason')
|
||||||
|
.setDescription('Note about the user')
|
||||||
|
.setRequired(true)),
|
||||||
|
{
|
||||||
|
behaviorWhenNotIdentical: RegisterBehavior.Overwrite,
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Command run
|
||||||
|
public async chatInputRun(interaction: Command.ChatInputCommandInteraction) {
|
||||||
|
// Get the arguments
|
||||||
|
const user = interaction.options.getUser('user', true);
|
||||||
|
const duration = interaction.options.getString('duration', true);
|
||||||
|
const reason = interaction.options.getString('reason', true);
|
||||||
|
const mod = interaction.member;
|
||||||
|
const { guild } = interaction;
|
||||||
|
|
||||||
|
// Checks if all the variables are of the right type
|
||||||
|
if (guild === null || mod === null) {
|
||||||
|
await interaction.reply({
|
||||||
|
content: 'Error fetching user!',
|
||||||
|
ephemeral: true,
|
||||||
|
fetchReply: true,
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const time = new Duration(duration);
|
||||||
|
|
||||||
|
if (Number.isNaN(time.offset)) {
|
||||||
|
await interaction.reply({
|
||||||
|
content: 'Invalid ban duration input',
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const ban = await this.ban(user.id, mod.user.id, time, reason, guild);
|
||||||
|
|
||||||
|
await interaction.reply({ content: ban.message });
|
||||||
|
}
|
||||||
|
|
||||||
|
private async ban(
|
||||||
|
userId: Snowflake,
|
||||||
|
modId: Snowflake,
|
||||||
|
time: Duration,
|
||||||
|
reason: string,
|
||||||
|
guild: Guild,
|
||||||
|
) {
|
||||||
|
const info = {
|
||||||
|
message: '',
|
||||||
|
success: false,
|
||||||
|
};
|
||||||
|
|
||||||
|
const banLength = new DurationFormatter().format(time.offset);
|
||||||
|
|
||||||
|
let user = guild.client.users.cache.get(userId);
|
||||||
|
|
||||||
|
if (user === undefined) {
|
||||||
|
user = await guild.client.users.fetch(userId) as User;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Gets mod's GuildMember
|
||||||
|
const mod = guild.members.cache.get(modId);
|
||||||
|
|
||||||
|
// Checks if guildMember is null
|
||||||
|
if (mod === undefined) {
|
||||||
|
info.message = 'Error fetching mod!';
|
||||||
|
return info;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (await checkTempBan(userId)) {
|
||||||
|
info.message = `${user} is already temp banned!`;
|
||||||
|
return info;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if mod is in database
|
||||||
|
await updateUser(mod);
|
||||||
|
|
||||||
|
// Gets guildMember
|
||||||
|
let member = guild.members.cache.get(userId);
|
||||||
|
|
||||||
|
if (member === undefined) {
|
||||||
|
member = await guild.members.fetch(userId)
|
||||||
|
.catch(() => undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (member !== undefined) {
|
||||||
|
// Checks if the user is not restricted
|
||||||
|
if (member.roles.cache.has(IDs.roles.vegan.vegan)) {
|
||||||
|
info.message = 'You need to restrict the user first!';
|
||||||
|
return info;
|
||||||
|
}
|
||||||
|
|
||||||
|
await updateUser(member);
|
||||||
|
|
||||||
|
// Send DM for reason of ban
|
||||||
|
await member.send(`You have been temporarily banned from ARA for ${banLength}. Reason: ${reason}`
|
||||||
|
+ '\n\nhttps://vbcamp.org/ARA')
|
||||||
|
.catch(() => {});
|
||||||
|
|
||||||
|
// Ban the user
|
||||||
|
await member.ban({ reason });
|
||||||
|
} else if (!await userExists(userId)) {
|
||||||
|
await addEmptyUser(userId);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add ban to database
|
||||||
|
await addTempBan(userId, modId, time.fromNow, reason);
|
||||||
|
|
||||||
|
// Create scheduled task to unban
|
||||||
|
this.container.tasks.create('tempBan', {
|
||||||
|
userId: user.id,
|
||||||
|
guildId: guild.id,
|
||||||
|
}, time.offset);
|
||||||
|
|
||||||
|
info.message = `${user} has been temporarily banned for ${banLength}.`;
|
||||||
|
info.success = true;
|
||||||
|
|
||||||
|
// Log the ban
|
||||||
|
let logChannel = guild.channels.cache
|
||||||
|
.get(IDs.channels.logs.restricted) as TextChannel | undefined;
|
||||||
|
|
||||||
|
if (logChannel === undefined) {
|
||||||
|
logChannel = await guild.channels
|
||||||
|
.fetch(IDs.channels.logs.restricted) as TextChannel | undefined;
|
||||||
|
if (logChannel === undefined) {
|
||||||
|
this.container.logger.error('Temp Ban Error: Could not fetch log channel');
|
||||||
|
info.message = `${user} has been temporarily banned for ${banLength}. `
|
||||||
|
+ 'This hasn\'t been logged in a text channel as log channel could not be found';
|
||||||
|
return info;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const log = new EmbedBuilder()
|
||||||
|
.setColor('#FF0000')
|
||||||
|
.setAuthor({ name: `Temp Banned ${user.tag}`, iconURL: `${user.avatarURL()}` })
|
||||||
|
.addFields(
|
||||||
|
{ name: 'User', value: `${user}`, inline: true },
|
||||||
|
{ name: 'Moderator', value: `${mod}`, inline: true },
|
||||||
|
{ name: 'Duration', value: banLength },
|
||||||
|
{ name: 'Reason', value: reason },
|
||||||
|
)
|
||||||
|
.setTimestamp()
|
||||||
|
.setFooter({ text: `ID: ${user.id}` });
|
||||||
|
|
||||||
|
await logChannel.send({ embeds: [log] });
|
||||||
|
|
||||||
|
return info;
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user