Added snowflake and experimental xp system, made logger easier to use
This commit is contained in:
parent
606c1ea1dc
commit
171253c52c
12 changed files with 137 additions and 43 deletions
|
@ -1,4 +1,4 @@
|
|||
const Guild = require("../utils/database.js");
|
||||
const db = require("../utils/database.js");
|
||||
const logger = require("../utils/logger.js");
|
||||
const misc = require("../utils/misc.js");
|
||||
const client = require("../utils/client.js");
|
||||
|
@ -6,10 +6,23 @@ const client = require("../utils/client.js");
|
|||
// run when the bot is added to a guild
|
||||
module.exports = async (guild) => {
|
||||
logger.log("info", `[GUILD JOIN] ${guild.name} (${guild.id}) added the bot. Owner: ${client.users.get(guild.ownerID).username}#${client.users.get(guild.ownerID).discriminator} (${guild.ownerID})`);
|
||||
const guildDB = new Guild({
|
||||
const guildDB = new db.guilds({
|
||||
id: guild.id,
|
||||
tags: misc.tagDefaults,
|
||||
prefix: "&"
|
||||
});
|
||||
const memberInfo = {};
|
||||
for (const member of guild.members) {
|
||||
memberInfo[member.id] = {
|
||||
xpAmount: 0,
|
||||
level: 0
|
||||
};
|
||||
}
|
||||
const xpDB = new db.xp({
|
||||
id: guild.id,
|
||||
members: memberInfo,
|
||||
enabled: false
|
||||
});
|
||||
await guildDB.save();
|
||||
await xpDB.save();
|
||||
};
|
||||
|
|
|
@ -12,16 +12,58 @@ module.exports = async (message) => {
|
|||
|
||||
// prefix can be a mention or a set of special characters
|
||||
const prefixMention = new RegExp(`^<@!?${client.user.id}> `);
|
||||
const guildConf = (await database.find({ id: message.channel.guild.id }).exec())[0];
|
||||
const guildConf = (await database.guilds.find({ id: message.channel.guild.id }).exec())[0];
|
||||
const prefix = prefixMention.test(message.content) ? message.content.match(prefixMention)[0] : guildConf.prefix;
|
||||
|
||||
// xp stuff
|
||||
const xp = (await database.xp.find({ id: message.channel.guild.id }).exec())[0];
|
||||
if (xp.enabled === true) {
|
||||
//console.log(xp.members);
|
||||
const info = xp.members.get(message.author.id);
|
||||
if (!info) {
|
||||
logger.log("Member not in XP database, adding");
|
||||
const memberInfo = {
|
||||
xpAmount: 1,
|
||||
level: 0
|
||||
};
|
||||
xp.members.set(message.author.id, memberInfo);
|
||||
await xp.save();
|
||||
} else {
|
||||
let newLevel;
|
||||
const newAmount = info.xpAmount + 1;
|
||||
//xp.members[message.author.id].xpAmount++;
|
||||
const level = Math.floor(0.1 * Math.sqrt(newAmount));
|
||||
if (info.level < level) {
|
||||
newLevel = info.level++;
|
||||
//xp.members[message.author.id].level++;
|
||||
logger.log(`${message.author.username} has leveled up`);
|
||||
if (message.channel.guild.id === "631290275456745502" && level === 5) {
|
||||
await message.author.addRole("638759280752853022", "level 5");
|
||||
await message.channel.createMessage(`${message.author.mention} just leveled up to level ${level}... AND unlocked the better members role!`);
|
||||
} else if (message.channel.guild.id === "631290275456745502" && level === 10) {
|
||||
await message.author.addRole("638822807626711078", "level 10");
|
||||
await message.channel.createMessage(`${message.author.mention} just leveled up to level ${level}... AND unlocked the even better members role!`);
|
||||
} else if (message.channel.guild.id === "631290275456745502" && level === 25) {
|
||||
await message.author.addRole("631299545657114645", "level 25");
|
||||
await message.channel.createMessage(`${message.author.mention} just leveled up to level ${level}... AND unlocked the best members role!`);
|
||||
} else {
|
||||
await message.channel.createMessage(`${message.author.mention} just leveled up to level ${level}!`);
|
||||
}
|
||||
}
|
||||
xp.members.set(message.author.id, {
|
||||
xpAmount: newAmount,
|
||||
level: newLevel ? newLevel : info.level
|
||||
});
|
||||
await xp.save();
|
||||
}
|
||||
}
|
||||
|
||||
// ignore other stuff
|
||||
// && !message.attachments && message.attachments[0].filename !== "1561668913236-3.gif"
|
||||
if (message.content.startsWith(prefix) === false && message.mentions.indexOf(client.user) <= -1 && message.channel.id !== "573553254575898626" && (!message.content.match(/https?:\/\/(media|cdn)\.discordapp\.(net|com)\/attachments\/596766080014221373\/606176845871972383\/1561668913236-3.gif/))) return;
|
||||
|
||||
// funny stuff
|
||||
if (message.channel.id === "573553254575898626" && message.channel.guild.id === "433408970955423765") {
|
||||
const generalChannel = client.guilds.get("322114245632327703").channels.get("322114245632327703");
|
||||
const generalChannel = client.guilds.get("631290275456745502").channels.get("631290275888627713");
|
||||
if (message.attachments.length !== 0) {
|
||||
const attachments = [];
|
||||
for (const attachment of message.attachments) {
|
||||
|
|
|
@ -7,22 +7,43 @@ const misc = require("../utils/misc.js");
|
|||
// run when ready
|
||||
module.exports = async () => {
|
||||
// make sure settings/tags exist
|
||||
for (const guild of client.guilds) {
|
||||
const guildDB = (await database.find({ id: guild.id }).exec())[0];
|
||||
for (const [id, guild] of client.guilds) {
|
||||
const guildDB = (await database.guilds.find({ id: id }).exec())[0];
|
||||
const xpDB = (await database.xp.find({ id: id }).exec())[0];
|
||||
// .length === 0 && guildDB.constructor === Object
|
||||
// !Object.entries(guildDB)
|
||||
if (!guildDB) {
|
||||
console.log(`Registering database entry for ${guild.id}...`);
|
||||
const newGuild = new database({
|
||||
id: guild.id,
|
||||
console.log(`Registering guild database entry for guild ${id}...`);
|
||||
const newGuild = new database.guilds({
|
||||
id: id,
|
||||
tags: misc.tagDefaults,
|
||||
prefix: "&"
|
||||
});
|
||||
await newGuild.save();
|
||||
}
|
||||
// .length === 0 && xpDB.constructor === Object
|
||||
// !Object.entries(xpDB)
|
||||
if (!xpDB) {
|
||||
console.log(`Registering xp database entry for guild ${id}...`);
|
||||
const memberInfo = {};
|
||||
for (const [id] of guild.members) {
|
||||
memberInfo[id] = {
|
||||
xpAmount: 0,
|
||||
level: 0
|
||||
};
|
||||
}
|
||||
const newXP = new database.xp({
|
||||
id: id,
|
||||
members: memberInfo,
|
||||
enabled: false
|
||||
});
|
||||
await newXP.save();
|
||||
}
|
||||
}
|
||||
|
||||
// set activity (a.k.a. the gamer code)
|
||||
(async function activityChanger() {
|
||||
client.editStatus("dnd", { name: `${misc.random(config.activityMessages)} | @esmBot help` });
|
||||
client.editStatus("dnd", { name: `${misc.random(config.activityMessages)} | @esmBot help`, url: "https://essem.space/esmBot/commands.html?dev=true" });
|
||||
setTimeout(activityChanger, 900000);
|
||||
})();
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue