v3.0 #145
6 changed files with 79 additions and 98 deletions
|
@ -20,6 +20,8 @@ FOLDERS_EVENTS=src/events
|
||||||
COMMANDS_DISABLED=
|
COMMANDS_DISABLED=
|
||||||
COMMANDS_DISABLED_MESSAGE=This command is disabled.
|
COMMANDS_DISABLED_MESSAGE=This command is disabled.
|
||||||
|
|
||||||
|
COMMANDS_MUTE_ROLE=Muted
|
||||||
|
|
||||||
EMBED_COLOUR=0x3050ba
|
EMBED_COLOUR=0x3050ba
|
||||||
EMBED_COLOUR_ERROR=0xD52803
|
EMBED_COLOUR_ERROR=0xD52803
|
||||||
|
|
||||||
|
|
|
@ -1,98 +0,0 @@
|
||||||
// Required Components
|
|
||||||
const { command } = require('vylbot-core');
|
|
||||||
const { MessageEmbed } = require('discord.js');
|
|
||||||
|
|
||||||
const embedColor = "0x3050ba";
|
|
||||||
|
|
||||||
// Command Class
|
|
||||||
class mute extends command {
|
|
||||||
constructor() {
|
|
||||||
// Set the command's run method, description, category, and usage
|
|
||||||
super("mute");
|
|
||||||
super.description = "Mutes the mentioned user with an optional reason";
|
|
||||||
super.category = "Moderation";
|
|
||||||
super.usage = "<@user> [reason]";
|
|
||||||
|
|
||||||
// Set the required configs for the command
|
|
||||||
super.requiredConfigs = "modrole";
|
|
||||||
super.requiredConfigs = "logchannel";
|
|
||||||
super.requiredConfigs = "muterole";
|
|
||||||
}
|
|
||||||
|
|
||||||
// The command's run method
|
|
||||||
mute(context) {
|
|
||||||
// Check if the user has the mod role
|
|
||||||
if (context.message.member.roles.cache.find(role => role.name == context.client.config.mute.modrole)) {
|
|
||||||
// Get the user first pinged in the message
|
|
||||||
const user = context.message.mentions.users.first();
|
|
||||||
|
|
||||||
// If the user object exists
|
|
||||||
if (user) {
|
|
||||||
// Get the guild member object of the mentioned user
|
|
||||||
const member = context.message.guild.member(user);
|
|
||||||
|
|
||||||
// If the member object exists, i.e. if the user is in the server
|
|
||||||
if (member) {
|
|
||||||
// Get the part of the arguments array which contains the reason
|
|
||||||
const reasonArgs = context.arguments;
|
|
||||||
reasonArgs.splice(0, 1);
|
|
||||||
|
|
||||||
// Join the reason into a string
|
|
||||||
const reason = reasonArgs.join(" ");
|
|
||||||
|
|
||||||
// If the server is available
|
|
||||||
if (context.message.guild.available) {
|
|
||||||
// If the bot client can manage the user's roles
|
|
||||||
if (member.manageable) {
|
|
||||||
// The embed to go into the bot log
|
|
||||||
const embedLog = new MessageEmbed()
|
|
||||||
.setTitle("Member Muted")
|
|
||||||
.setColor(embedColor)
|
|
||||||
.addField("User", `${user} \`${user.tag}\``, true)
|
|
||||||
.addField("Moderator", `${context.message.author} \`${context.message.author.tag}\``, true)
|
|
||||||
.addField("Reason", reason || "*none*")
|
|
||||||
.setThumbnail(user.displayAvatarURL);
|
|
||||||
|
|
||||||
// The embed to go into the channel the command was sent in
|
|
||||||
const embedPublic = new MessageEmbed()
|
|
||||||
.setColor(embedColor)
|
|
||||||
.setDescription(`${user} has been muted`)
|
|
||||||
.addField("Reason", reason || "*none*");
|
|
||||||
|
|
||||||
// Get the 'Muted' role
|
|
||||||
const mutedRole = context.message.guild.roles.cache.find(role => role.name == context.client.config.mute.muterole);
|
|
||||||
|
|
||||||
// Attempt to mute the user, if successful send the embeds, if not log the error
|
|
||||||
member.roles.add(mutedRole, reason).then(() => {
|
|
||||||
context.message.guild.channels.cache.find(channel => channel.name == context.client.config.mute.logchannel).send(embedLog);
|
|
||||||
context.message.channel.send(embedPublic);
|
|
||||||
|
|
||||||
context.message.delete();
|
|
||||||
}).catch(err => {
|
|
||||||
errorEmbed(context, "An error occurred");
|
|
||||||
console.log(err);
|
|
||||||
});
|
|
||||||
} else { // If the bot can't manage the user
|
|
||||||
errorEmbed(context, "I am unable to mute this user");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else { // If the member object doesn't exist
|
|
||||||
errorEmbed(context, "Please specify a valid user");
|
|
||||||
}
|
|
||||||
} else { // If the user object doesn't exist
|
|
||||||
errorEmbed(context, "Please specify a valid user");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Send an embed when an error occurs
|
|
||||||
function errorEmbed(context, message) {
|
|
||||||
const embed = new MessageEmbed()
|
|
||||||
.setColor(embedColor)
|
|
||||||
.setDescription(message);
|
|
||||||
|
|
||||||
context.message.channel.send(embed);
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = mute;
|
|
70
src/commands/mute.ts
Normal file
70
src/commands/mute.ts
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
import { Command, ICommandContext } from "vylbot-core";
|
||||||
|
import ErrorMessages from "../constants/ErrorMessages";
|
||||||
|
import ErrorEmbed from "../helpers/ErrorEmbed";
|
||||||
|
import LogEmbed from "../helpers/LogEmbed";
|
||||||
|
import PublicEmbed from "../helpers/PublicEmbed";
|
||||||
|
|
||||||
|
export default class Mute extends Command {
|
||||||
|
constructor() {
|
||||||
|
super();
|
||||||
|
|
||||||
|
super._category = "Moderation";
|
||||||
|
super._roles = [
|
||||||
|
process.env.ROLES_MODERATOR!
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public override async execute(context: ICommandContext) {
|
||||||
|
const targetUser = context.message.mentions.users.first();
|
||||||
|
|
||||||
|
if (!targetUser) {
|
||||||
|
const embed = new ErrorEmbed(context, "User does not exist");
|
||||||
|
embed.SendToCurrentChannel();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const targetMember = context.message.guild?.member(targetUser);
|
||||||
|
|
||||||
|
if (!targetMember) {
|
||||||
|
const embed = new ErrorEmbed(context, "User is not in this server");
|
||||||
|
embed.SendToCurrentChannel();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const reasonArgs = context.args;
|
||||||
|
reasonArgs.splice(0, 1);
|
||||||
|
|
||||||
|
const reason = reasonArgs.join(" ");
|
||||||
|
|
||||||
|
if (!context.message.guild?.available) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!targetMember.manageable) {
|
||||||
|
const embed = new ErrorEmbed(context, ErrorMessages.InsufficientBotPermissions);
|
||||||
|
embed.SendToCurrentChannel();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const logEmbed = new LogEmbed(context, "Member Muted");
|
||||||
|
logEmbed.AddUser("User", targetUser, true)
|
||||||
|
logEmbed.AddUser("Moderator", context.message.author);
|
||||||
|
logEmbed.AddReason(reason);
|
||||||
|
|
||||||
|
const publicEmbed = new PublicEmbed(context, "", `${targetUser} has been muted`);
|
||||||
|
publicEmbed.AddReason(reason);
|
||||||
|
|
||||||
|
const mutedRole = context.message.guild.roles.cache.find(role => role.name == process.env.COMMANDS_MUTE_ROLE);
|
||||||
|
|
||||||
|
if (!mutedRole) {
|
||||||
|
const embed = new ErrorEmbed(context, ErrorMessages.RoleNotFound);
|
||||||
|
embed.SendToCurrentChannel();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
await targetMember.roles.add(mutedRole, reason);
|
||||||
|
|
||||||
|
logEmbed.SendToModLogsChannel();
|
||||||
|
publicEmbed.SendToCurrentChannel();
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,4 +1,5 @@
|
||||||
export default class ErrorMessages {
|
export default class ErrorMessages {
|
||||||
public static readonly InsufficientBotPermissions = "Unable to do this action, am I missing permissions?";
|
public static readonly InsufficientBotPermissions = "Unable to do this action, am I missing permissions?";
|
||||||
public static readonly CantFindChannel = "Unable to find channel";
|
public static readonly CantFindChannel = "Unable to find channel";
|
||||||
|
public static readonly RoleNotFound = "Unable to find role";
|
||||||
}
|
}
|
|
@ -14,6 +14,11 @@ export default class PublicEmbed extends MessageEmbed {
|
||||||
this._context = context;
|
this._context = context;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Detail methods
|
||||||
|
public AddReason(message: String) {
|
||||||
|
super.addField("Reason", message || "*none*");
|
||||||
|
}
|
||||||
|
|
||||||
// Send methods
|
// Send methods
|
||||||
public SendToCurrentChannel() {
|
public SendToCurrentChannel() {
|
||||||
this._context.message.channel.send(this);
|
this._context.message.channel.send(this);
|
||||||
|
|
|
@ -12,6 +12,7 @@ if (!process.env.ROLES_MODERATOR) throw "ROLES_MODERATOR is required in .env";
|
||||||
if (!process.env.CHANNELS_LOGS_MESSAGE) throw "CHANNELS_LOGS_MESSAGE is required in .env";
|
if (!process.env.CHANNELS_LOGS_MESSAGE) throw "CHANNELS_LOGS_MESSAGE is required in .env";
|
||||||
if (!process.env.CHANNELS_LOGS_MEMBER) throw "CHANNELS_LOGS_MEMBER is required in .env";
|
if (!process.env.CHANNELS_LOGS_MEMBER) throw "CHANNELS_LOGS_MEMBER is required in .env";
|
||||||
if (!process.env.CHANNELS_LOGS_MOD) throw "CHANNELS_LOGS_MOD is required in .env";
|
if (!process.env.CHANNELS_LOGS_MOD) throw "CHANNELS_LOGS_MOD is required in .env";
|
||||||
|
if (!process.env.COMMANDS_MUTE_ROLE) throw "COMMANDS_MUTE_ROLE is required in .env";
|
||||||
|
|
||||||
const client = new CoreClient();
|
const client = new CoreClient();
|
||||||
client.start();
|
client.start();
|
Loading…
Reference in a new issue