Merge branch 'dev' into 'main'
Removed mute and added kick commands See merge request illegitimate/illegitimate-bot!45
This commit is contained in:
@@ -1,161 +0,0 @@
|
|||||||
const { SlashCommandBuilder, PermissionFlagsBits, userMention } = require('discord.js');
|
|
||||||
const dev = process.env.DEV;
|
|
||||||
const { color } = require('../config/options.json');
|
|
||||||
const { admin, helper, muted } = require('../config/roles.json');
|
|
||||||
const { staffOtherChannel } = require('../config/options.json');
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
name: 'mute',
|
|
||||||
description: 'Mute a user',
|
|
||||||
type: 'slash',
|
|
||||||
|
|
||||||
data: new SlashCommandBuilder()
|
|
||||||
.setName('mute')
|
|
||||||
.setDescription('Mute a user')
|
|
||||||
.addUserOption(option =>
|
|
||||||
option
|
|
||||||
.setName('user')
|
|
||||||
.setDescription('The user to mute')
|
|
||||||
.setRequired(true))
|
|
||||||
.addStringOption(option =>
|
|
||||||
option
|
|
||||||
.setName('reason')
|
|
||||||
.setDescription('The reason for the mute'))
|
|
||||||
.addStringOption(option =>
|
|
||||||
option
|
|
||||||
.setName('duration')
|
|
||||||
.setDescription('The duration of the mute'))
|
|
||||||
.setDefaultMemberPermissions(PermissionFlagsBits.Administrator)
|
|
||||||
.setDMPermission(false),
|
|
||||||
|
|
||||||
async execute(interaction) {
|
|
||||||
|
|
||||||
const member1 = interaction.options.getUser('user');
|
|
||||||
const member = interaction.guild.members.cache.get(member1.id);
|
|
||||||
const reason = interaction.options.getString('reason') ?? 'No reason provided';
|
|
||||||
const duration = interaction.options.getString('duration');
|
|
||||||
const guild = interaction.guild;
|
|
||||||
const embedColor = Number(color.replace('#', '0x'));
|
|
||||||
|
|
||||||
const userRoles = await guild.members.fetch(interaction.user.id).then(member => member.roles.cache.map(role => role.id));
|
|
||||||
const memberRoles = await guild.members.fetch(member1.id).then(member => member.roles.cache.map(role => role.id));
|
|
||||||
|
|
||||||
await interaction.deferReply({});
|
|
||||||
|
|
||||||
if (!userRoles.includes(admin || helper)) {
|
|
||||||
await interaction.editReply({
|
|
||||||
embeds: [{
|
|
||||||
description: "You don't have permission to use this command.",
|
|
||||||
color: embedColor,
|
|
||||||
footer: {
|
|
||||||
text: interaction.guild.name + " | Developed by @Taken#0002",
|
|
||||||
icon_url: interaction.guild.iconURL({ dynamic: true })
|
|
||||||
}
|
|
||||||
}]
|
|
||||||
});
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if (member.id === interaction.user.id) {
|
|
||||||
await interaction.editReply({
|
|
||||||
embeds: [{
|
|
||||||
description: "You can't mute yourself.",
|
|
||||||
color: embedColor,
|
|
||||||
footer: {
|
|
||||||
text: interaction.guild.name + " | Developed by @Taken#0002",
|
|
||||||
icon_url: interaction.guild.iconURL({ dynamic: true })
|
|
||||||
}
|
|
||||||
}]
|
|
||||||
});
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if (member.id === dev) {
|
|
||||||
await interaction.editReply({
|
|
||||||
embeds: [{
|
|
||||||
description: "You can't mute my developer.",
|
|
||||||
color: embedColor,
|
|
||||||
footer: {
|
|
||||||
text: interaction.guild.name + " | Developed by @Taken#0002",
|
|
||||||
icon_url: interaction.guild.iconURL({ dynamic: true })
|
|
||||||
}
|
|
||||||
}]
|
|
||||||
});
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// if (memberRoles.includes(admin) || memberRoles.includes(helper)) {
|
|
||||||
// await interaction.editReply({
|
|
||||||
// embeds: [{
|
|
||||||
// description: "You can't mute a staff member.",
|
|
||||||
// color: embedColor,
|
|
||||||
// footer: {
|
|
||||||
// text: interaction.guild.name + " | Developed by @Taken#0002",
|
|
||||||
// icon_url: interaction.guild.iconURL({ dynamic: true })
|
|
||||||
// }
|
|
||||||
// }]
|
|
||||||
// });
|
|
||||||
// return
|
|
||||||
// }
|
|
||||||
|
|
||||||
if (!duration) {
|
|
||||||
await member.roles.add(muted, reason);
|
|
||||||
await interaction.editReply({
|
|
||||||
embeds: [{
|
|
||||||
description: "Successfully muted " + userMention(member1.id) + " forever.",
|
|
||||||
color: embedColor,
|
|
||||||
footer: {
|
|
||||||
text: interaction.guild.name + " | Developed by @Taken#0002",
|
|
||||||
icon_url: interaction.guild.iconURL({ dynamic: true })
|
|
||||||
}
|
|
||||||
}]
|
|
||||||
})
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
console.log(duration);
|
|
||||||
|
|
||||||
const weeks = duration.replace(/[0-9][dhms]/g, '').replace(/w/g, '')
|
|
||||||
const days = duration.replace(/[0-9][whms]/g, '').replace(/d/g, '')
|
|
||||||
const hours = duration.replace(/[0-9][wdms]/g, '').replace(/h/g, '')
|
|
||||||
const minutes = duration.replace(/[0-9][wdhs]/g, '').replace(/m/g, '')
|
|
||||||
const seconds = duration.replace(/[0-9][wdhm]/g, '').replace(/s/g, '')
|
|
||||||
|
|
||||||
const nweeks = Number(weeks) ?? 0;
|
|
||||||
const ndays = Number(days) ?? 0;
|
|
||||||
const nhours = Number(hours) ?? 0;
|
|
||||||
const nminutes = Number(minutes) ?? 0;
|
|
||||||
const nseconds = Number(seconds) ?? 0;
|
|
||||||
|
|
||||||
const time = nweeks * 604800000 + ndays * 86400000 + nhours * 3600000 + nminutes * 60000 + nseconds * 1000;
|
|
||||||
const mutedTime = (nweeks > 0 ? nweeks + " week(s), " : "") + (ndays > 0 ? ndays + " day(s), " : "") + (nhours > 0 ? nhours + " hour(s), " : "") + (nminutes > 0 ? nminutes + " minute(s), " : "") + (nseconds > 0 ? nseconds + " second(s)" : "");
|
|
||||||
|
|
||||||
await member.roles.add(muted, reason);
|
|
||||||
await interaction.editReply({
|
|
||||||
embeds: [{
|
|
||||||
description: "Successfully muted " + userMention(member1.id) + " for " + mutedTime + ".",
|
|
||||||
color: embedColor,
|
|
||||||
footer: {
|
|
||||||
text: interaction.guild.name + " | Developed by @Taken#0002",
|
|
||||||
icon_url: interaction.guild.iconURL({ dynamic: true })
|
|
||||||
}
|
|
||||||
}]
|
|
||||||
});
|
|
||||||
|
|
||||||
const logChannel = interaction.guild.channels.cache.get(staffOtherChannel);
|
|
||||||
|
|
||||||
setTimeout(async () => {
|
|
||||||
await member.roles.remove(muted, "Mute duration has ended.");
|
|
||||||
await logChannel.send({
|
|
||||||
embeds: [{
|
|
||||||
description: userMention(member1.id) + " has been unmuted.",
|
|
||||||
color: embedColor,
|
|
||||||
footer: {
|
|
||||||
text: "ID: " + member1.id,
|
|
||||||
icon_url: interaction.guild.iconURL({ dynamic: true })
|
|
||||||
}
|
|
||||||
}]
|
|
||||||
})
|
|
||||||
}, time);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
82
commands/kick.js
Normal file
82
commands/kick.js
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
const { SlashCommandBuilder, PermissionFlagsBits, userMention } = require('discord.js')
|
||||||
|
const { admin, helper } = require('../config/roles.json')
|
||||||
|
const { color } = require('../config/options.json')
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
name: 'kick',
|
||||||
|
description: 'Kick a member from the server.',
|
||||||
|
type: 'slash',
|
||||||
|
|
||||||
|
data: new SlashCommandBuilder()
|
||||||
|
.setName('kick')
|
||||||
|
.setDescription('Kick a member from the server.')
|
||||||
|
.addUserOption(option =>
|
||||||
|
option
|
||||||
|
.setName('member')
|
||||||
|
.setDescription('Member to kick.')
|
||||||
|
.setRequired(true))
|
||||||
|
.addStringOption(option =>
|
||||||
|
option
|
||||||
|
.setName('reason')
|
||||||
|
.setDescription('Reason for kicking the member.'))
|
||||||
|
.setDefaultMemberPermissions(PermissionFlagsBits.KickMembers)
|
||||||
|
.setDMPermission(false),
|
||||||
|
|
||||||
|
async execute(interaction) {
|
||||||
|
|
||||||
|
await interaction.deferReply()
|
||||||
|
|
||||||
|
const member = interaction.options.getMember('member')
|
||||||
|
const reason = interaction.options.getString('reason') ?? "No reason provided."
|
||||||
|
const mod = await interaction.guild.members.fetch(interaction.user.id)
|
||||||
|
const memberRoles = member.roles.cache.map(role => role.id)
|
||||||
|
const modRoles = mod.roles.cache.map(role => role.id)
|
||||||
|
const embedColor = Number(color.replace('#', '0x'))
|
||||||
|
|
||||||
|
if (!modRoles.includes(helper) && !modRoles.includes(admin)) {
|
||||||
|
await interaction.editReply("You do not have permission to use this command.")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if (member.id === interaction.applicationId) {
|
||||||
|
await interaction.editReply("I cannot kick myself.")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if (member.id === interaction.guild.ownerId) {
|
||||||
|
await interaction.editReply("I cannot kick the server owner.")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if (member.id === mod.id) {
|
||||||
|
return interaction.editReply("You cannot kick yourself.")
|
||||||
|
}
|
||||||
|
|
||||||
|
if (memberRoles.includes(helper) || memberRoles.includes(admin)) {
|
||||||
|
await interaction.editReply("I cannot kick a moderator.")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!member.kickable) {
|
||||||
|
await interaction.editReply("I cannot kick this member.")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
await member.kick(reason + ` - ${mod.user.username}`)
|
||||||
|
|
||||||
|
await interaction.editReply({
|
||||||
|
embeds: [{
|
||||||
|
title: "Member Kicked",
|
||||||
|
description: "**User:** " + userMention(member.user.id) + "\n" +
|
||||||
|
"**Reason:** " + reason + "\n" +
|
||||||
|
"**Moderator:** " + mod.user.username,
|
||||||
|
color: embedColor,
|
||||||
|
footer: {
|
||||||
|
text: member.user.id,
|
||||||
|
icon_url: member.user.avatarURL({ dynamic: true })
|
||||||
|
},
|
||||||
|
}]
|
||||||
|
})
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user