Add (almost complete) slash command support

This commit is contained in:
Nathaniel Mason 2022-04-22 05:44:02 +01:00
parent e3318d26c7
commit ab2cd6bd7d
27 changed files with 585 additions and 443 deletions

View File

@ -11,32 +11,37 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.STRING type: Constants.ApplicationCommandOptionTypes.STRING
}], }],
async execute (client, message, args, config) { async parseMessage (client, config, message, args) {
await message.channel.send(this.handle(client, config, message.author, args.slice(0).join(' ')));
},
async parseInteraction (client, config, interaction) {
await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getString('question')));
},
handle (client, config, user, question) {
const index = Math.floor(Math.random() * config.answers.length); const index = Math.floor(Math.random() * config.answers.length);
const answer = config.answers[index]; const answer = config.answers[index];
const question = args.slice(0).join(' '); const avatarURL = user.displayAvatarURL();
const avatarURL = message.author.displayAvatarURL();
if (!question) { if (!question) return client.generateErrorMessage('You need to ask a question!', avatarURL);
await message.channel.send(client.generateErrorMessage('You need to ask a question!', avatarURL));
} else { return {
await message.channel.send({ embeds: [{
embeds: [{ title: ':8ball: 8Ball',
title: ':8ball: 8Ball', description: `Your amazing question: **${question}**`,
description: `Your amazing question: **${question}**`, color: 9442302,
color: 9442302, footer: {
footer: { icon_url: avatarURL,
icon_url: avatarURL, text: config.footerTxt
text: config.footerTxt },
}, fields: [
fields: [ {
{ name: 'Answer',
name: 'Answer', value: `${answer}`
value: `${answer}` }
} ]
] }]
}] };
});
}
} }
}; };

View File

@ -14,24 +14,32 @@ module.exports = {
name: 'userid', name: 'userid',
description: "Another user's ID", description: "Another user's ID",
required: false, required: false,
type: Constants.ApplicationCommandOptionTypes.INTEGER type: Constants.ApplicationCommandOptionTypes.STRING
}], }],
async execute (client, message, args, config) { async parseMessage (client, config, message, args) {
const user = message.mentions.users.first() || client.users.cache.get(args[0]) || message.author; const target = message.mentions.users.first() || client.users.cache.get(args[0]) || message.author;
await message.channel.send(this.handle(client, config, message.author, target));
},
await message.channel.send({ async parseInteraction (client, config, interaction) {
const target = interaction.options.getUser('user') || client.users.cache.get(interaction.options.getString('userid')) || interaction.user;
await interaction.reply(this.handle(client, config, interaction.user, target));
},
handle (_, config, user, target) {
return {
embeds: [{ embeds: [{
title: `:frame_photo: ${user.username}'s Beautiful Avatar!`, title: `:frame_photo: ${target.username}'s Beautiful Avatar!`,
color: 9442302, color: 9442302,
footer: { footer: {
icon_url: message.author.displayAvatarURL(), icon_url: user.displayAvatarURL(),
text: config.footerTxt text: config.footerTxt
}, },
image: { image: {
url: user.displayAvatarURL() url: target.displayAvatarURL()
} }
}] }]
}); };
} }
}; };

View File

@ -11,27 +11,30 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
}], }],
async execute (client, message, _, config) { async parseMessage (client, config, message) {
const taggedUser = message.mentions.users.first(); await message.channel.send(this.handle(client, config, message.author, message.mentions.users.first()));
const avatarURL = message.author.displayAvatarURL(); },
if (!taggedUser) { async parseInteraction (client, config, interaction) {
await message.channel.send(client.generateErrorMessage('You need to @mention a user!', avatarURL)); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getUser('user')));
} else { },
await message.channel.send({
embeds: [{ handle (client, config, user, target) {
title: '<a:SylvBonk:801185845847130113> Bonk', if (!target) return client.generateErrorMessage('You need to @mention a user!', user.displayAvatarURL());
description: `${taggedUser} You have been bonked by ${message.author}!`,
color: 9442302, return {
footer: { embeds: [{
icon_url: avatarURL, title: '<a:SylvBonk:801185845847130113> Bonk',
text: config.footerTxt description: `${target} You have been bonked by ${user}!`,
}, color: 9442302,
image: { footer: {
url: 'https://cdn.discordapp.com/attachments/793537380330111028/801194481549312060/HappyBONK.gif' icon_url: user.displayAvatarURL(),
} text: config.footerTxt
}] },
}); image: {
} url: 'https://cdn.discordapp.com/attachments/793537380330111028/801194481549312060/HappyBONK.gif'
}
}]
};
} }
}; };

View File

@ -11,26 +11,30 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
}], }],
async execute (_0, message, _1, config) { async parseMessage (client, config, message) {
const taggedUser = message.mentions.users.first(); await message.channel.send(this.handle(client, config, message.author, message.mentions.users.first()));
},
if (!taggedUser) { async parseInteraction (client, config, interaction) {
await message.channel.send('*slams cheese on desk*\n**Cheese.** https://www.youtube.com/watch?v=Or4IE8fkpn4'); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getUser('user')));
} else { },
await message.channel.send({
embeds: [{ handle (_, config, user, target) {
title: ':cheese: Cheesed', if (!target) return '*slams cheese on desk*\n**Cheese.** https://www.youtube.com/watch?v=Or4IE8fkpn4';
description: `${taggedUser} You have been cheesed by ${message.author}!`,
color: 16312092, return {
footer: { embeds: [{
icon_url: message.author.displayAvatarURL(), title: ':cheese: Cheesed',
text: config.footerTxt description: `${target} You have been cheesed by ${user}!`,
}, color: 16312092,
image: { footer: {
url: 'https://cdn.discordapp.com/attachments/803658122299572255/812867714368536636/R06325af354168febcafd96b8328b7590.png' icon_url: user.displayAvatarURL(),
} text: config.footerTxt
}] },
}); image: {
} url: 'https://cdn.discordapp.com/attachments/803658122299572255/812867714368536636/R06325af354168febcafd96b8328b7590.png'
}
}]
};
} }
}; };

