diff options
-rw-r--r-- | bot.js | 6 | ||||
-rw-r--r-- | handler/command.js | 35 |
2 files changed, 41 insertions, 0 deletions
@@ -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);
}
|