aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--bot.js6
-rw-r--r--handler/command.js35
2 files changed, 41 insertions, 0 deletions
diff --git a/bot.js b/bot.js
index f45b6b6..6f993a7 100644
--- a/bot.js
+++ b/bot.js
@@ -13,6 +13,9 @@ if (!fs.existsSync("./user/spoilers.json")) fs.writeFileSync("./user/spoilers.js
if (!fs.existsSync("./user/servers.json")) fs.writeFileSync("./user/servers.json", "{}");
if (!fs.existsSync("./reports")) fs.mkdirSync("./reports");
if (!fs.existsSync("./stats")) fs.mkdirSync("./stats");
+if (!fs.existsSync("./stats/by-date.json")) fs.writeFileSync("./stats/by-date.json", '{}');
+if (!fs.existsSync("./stats/by-day.json")) fs.writeFileSync("./stats/by-day.json", '{"0":{},"1":{},"2":{},"3":{},"4":{},"5":{},"6":{}}');
+if (!fs.existsSync("./stats/by-hour.json")) fs.writeFileSync("./stats/by-hour.json", '{"0":{},"1":{},"2":{},"3":{},"4":{},"5":{},"6":{},"7":{},"8":{},"9":{},"10":{},"11":{},"12":{},"13":{},"14":{},"15":{},"16":{},"17":{},"18":{},"19":{},"20":{},"21":{},"22":{},"23":{}}');
if (!fs.existsSync("./stats/commands.json")) fs.writeFileSync("./stats/commands.json", "{}");
if (!fs.existsSync("./stats/ponies.json")) fs.writeFileSync("./stats/ponies.json", "{}");
if (!fs.existsSync("./stats/buttons.json")) fs.writeFileSync("./stats/buttons.json", "{}");
@@ -39,6 +42,9 @@ global.statsPonies = JSON.parse(fs.readFileSync("./stats/ponies.json").toString(
global.statsButtons = JSON.parse(fs.readFileSync("./stats/buttons.json").toString());
global.statsMenu = JSON.parse(fs.readFileSync("./stats/menu.json").toString());
global.statsQueries = JSON.parse(fs.readFileSync("./stats/queries.json").toString());
+global.statsDate = JSON.parse(fs.readFileSync("./stats/by-date.json").toString());
+global.statsHour = JSON.parse(fs.readFileSync("./stats/by-hour.json").toString());
+global.statsDay = JSON.parse(fs.readFileSync("./stats/by-day.json").toString());
global.cooldowns = {};
global.l = (en, fr, id, gid) => {
diff --git a/handler/command.js b/handler/command.js
index 3869c6d..c1957ae 100644
--- a/handler/command.js
+++ b/handler/command.js
@@ -20,13 +20,48 @@ const commandHelp = require('../commands/help');
module.exports = async (interaction) => {
console.log(interaction.user.tag + " (" + interaction.user.id + ") used command /" + interaction.commandName);
+
if (statsCommands[interaction.commandName] !== undefined) {
statsCommands[interaction.commandName]++;
} else {
statsCommands[interaction.commandName] = 1;
}
+ statsCommands["_total"] = Object.keys(statsCommands).filter(i => i !== "_total").map(i => statsCommands[i]).reduce((a, b) => a + b);
fs.writeFile("./stats/commands.json", JSON.stringify(statsCommands), () => {});
+ if (statsHour[new Date().getUTCHours().toString()] === undefined) {
+ statsHour[new Date().getUTCHours().toString()] = {};
+ }
+ if (statsHour[new Date().getUTCHours().toString()][interaction.commandName] !== undefined) {
+ statsHour[new Date().getUTCHours().toString()][interaction.commandName]++;
+ } else {
+ statsHour[new Date().getUTCHours().toString()][interaction.commandName] = 1;
+ }
+ statsHour[new Date().getUTCHours().toString()]["_total"] = Object.keys(statsHour[new Date().getUTCHours().toString()]).filter(i => i !== "_total").map(i => statsHour[new Date().getUTCHours().toString()][i]).reduce((a, b) => a + b);
+ fs.writeFile("./stats/by-hour.json", JSON.stringify(statsHour), () => {});
+
+ if (statsDay[new Date().getUTCDay().toString()] === undefined) {
+ statsDay[new Date().getUTCDay().toString()] = {};
+ }
+ if (statsDay[new Date().getUTCDay().toString()][interaction.commandName] !== undefined) {
+ statsDay[new Date().getUTCDay().toString()][interaction.commandName]++;
+ } else {
+ statsDay[new Date().getUTCDay().toString()][interaction.commandName] = 1;
+ }
+ statsDay[new Date().getUTCDay().toString()]["_total"] = Object.keys(statsDay[new Date().getUTCDay().toString()]).filter(i => i !== "_total").map(i => statsDay[new Date().getUTCDay().toString()][i]).reduce((a, b) => a + b);
+ fs.writeFile("./stats/by-day.json", JSON.stringify(statsDay), () => {});
+
+ if (statsDate[new Date().toISOString().split("T")[0]] === undefined) {
+ statsDate[new Date().toISOString().split("T")[0]] = {};
+ }
+ if (statsDate[new Date().toISOString().split("T")[0]][interaction.commandName] !== undefined) {
+ statsDate[new Date().toISOString().split("T")[0]][interaction.commandName]++;
+ } else {
+ statsDate[new Date().toISOString().split("T")[0]][interaction.commandName] = 1;
+ }
+ statsDate[new Date().toISOString().split("T")[0]]["_total"] = Object.keys(statsDate[new Date().toISOString().split("T")[0]]).filter(i => i !== "_total").map(i => statsDate[new Date().toISOString().split("T")[0]][i]).reduce((a, b) => a + b);
+ fs.writeFile("./stats/by-date.json", JSON.stringify(statsDate), () => {});
+
if (interaction.commandName === 'random') {
await commandRandom(interaction);
}