View File

@ -4,27 +4,32 @@ module.exports = {
description: 'Give some lines of input, and get one back at random', description: 'Give some lines of input, and get one back at random',
options: [], options: [],
async execute (client, message, _, config) { async parseMessage (client, config, message, args) {
const avatarURL = message.author.displayAvatarURL();
let [head, ...options] = message.content.split(/\s*\n\s*/); let [head, ...options] = message.content.split(/\s*\n\s*/);
head = head.slice(this.name.length + config.prefix.length); head = head.slice(this.name.length + config.prefix.length);
if (head) options.push(head); if (head) options.push(head);
await message.channel.send(this.handle(client, config, message.author, options));
},
if (!options.length) { // TODO: Figure out variable input
await message.channel.send(client.generateErrorMessage('You need to provide some input!', avatarURL)); async parseInteraction (client, config, interaction) {
} else { await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getString('question')));
const answer = options[Math.floor(Math.random() * options.length)]; },
await message.channel.send({
embeds: [{ handle (client, config, user, options) {
title: 'I have made my decision:', if (!options.length) return client.generateErrorMessage('You need to provide some input!', user.displayAvatarURL());
description: answer,
color: 8311585, const answer = options[Math.floor(Math.random() * options.length)];
footer: { return {
icon_url: avatarURL, embeds: [{
text: config.footerTxt title: 'I have made my decision:',
} description: answer,
}] color: 8311585,
}); footer: {
} icon_url: user.displayAvatarURL(),
text: config.footerTxt
}
}]
};
} }
}; };

View File

@ -4,14 +4,22 @@ module.exports = {
description: 'Attributions to open source components used by Anitrox', description: 'Attributions to open source components used by Anitrox',
options: [], options: [],
async execute (_0, message, _1, config) { async parseMessage (_, config, message) {
await message.channel.send({ await message.channel.send(this.handle(config, message.author));
},
async parseInteraction (_, config, interaction) {
await interaction.reply(this.handle(config, interaction.user));
},
handle (config, user) {
return {
embeds: [{ embeds: [{
title: 'Contributors', title: 'Contributors',
description: 'Links to check out our contributors!', description: 'Links to check out our contributors!',
color: 52508, color: 52508,
footer: { footer: {
icon_url: message.author.displayAvatarURL(), icon_url: user.displayAvatarURL(),
text: config.footerTxt text: config.footerTxt
}, },
thumbnail: { thumbnail: {
@ -32,6 +40,6 @@ module.exports = {
} }
] ]
}] }]
}); };
} }
}; };

View File

@ -18,29 +18,31 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
}], }],
async execute (client, message, _, config) { async parseMessage (client, config, message) {
const taggedUser = message.mentions.users.first(); await message.channel.send(this.handle(client, config, message.author, message.mentions.users.first()));
const index = Math.floor(Math.random() * gifchoices.length); },
const gif = (gifchoices[index]);
const avatarURL = message.author.displayAvatarURL();
if (!taggedUser) { async parseInteraction (client, config, interaction) {
await message.channel.send(client.generateErrorMessage('You need to @mention a user!', avatarURL)); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getUser('user')));
} else { },
await message.channel.send({
embeds: [{ handle (client, config, user, target) {
title: ':heart: Cuddle', if (!target) return client.generateErrorMessage('You need to @mention a user!', user.displayAvatarURL());
description: `${taggedUser} You have been cuddled by ${message.author}!`,
color: 9442302, const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
footer: { return {
icon_url: avatarURL, embeds: [{
text: config.footerTxt title: ':heart: Cuddle',
}, description: `${target} You have been cuddled by ${user}!`,
image: { color: 9442302,
url: gif footer: {
} icon_url: user.displayAvatarURL(),
}] text: config.footerTxt
}); },
} image: {
url: gif
}
}]
};
} }
}; };

View File

