redis stuff
This commit is contained in:
parent
0d8878ed37
commit
68b467ac71
2 changed files with 77 additions and 21 deletions
51
bot/index.js
51
bot/index.js
|
@ -13,16 +13,18 @@ class Custom extends Client {
|
|||
constructor (options) {
|
||||
super(options);
|
||||
|
||||
this.path = __dirname;
|
||||
this.config = require("../config.json");
|
||||
this.dev = true;
|
||||
if (this.config.devmode === false) {
|
||||
this.dev = false;
|
||||
//sentry.init({ dsn: this.config.keys.sentry });
|
||||
}
|
||||
|
||||
this.path = __dirname;
|
||||
this.logger = require("./util/logger");
|
||||
this.util = new (require("./util/util"))(this);
|
||||
this.messageUtil = new (require("./util/messageUtil"))(this);
|
||||
this.dev = false;
|
||||
|
||||
if (this.config.devmode === true) {
|
||||
this.dev = true;
|
||||
}
|
||||
this.db = new (require("./util/redis"))(this)
|
||||
|
||||
// Create collections to store loaded commands and aliases in
|
||||
this.commands = new Collection();
|
||||
|
@ -37,20 +39,35 @@ class Custom extends Client {
|
|||
}
|
||||
}
|
||||
|
||||
// Initialize client
|
||||
const client = new Custom();
|
||||
/* Enable this later
|
||||
if (client.dev !== true) {
|
||||
sentry.init({ dsn: client.config.keys.sentry });
|
||||
}
|
||||
*/
|
||||
// Initialization function, so we can use async/await
|
||||
const init = async () => {
|
||||
// Initialize client
|
||||
const client = new Custom();
|
||||
|
||||
client.commandHandler.loadAll();
|
||||
client.eventHandler.loadAll();
|
||||
// Initialize Redis database
|
||||
await client.db.init();
|
||||
|
||||
if (client.dev === true) {
|
||||
await client.commandHandler.loadAll();
|
||||
await client.eventHandler.loadAll();
|
||||
|
||||
if (client.dev === true) {
|
||||
client.logger.warn("Development mode is on. Some features (such as Sentry) are disabled.");
|
||||
client.login(client.config.devtoken);
|
||||
} else {
|
||||
} else {
|
||||
client.login(client.config.token);
|
||||
}
|
||||
}
|
||||
|
||||
init();
|
||||
|
||||
// Catch exceptions/rejections and give more details on the stack trace
|
||||
process.on("uncaughtException", (err) => {
|
||||
const errorMsg = err.stack.replace(new RegExp(`${__dirname}/`, "g"), "./")
|
||||
console.error("Uncaught Exception: ", errorMsg)
|
||||
process.exit(1)
|
||||
});
|
||||
|
||||
process.on("unhandledRejection", err => {
|
||||
console.error("Uncaught Promise Error: ", err)
|
||||
});
|
||||
|
||||
|
|
39
bot/util/redis.js
Normal file
39
bot/util/redis.js
Normal file
|
@ -0,0 +1,39 @@
|
|||
const redis = require('redis')
|
||||
const generators = require('redis-async-gen')
|
||||
|
||||
class Redis {
|
||||
constructor(client) {
|
||||
// Create redis client
|
||||
this.global = redis.createClient(this.client.config.redis)
|
||||
this.server = this.global.duplicate({ db: 1 })
|
||||
this.member = this.global.duplicate({ db: 2 })
|
||||
this.user = this.global.duplicate({ db: 3 })
|
||||
|
||||
// Deletes specified guild entry
|
||||
this.deleteGuild = async function (id) {
|
||||
this.server.del(id)
|
||||
var { keysMatching } = await generators.using(this.member)
|
||||
// eslint-disable-next-line no-unused-vars
|
||||
for await (const key of keysMatching(id + '-*')) {
|
||||
this.member.del(key)
|
||||
}
|
||||
}
|
||||
|
||||
// Deletes specified user and their member entries in guilds
|
||||
this.deleteUser = async function (id) {
|
||||
this.user.del(id)
|
||||
var { keysMatching } = await generators.using(this.member)
|
||||
// eslint-disable-next-line no-unused-vars
|
||||
for await (const key of keysMatching('*-' + id)) {
|
||||
this.member.del(key)
|
||||
}
|
||||
}
|
||||
|
||||
// Deletes member of user in specified guild
|
||||
this.deleteMember = async function (guildId, id) {
|
||||
this.member.del(guildId + '-' + id)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = Redis
|
Loading…
Reference in a new issue