remove self roles slashcommand
This commit is contained in:
parent
81bb307896
commit
dfe673bebc
@ -50,6 +50,44 @@ const registerSelfRoles = async (interaction) => {
|
|||||||
return response;
|
return response;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const removeSelfRoles = async (interaction, msgID) => {
|
||||||
|
const { channel } = interaction;
|
||||||
|
|
||||||
|
try {
|
||||||
|
// Try fetching message from channel
|
||||||
|
await channel.messages.fetch(msgID);
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error);
|
||||||
|
// Reply to acknowledge command
|
||||||
|
await interaction.reply({
|
||||||
|
content: `Failed to fetch message!`,
|
||||||
|
ephemeral: true
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Try deleting message from database
|
||||||
|
const count = await Message.destroy({
|
||||||
|
where: {
|
||||||
|
id: msgID
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Set reply based on result of deletion
|
||||||
|
let response = 'Successfully removed';
|
||||||
|
if (count === 0)
|
||||||
|
response = 'Failed to remove';
|
||||||
|
|
||||||
|
// Reply to acknowledge command
|
||||||
|
await interaction.reply({
|
||||||
|
content: `${response} self roles from message!`,
|
||||||
|
ephemeral: true
|
||||||
|
});
|
||||||
|
|
||||||
|
console.info(`[INFO] Removed self roles from message with ID '${msgID}'.`);
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
export const data = new SlashCommandBuilder()
|
export const data = new SlashCommandBuilder()
|
||||||
.setName('self_roles')
|
.setName('self_roles')
|
||||||
.setDMPermission(false)
|
.setDMPermission(false)
|
||||||
@ -92,6 +130,17 @@ export const data = new SlashCommandBuilder()
|
|||||||
.addStringOption((option) =>
|
.addStringOption((option) =>
|
||||||
option.setName('emoji').setRequired(true).setDescription('The emoji to be reacted with.')
|
option.setName('emoji').setRequired(true).setDescription('The emoji to be reacted with.')
|
||||||
)
|
)
|
||||||
|
)
|
||||||
|
.addSubcommand((subcommand) =>
|
||||||
|
subcommand
|
||||||
|
.setName('remove')
|
||||||
|
.setDescription('Remove self roles from a message.')
|
||||||
|
.addStringOption((option) =>
|
||||||
|
option
|
||||||
|
.setName('id')
|
||||||
|
.setRequired(true)
|
||||||
|
.setDescription('The ID to reference the message to be removed.')
|
||||||
|
)
|
||||||
);
|
);
|
||||||
export async function execute(interaction) {
|
export async function execute(interaction) {
|
||||||
const { options } = interaction;
|
const { options } = interaction;
|
||||||
@ -120,6 +169,11 @@ export async function execute(interaction) {
|
|||||||
await addSelfRoles(interaction, msgID, role, emoji);
|
await addSelfRoles(interaction, msgID, role, emoji);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case 'remove': {
|
||||||
|
const msgID = options.getString('id');
|
||||||
|
await removeSelfRoles(interaction, msgID);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (createNew) {
|
if (createNew) {
|
||||||
|
Loading…
Reference in New Issue
Block a user