@ -1,37 +1,44 @@
const { Constants } = require('discord.js'); const { Constants } = require('discord.js');
const { inspect } = require('util'); const { inspect } = require('util');
module.exports = { module.exports = {
name: require('path').parse(__filename).name, name: require('path').parse(__filename).name,
description: 'Executes JS code', description: 'handles JS code',
options: [{ options: [{
name: 'text', name: 'code',
description: 'The string to evaluate', description: 'The string to evaluate',
required: true, required: true,
type: Constants.ApplicationCommandOptionTypes.STRING type: Constants.ApplicationCommandOptionTypes.STRING
}], }],
async execute (_, message, args, config) { async parseMessage (client, config, message, args) {
if (message.author.id === config.ownerID) { await message.channel.send(this.handle(client, config, message.author, args.join(' ')));
},
async parseInteraction (client, config, interaction) {
await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getString('code')));
},
handle (_, config, user, code) {
if (user.id === config.ownerID) {
try { try {
const code = args.join(' ');
const evaled = inspect(eval(code)); const evaled = inspect(eval(code));
await message.channel.send(evaled, { code: 'xl' }); // await message.channel.send(evaled, { code: 'xl' });
return `\`\`\`js\n${evaled}\n\`\`\``;
} catch (error) { } catch (error) {
await message.channel.send({ return {
embeds: [{ embeds: [{
title: '<:AnitroxError:809651936563429416> **Something went wrong! **', title: '<:AnitroxError:809651936563429416> **Something went wrong! **',
color: 13632027, color: 13632027,
footer: { footer: {
icon_url: message.author.displayAvatarURL(), icon_url: user.displayAvatarURL(),
text: config.footerTxt text: config.footerTxt
}, },
fields: [ fields: [
{ {
name: '**What Happened?**', name: '**What Happened?**',
value: 'The command you tried to run failed to execute due to an error.' value: 'The command you tried to run failed to handle due to an error.'
}, },
{ {
name: 'Error Info', name: 'Error Info',
@ -39,7 +46,7 @@ module.exports = {
} }
] ]
}] }]
}); };
} }
}; };
} }

View File

@ -4,14 +4,22 @@ module.exports = {
description: 'Get help on anything from commands, to what the bot does! just not your homework..', description: 'Get help on anything from commands, to what the bot does! just not your homework..',
options: [], options: [],
async execute (_0, message, _1, config) { async parseMessage (client, config, message) {
await message.channel.send({ await message.channel.send(this.handle(client, config, message.author));
},
async parseInteraction (client, config, interaction) {
await interaction.reply(this.handle(client, config, interaction.user));
},
handle (_, config, user) {
return {
embeds: [{ embeds: [{
title: 'HELP! SEYMOUR! THE BOT IS ON FIRE!', title: 'HELP! SEYMOUR! THE BOT IS ON FIRE!',
description: 'Get help on anything from commands, to what the bot does! just not your homework..', description: 'Get help on anything from commands, to what the bot does! just not your homework..',
color: 9442302, color: 9442302,
footer: { footer: {
icon_url: message.author.displayAvatarURL(), icon_url: user.displayAvatarURL(),
text: `${config.footerTxt} | No mother it's just the northern lights` text: `${config.footerTxt} | No mother it's just the northern lights`
}, },
fields: [ fields: [
@ -25,6 +33,6 @@ module.exports = {
} }
] ]
}] }]
}); };
} }
}; };

View File

@ -19,28 +19,31 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
}], }],
async execute (client, message, _, config) { async parseMessage (client, config, message) {
const taggedUser = message.mentions.users.first(); await message.channel.send(this.handle(client, config, message.author, message.mentions.users.first()));
const avatarURL = message.author.displayAvatarURL(); },
if (!taggedUser) { async parseInteraction (client, config, interaction) {
await message.channel.send(client.generateErrorMessage('You need to @mention a user!', avatarURL)); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getUser('user')));
} else { },
const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
await message.channel.send({ handle (client, config, user, target) {
embeds: [{ if (!target) return client.generateErrorMessage('You need to @mention a user!', user.displayAvatarURL());
title: '<a:ABlobCatHuggle:801232248035999784> Hug',
description: `${taggedUser} You have been hugged by ${message.author}!`, const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
color: 8311585, return {
footer: { embeds: [{
icon_url: avatarURL, title: '<a:ABlobCatHuggle:801232248035999784> Hug',
text: config.footerTxt description: `${target} You have been hugged by ${user}!`,
}, color: 8311585,
image: { footer: {
url: gif icon_url: user.displayAvatarURL(),
} text: config.footerTxt
}] },
}); image: {
} url: gif
}
}]
};
} }
}; };

View File

@ -20,18 +20,26 @@ module.exports = {
description: 'Shows bot and host information', description: 'Shows bot and host information',
options: [], options: [],
async execute (client, message, _, config) { async parseMessage (client, config, message) {
await message.channel.send(this.handle(client, config, message.author));
},
async parseInteraction (client, config, interaction) {
await interaction.reply(this.handle(client, config, interaction.user));
},
async handle (client, config, user) {
const os = require('os'); const os = require('os');
const osu = require('node-os-utils'); const osu = require('node-os-utils');
const cpu = osu.cpu; const cpu = osu.cpu;
await message.channel.send({ return {
embeds: [{ embeds: [{
title: '<:AnitroxInfo:809651936831733791> Information about Anitrox', title: '<:AnitroxInfo:809651936831733791> Information about Anitrox',
description: "Everything you've ever wanted to know about your favorite bot, Anitrox!", description: "Everything you've ever wanted to know about your favorite bot, Anitrox!",
color: 9442302, color: 9442302,
footer: { footer: {
icon_url: message.author.displayAvatarURL(), icon_url: user.displayAvatarURL(),
text: config.footerTxt text: config.footerTxt
}, },
thumbnail: { thumbnail: {
@ -104,6 +112,6 @@ module.exports = {
} }
] ]
}] }]
}); };
} }
}; };

View File

