Class commands, improved sharding, and many other changes (#88)
* Load commands recursively
* Sort commands
* Missed a couple of spots
* missed even more spots apparently
* Ported commands in "fun" category to new class-based format, added babel eslint plugin
* Ported general commands, removed old/unneeded stuff, replaced moment with day, many more fixes I lost track of
* Missed a spot
* Removed unnecessary abort-controller package, add deprecation warning for mongo database
* Added imagereload, clarified premature end message
* Fixed docker-compose path issue, added total bot uptime to stats, more fixes for various parts
* Converted image commands into classes, fixed reload, ignore another WS event, cleaned up command handler and image runner
* Converted music/soundboard commands to class format
* Cleanup unnecessary logs
* awful tag command class port
* I literally somehow just learned that you can leave out the constructor in classes
* Pass client directly to commands/events, cleaned up command handler
* Migrated bot to eris-sharder, fixed some error handling stuff
* Remove unused modules
* Fixed type returning
* Switched back to Eris stable
* Some fixes and cleanup
* might wanna correct this
* Implement image command ratelimiting
* Added Bot token prefix, added imagestats, added running endpoint to API
2021-04-12 16:16:12 +00:00
|
|
|
if (process.platform === "win32") console.error("\x1b[1m\x1b[31m\x1b[40m" + `WIN32 IS NOT OFFICIALLY SUPPORTED!
|
2020-12-03 16:30:33 +00:00
|
|
|
Although there's a (very) slim chance of it working, multiple aspects of the bot are built with UNIX-like systems in mind and could break on Win32-based systems. If you want to run the bot on Windows, using Windows Subsystem for Linux is highly recommended.
|
|
|
|
The bot will continue to run past this message, but keep in mind that it could break at any time. Continue running at your own risk; alternatively, stop the bot using Ctrl+C and install WSL.` + "\x1b[0m");
|
|
|
|
|
2019-11-13 00:09:06 +00:00
|
|
|
// load config from .env file
|
|
|
|
require("dotenv").config();
|
|
|
|
|
2021-04-21 18:35:06 +00:00
|
|
|
// main sharding manager
|
2021-07-05 04:15:27 +00:00
|
|
|
const { Fleet } = require("eris-fleet");
|
|
|
|
const { isMaster } = require("cluster");
|
2021-07-05 13:14:52 +00:00
|
|
|
// some utils
|
2021-07-05 04:15:27 +00:00
|
|
|
const path = require("path");
|
2021-07-05 13:14:52 +00:00
|
|
|
const winston = require("winston");
|
2021-04-21 18:35:06 +00:00
|
|
|
// dbl posting
|
|
|
|
const TopGG = require("@top-gg/sdk");
|
2021-04-27 02:53:27 +00:00
|
|
|
const dbl = process.env.NODE_ENV === "production" && process.env.DBL !== "" ? new TopGG.Api(process.env.DBL) : null;
|
Class commands, improved sharding, and many other changes (#88)
* Load commands recursively
* Sort commands
* Missed a couple of spots
* missed even more spots apparently
* Ported commands in "fun" category to new class-based format, added babel eslint plugin
* Ported general commands, removed old/unneeded stuff, replaced moment with day, many more fixes I lost track of
* Missed a spot
* Removed unnecessary abort-controller package, add deprecation warning for mongo database
* Added imagereload, clarified premature end message
* Fixed docker-compose path issue, added total bot uptime to stats, more fixes for various parts
* Converted image commands into classes, fixed reload, ignore another WS event, cleaned up command handler and image runner
* Converted music/soundboard commands to class format
* Cleanup unnecessary logs
* awful tag command class port
* I literally somehow just learned that you can leave out the constructor in classes
* Pass client directly to commands/events, cleaned up command handler
* Migrated bot to eris-sharder, fixed some error handling stuff
* Remove unused modules
* Fixed type returning
* Switched back to Eris stable
* Some fixes and cleanup
* might wanna correct this
* Implement image command ratelimiting
* Added Bot token prefix, added imagestats, added running endpoint to API
2021-04-12 16:16:12 +00:00
|
|
|
|
2021-07-05 13:14:52 +00:00
|
|
|
if (isMaster) {
|
|
|
|
console.log(`
|
|
|
|
,*\`$ z\`"v
|
|
|
|
F zBw\`% A ,W "W
|
|
|
|
,\` ,EBBBWp"%. ,-=~~==-,+* 4BBE T
|
|
|
|
M BBBBBBBB* ,w=####Wpw 4BBBBB# 1
|
|
|
|
F BBBBBBBMwBBBBBBBBBBBBB#wXBBBBBH E
|
|
|
|
F BBBBBBkBBBBBBBBBBBBBBBBBBBBE4BL k
|
|
|
|
# BFBBBBBBBBBBBBF" "RBBBW F
|
|
|
|
V ' 4BBBBBBBBBBM TBBL F
|
|
|
|
F BBBBBBBBBBF JBB L
|
|
|
|
F FBBBBBBBEB BBL 4
|
|
|
|
E [BB4BBBBEBL BBL 4
|
|
|
|
I #BBBBBBBEB 4BBH *w
|
|
|
|
A 4BBBBBBBBBEW, ,BBBB W [
|
|
|
|
.A ,k 4BBBBBBBBBBBEBW####BBBBBBM BF F
|
|
|
|
k <BBBw BBBBEBBBBBBBBBBBBBBBBBQ4BM #
|
|
|
|
5, REBBB4BBBBB#BBBBBBBBBBBBP5BFF ,F
|
|
|
|
*w \`*4BBW\`"FF#F##FFFF"\` , * +"
|
|
|
|
*+, " F'"'*^~~~^"^\` V+*^
|
|
|
|
\`"""
|
|
|
|
|
|
|
|
esmBot ${require("./package.json").version}, powered by eris-fleet ${require("./node_modules/eris-fleet/package.json").version}
|
|
|
|
`);
|
|
|
|
// a bit of a hacky way to get the eris-fleet version
|
|
|
|
}
|
|
|
|
|
2021-07-05 04:15:27 +00:00
|
|
|
const Admiral = new Fleet({
|
|
|
|
path: path.join(__dirname, "./shard.js"),
|
|
|
|
token: `Bot ${process.env.TOKEN}`,
|
|
|
|
startingStatus: {
|
|
|
|
status: "idle",
|
|
|
|
game: {
|
|
|
|
name: "Starting esmBot..."
|
|
|
|
}
|
|
|
|
},
|
2021-07-06 00:20:21 +00:00
|
|
|
whatToLog: {
|
|
|
|
blacklist: ["stats_update"]
|
|
|
|
},
|
Class commands, improved sharding, and many other changes (#88)
* Load commands recursively
* Sort commands
* Missed a couple of spots
* missed even more spots apparently
* Ported commands in "fun" category to new class-based format, added babel eslint plugin
* Ported general commands, removed old/unneeded stuff, replaced moment with day, many more fixes I lost track of
* Missed a spot
* Removed unnecessary abort-controller package, add deprecation warning for mongo database
* Added imagereload, clarified premature end message
* Fixed docker-compose path issue, added total bot uptime to stats, more fixes for various parts
* Converted image commands into classes, fixed reload, ignore another WS event, cleaned up command handler and image runner
* Converted music/soundboard commands to class format
* Cleanup unnecessary logs
* awful tag command class port
* I literally somehow just learned that you can leave out the constructor in classes
* Pass client directly to commands/events, cleaned up command handler
* Migrated bot to eris-sharder, fixed some error handling stuff
* Remove unused modules
* Fixed type returning
* Switched back to Eris stable
* Some fixes and cleanup
* might wanna correct this
* Implement image command ratelimiting
* Added Bot token prefix, added imagestats, added running endpoint to API
2021-04-12 16:16:12 +00:00
|
|
|
clientOptions: {
|
|
|
|
disableEvents: {
|
|
|
|
CHANNEL_DELETE: true,
|
|
|
|
GUILD_BAN_REMOVE: true,
|
|
|
|
GUILD_MEMBER_ADD: true,
|
|
|
|
GUILD_MEMBER_REMOVE: true,
|
|
|
|
GUILD_MEMBER_UPDATE: true,
|
|
|
|
GUILD_ROLE_CREATE: true,
|
|
|
|
GUILD_ROLE_DELETE: true,
|
|
|
|
GUILD_ROLE_UPDATE: true,
|
|
|
|
TYPING_START: true,
|
|
|
|
MESSAGE_DELETE_BULK: true
|
|
|
|
},
|
|
|
|
allowedMentions: {
|
|
|
|
everyone: false,
|
|
|
|
roles: false,
|
|
|
|
users: true,
|
|
|
|
repliedUser: true
|
|
|
|
},
|
2021-04-15 00:57:35 +00:00
|
|
|
guildSubscriptions: false,
|
|
|
|
intents: [
|
|
|
|
"guilds",
|
|
|
|
"guildVoiceStates",
|
|
|
|
"guildMessages",
|
|
|
|
"guildMessageReactions",
|
|
|
|
"directMessages",
|
|
|
|
"directMessageReactions"
|
2021-06-26 20:56:02 +00:00
|
|
|
],
|
|
|
|
stats: {
|
|
|
|
requestTimeout: 30000
|
|
|
|
}
|
2021-07-06 00:20:21 +00:00
|
|
|
},
|
|
|
|
services: [
|
2021-07-06 14:22:51 +00:00
|
|
|
{ name: "prometheus", path: path.join(__dirname, "./utils/services/prometheus.js") },
|
2021-07-06 00:20:21 +00:00
|
|
|
{ name: "image", path: path.join(__dirname, "./utils/services/image.js")}
|
|
|
|
]
|
2021-04-21 18:35:06 +00:00
|
|
|
});
|
|
|
|
|
2021-07-05 04:15:27 +00:00
|
|
|
if (isMaster) {
|
2021-07-05 13:14:52 +00:00
|
|
|
const logger = winston.createLogger({
|
|
|
|
levels: {
|
|
|
|
error: 0,
|
|
|
|
warn: 1,
|
|
|
|
info: 2,
|
|
|
|
main: 3,
|
|
|
|
debug: 4
|
|
|
|
},
|
|
|
|
transports: [
|
|
|
|
new winston.transports.Console({ format: winston.format.colorize({ all: true }) }),
|
|
|
|
new winston.transports.File({ filename: "logs/error.log", level: "error" }),
|
|
|
|
new winston.transports.File({ filename: "logs/main.log" })
|
|
|
|
],
|
|
|
|
level: "main",
|
|
|
|
format: winston.format.combine(
|
|
|
|
winston.format.timestamp({ format: "YYYY-MM-DD HH:mm:ss" }),
|
|
|
|
winston.format.printf((info) => {
|
|
|
|
const {
|
|
|
|
timestamp, level, message, ...args
|
|
|
|
} = info;
|
|
|
|
|
|
|
|
return `[${timestamp}]: [${level.toUpperCase()}] - ${message} ${Object.keys(args).length ? JSON.stringify(args, null, 2) : ""}`;
|
|
|
|
}),
|
|
|
|
)
|
|
|
|
});
|
|
|
|
|
|
|
|
winston.addColors({
|
|
|
|
info: "green",
|
|
|
|
main: "gray",
|
|
|
|
debug: "purple",
|
|
|
|
warn: "yellow",
|
|
|
|
error: "red"
|
|
|
|
});
|
2021-07-06 00:20:21 +00:00
|
|
|
|
2021-07-05 13:14:52 +00:00
|
|
|
Admiral.on("log", (m) => logger.main(m));
|
2021-07-06 00:20:21 +00:00
|
|
|
Admiral.on("info", (m) => logger.info(m));
|
2021-07-05 13:14:52 +00:00
|
|
|
Admiral.on("debug", (m) => logger.debug(m));
|
|
|
|
Admiral.on("warn", (m) => logger.warn(m));
|
|
|
|
Admiral.on("error", (m) => logger.error(m));
|
2021-07-05 04:15:27 +00:00
|
|
|
|
2021-04-27 02:53:27 +00:00
|
|
|
if (dbl) {
|
2021-07-05 04:15:27 +00:00
|
|
|
Admiral.on("stats", async (m) => {
|
|
|
|
await dbl.postStats({
|
|
|
|
serverCount: m.guilds,
|
|
|
|
shardCount: m.shardCount
|
|
|
|
});
|
2021-04-27 02:53:27 +00:00
|
|
|
});
|
2021-04-21 18:35:06 +00:00
|
|
|
}
|
2021-07-05 04:15:27 +00:00
|
|
|
}
|