Added count, added some new playing lines, fixed security issue with hackban
This commit is contained in:
parent
e9f4109f43
commit
c65a8115aa
6 changed files with 94 additions and 4 deletions
43
commands/count.js
Normal file
43
commands/count.js
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
const client = require("../utils/client.js");
|
||||||
|
const paginator = require("../utils/pagination/pagination.js");
|
||||||
|
const database = require("../utils/database.js");
|
||||||
|
|
||||||
|
exports.run = async (message) => {
|
||||||
|
if (!message.channel.guild.members.get(client.user.id).permission.has("addReactions") && !message.channel.permissionsOf(client.user.id).has("addReactions")) return `${message.author.mention}, I don't have the \`Add Reactions\` permission!`;
|
||||||
|
if (!message.channel.guild.members.get(client.user.id).permission.has("embedLinks") && !message.channel.permissionsOf(client.user.id).has("embedLinks")) return `${message.author.mention}, I don't have the \`Embed Links\` permission!`;
|
||||||
|
const counts = (await database.global.findOne({}).lean().exec()).cmdCounts;
|
||||||
|
const countArray = [];
|
||||||
|
const sortedValues = Object.entries(counts).sort((a, b) => {
|
||||||
|
return b[1] - a[1];
|
||||||
|
});
|
||||||
|
console.log(sortedValues);
|
||||||
|
for (const [key, value] of sortedValues) {
|
||||||
|
countArray.push(`**${key}**: ${value}`);
|
||||||
|
}
|
||||||
|
const embeds = [];
|
||||||
|
const groups = countArray.map((item, index) => {
|
||||||
|
return index % 15 === 0 ? countArray.slice(index, index + 15) : null;
|
||||||
|
}).filter((item) => {
|
||||||
|
return item;
|
||||||
|
});
|
||||||
|
for (const [i, value] of groups.entries()) {
|
||||||
|
embeds.push({
|
||||||
|
"embed": {
|
||||||
|
"title": "Command Usage Counts",
|
||||||
|
"color": 16711680,
|
||||||
|
"footer": {
|
||||||
|
"text": `Page ${i + 1} of ${groups.length}`
|
||||||
|
},
|
||||||
|
"description": value.join("\n"),
|
||||||
|
"author": {
|
||||||
|
"name": message.author.username,
|
||||||
|
"icon_url": message.author.avatarURL
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return paginator(message, embeds);
|
||||||
|
};
|
||||||
|
|
||||||
|
exports.category = 1;
|
||||||
|
exports.help = "Gets how many times every command was used";
|
|
@ -1,4 +1,8 @@
|
||||||
|
const client = require("../utils/client.js");
|
||||||
|
|
||||||
exports.run = async (message, args) => {
|
exports.run = async (message, args) => {
|
||||||
|
if (!message.member.permission.has("banMembers")) return `${message.author.mention}, you need to have the \`Ban Members\` permission on this server to ban people!`;
|
||||||
|
if (!message.channel.guild.members.get(client.user.id).permission.has("banMembers") && !message.channel.permissionsOf(client.user.id).has("banMembers")) return `${message.author.mention}, I don't have the \`Ban Members\` permission!`;
|
||||||
if (!args[0].match(/^<?[@#]?[&!]?\d+>?$/) && args[0] < 21154535154122752) return `${message.author.mention}, that's not a valid snowflake!`;
|
if (!args[0].match(/^<?[@#]?[&!]?\d+>?$/) && args[0] < 21154535154122752) return `${message.author.mention}, that's not a valid snowflake!`;
|
||||||
try {
|
try {
|
||||||
const id = args[0].replace("@", "").replace("#", "").replace("!", "").replace("&", "").replace("<", "").replace(">", "");
|
const id = args[0].replace("@", "").replace("#", "").replace("!", "").replace("&", "").replace("<", "").replace(">", "");
|
||||||
|
|
|
@ -39,6 +39,9 @@ module.exports = async (message) => {
|
||||||
// actually run the command
|
// actually run the command
|
||||||
logger.log("info", `${message.author.username} (${message.author.id}) ran command ${command}`);
|
logger.log("info", `${message.author.username} (${message.author.id}) ran command ${command}`);
|
||||||
try {
|
try {
|
||||||
|
const global = (await database.global.findOne({}).exec());
|
||||||
|
global.cmdCounts.set(collections.aliases.has(command) ? collections.aliases.get(command) : command, global.cmdCounts.get(command) + 1);
|
||||||
|
await global.save();
|
||||||
const result = await cmd(message, args, content.replace(command, "").trim()); // we also provide the message content as a parameter for cases where we need more accuracy
|
const result = await cmd(message, args, content.replace(command, "").trim()); // we also provide the message content as a parameter for cases where we need more accuracy
|
||||||
if (typeof result === "string" || (typeof result === "object" && result.embed)) {
|
if (typeof result === "string" || (typeof result === "object" && result.embed)) {
|
||||||
await client.createMessage(message.channel.id, result);
|
await client.createMessage(message.channel.id, result);
|
||||||
|
|
|
@ -2,6 +2,7 @@ const gm = require("gm");
|
||||||
const { promisify } = require("util");
|
const { promisify } = require("util");
|
||||||
const client = require("../utils/client.js");
|
const client = require("../utils/client.js");
|
||||||
const database = require("../utils/database.js");
|
const database = require("../utils/database.js");
|
||||||
|
const collections = require("../utils/collections.js");
|
||||||
const logger = require("../utils/logger.js");
|
const logger = require("../utils/logger.js");
|
||||||
const messages = require("../messages.json");
|
const messages = require("../messages.json");
|
||||||
const misc = require("../utils/misc.js");
|
const misc = require("../utils/misc.js");
|
||||||
|
@ -16,11 +17,11 @@ module.exports = async () => {
|
||||||
for (const [id] of client.guilds) {
|
for (const [id] of client.guilds) {
|
||||||
const guildDB = (
|
const guildDB = (
|
||||||
await database.guilds
|
await database.guilds
|
||||||
.find({
|
.findOne({
|
||||||
id: id,
|
id: id,
|
||||||
})
|
})
|
||||||
.exec()
|
.exec()
|
||||||
)[0];
|
);
|
||||||
if (!guildDB) {
|
if (!guildDB) {
|
||||||
logger.log(`Registering guild database entry for guild ${id}...`);
|
logger.log(`Registering guild database entry for guild ${id}...`);
|
||||||
const newGuild = new database.guilds({
|
const newGuild = new database.guilds({
|
||||||
|
@ -44,6 +45,25 @@ module.exports = async () => {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const global = (await database.global.findOne({}).exec());
|
||||||
|
if (!global) {
|
||||||
|
const countObject = {};
|
||||||
|
for (const command of collections.commands.keys()) {
|
||||||
|
countObject[command] = 0;
|
||||||
|
}
|
||||||
|
const newGlobal = new database.global({
|
||||||
|
cmdCounts: countObject
|
||||||
|
});
|
||||||
|
await newGlobal.save();
|
||||||
|
} else {
|
||||||
|
for (const command of collections.commands.keys()) {
|
||||||
|
if (!global.cmdCounts.has(command)) {
|
||||||
|
global.cmdCounts.set(command, 0);
|
||||||
|
await global.save();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// generate docs
|
// generate docs
|
||||||
if (helpGenerator) {
|
if (helpGenerator) {
|
||||||
await helpGenerator(process.env.OUTPUT);
|
await helpGenerator(process.env.OUTPUT);
|
||||||
|
|
|
@ -88,5 +88,19 @@
|
||||||
"XMPlay",
|
"XMPlay",
|
||||||
"OpenMPT",
|
"OpenMPT",
|
||||||
"follow @esmBot_ on Twitter",
|
"follow @esmBot_ on Twitter",
|
||||||
"with GIFs"
|
"with GIFs",
|
||||||
|
"check out more stuff at projectlounge.pw",
|
||||||
|
"the",
|
||||||
|
"sissy hypnosis",
|
||||||
|
"Yandere Simulator",
|
||||||
|
"PogChamp",
|
||||||
|
"yourself",
|
||||||
|
"sentience",
|
||||||
|
"with Brody Foxx",
|
||||||
|
"AOL Instant Messenger",
|
||||||
|
"beep boop",
|
||||||
|
"Animal Crossing: New Horizons",
|
||||||
|
"Hello, Gordon!",
|
||||||
|
"the j",
|
||||||
|
"Want esmBot to play some new games? Send suggestions!"
|
||||||
]
|
]
|
|
@ -22,5 +22,11 @@ const tweetSchema = new mongoose.Schema({
|
||||||
});
|
});
|
||||||
const TweetCollection = mongoose.model("TweetCollection", tweetSchema);
|
const TweetCollection = mongoose.model("TweetCollection", tweetSchema);
|
||||||
|
|
||||||
|
const globalSchema = new mongoose.Schema({
|
||||||
|
cmdCounts: Map
|
||||||
|
});
|
||||||
|
const Global = mongoose.model("Global", globalSchema);
|
||||||
|
|
||||||
exports.guilds = Guild;
|
exports.guilds = Guild;
|
||||||
exports.tweets = TweetCollection;
|
exports.tweets = TweetCollection;
|
||||||
|
exports.global = Global;
|
Loading…
Reference in a new issue