@ -4,14 +4,22 @@ module.exports = {
description: 'Add Anitrox to your beautiful server!', description: 'Add Anitrox to your beautiful server!',
options: [], options: [],
async execute (_0, message, _1, config) { async parseMessage (client, config, message, args) {
await message.channel.send({ await message.channel.send(this.handle(client, config, message.author, args.slice(0).join(' ')));
},
async parseInteraction (client, config, interaction) {
await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getString('question')));
},
handle (_, config, user) {
return {
embeds: [{ embeds: [{
title: 'Add Anitrox to your Server!', title: 'Add Anitrox to your Server!',
description: 'Weather you want stable, or that squeaky clean fresh PTB build, we gotchu.', description: 'Weather you want stable, or that squeaky clean fresh PTB build, we gotchu.',
color: 9442302, color: 9442302,
footer: { footer: {
icon_url: message.author.displayAvatarURL(), icon_url: user.displayAvatarURL(),
text: config.footerTxt text: config.footerTxt
}, },
thumbnail: { thumbnail: {
@ -32,6 +40,6 @@ module.exports = {
} }
] ]
}] }]
}); };
} }
}; };

View File

@ -19,28 +19,31 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
}], }],
async execute (client, message, _, config) { async parseMessage (client, config, message) {
const taggedUser = message.mentions.users.first(); await message.channel.send(this.handle(client, config, message.author, message.mentions.users.first()));
const avatarURL = message.author.displayAvatarURL(); },
if (!taggedUser) { async parseInteraction (client, config, interaction) {
await message.channel.send(client.generateErrorMessage('You need to @mention a user!', avatarURL)); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getUser('user')));
} else { },
const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
await message.channel.send({ handle (client, config, user, target) {
embeds: [{ if (!target) return client.generateErrorMessage('You need to @mention a user!', user.displayAvaterURL());
title: ':heart: Kiss',
description: `${taggedUser} You have been kissed by ${message.author}!`, const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
color: 9442302, return {
footer: { embeds: [{
icon_url: avatarURL, title: ':heart: Kiss',
text: config.footerTxt description: `${target} You have been kissed by ${user}!`,
}, color: 9442302,
image: { footer: {
url: gif icon_url: user.displayAvaterURL(),
} text: config.footerTxt
}] },
}); image: {
} url: gif
}
}]
};
} }
}; };

View File

@ -29,28 +29,31 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
}], }],
async execute (client, message, _, config) { async parseMessage (client, config, message) {
const taggedUser = message.mentions.users.first(); await message.channel.send(this.handle(client, config, message.author, message.mentions.users.first()));
const avatarURL = message.author.displayAvatarURL(); },
if (!taggedUser) { async parseInteraction (client, config, interaction) {
await message.channel.send(client.generateErrorMessage('You need to @mention a user!', avatarURL)); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getUser('user')));
} else { },
const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
await message.channel.send({ handle (client, config, user, target) {
embeds: [{ if (!target) return client.generateErrorMessage('You need to @mention a user!', user.displayAvatarURL());
title: ':heart: <:lesbian:803831629428686849> Kiss',
description: `${taggedUser} You have been kissed by ${message.author}!`, const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
color: 8311585, return {
footer: { embeds: [{
icon_url: avatarURL, title: ':heart: <:lesbian:803831629428686849> Kiss',
text: config.footerTxt description: `${target} You have been kissed by ${user}!`,
}, color: 8311585,
image: { footer: {
url: gif icon_url: user.displayAvatarURL(),
} text: config.footerTxt
}] },
}); image: {
} url: gif
}
}]
};
} }
}; };

View File

@ -18,28 +18,30 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
}], }],
async execute (client, message, _, config) { async parseMessage (client, config, message) {
const taggedUser = message.mentions.users.first(); await message.channel.send(this.handle(client, config, message.author, message.mentions.users.first()));
const avatarURL = message.author.displayAvatarURL(); },
if (!taggedUser) { async parseInteraction (client, config, interaction) {
await message.channel.send(client.generateErrorMessage('You need to @mention a user!', avatarURL)); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getUser('user')));
} else { },
const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
await message.channel.send({ handle (client, config, user, target) {
embeds: [{ if (!target) return client.generateErrorMessage('You need to @mention a user!', user.displayAvatarURL());
title: '<a:LeafeonLick:806396195089154058> Lick', const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
description: `${taggedUser} You have been licked by ${message.author}!`, return {
color: 8311585, embeds: [{
footer: { title: '<a:LeafeonLick:806396195089154058> Lick',
icon_url: avatarURL, description: `${target} You have been licked by ${user}!`,
text: config.footerTxt color: 8311585,
}, footer: {
image: { icon_url: user.displayAvatarURL(),
url: gif text: config.footerTxt
} },
}] image: {
}); url: gif
} }
}]
};
} }
}; };

View File

@ -18,28 +18,31 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
}], }],
async execute (client, message, _, config) { async parseMessage (client, config, message) {
const taggedUser = message.mentions.users.first(); await message.channel.send(this.handle(client, config, message.author, message.mentions.users.first()));
const avatarURL = message.author.displayAvatarURL(); },
if (!taggedUser) { async parseInteraction (client, config, interaction) {
await message.channel.send(client.generateErrorMessage('You need to @mention a user!', avatarURL)); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getUser('user')));
} else { },
const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
await message.channel.send({ handle (client, config, user, target) {
embeds: [{ if (!target) return client.generateErrorMessage('You need to @mention a user!', user.displayAvatarURL());
title: '<:BlobNomBlob:801241117919805510> Nom',
description: `${taggedUser} You have been nommed by ${message.author}!`, const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
color: 8311585, return {
footer: { embeds: [{
icon_url: avatarURL, title: '<:BlobNomBlob:801241117919805510> Nom',
text: config.footerTxt description: `${target} You have been nommed by ${user}!`,
}, color: 8311585,
image: { footer: {
url: gif icon_url: user.displayAvatarURL(),
} text: config.footerTxt
}] },
}); image: {
} url: gif
}
}]
};
} }
}; };

