silvanus/main.js

92 lines
2.7 KiB
JavaScript
Raw Normal View History

2023-01-18 00:35:24 +00:00
/* eslint-disable no-case-declarations */
/* eslint-disable indent */
// dotenv for handling environment variables
const dotenv = require('dotenv');
dotenv.config();
const token = process.env.TOKEN;
const statusChannelId = process.env.STATUSCHANNELID;
2023-01-18 00:35:24 +00:00
// Discord.JS
2023-01-24 01:50:14 +00:00
const { Client, GatewayIntentBits, Partials, ActivityType } = require('discord.js');
2023-01-18 00:35:24 +00:00
const client = new Client({
intents: [
GatewayIntentBits.Guilds,
GatewayIntentBits.GuildMessages,
GatewayIntentBits.GuildMessageReactions,
2023-01-18 01:27:04 +00:00
GatewayIntentBits.MessageContent
2023-01-18 00:35:24 +00:00
],
partials: [
Partials.Channel,
2023-01-18 01:27:04 +00:00
Partials.Message
2023-01-18 00:35:24 +00:00
],
});
// Various imports
2023-01-19 17:44:49 +00:00
const fn = require('./modules/functions.js');
const strings = require('./data/strings.json');
const dbfn = require('./modules/dbfn.js');
const isDev = process.env.DEBUG;
2023-01-18 00:35:24 +00:00
client.once('ready', async () => {
await fn.collectionBuilders.slashCommands(client);
await fn.collectionBuilders.guildInfos(client);
await fn.setupCollectors(client);
2023-01-18 00:35:24 +00:00
console.log('Ready!');
2023-01-24 01:50:14 +00:00
client.user.setActivity({ name: strings.activity.name, type: ActivityType.Watching });
if (isDev == 'false') {
client.channels.fetch(statusChannelId).then(channel => {
channel.send(`${new Date().toISOString()} -- \nStartup Sequence Complete <@481933290912350209>`);
});
}
2023-01-18 00:35:24 +00:00
});
// slash-commands
client.on('interactionCreate', async interaction => {
if (interaction.isCommand()) {
2023-02-19 23:36:20 +00:00
if (isDev) {
console.log(interaction);
}
2023-01-18 00:35:24 +00:00
const { commandName } = interaction;
if (client.slashCommands.has(commandName)) {
client.slashCommands.get(commandName).execute(interaction);
} else {
interaction.reply('Sorry, I don\'t have access to that command.');
console.error('Slash command attempted to run but not found: ' + commandName);
2023-01-18 00:35:24 +00:00
}
}
2023-02-12 20:29:38 +00:00
if (interaction.isButton()) {
switch (interaction.component.customId) {
case 'refresh':
// console.log(JSON.stringify(interaction));
await fn.refresh(interaction).catch(err => {
interaction.channel.send(fn.builders.errorEmbed(err));
});
break;
case 'deleteping':
if (interaction.message.deletable) {
await interaction.message.delete().catch(err => {
console.error(err);
});
}
break;
case 'waterpingrole':
2023-02-12 21:00:04 +00:00
const waterPingStatus = await fn.buttonHandlers.waterPing(interaction);
await interaction.reply(waterPingStatus).catch(err => console.error(err));
2023-02-12 20:29:38 +00:00
break;
case 'fruitpingrole':
2023-02-12 21:00:04 +00:00
const fruitPingStatus = await fn.buttonHandlers.fruitPing(interaction);
await interaction.reply(fruitPingStatus).catch(err => console.error(err));
2023-02-12 20:29:38 +00:00
break;
default:
break;
}
2023-01-18 00:35:24 +00:00
}
});
process.on('unhandledRejection', error => {
console.error('Unhandled promise rejection:', error);
});
2023-01-18 00:35:24 +00:00
client.login(token);