mirror of
https://github.com/warengroup/eximiabots-radiox.git
synced 2024-12-25 13:13:18 +00:00
102 lines
3.2 KiB
JavaScript
102 lines
3.2 KiB
JavaScript
import Datastore from "../datastore.js";
|
||
import fetch from "node-fetch";
|
||
|
||
module.exports = {
|
||
name: 'ready',
|
||
async execute(client) {
|
||
|
||
client.funcs.logger("Bot", "Ready");
|
||
|
||
/*DATASTORE*/
|
||
client.funcs.logger('Datastore', 'Initialize');
|
||
client.datastore = new Datastore();
|
||
|
||
client.funcs.logger('Datastore');
|
||
client.datastore.map.forEach(datastore => {
|
||
console.log("- " + datastore.guild.id + " / " + datastore.guild.name);
|
||
});
|
||
console.log("\n");
|
||
|
||
client.funcs.logger('Datastore', 'Ready');
|
||
|
||
/*DEVELOPERS*/
|
||
client.funcs.logger('Developers');
|
||
|
||
client.developers = "";
|
||
let user = "";
|
||
for (let i = 0; i < client.config.devId.length; i++) {
|
||
user = await client.users.fetch(client.config.devId[i]);
|
||
console.log("- " + user.tag);
|
||
if (i == client.config.devId.length - 1) {
|
||
client.developers += user.tag;
|
||
} else {
|
||
client.developers += user.tag + " & ";
|
||
}
|
||
}
|
||
console.log("\n");
|
||
|
||
/*STATIONS*/
|
||
try {
|
||
client.funcs.logger('Stations', 'Started fetching list – ' + client.config.stationslistUrl);
|
||
client.stations = await fetch(client.config.stationslistUrl)
|
||
.then(client.funcs.checkFetchStatus)
|
||
.then(response => response.json());
|
||
|
||
client.funcs.logger('Stations');
|
||
client.stations.forEach(station => {
|
||
console.log("- " + station.name);
|
||
});
|
||
console.log("\n");
|
||
|
||
client.funcs.logger('Stations', 'Successfully fetched list');
|
||
} catch (error) {
|
||
client.funcs.logger('Stations', 'Fetching list failed');
|
||
console.error(error + "\n");
|
||
}
|
||
|
||
setInterval(async () => {
|
||
try {
|
||
client.funcs.logger('Stations', 'Started fetching list – ' + client.config.stationslistUrl);
|
||
client.stations = await fetch(client.config.stationslistUrl)
|
||
.then(client.funcs.checkFetchStatus)
|
||
.then(response => response.json());
|
||
|
||
client.funcs.logger('Stations', 'Successfully fetched list');
|
||
} catch (error) {
|
||
client.funcs.logger('Stations', 'Fetching list failed');
|
||
//console.error(error);
|
||
}
|
||
}, 3600000);
|
||
|
||
if(!client.stations) {
|
||
client.user.setStatus('dnd');
|
||
}
|
||
|
||
/*GUILDS*/
|
||
client.funcs.logger('Guilds', 'Started fetching list');
|
||
|
||
client.funcs.logger('Guilds');
|
||
let guilds = await client.guilds.fetch();
|
||
guilds.forEach(guild => {
|
||
console.log("- " + guild.id + " / " + guild.name);
|
||
});
|
||
console.log("\n");
|
||
|
||
client.funcs.logger('Guilds', 'Successfully fetched list');
|
||
|
||
/*STATISTICS*/
|
||
client.datastore.calculateGlobal(client);
|
||
|
||
/*EMOJIS*/
|
||
require(`../emojis.js`).execute(client);
|
||
|
||
/*COMMANDS*/
|
||
require(`../commands.js`).execute(client);
|
||
|
||
setTimeout(function () {
|
||
/*RESTORE RADIO*/
|
||
require(`../restoreradio.js`).execute(client, guilds);
|
||
}, 5000);
|
||
|
||
}
|
||
} |