View File

@ -17,28 +17,30 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
}], }],
async execute (client, message, _, config) { async parseMessage (client, config, message) {
const taggedUser = message.mentions.users.first(); await message.channel.send(this.handle(client, config, message.author, message.mentions.users.first()));
const avatarURL = message.author.displayAvatarURL(); },
if (!taggedUser) { async parseInteraction (client, config, interaction) {
await message.channel.send(client.generateErrorMessage('You need to @mention a user!', avatarURL)); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getUser('user')));
} else { },
const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
await message.channel.send({ handle (client, config, user, target) {
embeds: [{ if (!target) return client.generateErrorMessage('You need to @mention a user!', user.displayAvatarURL());
title: '<:pats:801238281286713355> Pat', const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
description: `${taggedUser} You have been patted by ${message.author}!`, return {
color: 8311585, embeds: [{
footer: { title: '<:pats:801238281286713355> Pat',
icon_url: avatarURL, description: `${target} You have been patted by ${user}!`,
text: config.footerTxt color: 8311585,
}, footer: {
image: { icon_url: user.displayAvatarURL(),
url: gif text: config.footerTxt
} },
}] image: {
}); url: gif
} }
}]
};
} }
}; };

View File

@ -4,20 +4,28 @@ module.exports = {
description: 'Gets bot ping', description: 'Gets bot ping',
options: [], options: [],
async execute (client, message, _, config) { async parseMessage (client, config, message, args) {
await message.channel.send(await this.handle(client, config, message.author, args.slice(0).join(' ')));
},
async parseInteraction (client, config, interaction) {
await interaction.reply(await this.handle(client, config, interaction.user, interaction.options.getString('question')));
},
async handle (client, config, user) {
const index = Math.floor(Math.random() * config.locations.length); const index = Math.floor(Math.random() * config.locations.length);
const location = config.locations[index]; const location = config.locations[index];
await message.channel.send({ return {
embeds: [{ embeds: [{
title: ':ping_pong: Ping', title: ':ping_pong: Ping',
description: `**Pong!** We pinged **${location}** and got ${client.ws.ping} ms.`, description: `**Pong!** We pinged **${location}** and got ${client.ws.ping} ms.`,
color: 9442302, color: 9442302,
footer: { footer: {
icon_url: message.author.displayAvatarURL(), icon_url: user.displayAvatarURL(),
text: config.footerTxt text: config.footerTxt
} }
}] }]
}); };
} }
}; };

View File

@ -17,28 +17,31 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
}], }],
async execute (client, message, _, config) { async parseMessage (client, config, message) {
const taggedUser = message.mentions.users.first(); await message.channel.send(this.handle(client, config, message.author, message.mentions.users.first()));
const avatarURL = message.author.displayAvatarURL(); },
if (!taggedUser) { async parseInteraction (client, config, interaction) {
await message.channel.send(client.generateErrorMessage('You need to @mention a user!', avatarURL)); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getUser('user')));
} else { },
const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
await message.channel.send({ handle (client, config, user, target) {
embeds: [{ if (!target) return client.generateErrorMessage('You need to @mention a user!', user.displayAvatarURL());
title: '👉 Poke!',
description: `${taggedUser} You have been poked by ${message.author}!`, const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
color: 8311585, return {
footer: { embeds: [{
icon_url: avatarURL, title: '👉 Poke!',
text: config.footerTxt description: `${target} You have been poked by ${user}!`,
}, color: 8311585,
image: { footer: {
url: gif icon_url: user.displayAvatarURL(),
} text: config.footerTxt
}] },
}); image: {
} url: gif
}
}]
};
} }
}; };

View File

