// 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 . */ import { Args, Command, RegisterBehavior } from '@sapphire/framework'; import type { Guild, User, Message } from 'discord.js'; import IDs from '#utils/ids'; import { roleAddLog, roleRemoveLog } from '#utils/logging/role'; export class VerifierCommand extends Command { public constructor(context: Command.Context, options: Command.Options) { super(context, { ...options, name: 'verifier', description: 'Gives/removes the verifier role', preconditions: ['VerifierCoordinatorOnly'], }); } // 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 give/remove verifier role') .setRequired(true)), { behaviorWhenNotIdentical: RegisterBehavior.Overwrite, }, ); } // Command run public async chatInputRun(interaction: Command.ChatInputCommandInteraction) { // Get the arguments const user = interaction.options.getUser('user', true); const mod = interaction.user; const { guild } = interaction; // Checks if all the variables are of the right type if (guild === null) { await interaction.reply({ content: 'Error fetching guild!', ephemeral: true, fetchReply: true, }); return; } await interaction.deferReply({ ephemeral: true }); const info = await this.manageVerifier(user, mod, guild); await interaction.editReply(info.message); } public async messageRun(message: Message, args: Args) { // Get arguments let user: User; try { user = await args.pick('user'); } catch { await message.react('❌'); await message.reply('User was not provided!'); return; } const mod = message.author; if (mod === null) { await message.react('❌'); await message.reply('Verifier coordinator not found! Try again or contact a developer!'); return; } const { guild } = message; if (guild === null) { await message.react('❌'); await message.reply('Guild not found! Try again or contact a developer!'); return; } const info = await this.manageVerifier(user, mod, guild); await message.reply(info.message); await message.react(info.success ? '✅' : '❌'); } private async manageVerifier(user: User, mod: User, guild: Guild) { const info = { message: '', success: false, }; const member = guild.members.cache.get(user.id); const verifier = guild.roles.cache.get(IDs.roles.staff.verifier); // Checks if user's GuildMember was found in cache if (member === undefined) { info.message = 'Error fetching guild member for the user!'; return info; } if (verifier === undefined) { info.message = 'Error fetching verifier role from cache!'; return info; } // Checks if the user has Verifier and to give them or remove them based on if they have it if (member.roles.cache.has(IDs.roles.staff.verifier)) { // Remove the Verifier role from the user await member.roles.remove(verifier); await roleRemoveLog(user.id, mod.id, verifier, true); info.message = `Removed the ${verifier.name} role from ${user}`; info.success = true; return info; } // Add Verifier role to the user await member.roles.add(verifier); await roleAddLog(user.id, mod.id, verifier, true); info.message = `Gave ${user} the ${verifier.name} role!`; await user.send(`You have been given the ${verifier.name} role by ${mod}!`) .catch(() => {}); info.success = true; return info; } }