@ -4,40 +4,50 @@ module.exports = {
description: 'Reloads a command', description: 'Reloads a command',
options: [], options: [],
async execute (client, message, args, config) { async parseMessage (client, config, message, args) {
const avatarURL = message.author.displayAvatarURL(); await message.channel.send(this.handle(client, config, message.author, args.split(' ')));
if (message.author.id === config.ownerID) { },
if (!args.length) {
await message.channel.send(client.generateErrorMessage('You forgot to provide anything to reload, you pillock', avatarURL)); // TODO: figure out variable input (again)
} async parseInteraction (client, config, interaction) {
await interaction.reply(this.handle(client, config, interaction.user));
},
handle (client, config, user, args) {
if (user.id === config.ownerID) {
if (!args) return client.generateErrorMessage('You forgot to provide anything to reload, you pillock', user.displayAvatarURL());
let returnMessage = '';
args.forEach(async (arg) => { args.forEach(async (arg) => {
const commandName = arg.toLowerCase(); const commandName = arg.toLowerCase();
const command = message.client.commands.get(commandName) || const command = client.commands.get(commandName) ||
message.client.commands.find(cmd => cmd.aliases && cmd.aliases.includes(commandName)); client.commands.find(cmd => cmd.aliases && cmd.aliases.includes(commandName));
if (!command) { if (!command) {
await message.channel.send(client.generateErrorMessage(`There is no command with name or alias \`${commandName}\`, ${message.author}!`, avatarURL)); returnMessage += `There is no command with name or alias \`${commandName}\`\n`;
} else { } else {
delete require.cache[require.resolve(`./${command.name}.js`)]; delete require.cache[require.resolve(`./${command.name}.js`)];
try { try {
const newCommand = require(`./${command.name}.js`); const newCommand = require(`./${command.name}.js`);
client.commands.set(newCommand.name, newCommand); client.commands.set(newCommand.name, newCommand);
await message.channel.send(`<:AnitroxSuccess:809651936819019796> **Reloaded \`${command.name}\` successfully!**`); returnMessage += `Successfully reloaded \`${commandName}\`\n`;
console.log(`User reloaded ${command.name}.`); console.log(`User reloaded ${command.name}.`);
} catch (error) { } catch (error) {
console.error(error); console.error(error);
await message.channel.send(client.generateErrorMessage(`There was an error while reloading \`${command.name}\`:\n\`${error.message}\``, avatarURL)); returnMessage += `There was an error while reloading \`${command.name}\`\n`;
} }
} }
}); });
return returnMessage;
} else { } else {
message.channel.send({ return {
embeds: [{ embeds: [{
title: '<:AnitroxDenied:809651936642203668> **403 Forbidden**', title: '<:AnitroxDenied:809651936642203668> **403 Forbidden**',
color: 13632027, color: 13632027,
footer: { footer: {
icon_url: avatarURL, icon_url: user.displayAvatarURL(),
text: config.footerTxt text: config.footerTxt
}, },
fields: [ fields: [
@ -47,7 +57,7 @@ module.exports = {
} }
] ]
}] }]
}); };
} }
} }
}; };

View File

@ -4,18 +4,26 @@ module.exports = {
description: 'Restarts the bot', description: 'Restarts the bot',
options: [], options: [],
async execute (client, message, _, config) { async parseMessage (client, config, message, args) {
if (message.author.id === config.ownerID) { await message.channel.send(await this.handle(client, config, message.author, args.slice(0).join(' ')));
},
async parseInteraction (client, config, interaction) {
await interaction.reply(await this.handle(client, config, interaction.user, interaction.options.getString('question')));
},
async handle (client, config, user) {
if (user.id === config.ownerID) {
console.log('Anitrox is restarting now!'); console.log('Anitrox is restarting now!');
await message.channel.send('<a:NyabotWorking:697147309531594843> Restarting...'); // await message.channel.send('<a:NyabotWorking:697147309531594843> Restarting...');
try { try {
client.destroy(); client.destroy();
await client.login(config.token); await client.login(config.token);
await message.channel.send('<:NyabotSuccess:697211376740859914> Restart Successful');
console.log('All systems go'); console.log('All systems go');
} catch (e) { console.log(e); } return '<:NyabotSuccess:697211376740859914> Restart Successful';
} catch (e) { console.error(e); }
} else { } else {
await message.channel.send('<:NyabotDenied:697145462565896194> Access Denied, You must be bot owner to execute this command.'); return '<:NyabotDenied:697145462565896194> Access Denied, You must be bot owner to execute this command.';
} }
} }
}; };

View File

@ -11,39 +11,49 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.STRING type: Constants.ApplicationCommandOptionTypes.STRING
}], }],
async execute (client, message, args, config) { async parseMessage (client, config, message, args) {
const avatarURL = message.author.displayAvatarURL(); await message.channel.send(this.handle(client, config, message.author, args.slice(0).join(' ')));
},
if (message.channel.permissionsFor(message.author).has('CHANGE_NICKNAME')) { async parseInteraction (client, config, interaction) {
const newnick = args.slice(0).join(' '); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getString('question')));
try { },
await message.member.setNickname(newnick, "Nickname change requested by the server member. If you don't want users to be able to change their nickname disable 'CHANGE_NICKNAME' via Change Nickname in Roles.");
await message.channel.send({ handle (client, config, user, newNick) {
embeds: [{ return "Discord has an inbuilt slash command for this, so I think it's best we deprecate this";
title: '<:AnitroxSuccess:809651936819019796> Nickname Changed',
color: 9442302, // const avatarURL = message.author.displayAvatarURL();
footer: {
icon_url: message.author.displayAvatarURL(), // if (message.channel.permissionsFor(message.author).has('CHANGE_NICKNAME')) {
text: config.footerTxt // const newnick = args.slice(0).join(' ');
}, // try {
fields: [ // await message.member.setNickname(newnick, "Nickname change requested by the server member. If you don't want users to be able to change their nickname disable 'CHANGE_NICKNAME' via Change Nickname in Roles.");
{ // await message.channel.send({
name: 'Changed nickname successfully!', // embeds: [{
value: `New Nickname: ${newnick}` // title: '<:AnitroxSuccess:809651936819019796> Nickname Changed',
}, // color: 9442302,
{ // footer: {
name: 'New Nickname', // icon_url: message.author.displayAvatarURL(),
value: newnick, // text: config.footerTxt
inline: true // },
} // fields: [
] // {
}] // name: 'Changed nickname successfully!',
}); // value: `New Nickname: ${newnick}`
} catch (error) { // },
await message.channel.send(client.generateErrorMessage('Failed to set user nickname. Does the bot have the correct permissions?', avatarURL)); // {
}; // name: 'New Nickname',
} else { // value: newnick,
await message.channel.send(client.generateErrorMessage('You need to have permission ``CHANGE_NICKNAME`` to change your nick!', avatarURL)); // inline: true
} // }
// ]
// }]
// });
// } catch (error) {
// await message.channel.send(client.generateErrorMessage('Failed to set user nickname. Does the bot have the correct permissions?', avatarURL));
// };
// } else {
// await message.channel.send(client.generateErrorMessage('You need to have permission ``CHANGE_NICKNAME`` to change your nick!', avatarURL));
// }
} }
}; };

View File

@ -11,27 +11,29 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
}], }],
async execute (client, message, _, config) { async parseMessage (client, config, message) {
const taggedUser = message.mentions.users.first(); await message.channel.send(this.handle(client, config, message.author, message.mentions.users.first()));
const avatarURL = message.author.displayAvatarURL(); },
if (!taggedUser) { async parseInteraction (client, config, interaction) {
await message.channel.send(client.generateErrorMessage('You need to @mention a user!', avatarURL)); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getUser('user')));
} else { },
await message.channel.send({
embeds: [{ handle (client, config, user, target) {
title: ':anger: Slap', if (!target) return client.generateErrorMessage('You need to @mention a user!', user.displayAvatarURL());
description: `${taggedUser} You have been slapped by ${message.author}!`, return {
color: 9442302, embeds: [{
footer: { title: ':anger: Slap',
icon_url: avatarURL, description: `${target} You have been slapped by ${user}!`,
text: config.footerTxt color: 9442302,
}, footer: {
image: { icon_url: user.displayAvatarURL(),
url: 'https://media1.tenor.com/images/b6d8a83eb652a30b95e87cf96a21e007/tenor.gif?itemid=10426943' text: config.footerTxt
} },
}] image: {
}); url: 'https://media1.tenor.com/images/b6d8a83eb652a30b95e87cf96a21e007/tenor.gif?itemid=10426943'
} }
}]
};
} }
}; };

View File

@ -17,28 +17,31 @@ module.exports = {
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
}], }],
async execute (client, message, _, config) { async parseMessage (client, config, message) {
const taggedUser = message.mentions.users.first(); await message.channel.send(this.handle(client, config, message.author, message.mentions.users.first()));
const avatarURL = message.author.displayAvatarURL(); },
if (!taggedUser) { async parseInteraction (client, config, interaction) {
await message.channel.send(client.generateErrorMessage('You need to @mention a user!', avatarURL)); await interaction.reply(this.handle(client, config, interaction.user, interaction.options.getUser('user')));
} else { },
const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
await message.channel.send({ handle (client, config, user, target) {
embeds: [{ if (!target) return client.generateErrorMessage('You need to @mention a user!', user.displayAvatarURL());
title: '<:BlobSnuggleCat:806759753450782731> Snuggle',
description: `${taggedUser} You have been snuggled by ${message.author}!`, const gif = gifchoices[Math.floor(Math.random() * gifchoices.length)];
color: 9442302, return {
footer: { embeds: [{
icon_url: avatarURL, title: '<:BlobSnuggleCat:806759753450782731> Snuggle',
text: config.footerTxt description: `${target} You have been snuggled by ${user}!`,
}, color: 9442302,
image: { footer: {
url: gif icon_url: user.displayAvatarURL(),
} text: config.footerTxt
}] },
}); image: {
} url: gif
}
}]
};
} }
}; };

View File

@ -4,33 +4,42 @@ module.exports = {
description: "IT'S TIME TO STOP!... the bot", description: "IT'S TIME TO STOP!... the bot",
options: [], options: [],
async execute (_0, message, _1, config) { async parseMessage (client, config, message, args) {
if (message.author.id === config.ownerID) { await message.channel.send(await this.handle(client, config, message.author, args.slice(0).join(' ')));
await message.channel.send({ process.exit();
},
async parseInteraction (client, config, interaction) {
await interaction.reply(await this.handle(client, config, interaction.user, interaction.options.getString('question')));
process.exit();
},
async handle (_, config, user) {
if (user.id === config.ownerID) {
console.log('The bot is shutting down! Bye bye!');
return {
embeds: [{ embeds: [{
title: '<a:AnitroxWorking:697147309531594843> **Shutting Down...**', title: '<a:AnitroxWorking:697147309531594843> **Shutting Down...**',
description: 'See you next time!', description: 'See you next time!',
color: 9442302, color: 9442302,
footer: { footer: {
icon_url: message.author.displayAvatarURL(), icon_url: user.displayAvatarURL(),
text: config.footerTxt text: config.footerTxt
} }
}] }]
}); };
console.log('The bot is shutting down! Bye bye!');
process.exit();
} else { } else {
await message.channel.send({ return {
embeds: [{ embeds: [{
title: '<:AnitroxDenied:809651936642203668> 403 Forbidden', title: '<:AnitroxDenied:809651936642203668> 403 Forbidden',
description: 'You need to be the bot owner to execute this command!', description: 'You need to be the bot owner to execute this command!',
color: 13632027, color: 13632027,
footer: { footer: {
icon_url: message.author.displayAvatarURL(), icon_url: user.displayAvatarURL(),
text: config.footerTxt text: config.footerTxt
} }
}] }]
}); };
} }
} }
}; };

View File

@ -9,66 +9,68 @@ module.exports = {
description: 'Another user', description: 'Another user',
required: false, required: false,
type: Constants.ApplicationCommandOptionTypes.USER type: Constants.ApplicationCommandOptionTypes.USER
},
{
name: 'userid',
description: "Another user's ID",
required: false,
type: Constants.ApplicationCommandOptionTypes.INTEGER
}], }],
async execute (_0, message, _1, config) { async parseMessage (client, config, message) {
const user = message.mentions.users.first() || message.member; const target = message.mentions.members.first() || message.member;
await message.channel.send(this.handle(client, config, message.author, target));
},
await message.channel.send({ async parseInteraction (client, config, interaction) {
const target = interaction.options.getUser('user') ? (await interaction.guild.members.fetch(interaction.options.getUser('user'))) : interaction.member;
await interaction.reply(this.handle(client, config, interaction.user, target));
},
handle (client, config, user, target) {
return {
embeds: [{ embeds: [{
title: `Everything you've ever wanted to know about ${user.user}!`, title: `Everything you've ever wanted to know about ${target}!`,
color: 9442302, color: 9442302,
footer: { footer: {
icon_url: message.author.displayAvatarURL(), icon_url: user.displayAvatarURL(),
text: config.footerTxt text: config.footerTxt
}, },
thumbnail: { thumbnail: {
url: user.user.displayAvatarURL() url: target.displayAvatarURL()
}, },
fields: [ fields: [
{ {
name: 'Username', name: 'Username',
value: user.user.username, value: target.user.username,
inline: true inline: true
}, },
{ {
name: 'Discriminator', name: 'Discriminator',
value: user.user.discriminator, value: target.user.discriminator,
inline: true inline: true
}, },
{ {
name: 'Full Username', name: 'Full Username',
value: user.user.tag, value: target.user.tag,
inline: true inline: true
}, },
{ {
name: 'User Profile Picture', name: 'User Profile Picture',
value: user.user.displayAvatarURL() value: target.user.displayAvatarURL()
}, },
{ {
name: 'User Status', name: 'User Status',
value: user.presence?.status ?? 'Error getting status, does the bot have the GUILD_PRESENCES intent?' value: target.presence?.status ?? (config.intents.includes('GUILD_PRESENCES') ? 'Offline' : 'Missing GUILD_PRESENCES intent')
// IMPORTANT NOTE: // IMPORTANT NOTE:
// There seems to be an issue where offline and invisible users return a null presense // There seems to be an issue where offline and invisible users return a null presense
// I'll try to patch this soon if I can figure out why // I'll try to patch this soon if I can figure out why
}, },
{ {
name: 'User ID', name: 'User ID',
value: `\`${user.user.id}\`` value: `\`${target.user.id}\``
}, },
{ {
name: 'User Joined Discord', name: 'User Joined Discord',
value: user.user.createdAt.toString(), value: target.user.createdAt.toString(),
inline: true inline: true
} }
] ]
}] }]
}); };
} }
}; };

View File

@ -32,25 +32,26 @@ client.generateErrorMessage = (errorMsg, avatarURL) => ({
client.on('error', (e) => console.log(`[ERROR] ${e}`)); client.on('error', (e) => console.log(`[ERROR] ${e}`));
client.on('warn', (e) => (`[WARN] ${e}`)); client.on('warn', (e) => (`[WARN] ${e}`));
client.once('ready', async () => { client.once('ready', async () => {
const commands = config.sandbox ? client.guilds.cache.get(config.sandboxGuild)?.commands : client.application.commands; // const commands = config.sandbox ? client.guilds.cache.get(config.sandboxGuild)?.commands : client.application.commands;
if (config.sandbox) { // if (config.sandbox) {
console.log('deleting previous commands from sandbox'); // console.log('deleting previous commands from sandbox');
const localCommands = await commands.fetch(); // const localCommands = await commands.fetch();
localCommands.forEach(async x => { // localCommands.forEach(async x => {
await commands.delete(x); // await commands.delete(x);
}); // });
// console.log('deleting global commands'); // console.log('deleting global commands');
// const globalCommands = await client.application.commands.fetch(); // const globalCommands = await client.application.commands.fetch();
// globalCommands.forEach(async x => { // globalCommands.forEach(async x => {
// await client.application.commands.delete(x); // await client.application.commands.delete(x);
// }); // });
} // }
client.commands.forEach(async command => { // client.commands.forEach(async command => {
await commands.create(command); // await commands.create(command);
}); // console.log(command);
// });
// console.clear(); // console.clear();
console.log(' ___ _ __ '); console.log(' ___ _ __ ');
@ -78,9 +79,9 @@ client.on('messageCreate', async (message) => {
if (!client.commands.has(command)) return; if (!client.commands.has(command)) return;
try { try {
await client.commands.get(command).execute(client, message, args, config); await client.commands.get(command).parseMessage(client, config, message, args);
} catch (error) { } catch (error) {
console.trace(); console.log(error);
message.channel.send({ message.channel.send({
embeds: [{ embeds: [{
title: '<:AnitroxError:809651936563429416> **Something went wrong!**', title: '<:AnitroxError:809651936563429416> **Something went wrong!**',
@ -95,4 +96,8 @@ client.on('messageCreate', async (message) => {
} }
}); });
client.on('interactionCreate', async (interaction) => {
client.commands.get(interaction.commandName).parseInteraction(client, config, interaction);
});
client.login(config.token); client.login(config.token);