├── .gitignore ├── LICENSE ├── README.md ├── commands ├── admin │ ├── eval.js │ ├── reload.js │ ├── restart.js │ ├── set-avatar.js │ ├── set-presence.js │ └── set-username.js ├── bot │ ├── bot_info.js │ ├── invite.js │ └── ping.js ├── extra │ ├── avatar.js │ ├── black.js │ ├── fake-youtube-comment.js │ ├── gay.js │ ├── hug.js │ ├── joke.js │ ├── meme.js │ ├── rank.js │ ├── say.js │ └── wasted.js ├── mods │ ├── all-roles.js │ ├── ban.js │ ├── clear.js │ ├── kick.js │ ├── lock.js │ ├── role.js │ ├── serverinfo.js │ ├── setnick.js │ ├── unban.js │ ├── unlock.js │ └── userinfo.js └── tickets │ ├── create-ticket.js │ └── delete-ticket.js ├── events ├── client │ └── ready.js └── guild │ └── message.js ├── handlers ├── events.js └── handlers.js ├── index.js ├── package-lock.json └── package.json /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | config.json -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Additional Functionality 4 | - Copyright (c) 2021 me@fnrr.dev (Fnr) 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining a copy 7 | of this software and associated documentation files (the "Software"), to deal 8 | in the Software without restriction, including without limitation the rights 9 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 10 | copies of the Software, and to permit persons to whom the Software is 11 | furnished to do so, subject to the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be included in all 14 | copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 19 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 21 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 22 | SOFTWARE. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Discord bot made by Fnr#0017 2 | 3 | # If you want your bot support slash commands check this [Repo](https://github.com/FnrDev/slash-commands) 4 | 5 | - get started 6 | 7 | 1- First create file named "config.json" 8 | 2- npm install 9 | 10 | - config.json 11 | ```js 12 | { 13 | "token": "Your discord bot token", 14 | "prefix": "Your discord bot prefix" 15 | } 16 | ``` 17 | 18 | Bot commands: 19 | - ban command 20 | - kick command 21 | - botinfo command 22 | - say command 23 | - change nickname command 24 | - userinfo command 25 | - serverinfo command 26 | - ping command 27 | - avatar command 28 | - set avatar command for bot 29 | - set username command for bot 30 | - set presence command for bot 31 | - restart command 32 | - add role command 33 | - clear command 34 | 35 | - **And alot more..** 36 | 37 | 38 | 39 | --------------------------------------------------------------- 40 | 41 | 42 | في البدايه سو ملف اسمه "config.json" 43 | 44 | بعدها حمل بكجات عن طريق امر "npm install" 45 | 46 | ```js 47 | { 48 | "token": "Your discord bot token", 49 | "prefix": "Your discord bot prefix" 50 | } 51 | ``` 52 | -------------------------------------------------------------------------------- /commands/admin/eval.js: -------------------------------------------------------------------------------- 1 | // You can put more than 2 ids 2 | const ownerID = ['ownerid1', 'OwnerID2'] 3 | 4 | module.exports = { 5 | name: "eval", 6 | run: async(client, message, args) => { 7 | if (!ownerID.includes(message.author.id)) return 8 | let incode = args.join(" ") 9 | let code = eval(incode) 10 | try { 11 | if (typeof incode !== 'string') 12 | code = require('util').inspect(code, { depth: 0}) 13 | message.channel.send(`\`\`\`js\n${code}\n\`\`\``) 14 | } catch (e) { 15 | message.channel.send(`\`\`\`js\n${e}\n\`\`\``) 16 | } 17 | } 18 | } -------------------------------------------------------------------------------- /commands/admin/reload.js: -------------------------------------------------------------------------------- 1 | const fs = require('fs'); 2 | const Developer = ['596227913209217024'] 3 | 4 | module.exports = { 5 | name: "reload", 6 | run: async(client, message, args, msg) => { 7 | if (!Developer.includes(message.author.id)) return; 8 | if (!args[0]) { 9 | return message.channel.send(':x: **Missing file name!**') 10 | } 11 | const cmd = args[0].toLowerCase(); 12 | const command = message.client.commands.get(cmd) 13 | if (!command) { 14 | return message.channel.send(`There is no command with name or alias \`${cmd}\`, ${message.author}!`); 15 | } 16 | const commandFolders = fs.readdirSync('./commands'); 17 | const folderName = commandFolders.find(folder => fs.readdirSync(`./commands/${folder}`).includes(`${cmd}.js`)); 18 | delete require.cache[require.resolve(`../${folderName}/${command.name}.js`)]; 19 | try { 20 | const newCommand = require(`../${folderName}/${command.name}.js`); 21 | message.client.commands.set(newCommand.name, newCommand); 22 | message.channel.send(`Command \`${command.name}\` was reloaded!`); 23 | } catch (error) { 24 | return message.channel.send(`There was an error while reloading a command \`${command.name}\`:\n\`${error.message}\``); 25 | } 26 | }, 27 | }; -------------------------------------------------------------------------------- /commands/admin/restart.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | const Fnr = '596227913209217024' 3 | 4 | module.exports = { 5 | name: "restart", 6 | run: async(client, message, args) => { 7 | if (!Fnr.includes(message.author.id)) return 8 | const setting = require('../../config.json') 9 | message.channel.send('Restarting...') 10 | client.destroy() 11 | client.login(setting.token) 12 | return message.channel.send(`**Successfully restarting ${client.user.username}**`) 13 | } 14 | } -------------------------------------------------------------------------------- /commands/admin/set-avatar.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | 3 | module.exports = { 4 | name: "setav", 5 | run: async(client, message, args) => { 6 | if (!message.member.hasPermission('ADMINISTRATOR')) return message.channel.send('You dont have permission to do this command!') 7 | let avatar = args[0] 8 | if (!avatar) return message.channel.send('You need to input avatar url!') 9 | client.user.setAvatar(avatar) 10 | .then(message.channel.send('Successfully changed avatar')) 11 | .catch(err => { 12 | return message.channel.send('There was an error') 13 | }) 14 | } 15 | } -------------------------------------------------------------------------------- /commands/admin/set-presence.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | 3 | module.exports = { 4 | name: "status", 5 | run: async(client, message, args) => { 6 | if (!message.member.hasPermission('ADMINISTRATOR')) return message.channel.send('You dont have permission to do this command!') 7 | let status = args.join(" ") 8 | if (!status) return message.channel.send('You need to input status') 9 | client.user.setPresence({ 10 | activity: { 11 | name: status, 12 | type: 0, 13 | } 14 | }) 15 | .then(message.channel.send(`Successfully changed bot status to **${status}**`)) 16 | .catch(err => { 17 | return message.channel.send('There was an error') 18 | }) 19 | } 20 | } -------------------------------------------------------------------------------- /commands/admin/set-username.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | 3 | module.exports = { 4 | name: "setusername", 5 | run: async(client, message, args) => { 6 | if (!message.member.hasPermission('ADMINISTRATOR')) return message.channel.send('You dont have permission to do this command!') 7 | let username = args.join(" ") 8 | if (!username) return message.channel.send('You need to input username!') 9 | client.user.setUsername(username) 10 | .then(message.channel.send(`Successfully changed username to **${username}**`)) 11 | .catch(err => { 12 | return message.channel.send('There was an error') 13 | }) 14 | } 15 | } -------------------------------------------------------------------------------- /commands/bot/bot_info.js: -------------------------------------------------------------------------------- 1 | const { MessageEmbed } = require('discord.js'); 2 | 3 | module.exports = { 4 | name: "binfo", 5 | category: "bot", 6 | description: "Get info about bot", 7 | timeout: 3000, 8 | run: async(client, message) => { 9 | const embed = new MessageEmbed() 10 | .setTitle('Bot info') 11 | .setColor('RANDOM') 12 | .setFooter('By Fnr#0017 | Github: FnrDev') 13 | .setThumbnail(client.user.displayAvatarURL()) 14 | .addFields( 15 | { 16 | name: "Total Guilds: ", 17 | value: `${client.guilds.cache.size} Guilds`, 18 | inline: true 19 | }, 20 | { 21 | name: "Total Users: ", 22 | value: `${client.users.cache.size} Users`, 23 | inline: true 24 | }, 25 | { 26 | name: "Total Channels: ", 27 | value: `${client.channels.cache.size} Channels`, 28 | inline: true 29 | }, 30 | { 31 | name: "You can get me for free at: ", 32 | value: `[Link](https://github.com/FnrDev/moderation-discord-bot)`, 33 | inline: true 34 | } 35 | ) 36 | await message.channel.send(embed) 37 | } 38 | } -------------------------------------------------------------------------------- /commands/bot/invite.js: -------------------------------------------------------------------------------- 1 | const { MessageEmbed } = require('discord.js') 2 | 3 | module.exports = { 4 | name: "invite", 5 | run: (client, message) => { 6 | const embed = new MessageEmbed() 7 | .setAuthor(client.user.username, client.user.displayAvatarURL({ dynamic: true })) 8 | .setDescription(`[Invite Link](https://discord.com/api/oauth2/authorize?client_id=${client.user.id}&permissions=8&scope=bot)`) 9 | .setColor('RANDOM') 10 | .setFooter(`Requested by ${message.author.tag}`, message.author.displayAvatarURL({ dynamic: true })) 11 | message.channel.send(embed) 12 | } 13 | } -------------------------------------------------------------------------------- /commands/bot/ping.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | 3 | module.exports = { 4 | name: 'ping', 5 | run: async(client, message) => { 6 | const msg = await message.channel.send('Pinging...') 7 | const ping = "```js\nLatency Ping is : " + Math.floor(msg.createdTimestamp - message.createdTimestamp) + " ms" + "\nAPI Ping : " + Math.round(client.ws.ping) + " ms" + "```" 8 | msg.edit(ping) 9 | } 10 | } -------------------------------------------------------------------------------- /commands/extra/avatar.js: -------------------------------------------------------------------------------- 1 | const { MessageEmbed } = require('discord.js'); 2 | 3 | module.exports = { 4 | name: "avatar", 5 | run: async (client, message, args) => { 6 | const mentionMember = message.mentions.members.first() || message.guild.members.cache.get(args[0]) || message.member; 7 | let avatar = mentionMember.user.displayAvatarURL({size: 4096, dynamic: true}); 8 | const embed = new MessageEmbed() 9 | .setTitle(`${mentionMember.user.tag} Avatar`) 10 | .setDescription(`[Avatar URL](${avatar})`) 11 | .setColor('RANDOM') 12 | .setImage(avatar) 13 | .setFooter(`Requested by ${message.author.tag}` , message.author.displayAvatarURL({dynamic: true})) 14 | return message.channel.send(embed); 15 | } 16 | } -------------------------------------------------------------------------------- /commands/extra/black.js: -------------------------------------------------------------------------------- 1 | const { MessageAttachment } = require('discord.js') 2 | const axios = require('axios') 3 | 4 | module.exports = { 5 | name: "change", 6 | run: async(client, message, args) => { 7 | const mentionMember = message.mentions.members.first() || message.author 8 | const url = `https://some-random-api.ml/canvas/color?color=%23000000&avatar=${mentionMember.user.displayAvatarURL({ format: 'png'})}` 9 | 10 | let response, data 11 | try { 12 | response = await axios.get(url) 13 | data = response.data 14 | } catch (e) { 15 | return message.channel.send('There was an error please try again') 16 | } 17 | message.channel.send({ 18 | files: 19 | [url] 20 | }) 21 | } 22 | } -------------------------------------------------------------------------------- /commands/extra/fake-youtube-comment.js: -------------------------------------------------------------------------------- 1 | const { MessageEmbed } = require('discord.js') 2 | const axios = require('axios') 3 | 4 | module.exports = { 5 | name: "yt", 6 | run: async(client, message, args) => { 7 | let comment = args.join(" ") 8 | if (!comment) { 9 | return message.channel.send('You need to input your comment') 10 | } 11 | const url = `https://some-random-api.ml/canvas/youtube-comment?comment=${comment}&username=${message.author.username}&avatar=${message.author.displayAvatarURL({ format: 'png'})}` 12 | 13 | let response, data 14 | try { 15 | response = await axios.get(url) 16 | data = response.data 17 | } catch (e) { 18 | return message.channel.send('There was an error please try again') 19 | } 20 | message.channel.send({ 21 | files: 22 | [url] 23 | }) 24 | } 25 | } -------------------------------------------------------------------------------- /commands/extra/gay.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | const axios = require('axios') 3 | 4 | module.exports = { 5 | name: "gay", 6 | run: async(client, message, args) => { 7 | const mentionMember = message.mentions.members.first() || message.author 8 | const url = `https://some-random-api.ml/canvas/gay?avatar=${mentionMember.user.displayAvatarURL({ format: 'png'})}` 9 | 10 | let response, data 11 | try { 12 | response = await axios.get(url) 13 | data = response.data 14 | } catch (e) { 15 | return message.channel.send('There was an error!') 16 | } 17 | await message.channel.send({ 18 | files: 19 | [url] 20 | }) 21 | } 22 | } -------------------------------------------------------------------------------- /commands/extra/hug.js: -------------------------------------------------------------------------------- 1 | const { MessageEmbed } = require('discord.js') 2 | const axios = require('axios') 3 | 4 | module.exports = { 5 | name: "hug", 6 | run: async(client, message, args) => { 7 | const url = 'https://some-random-api.ml/animu/hug' 8 | 9 | let response, data 10 | try { 11 | response = await axios.get(url) 12 | data = response.data 13 | } catch (e) { 14 | return message.channel.send('There was an error!') 15 | } 16 | const mentionMember = message.mentions.members.first() 17 | if (!mentionMember) { 18 | return message.channel.send("You can't hug yourself") 19 | } 20 | if (message.author.id == mentionMember.id) { 21 | return message.channel.send("You can't hug yourself") 22 | } 23 | const embed = new MessageEmbed() 24 | .setDescription(`<@${message.author.id}> hugs ${mentionMember}`) 25 | .setImage(data.link) 26 | .setColor('RANDOM') 27 | await message.channel.send(embed) 28 | } 29 | } -------------------------------------------------------------------------------- /commands/extra/joke.js: -------------------------------------------------------------------------------- 1 | const { MessageEmbed } = require('discord.js') 2 | const axios = require('axios') 3 | 4 | module.exports = { 5 | name: "joke", 6 | run: async(client, message, args) => { 7 | const url = 'https://some-random-api.ml/joke' 8 | let joke, response; 9 | try { 10 | response = await axios.get(url) 11 | joke = response.data 12 | } catch (e) { 13 | return message.channel.send('There was an error!') 14 | } 15 | const embed = new MessageEmbed() 16 | .setTitle('Joke: ') 17 | .setColor('RANDOM') 18 | .setDescription(`Joke: ${joke.joke}`) 19 | await message.channel.send(embed) 20 | } 21 | } -------------------------------------------------------------------------------- /commands/extra/meme.js: -------------------------------------------------------------------------------- 1 | const { MessageEmbed } = require('discord.js') 2 | const axios = require('axios') 3 | 4 | module.exports = { 5 | name: "meme", 6 | run: async(client, message, args) => { 7 | const url = 'https://meme-api.herokuapp.com/gimme' 8 | 9 | let data, response; 10 | try { 11 | response = await axios.get(url) 12 | data = response.data 13 | } catch (e) { 14 | return message.channel.send('There was an error') 15 | } 16 | const embed = new MessageEmbed() 17 | .setTitle('Meme URL') 18 | .setURL(data.postLink) 19 | .setDescription(`Meme Title: **${data.title}**`) 20 | .setColor('RANDOM') 21 | .setImage(data.url) 22 | await message.channel.send(embed) 23 | } 24 | } -------------------------------------------------------------------------------- /commands/extra/rank.js: -------------------------------------------------------------------------------- 1 | const { MessageAttachment } = require('discord.js') 2 | const canvacord = require('canvacord') 3 | 4 | module.exports = { 5 | name: "rank", 6 | run: async(client, message, args) => { 7 | const mentionMember = message.mentions.members.first() || message.guild.members.cache.get(args[0]) || message.member; // Get user mention or message author 8 | const img = mentionMember.user.displayAvatarURL({ format: 'png'}) // format user image to "png" format 9 | if (mentionMember.user.bot) { 10 | return message.channel.send('You cant do that in bots') // You cant get rank about bots 11 | } 12 | message.channel.startTyping(4) // start typing for 4 secounds 13 | const rank = new canvacord.Rank() 14 | .setAvatar(img) // user avatar 15 | .setUsername(mentionMember.user.username) // username for mention member or message author 16 | .setDiscriminator(mentionMember.user.discriminator) // discriminator for mention member or message author 17 | .setProgressBar("#FFFFFF", "COLOR") // progress bar for image 18 | .setCurrentXP(5) // current xp for user 19 | .setRequiredXP(10) // require xp for user 20 | .setStatus(mentionMember.user.presence.status) // user status for user. note you need to enable "PRESENCE INTENT" read https://support.discord.com/hc/en-us/articles/360040720412 for more info 21 | rank.build() // build the image 22 | .then(buffer => { 23 | const image = new MessageAttachment(buffer, 'RankCard.png') 24 | message.channel.send(image) // sending image to channel 25 | message.channel.stopTyping(true) // force stop typing after sending image 26 | }) 27 | } 28 | } -------------------------------------------------------------------------------- /commands/extra/say.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | 3 | module.exports = { 4 | name: "say", 5 | run: async(client, message, args) => { 6 | message.channel.send(args.join(" ")) 7 | } 8 | } -------------------------------------------------------------------------------- /commands/extra/wasted.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | const axios = require('axios') 3 | 4 | module.exports = { 5 | name: "wasted", 6 | run: async(client, message, args) => { 7 | const mentionMember = message.mentions.members.first() 8 | const url = `https://some-random-api.ml/canvas/wasted?avatar=${mentionMember.user.displayAvatarURL({ format: 'png'})}` 9 | let response, data 10 | try { 11 | response = await axios.get(url) 12 | data = response.data 13 | } catch (e) { 14 | return message.channel.send('There was an error') 15 | } 16 | message.channel.send({ 17 | files: 18 | [url] 19 | }) 20 | } 21 | } -------------------------------------------------------------------------------- /commands/mods/all-roles.js: -------------------------------------------------------------------------------- 1 | const { MessageEmbed } = require('discord.js') 2 | 3 | module.exports = { 4 | name: "roles", 5 | run: async(client, message, args) => { 6 | if (!message.member.hasPermission('MANAGE_ROLES')) { 7 | const embed = new MessageEmbed() 8 | .setTitle('You dont have permission to do this command!') 9 | .setColor('#ff0000') 10 | return message.channel.send(embed) 11 | } 12 | let rolemap = message.guild.roles.cache.sort((a, b) => b.position - a.position).map(r => r).join(" ,") 13 | if (rolemap.length > 1024) return message.channel.send('To many roles to display') 14 | if (!rolemap) return message.channel.send('No roles in this server') 15 | const embed = new MessageEmbed() 16 | .setTitle(`All roles in guild ${message.guild.name}`) 17 | .addField("Role List: ", rolemap) 18 | message.channel.send(embed) 19 | } 20 | } -------------------------------------------------------------------------------- /commands/mods/ban.js: -------------------------------------------------------------------------------- 1 | const {MessageEmbed} = require('discord.js') 2 | 3 | module.exports = { 4 | name: "ban", 5 | run: async(client, message, args) => { 6 | if (!message.member.hasPermission('BAN_MEMBERS')) return message.channel.send('You dont have permission to do this command!') 7 | const mentionMember = message.mentions.members.first() || message.guild.members.cache.get(args[0]) 8 | if (!mentionMember) return message.channel.send('You need to mention a user!') 9 | if (mentionMember == message.author.id) return message.channel.send('You cant ban yourself!') 10 | if (mentionMember.id == client.user.id) return message.channel.send('You cant ban me!') 11 | const botRole = message.guild.member(message.guild.me).roles.highest.position; 12 | const role = mentionMember.roles.highest.position; 13 | const authorRole = message.member.roles.highest.position; 14 | if (authorRole <= role) { 15 | return message.channel.send("I can't ban this member because that member has role position is higher than my role or same as you!") 16 | } 17 | if (botRole <= role) { 18 | return message.channel.send("I can't ban this member because that member has role position is higher than my role or same as you!") 19 | } 20 | try { 21 | let reason = args.slice(1).join(" ") || 'There are no reason' 22 | const embed = new MessageEmbed() 23 | .setTitle('You have been banned') 24 | .setDescription(`You have been banned in **${message.guild.name}** for **${reason}** by ${message.author.tag}`) 25 | .setFooter(message.author.tag, message.author.displayAvatarURL({ dynamic: true})) 26 | mentionMember.send(embed) 27 | await mentionMember.ban({ reason: reason, days: 7 }) 28 | message.channel.send(`Successfully ban ${mentionMember} with reason ${reason}`) 29 | } catch(e) { 30 | return message.channel.send('There was an error') 31 | } 32 | } 33 | } -------------------------------------------------------------------------------- /commands/mods/clear.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | 3 | module.exports = { 4 | name: "clear", 5 | run: async(client, message, args) => { 6 | if (!message.member.hasPermission('MANAGE_MESSAGES')) return message.channel.send('You dont have permission to do this command!') 7 | 8 | if (!args[0]) return message.channel.send('Please enter a amont from 1 to 100') 9 | message.delete() 10 | let deleteAmont 11 | if (parseInt(args[0]) > 100) { 12 | deleteAmont = 100; 13 | } else { 14 | deleteAmont = parseInt(args[0]) 15 | } 16 | await message.channel.bulkDelete(deleteAmont, true) 17 | await message.channel.send(`Successfully deleted ${deleteAmont} messages`) 18 | .then(m => m.delete({ timeout: 2000})) 19 | .catch(err => { 20 | return message.channel.send('There was an error!') 21 | }) 22 | } 23 | } -------------------------------------------------------------------------------- /commands/mods/kick.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | 3 | module.exports = { 4 | name: "kick", 5 | run: async(client, message, args) => { 6 | if (!message.member.hasPermission('KICK_MEMBERS')) return message.channel.send('You dont have permission to do this command!') 7 | const mentionMember = message.mentions.members.first() || message.guild.members.cache.get(args[0]) 8 | if (!mentionMember) return message.channel.send('You need to mention a member!') 9 | if (mentionMember.id == message.author.id) return message.channel.send('You cant kick yourself!') 10 | if (mentionMember.id == client.user.id) return message.channel.send('You cant kick me') 11 | const botRole = message.guild.member(message.guild.me).roles.highest.position; 12 | const role = mentionMember.roles.highest.position; 13 | const authorRole = message.member.roles.highest.position; 14 | if (authorRole <= role) { 15 | return message.channel.send("I can't kick this member because that member has role position is higher than my role or same as you!") 16 | } 17 | if (botRole <= role) { 18 | return message.channel.send("I can't kick this member because that member has role position is higher than my role or same as you!") 19 | } 20 | try { 21 | await mentionMember.kick() 22 | message.channel.send(`Successfully kick ${mentionMember}`) 23 | } catch(e) { 24 | return message.channel.send('There was an error') 25 | } 26 | } 27 | } -------------------------------------------------------------------------------- /commands/mods/lock.js: -------------------------------------------------------------------------------- 1 | const { MessageEmbed } = require('discord.js') 2 | 3 | module.exports = { 4 | name: 'lock', 5 | run: async(client, message, args) => { 6 | if (!message.member.hasPermission('MANAGE_CHANNELS')) { 7 | const embed = new MessageEmbed() 8 | .setTitle('You dont have permission to do this command!') 9 | .setColor('#ff0000') 10 | return message.channel.send(embed) 11 | } 12 | const role = message.guild.roles.cache.find(role => role.name == '@everyone') 13 | const mentionChannel = message.mentions.channels.first() || message.channel 14 | const reason = args.slice(1).join(" ") || 'With no reason' 15 | 16 | mentionChannel.updateOverwrite(role, { 17 | 'SEND_MESSAGES': false, 18 | }) 19 | .then(message.channel.send(`Successfully locked ${mentionChannel}\nwith reason **${reason}**`)) 20 | .catch(err => { 21 | return message.channel.send('There was an error!') 22 | }) 23 | } 24 | } -------------------------------------------------------------------------------- /commands/mods/role.js: -------------------------------------------------------------------------------- 1 | const { MessageEmbed } = require('discord.js') 2 | 3 | module.exports = { 4 | name: "role", 5 | run: async(client, message, args) => { 6 | if (!message.member.hasPermission('MANAGE_ROLES')) { 7 | return message.channel.send('You dont have permission to do this command!') 8 | } 9 | const mentionMember = message.mentions.members.first() || message.guild.members.cache.get(args[0]); 10 | if (!mentionMember) { 11 | return message.channel.send('You need to mention a member') 12 | } 13 | const roleName = args.slice(1).join(" "); 14 | if (!roleName) { 15 | return message.channel.send('Missing Role Name') 16 | } 17 | const botRole = message.guild.member(message.guild.me).roles.highest.position; 18 | const role = mentionMember.roles.highest.position; 19 | const authorRole = message.member.roles.highest.position; 20 | if (authorRole <= role) { 21 | return message.channel.send("I can't role this member because that member has role position is higher than my role or same as you!") 22 | } 23 | if (botRole <= role) { 24 | return message.channel.send("I can't role this member because that member has role position is higher than my role or same as you!") 25 | } 26 | try { 27 | let msg; 28 | const role = message.guild.roles.cache.get(message.guild.roles.cache.filter(r => r.name.toLowerCase().startsWith(roleName)).map(r => r.id)[0]) || message.mentions.roles.first() || message.guild.roles.cache.get(args[1]); 29 | if (!role) { 30 | return message.channel.send('i can\'t find role with this name!') 31 | } 32 | if (mentionMember._roles.includes(role.id)) { 33 | msg = '-' 34 | mentionMember.roles.remove(role, `By ${message.author.tag}`) 35 | message.channel.send(`✅ | Changed role for ${mentionMember} **${msg}${role.name}**`) 36 | } else { 37 | msg = '+' 38 | mentionMember.roles.add(role, `By ${message.author.tag}`) 39 | message.channel.send(`✅ | Changed role for ${mentionMember} **${msg}${role.name}**`) 40 | } 41 | } catch (e) { 42 | return message.channel.send(`There was an error **${e}**`) 43 | } 44 | } 45 | } -------------------------------------------------------------------------------- /commands/mods/serverinfo.js: -------------------------------------------------------------------------------- 1 | const { MessageEmbed, NewsChannel } = require('discord.js') 2 | 3 | module.exports = { 4 | name: 'server', 5 | run: async(client, message, args) => { 6 | const online = message.guild.members.cache.filter(m => m.user.presence.status == 'online').size 7 | const idle = message.guild.members.cache.filter(m => m.user.presence.status == 'idle').size 8 | const dnd = message.guild.members.cache.filter(m => m.user.presence.status == 'dnd').size 9 | const embed = new MessageEmbed() 10 | .setAuthor(message.guild.name, message.guild.iconURL()) 11 | .setColor('RANDOM') 12 | .setFooter(`Requested by ${message.author.tag}`, message.author.displayAvatarURL({ dynamic: true })) 13 | .setThumbnail(message.guild.iconURL({ dynamic: true })) 14 | .addFields( 15 | { 16 | name: 'Server ID: ', 17 | value: message.guild.id, 18 | inline: true 19 | }, 20 | { 21 | name: "Created At: ", 22 | value: message.guild.createdAt.toLocaleString(), 23 | inline: true 24 | }, 25 | { 26 | name: "Channels:", 27 | value: `**${message.guild.channels.cache.filter(c => c.type == 'text').size}** text | **${message.guild.channels.cache.filter(c => c.type == 'voice').size}** voice | **${message.guild.channels.cache.filter(c => c.type == 'category').size}** category` 28 | }, 29 | { 30 | name: "Owned By: ", 31 | value: `<@${message.guild.ownerID}>`, 32 | inline: true 33 | }, 34 | { 35 | name: `Members (${message.guild.memberCount})`, 36 | value: `**${online + idle + dnd}** Online`, 37 | inline: true 38 | }, 39 | { 40 | name: 'Region: ', 41 | value: message.guild.region, 42 | inline: true 43 | }, 44 | { 45 | name: "Verification Level: ", 46 | value: message.guild.verificationLevel, 47 | inline: true 48 | }, 49 | { 50 | name: "Total Boost: ", 51 | value: `${message.guild.premiumSubscriptionCount} Boost`, 52 | inline: true 53 | }, 54 | { 55 | name: "Boost Level: ", 56 | value: message.guild.premiumTier, 57 | inline: true 58 | }, 59 | { 60 | name: "Emojis: ", 61 | value: message.guild.emojis.cache.size >= 1 ? `There are ${message.guild.emojis.cache.size} emojis!` : 'There are no emojis :(', 62 | inline: true 63 | } 64 | ) 65 | await message.channel.send(embed) 66 | } 67 | } -------------------------------------------------------------------------------- /commands/mods/setnick.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js'); 2 | 3 | module.exports = { 4 | name: 'setnick', 5 | category: 'mods', 6 | description: 'Change nickname for user', 7 | run: async(client, message, args) => { 8 | if (!message.member.hasPermission('MANAGE_NICKNAMES')) { 9 | return message.channel.send('**⛔ You dont have permission to do this command!**') 10 | } 11 | const mention = message.mentions.members.first() || message.guild.members.cache.get(args[0]); 12 | if (!mention) return message.channel.send('**⛔ You need to mention a user!**') 13 | try { 14 | const nickname = args.slice(1).join(" ") 15 | if (!nickname) { 16 | mention.setNickname('') 17 | return message.channel.send(`✅ ${mention} nickname has been reset`) 18 | } 19 | if (nickname) { 20 | await mention.setNickname(nickname) 21 | message.channel.send(`✅ ${mention} nickname has been set to **${nickname}**`) 22 | } 23 | } catch (e) { 24 | return message.channel.send(':x: i cant change nickname for this member') 25 | } 26 | } 27 | } -------------------------------------------------------------------------------- /commands/mods/unban.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | 3 | module.exports = { 4 | name: "unban", 5 | run: async(client, message, args) => { 6 | if (!message.member.hasPermission('MANAGE_BANS')) { 7 | return message.channel.send('You dont have permission to do this command!') 8 | } 9 | const mentionMember = args[0] 10 | if (!mentionMember) { 11 | return message.channel.send('Please mention a member to unban!') 12 | } 13 | try { 14 | message.guild.fetchBans().then(bans => { 15 | message.guild.members.unban(mentionMember) 16 | }) 17 | message.channel.send(`Successfully <@${mentionMember}> has been unbanned`) 18 | } catch(e) { 19 | return message.channel.send(`There was an error \n\n ${e}`) 20 | } 21 | } 22 | } -------------------------------------------------------------------------------- /commands/mods/unlock.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | 3 | module.exports = { 4 | name: "unlock", 5 | run: async(client, message, args) => { 6 | if (!message.member.hasPermission('MANAGE_CHANNELS')) return message.channel.send('You dont have permission to do this command!') 7 | const role = message.guild.roles.cache.find(role => role.name == '@everyone') 8 | const mentionChannel = message.mentions.channels.first() || message.channel 9 | mentionChannel.updateOverwrite(role, { 10 | 'SEND_MESSAGES': null, 11 | }) 12 | .then(message.channel.send(`Successfully unlocked ${mentionChannel}`)) 13 | .catch(err => { 14 | return message.channel.send('There was an error!') 15 | }) 16 | } 17 | } -------------------------------------------------------------------------------- /commands/mods/userinfo.js: -------------------------------------------------------------------------------- 1 | const {MessageEmbed, Role} = require('discord.js') 2 | 3 | module.exports = { 4 | name: 'user', 5 | run: async(client, message, args) => { 6 | const mentionMember = message.mentions.members.first() || message.guild.members.cache.get(args[0]) || message.member 7 | const embed = new MessageEmbed() 8 | .setAuthor(mentionMember.user.tag, mentionMember.user.displayAvatarURL({ dynamic: true })) 9 | .setColor('RANDOM') 10 | .setThumbnail(mentionMember.user.displayAvatarURL({dynamic: true})) 11 | .addFields( 12 | { 13 | name: "Account Created At: ", 14 | value: mentionMember.user.createdAt.toLocaleString(), 15 | inline: true 16 | }, 17 | { 18 | name: "Joined At: ", 19 | value: mentionMember.guild.joinedAt.toLocaleString(), 20 | inline: true 21 | }, 22 | { 23 | name: "User ID: ", 24 | value: mentionMember.id, 25 | inline: true 26 | }, 27 | { 28 | name: "Is it a bot?", 29 | value: mentionMember.user.bot, 30 | inline: true 31 | }, 32 | { 33 | name: "Avatar URL: ", 34 | value: `[Avatar Link](${mentionMember.user.displayAvatarURL({dynamic: true})})`, 35 | inline: true 36 | }, 37 | { 38 | name: "Boosted Since:", 39 | value: mentionMember.premiumSince || 'User dont have boost in this server', 40 | inline: true 41 | }, 42 | { 43 | name: "User Roles: ", 44 | value: mentionMember.roles.cache.map(role => role.toString()).join(" ,"), 45 | inline: true 46 | } 47 | ) 48 | await message.channel.send(embed) 49 | } 50 | } -------------------------------------------------------------------------------- /commands/tickets/create-ticket.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | 3 | module.exports = { 4 | name: "new", 5 | run: async(client, message, args) => { 6 | const ticketChannel = await message.guild.channels.create(`ticket-${message.author.username}`, { 7 | permissionOverwrites: [ 8 | { 9 | allow: ['VIEW_CHANNEL', 'SEND_MESSAGES'], 10 | id: message.author.id 11 | }, 12 | { 13 | allow: ['VIEW_CHANNEL', 'SEND_MESSAGES', 'MANAGE_CHANNELS', 'MANAGE_MESSAGES'], 14 | id: '750645386128916482' 15 | }, 16 | { 17 | deny: ['VIEW_CHANNEL', 'SEND_MESSAGES'], 18 | id: message.guild.id 19 | } 20 | ] 21 | }) 22 | const msg = await ticketChannel.send(`You have created a ticket ${message.author}`) 23 | .then(message.channel.send(`Successfully created a new ticket ${ticketChannel}!`)) 24 | .catch(err => { 25 | return message.channel.send('There was an error please contact the developer') 26 | }) 27 | } 28 | } -------------------------------------------------------------------------------- /commands/tickets/delete-ticket.js: -------------------------------------------------------------------------------- 1 | const Discord = require('discord.js') 2 | 3 | module.exports = { 4 | name: "close", 5 | run: async(client, message, args) => { 6 | // You need to replace "Your mod role id" to mod role id 7 | if (!message.guild.roles.cache.get('Your mod role id')) { 8 | // if someone try to use this command will return this message 9 | return message.channel.send('You dont have permission to do this command!') 10 | } 11 | // You need to do this command in ticket only - dont try this is public chat 12 | message.channel.delete() 13 | } 14 | } -------------------------------------------------------------------------------- /events/client/ready.js: -------------------------------------------------------------------------------- 1 | module.exports = client => { 2 | let botStatus = [ 3 | 'instagram: @bcoq', 4 | 'Discord: Fnr#0017', 5 | 'Github: FnrDev' 6 | ] 7 | setInterval(function() { 8 | let status = botStatus[Math.floor(Math.random() * botStatus.length)] 9 | client.user.setActivity(status, {type: 'WATCHING'}) 10 | }, 20000) 11 | console.log(`Logged in as ${client.user.username}`); 12 | }; -------------------------------------------------------------------------------- /events/guild/message.js: -------------------------------------------------------------------------------- 1 | const Timeout = new Set(); 2 | const { MessageEmbed, WebhookClient } = require('discord.js') 3 | const { prefix } = require('../../config.json') 4 | const ms = require('ms') 5 | 6 | module.exports = async (bot , message) => { 7 | if (message.author.bot) return; 8 | if (!message.content.toLowerCase().startsWith(prefix)) return; 9 | if(!message.member) message.member = await message.guild.fetchMember(message); 10 | if(!message.guild) return; 11 | const args = message.content.slice(prefix.length).trim().split(/ +/g); 12 | const cmd = args.shift().toLowerCase(); 13 | if (cmd.length === 0) return; 14 | let command = bot.commands.get(cmd); 15 | if (!command) command = bot.commands.get(bot.aliases.get(cmd)); 16 | if (command) { 17 | if (command.timeout) { 18 | if (Timeout.has(`${message.author.id}${command.name}`)) { 19 | const embed = new MessageEmbed() 20 | .setTitle('You are in timeout!') 21 | .setDescription(`:x: You need to wait ${ms(command.timeout)} to use command again`) 22 | .setColor('#ff0000') 23 | return message.channel.send(embed) 24 | } else { 25 | command.run(bot, message, args); 26 | Timeout.add(`${message.author.id}${command.name}`) 27 | setTimeout(() => { 28 | Timeout.delete(`${message.author.id}${command.name}`) 29 | }, command.timeout); 30 | const webhook = new WebhookClient('id', 'token') 31 | const embed = new MessageEmbed() 32 | .setAuthor(message.author.tag, message.author.displayAvatarURL({ dynamic: true })) 33 | .setThumbnail(message.guild.iconURL({ dynamic: true })) 34 | .setColor('#fab20a') 35 | .addFields( 36 | { 37 | name: "Guild Name:", 38 | value: message.guild.name 39 | }, 40 | { 41 | name: "Guild ID:", 42 | value: message.guild.id 43 | }, 44 | { 45 | name: "Command Runs:", 46 | value: command.name 47 | }, 48 | { 49 | name: "Channel Name:", 50 | value: message.channel.name 51 | }, 52 | { 53 | name: "Channel ID:", 54 | value: message.channel.id 55 | } 56 | ) 57 | await webhook.send('', { 58 | username: bot.user.username, 59 | avatarURL: bot.user.displayAvatarURL(), 60 | embeds: [embed] 61 | }) 62 | } 63 | } else { 64 | command.run(bot,message,args) 65 | } 66 | } 67 | } -------------------------------------------------------------------------------- /handlers/events.js: -------------------------------------------------------------------------------- 1 | const { readdirSync } = require("fs"); 2 | module.exports = (client) => { 3 | const load = dirs => { 4 | const events = readdirSync(`./events/${dirs}/`).filter(d => d.endsWith("js") ); 5 | for (let file of events) { 6 | let evt = require(`../events/${dirs}/${file}`); 7 | let eName = file.split('.')[0]; 8 | client.on(eName, evt.bind(null,client)); 9 | } 10 | }; 11 | ["client", "guild"].forEach((x) => load(x)); 12 | }; -------------------------------------------------------------------------------- /handlers/handlers.js: -------------------------------------------------------------------------------- 1 | const { readdirSync } = require('fs'); 2 | module.exports = (bot) => { 3 | readdirSync("./commands/").map(dir => { 4 | const commands = readdirSync(`./commands/${dir}/`).map(cmd=> { 5 | let pull = require(`../commands/${dir}/${cmd}`) 6 | bot.commands.set(pull.name, pull) 7 | if (pull.aliases) { 8 | pull.aliases.map(p => bot.aliases.set(p, pull)) 9 | } 10 | }) 11 | }) 12 | } -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | const Discord = require("discord.js"); 2 | const fs = require("fs"); 3 | const moment = require('moment'); 4 | const client = new Discord.Client({ 5 | disableEveryone: true, 6 | }); 7 | const config = require('./config.json'); 8 | const token = config.token; 9 | client.commands = new Discord.Collection(); 10 | client.aliases = new Discord.Collection(); 11 | client.categories = fs.readdirSync("./commands/"); 12 | client.prefix = config.prefix; 13 | 14 | 15 | ["handlers", "events"].forEach(handler => { 16 | require(`./handlers/${handler}`)(client); 17 | }); 18 | 19 | 20 | client.login(token); -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "fnr-assaist", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "fnr-assaist", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "axios": "^0.21.0", 13 | "canvacord": "^5.0.8", 14 | "discord.js": "^12.4.1", 15 | "fs": "0.0.1-security", 16 | "mongoose": "^5.11.8", 17 | "ms": "^2.1.2", 18 | "nodemailer": "^6.4.16" 19 | } 20 | }, 21 | "node_modules/@canvacord/assets": { 22 | "version": "1.0.0", 23 | "resolved": "https://registry.npmjs.org/@canvacord/assets/-/assets-1.0.0.tgz", 24 | "integrity": "sha512-iPOJtM3XV8nQNNYW8V2G/+bgI//bzpy/lBfnlddjxnuwVs8fD9Q7Od00twvWrST0SdkBSaf3ndWpiC6CL1a/qg==" 25 | }, 26 | "node_modules/@discordjs/collection": { 27 | "version": "0.1.6", 28 | "resolved": "https://registry.npmjs.org/@discordjs/collection/-/collection-0.1.6.tgz", 29 | "integrity": "sha512-utRNxnd9kSS2qhyivo9lMlt5qgAUasH2gb7BEOn6p0efFh24gjGomHzWKMAPn2hEReOPQZCJaRKoURwRotKucQ==" 30 | }, 31 | "node_modules/@discordjs/form-data": { 32 | "version": "3.0.1", 33 | "resolved": "https://registry.npmjs.org/@discordjs/form-data/-/form-data-3.0.1.tgz", 34 | "integrity": "sha512-ZfFsbgEXW71Rw/6EtBdrP5VxBJy4dthyC0tpQKGKmYFImlmmrykO14Za+BiIVduwjte0jXEBlhSKf0MWbFp9Eg==", 35 | "dependencies": { 36 | "asynckit": "^0.4.0", 37 | "combined-stream": "^1.0.8", 38 | "mime-types": "^2.1.12" 39 | }, 40 | "engines": { 41 | "node": ">= 6" 42 | } 43 | }, 44 | "node_modules/@types/bson": { 45 | "version": "4.0.3", 46 | "resolved": "https://registry.npmjs.org/@types/bson/-/bson-4.0.3.tgz", 47 | "integrity": "sha512-mVRvYnTOZJz3ccpxhr3wgxVmSeiYinW+zlzQz3SXWaJmD1DuL05Jeq7nKw3SnbKmbleW5qrLG5vdyWe/A9sXhw==", 48 | "dependencies": { 49 | "@types/node": "*" 50 | } 51 | }, 52 | "node_modules/@types/mongodb": { 53 | "version": "3.6.3", 54 | "resolved": "https://registry.npmjs.org/@types/mongodb/-/mongodb-3.6.3.tgz", 55 | "integrity": "sha512-6YNqGP1hk5bjUFaim+QoFFuI61WjHiHE1BNeB41TA00Xd2K7zG4lcWyLLq/XtIp36uMavvS5hoAUJ+1u/GcX2Q==", 56 | "dependencies": { 57 | "@types/bson": "*", 58 | "@types/node": "*" 59 | } 60 | }, 61 | "node_modules/@types/node": { 62 | "version": "14.14.14", 63 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.14.14.tgz", 64 | "integrity": "sha512-UHnOPWVWV1z+VV8k6L1HhG7UbGBgIdghqF3l9Ny9ApPghbjICXkUJSd/b9gOgQfjM1r+37cipdw/HJ3F6ICEnQ==" 65 | }, 66 | "node_modules/abbrev": { 67 | "version": "1.1.1", 68 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 69 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 70 | }, 71 | "node_modules/abort-controller": { 72 | "version": "3.0.0", 73 | "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", 74 | "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", 75 | "dependencies": { 76 | "event-target-shim": "^5.0.0" 77 | }, 78 | "engines": { 79 | "node": ">=6.5" 80 | } 81 | }, 82 | "node_modules/ansi-regex": { 83 | "version": "2.1.1", 84 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 85 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 86 | "engines": { 87 | "node": ">=0.10.0" 88 | } 89 | }, 90 | "node_modules/aproba": { 91 | "version": "1.2.0", 92 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 93 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" 94 | }, 95 | "node_modules/are-we-there-yet": { 96 | "version": "1.1.5", 97 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", 98 | "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", 99 | "dependencies": { 100 | "delegates": "^1.0.0", 101 | "readable-stream": "^2.0.6" 102 | } 103 | }, 104 | "node_modules/asynckit": { 105 | "version": "0.4.0", 106 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 107 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 108 | }, 109 | "node_modules/axios": { 110 | "version": "0.21.0", 111 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.21.0.tgz", 112 | "integrity": "sha512-fmkJBknJKoZwem3/IKSSLpkdNXZeBu5Q7GA/aRsr2btgrptmSCxi2oFjZHqGdK9DoTil9PIHlPIZw2EcRJXRvw==", 113 | "dependencies": { 114 | "follow-redirects": "^1.10.0" 115 | } 116 | }, 117 | "node_modules/balanced-match": { 118 | "version": "1.0.0", 119 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 120 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 121 | }, 122 | "node_modules/bl": { 123 | "version": "2.2.1", 124 | "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.1.tgz", 125 | "integrity": "sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g==", 126 | "dependencies": { 127 | "readable-stream": "^2.3.5", 128 | "safe-buffer": "^5.1.1" 129 | } 130 | }, 131 | "node_modules/bluebird": { 132 | "version": "3.5.1", 133 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", 134 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" 135 | }, 136 | "node_modules/brace-expansion": { 137 | "version": "1.1.11", 138 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 139 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 140 | "dependencies": { 141 | "balanced-match": "^1.0.0", 142 | "concat-map": "0.0.1" 143 | } 144 | }, 145 | "node_modules/bson": { 146 | "version": "1.1.5", 147 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.5.tgz", 148 | "integrity": "sha512-kDuEzldR21lHciPQAIulLs1LZlCXdLziXI6Mb/TDkwXhb//UORJNPXgcRs2CuO4H0DcMkpfT3/ySsP3unoZjBg==", 149 | "engines": { 150 | "node": ">=0.6.19" 151 | } 152 | }, 153 | "node_modules/canvacord": { 154 | "version": "5.0.8", 155 | "resolved": "https://registry.npmjs.org/canvacord/-/canvacord-5.0.8.tgz", 156 | "integrity": "sha512-1/0+p40FHeyc7csAofXuAa0nULBAEnTl+KfN67LarfQFo85hgcEP+y+btJ0h5qSJkD14zZVcugZ/WWZlBX38nA==", 157 | "dependencies": { 158 | "@canvacord/assets": "^1.0.0", 159 | "canvas": "^2.6.1", 160 | "gifencoder": "^2.0.1", 161 | "moment": "^2.29.0", 162 | "moment-duration-format": "^2.3.2", 163 | "node-canvas-with-twemoji-and-discord-emoji": "^1.1.4" 164 | } 165 | }, 166 | "node_modules/canvas": { 167 | "version": "2.6.1", 168 | "resolved": "https://registry.npmjs.org/canvas/-/canvas-2.6.1.tgz", 169 | "integrity": "sha512-S98rKsPcuhfTcYbtF53UIJhcbgIAK533d1kJKMwsMwAIFgfd58MOyxRud3kktlzWiEkFliaJtvyZCBtud/XVEA==", 170 | "hasInstallScript": true, 171 | "dependencies": { 172 | "nan": "^2.14.0", 173 | "node-pre-gyp": "^0.11.0", 174 | "simple-get": "^3.0.3" 175 | }, 176 | "engines": { 177 | "node": ">=6" 178 | } 179 | }, 180 | "node_modules/chownr": { 181 | "version": "1.1.4", 182 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", 183 | "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==" 184 | }, 185 | "node_modules/code-point-at": { 186 | "version": "1.1.0", 187 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 188 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", 189 | "engines": { 190 | "node": ">=0.10.0" 191 | } 192 | }, 193 | "node_modules/combined-stream": { 194 | "version": "1.0.8", 195 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 196 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 197 | "dependencies": { 198 | "delayed-stream": "~1.0.0" 199 | }, 200 | "engines": { 201 | "node": ">= 0.8" 202 | } 203 | }, 204 | "node_modules/concat-map": { 205 | "version": "0.0.1", 206 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 207 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 208 | }, 209 | "node_modules/console-control-strings": { 210 | "version": "1.1.0", 211 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 212 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" 213 | }, 214 | "node_modules/core-util-is": { 215 | "version": "1.0.2", 216 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 217 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 218 | }, 219 | "node_modules/debug": { 220 | "version": "3.2.7", 221 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 222 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 223 | "dependencies": { 224 | "ms": "^2.1.1" 225 | } 226 | }, 227 | "node_modules/decompress-response": { 228 | "version": "4.2.1", 229 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-4.2.1.tgz", 230 | "integrity": "sha512-jOSne2qbyE+/r8G1VU+G/82LBs2Fs4LAsTiLSHOCOMZQl2OKZ6i8i4IyHemTe+/yIXOtTcRQMzPcgyhoFlqPkw==", 231 | "dependencies": { 232 | "mimic-response": "^2.0.0" 233 | }, 234 | "engines": { 235 | "node": ">=8" 236 | } 237 | }, 238 | "node_modules/deep-extend": { 239 | "version": "0.6.0", 240 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 241 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 242 | "engines": { 243 | "node": ">=4.0.0" 244 | } 245 | }, 246 | "node_modules/delayed-stream": { 247 | "version": "1.0.0", 248 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 249 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 250 | "engines": { 251 | "node": ">=0.4.0" 252 | } 253 | }, 254 | "node_modules/delegates": { 255 | "version": "1.0.0", 256 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 257 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" 258 | }, 259 | "node_modules/denque": { 260 | "version": "1.4.1", 261 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.4.1.tgz", 262 | "integrity": "sha512-OfzPuSZKGcgr96rf1oODnfjqBFmr1DVoc/TrItj3Ohe0Ah1C5WX5Baquw/9U9KovnQ88EqmJbD66rKYUQYN1tQ==", 263 | "engines": { 264 | "node": ">=0.10" 265 | } 266 | }, 267 | "node_modules/detect-libc": { 268 | "version": "1.0.3", 269 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz", 270 | "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=", 271 | "bin": { 272 | "detect-libc": "bin/detect-libc.js" 273 | }, 274 | "engines": { 275 | "node": ">=0.10" 276 | } 277 | }, 278 | "node_modules/discord.js": { 279 | "version": "12.4.1", 280 | "resolved": "https://registry.npmjs.org/discord.js/-/discord.js-12.4.1.tgz", 281 | "integrity": "sha512-KxOB8LOAN3GmrvkD6a6Fr1nlfArIFZ+q7Uqg4T/5duB90GZy9a0/Py2E+Y+eHKP6ZUCR2mbNMLCcHGjahiaNqA==", 282 | "dependencies": { 283 | "@discordjs/collection": "^0.1.6", 284 | "@discordjs/form-data": "^3.0.1", 285 | "abort-controller": "^3.0.0", 286 | "node-fetch": "^2.6.1", 287 | "prism-media": "^1.2.2", 288 | "setimmediate": "^1.0.5", 289 | "tweetnacl": "^1.0.3", 290 | "ws": "^7.3.1" 291 | }, 292 | "engines": { 293 | "node": ">=12.0.0" 294 | } 295 | }, 296 | "node_modules/event-target-shim": { 297 | "version": "5.0.1", 298 | "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz", 299 | "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==", 300 | "engines": { 301 | "node": ">=6" 302 | } 303 | }, 304 | "node_modules/follow-redirects": { 305 | "version": "1.13.0", 306 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.13.0.tgz", 307 | "integrity": "sha512-aq6gF1BEKje4a9i9+5jimNFIpq4Q1WiwBToeRK5NvZBd/TRsmW8BsJfOEGkr76TbOyPVD3OVDN910EcUNtRYEA==", 308 | "engines": { 309 | "node": ">=4.0" 310 | } 311 | }, 312 | "node_modules/fs": { 313 | "version": "0.0.1-security", 314 | "resolved": "https://registry.npmjs.org/fs/-/fs-0.0.1-security.tgz", 315 | "integrity": "sha1-invTcYa23d84E/I4WLV+yq9eQdQ=" 316 | }, 317 | "node_modules/fs-extra": { 318 | "version": "8.1.0", 319 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", 320 | "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", 321 | "dependencies": { 322 | "graceful-fs": "^4.2.0", 323 | "jsonfile": "^4.0.0", 324 | "universalify": "^0.1.0" 325 | }, 326 | "engines": { 327 | "node": ">=6 <7 || >=8" 328 | } 329 | }, 330 | "node_modules/fs-extra/node_modules/jsonfile": { 331 | "version": "4.0.0", 332 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 333 | "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", 334 | "dependencies": { 335 | "graceful-fs": "^4.1.6" 336 | } 337 | }, 338 | "node_modules/fs-minipass": { 339 | "version": "1.2.7", 340 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.7.tgz", 341 | "integrity": "sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA==", 342 | "dependencies": { 343 | "minipass": "^2.6.0" 344 | } 345 | }, 346 | "node_modules/fs.realpath": { 347 | "version": "1.0.0", 348 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 349 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 350 | }, 351 | "node_modules/gauge": { 352 | "version": "2.7.4", 353 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 354 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 355 | "dependencies": { 356 | "aproba": "^1.0.3", 357 | "console-control-strings": "^1.0.0", 358 | "has-unicode": "^2.0.0", 359 | "object-assign": "^4.1.0", 360 | "signal-exit": "^3.0.0", 361 | "string-width": "^1.0.1", 362 | "strip-ansi": "^3.0.1", 363 | "wide-align": "^1.1.0" 364 | } 365 | }, 366 | "node_modules/gifencoder": { 367 | "version": "2.0.1", 368 | "resolved": "https://registry.npmjs.org/gifencoder/-/gifencoder-2.0.1.tgz", 369 | "integrity": "sha512-x19DcyWY10SkshBpokqFOo/HBht9GB75evRYvaLMbez9p+yB/o+kt0fK9AwW59nFiAMs2UUQsjv1lX/hvu9Ong==", 370 | "dependencies": { 371 | "canvas": "^2.2.0" 372 | } 373 | }, 374 | "node_modules/glob": { 375 | "version": "7.1.6", 376 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 377 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 378 | "dependencies": { 379 | "fs.realpath": "^1.0.0", 380 | "inflight": "^1.0.4", 381 | "inherits": "2", 382 | "minimatch": "^3.0.4", 383 | "once": "^1.3.0", 384 | "path-is-absolute": "^1.0.0" 385 | }, 386 | "engines": { 387 | "node": "*" 388 | } 389 | }, 390 | "node_modules/graceful-fs": { 391 | "version": "4.2.4", 392 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 393 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==" 394 | }, 395 | "node_modules/has-unicode": { 396 | "version": "2.0.1", 397 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 398 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" 399 | }, 400 | "node_modules/iconv-lite": { 401 | "version": "0.4.24", 402 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 403 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 404 | "dependencies": { 405 | "safer-buffer": ">= 2.1.2 < 3" 406 | }, 407 | "engines": { 408 | "node": ">=0.10.0" 409 | } 410 | }, 411 | "node_modules/ignore-walk": { 412 | "version": "3.0.3", 413 | "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.3.tgz", 414 | "integrity": "sha512-m7o6xuOaT1aqheYHKf8W6J5pYH85ZI9w077erOzLje3JsB1gkafkAhHHY19dqjulgIZHFm32Cp5uNZgcQqdJKw==", 415 | "dependencies": { 416 | "minimatch": "^3.0.4" 417 | } 418 | }, 419 | "node_modules/inflight": { 420 | "version": "1.0.6", 421 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 422 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 423 | "dependencies": { 424 | "once": "^1.3.0", 425 | "wrappy": "1" 426 | } 427 | }, 428 | "node_modules/inherits": { 429 | "version": "2.0.4", 430 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 431 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 432 | }, 433 | "node_modules/ini": { 434 | "version": "1.3.5", 435 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 436 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", 437 | "engines": { 438 | "node": "*" 439 | } 440 | }, 441 | "node_modules/is-fullwidth-code-point": { 442 | "version": "1.0.0", 443 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 444 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 445 | "dependencies": { 446 | "number-is-nan": "^1.0.0" 447 | }, 448 | "engines": { 449 | "node": ">=0.10.0" 450 | } 451 | }, 452 | "node_modules/isarray": { 453 | "version": "1.0.0", 454 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 455 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 456 | }, 457 | "node_modules/jsonfile": { 458 | "version": "5.0.0", 459 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-5.0.0.tgz", 460 | "integrity": "sha512-NQRZ5CRo74MhMMC3/3r5g2k4fjodJ/wh8MxjFbCViWKFjxrnudWSY5vomh+23ZaXzAS7J3fBZIR2dV6WbmfM0w==", 461 | "dependencies": { 462 | "graceful-fs": "^4.1.6", 463 | "universalify": "^0.1.2" 464 | } 465 | }, 466 | "node_modules/kareem": { 467 | "version": "2.3.2", 468 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.2.tgz", 469 | "integrity": "sha512-STHz9P7X2L4Kwn72fA4rGyqyXdmrMSdxqHx9IXon/FXluXieaFA6KJ2upcHAHxQPQ0LeM/OjLrhFxifHewOALQ==" 470 | }, 471 | "node_modules/memory-pager": { 472 | "version": "1.5.0", 473 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 474 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 475 | "optional": true 476 | }, 477 | "node_modules/mime-db": { 478 | "version": "1.44.0", 479 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.44.0.tgz", 480 | "integrity": "sha512-/NOTfLrsPBVeH7YtFPgsVWveuL+4SjjYxaQ1xtM1KMFj7HdxlBlxeyNLzhyJVx7r4rZGJAZ/6lkKCitSc/Nmpg==", 481 | "engines": { 482 | "node": ">= 0.6" 483 | } 484 | }, 485 | "node_modules/mime-types": { 486 | "version": "2.1.27", 487 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.27.tgz", 488 | "integrity": "sha512-JIhqnCasI9yD+SsmkquHBxTSEuZdQX5BuQnS2Vc7puQQQ+8yiP5AY5uWhpdv4YL4VM5c6iliiYWPgJ/nJQLp7w==", 489 | "dependencies": { 490 | "mime-db": "1.44.0" 491 | }, 492 | "engines": { 493 | "node": ">= 0.6" 494 | } 495 | }, 496 | "node_modules/mimic-response": { 497 | "version": "2.1.0", 498 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-2.1.0.tgz", 499 | "integrity": "sha512-wXqjST+SLt7R009ySCglWBCFpjUygmCIfD790/kVbiGmUgfYGuB14PiTd5DwVxSV4NcYHjzMkoj5LjQZwTQLEA==", 500 | "engines": { 501 | "node": ">=8" 502 | } 503 | }, 504 | "node_modules/minimatch": { 505 | "version": "3.0.4", 506 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 507 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 508 | "dependencies": { 509 | "brace-expansion": "^1.1.7" 510 | }, 511 | "engines": { 512 | "node": "*" 513 | } 514 | }, 515 | "node_modules/minimist": { 516 | "version": "1.2.5", 517 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 518 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 519 | }, 520 | "node_modules/minipass": { 521 | "version": "2.9.0", 522 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.9.0.tgz", 523 | "integrity": "sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg==", 524 | "dependencies": { 525 | "safe-buffer": "^5.1.2", 526 | "yallist": "^3.0.0" 527 | } 528 | }, 529 | "node_modules/minizlib": { 530 | "version": "1.3.3", 531 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.3.3.tgz", 532 | "integrity": "sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q==", 533 | "dependencies": { 534 | "minipass": "^2.9.0" 535 | } 536 | }, 537 | "node_modules/mkdirp": { 538 | "version": "0.5.5", 539 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 540 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 541 | "dependencies": { 542 | "minimist": "^1.2.5" 543 | }, 544 | "bin": { 545 | "mkdirp": "bin/cmd.js" 546 | } 547 | }, 548 | "node_modules/moment": { 549 | "version": "2.29.1", 550 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz", 551 | "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ==", 552 | "engines": { 553 | "node": "*" 554 | } 555 | }, 556 | "node_modules/moment-duration-format": { 557 | "version": "2.3.2", 558 | "resolved": "https://registry.npmjs.org/moment-duration-format/-/moment-duration-format-2.3.2.tgz", 559 | "integrity": "sha512-cBMXjSW+fjOb4tyaVHuaVE/A5TqkukDWiOfxxAjY+PEqmmBQlLwn+8OzwPiG3brouXKY5Un4pBjAeB6UToXHaQ==" 560 | }, 561 | "node_modules/mongodb": { 562 | "version": "3.6.3", 563 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.6.3.tgz", 564 | "integrity": "sha512-rOZuR0QkodZiM+UbQE5kDsJykBqWi0CL4Ec2i1nrGrUI3KO11r6Fbxskqmq3JK2NH7aW4dcccBuUujAP0ERl5w==", 565 | "dependencies": { 566 | "bl": "^2.2.1", 567 | "bson": "^1.1.4", 568 | "denque": "^1.4.1", 569 | "require_optional": "^1.0.1", 570 | "safe-buffer": "^5.1.2" 571 | }, 572 | "engines": { 573 | "node": ">=4" 574 | }, 575 | "optionalDependencies": { 576 | "saslprep": "^1.0.0" 577 | } 578 | }, 579 | "node_modules/mongoose": { 580 | "version": "5.11.8", 581 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.11.8.tgz", 582 | "integrity": "sha512-RRfrYLg7pyuyx7xu5hwadjIZZJB9W2jqIMkL1CkTmk/uOCX3MX2tl4BVIi2rJUtgMNwn6dy3wBD3soB8I9Nlog==", 583 | "dependencies": { 584 | "@types/mongodb": "^3.5.27", 585 | "bson": "^1.1.4", 586 | "kareem": "2.3.2", 587 | "mongodb": "3.6.3", 588 | "mongoose-legacy-pluralize": "1.0.2", 589 | "mpath": "0.8.1", 590 | "mquery": "3.2.3", 591 | "ms": "2.1.2", 592 | "regexp-clone": "1.0.0", 593 | "safe-buffer": "5.2.1", 594 | "sift": "7.0.1", 595 | "sliced": "1.0.1" 596 | }, 597 | "engines": { 598 | "node": ">=4.0.0" 599 | } 600 | }, 601 | "node_modules/mongoose-legacy-pluralize": { 602 | "version": "1.0.2", 603 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz", 604 | "integrity": "sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ==" 605 | }, 606 | "node_modules/mongoose/node_modules/safe-buffer": { 607 | "version": "5.2.1", 608 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 609 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 610 | }, 611 | "node_modules/mpath": { 612 | "version": "0.8.1", 613 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.8.1.tgz", 614 | "integrity": "sha512-norEinle9aFc05McBawVPwqgFZ7npkts9yu17ztIVLwPwO9rq0OTp89kGVTqvv5rNLMz96E5iWHpVORjI411vA==", 615 | "engines": { 616 | "node": ">=4.0.0" 617 | } 618 | }, 619 | "node_modules/mquery": { 620 | "version": "3.2.3", 621 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.2.3.tgz", 622 | "integrity": "sha512-cIfbP4TyMYX+SkaQ2MntD+F2XbqaBHUYWk3j+kqdDztPWok3tgyssOZxMHMtzbV1w9DaSlvEea0Iocuro41A4g==", 623 | "dependencies": { 624 | "bluebird": "3.5.1", 625 | "debug": "3.1.0", 626 | "regexp-clone": "^1.0.0", 627 | "safe-buffer": "5.1.2", 628 | "sliced": "1.0.1" 629 | }, 630 | "engines": { 631 | "node": ">=4.0.0" 632 | } 633 | }, 634 | "node_modules/mquery/node_modules/debug": { 635 | "version": "3.1.0", 636 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 637 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 638 | "dependencies": { 639 | "ms": "2.0.0" 640 | } 641 | }, 642 | "node_modules/mquery/node_modules/ms": { 643 | "version": "2.0.0", 644 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 645 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 646 | }, 647 | "node_modules/ms": { 648 | "version": "2.1.2", 649 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 650 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 651 | }, 652 | "node_modules/nan": { 653 | "version": "2.14.2", 654 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.2.tgz", 655 | "integrity": "sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ==" 656 | }, 657 | "node_modules/needle": { 658 | "version": "2.5.2", 659 | "resolved": "https://registry.npmjs.org/needle/-/needle-2.5.2.tgz", 660 | "integrity": "sha512-LbRIwS9BfkPvNwNHlsA41Q29kL2L/6VaOJ0qisM5lLWsTV3nP15abO5ITL6L81zqFhzjRKDAYjpcBcwM0AVvLQ==", 661 | "dependencies": { 662 | "debug": "^3.2.6", 663 | "iconv-lite": "^0.4.4", 664 | "sax": "^1.2.4" 665 | }, 666 | "bin": { 667 | "needle": "bin/needle" 668 | }, 669 | "engines": { 670 | "node": ">= 4.4.x" 671 | } 672 | }, 673 | "node_modules/node-canvas-with-twemoji-and-discord-emoji": { 674 | "version": "1.1.6", 675 | "resolved": "https://registry.npmjs.org/node-canvas-with-twemoji-and-discord-emoji/-/node-canvas-with-twemoji-and-discord-emoji-1.1.6.tgz", 676 | "integrity": "sha512-tZ5fx0TeMp8d30d2XOKWVIt2Nz9mjFG6Ws3GUoChsJfoTSul82+nKpnbZ7mAqe+jWKdKAoAZzfF6qYMxr5rypA==", 677 | "dependencies": { 678 | "canvas": "^2.6.1", 679 | "twemoji": "^13.0.1" 680 | } 681 | }, 682 | "node_modules/node-fetch": { 683 | "version": "2.6.1", 684 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.1.tgz", 685 | "integrity": "sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw==", 686 | "engines": { 687 | "node": "4.x || >=6.0.0" 688 | } 689 | }, 690 | "node_modules/node-pre-gyp": { 691 | "version": "0.11.0", 692 | "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.11.0.tgz", 693 | "integrity": "sha512-TwWAOZb0j7e9eGaf9esRx3ZcLaE5tQ2lvYy1pb5IAaG1a2e2Kv5Lms1Y4hpj+ciXJRofIxxlt5haeQ/2ANeE0Q==", 694 | "dependencies": { 695 | "detect-libc": "^1.0.2", 696 | "mkdirp": "^0.5.1", 697 | "needle": "^2.2.1", 698 | "nopt": "^4.0.1", 699 | "npm-packlist": "^1.1.6", 700 | "npmlog": "^4.0.2", 701 | "rc": "^1.2.7", 702 | "rimraf": "^2.6.1", 703 | "semver": "^5.3.0", 704 | "tar": "^4" 705 | }, 706 | "bin": { 707 | "node-pre-gyp": "bin/node-pre-gyp" 708 | } 709 | }, 710 | "node_modules/nodemailer": { 711 | "version": "6.4.16", 712 | "resolved": "https://registry.npmjs.org/nodemailer/-/nodemailer-6.4.16.tgz", 713 | "integrity": "sha512-68K0LgZ6hmZ7PVmwL78gzNdjpj5viqBdFqKrTtr9bZbJYj6BRj5W6WGkxXrEnUl3Co3CBXi3CZBUlpV/foGnOQ==", 714 | "engines": { 715 | "node": ">=6.0.0" 716 | } 717 | }, 718 | "node_modules/nopt": { 719 | "version": "4.0.3", 720 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.3.tgz", 721 | "integrity": "sha512-CvaGwVMztSMJLOeXPrez7fyfObdZqNUK1cPAEzLHrTybIua9pMdmmPR5YwtfNftIOMv3DPUhFaxsZMNTQO20Kg==", 722 | "dependencies": { 723 | "abbrev": "1", 724 | "osenv": "^0.1.4" 725 | }, 726 | "bin": { 727 | "nopt": "bin/nopt.js" 728 | } 729 | }, 730 | "node_modules/npm-bundled": { 731 | "version": "1.1.1", 732 | "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.1.1.tgz", 733 | "integrity": "sha512-gqkfgGePhTpAEgUsGEgcq1rqPXA+tv/aVBlgEzfXwA1yiUJF7xtEt3CtVwOjNYQOVknDk0F20w58Fnm3EtG0fA==", 734 | "dependencies": { 735 | "npm-normalize-package-bin": "^1.0.1" 736 | } 737 | }, 738 | "node_modules/npm-normalize-package-bin": { 739 | "version": "1.0.1", 740 | "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-1.0.1.tgz", 741 | "integrity": "sha512-EPfafl6JL5/rU+ot6P3gRSCpPDW5VmIzX959Ob1+ySFUuuYHWHekXpwdUZcKP5C+DS4GEtdJluwBjnsNDl+fSA==" 742 | }, 743 | "node_modules/npm-packlist": { 744 | "version": "1.4.8", 745 | "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.4.8.tgz", 746 | "integrity": "sha512-5+AZgwru5IevF5ZdnFglB5wNlHG1AOOuw28WhUq8/8emhBmLv6jX5by4WJCh7lW0uSYZYS6DXqIsyZVIXRZU9A==", 747 | "dependencies": { 748 | "ignore-walk": "^3.0.1", 749 | "npm-bundled": "^1.0.1", 750 | "npm-normalize-package-bin": "^1.0.1" 751 | } 752 | }, 753 | "node_modules/npmlog": { 754 | "version": "4.1.2", 755 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 756 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 757 | "dependencies": { 758 | "are-we-there-yet": "~1.1.2", 759 | "console-control-strings": "~1.1.0", 760 | "gauge": "~2.7.3", 761 | "set-blocking": "~2.0.0" 762 | } 763 | }, 764 | "node_modules/number-is-nan": { 765 | "version": "1.0.1", 766 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 767 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", 768 | "engines": { 769 | "node": ">=0.10.0" 770 | } 771 | }, 772 | "node_modules/object-assign": { 773 | "version": "4.1.1", 774 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 775 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 776 | "engines": { 777 | "node": ">=0.10.0" 778 | } 779 | }, 780 | "node_modules/once": { 781 | "version": "1.4.0", 782 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 783 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 784 | "dependencies": { 785 | "wrappy": "1" 786 | } 787 | }, 788 | "node_modules/os-homedir": { 789 | "version": "1.0.2", 790 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 791 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", 792 | "engines": { 793 | "node": ">=0.10.0" 794 | } 795 | }, 796 | "node_modules/os-tmpdir": { 797 | "version": "1.0.2", 798 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 799 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 800 | "engines": { 801 | "node": ">=0.10.0" 802 | } 803 | }, 804 | "node_modules/osenv": { 805 | "version": "0.1.5", 806 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", 807 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", 808 | "dependencies": { 809 | "os-homedir": "^1.0.0", 810 | "os-tmpdir": "^1.0.0" 811 | } 812 | }, 813 | "node_modules/path-is-absolute": { 814 | "version": "1.0.1", 815 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 816 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 817 | "engines": { 818 | "node": ">=0.10.0" 819 | } 820 | }, 821 | "node_modules/prism-media": { 822 | "version": "1.2.2", 823 | "resolved": "https://registry.npmjs.org/prism-media/-/prism-media-1.2.2.tgz", 824 | "integrity": "sha512-I+nkWY212lJ500jLe4tN9tWO7nRiBAVdMv76P9kffZjYhw20raMlW1HSSvS+MLXC9MmbNZCazMrAr+5jEEgTuw==" 825 | }, 826 | "node_modules/process-nextick-args": { 827 | "version": "2.0.1", 828 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 829 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 830 | }, 831 | "node_modules/rc": { 832 | "version": "1.2.8", 833 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 834 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 835 | "dependencies": { 836 | "deep-extend": "^0.6.0", 837 | "ini": "~1.3.0", 838 | "minimist": "^1.2.0", 839 | "strip-json-comments": "~2.0.1" 840 | }, 841 | "bin": { 842 | "rc": "cli.js" 843 | } 844 | }, 845 | "node_modules/readable-stream": { 846 | "version": "2.3.7", 847 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 848 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 849 | "dependencies": { 850 | "core-util-is": "~1.0.0", 851 | "inherits": "~2.0.3", 852 | "isarray": "~1.0.0", 853 | "process-nextick-args": "~2.0.0", 854 | "safe-buffer": "~5.1.1", 855 | "string_decoder": "~1.1.1", 856 | "util-deprecate": "~1.0.1" 857 | } 858 | }, 859 | "node_modules/regexp-clone": { 860 | "version": "1.0.0", 861 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-1.0.0.tgz", 862 | "integrity": "sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw==" 863 | }, 864 | "node_modules/require_optional": { 865 | "version": "1.0.1", 866 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 867 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 868 | "dependencies": { 869 | "resolve-from": "^2.0.0", 870 | "semver": "^5.1.0" 871 | } 872 | }, 873 | "node_modules/resolve-from": { 874 | "version": "2.0.0", 875 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 876 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=", 877 | "engines": { 878 | "node": ">=0.10.0" 879 | } 880 | }, 881 | "node_modules/rimraf": { 882 | "version": "2.7.1", 883 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 884 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 885 | "dependencies": { 886 | "glob": "^7.1.3" 887 | }, 888 | "bin": { 889 | "rimraf": "bin.js" 890 | } 891 | }, 892 | "node_modules/safe-buffer": { 893 | "version": "5.1.2", 894 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 895 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 896 | }, 897 | "node_modules/safer-buffer": { 898 | "version": "2.1.2", 899 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 900 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 901 | }, 902 | "node_modules/saslprep": { 903 | "version": "1.0.3", 904 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 905 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 906 | "optional": true, 907 | "dependencies": { 908 | "sparse-bitfield": "^3.0.3" 909 | }, 910 | "engines": { 911 | "node": ">=6" 912 | } 913 | }, 914 | "node_modules/sax": { 915 | "version": "1.2.4", 916 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 917 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" 918 | }, 919 | "node_modules/semver": { 920 | "version": "5.7.1", 921 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 922 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 923 | "bin": { 924 | "semver": "bin/semver" 925 | } 926 | }, 927 | "node_modules/set-blocking": { 928 | "version": "2.0.0", 929 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 930 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 931 | }, 932 | "node_modules/setimmediate": { 933 | "version": "1.0.5", 934 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", 935 | "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=" 936 | }, 937 | "node_modules/sift": { 938 | "version": "7.0.1", 939 | "resolved": "https://registry.npmjs.org/sift/-/sift-7.0.1.tgz", 940 | "integrity": "sha512-oqD7PMJ+uO6jV9EQCl0LrRw1OwsiPsiFQR5AR30heR+4Dl7jBBbDLnNvWiak20tzZlSE1H7RB30SX/1j/YYT7g==" 941 | }, 942 | "node_modules/signal-exit": { 943 | "version": "3.0.3", 944 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 945 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==" 946 | }, 947 | "node_modules/simple-concat": { 948 | "version": "1.0.1", 949 | "resolved": "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.1.tgz", 950 | "integrity": "sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q==" 951 | }, 952 | "node_modules/simple-get": { 953 | "version": "3.1.0", 954 | "resolved": "https://registry.npmjs.org/simple-get/-/simple-get-3.1.0.tgz", 955 | "integrity": "sha512-bCR6cP+aTdScaQCnQKbPKtJOKDp/hj9EDLJo3Nw4y1QksqaovlW/bnptB6/c1e+qmNIDHRK+oXFDdEqBT8WzUA==", 956 | "dependencies": { 957 | "decompress-response": "^4.2.0", 958 | "once": "^1.3.1", 959 | "simple-concat": "^1.0.0" 960 | } 961 | }, 962 | "node_modules/sliced": { 963 | "version": "1.0.1", 964 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", 965 | "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E=" 966 | }, 967 | "node_modules/sparse-bitfield": { 968 | "version": "3.0.3", 969 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 970 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 971 | "optional": true, 972 | "dependencies": { 973 | "memory-pager": "^1.0.2" 974 | } 975 | }, 976 | "node_modules/string_decoder": { 977 | "version": "1.1.1", 978 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 979 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 980 | "dependencies": { 981 | "safe-buffer": "~5.1.0" 982 | } 983 | }, 984 | "node_modules/string-width": { 985 | "version": "1.0.2", 986 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 987 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 988 | "dependencies": { 989 | "code-point-at": "^1.0.0", 990 | "is-fullwidth-code-point": "^1.0.0", 991 | "strip-ansi": "^3.0.0" 992 | }, 993 | "engines": { 994 | "node": ">=0.10.0" 995 | } 996 | }, 997 | "node_modules/strip-ansi": { 998 | "version": "3.0.1", 999 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 1000 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 1001 | "dependencies": { 1002 | "ansi-regex": "^2.0.0" 1003 | }, 1004 | "engines": { 1005 | "node": ">=0.10.0" 1006 | } 1007 | }, 1008 | "node_modules/strip-json-comments": { 1009 | "version": "2.0.1", 1010 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1011 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1012 | "engines": { 1013 | "node": ">=0.10.0" 1014 | } 1015 | }, 1016 | "node_modules/tar": { 1017 | "version": "4.4.13", 1018 | "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.13.tgz", 1019 | "integrity": "sha512-w2VwSrBoHa5BsSyH+KxEqeQBAllHhccyMFVHtGtdMpF4W7IRWfZjFiQceJPChOeTsSDVUpER2T8FA93pr0L+QA==", 1020 | "dependencies": { 1021 | "chownr": "^1.1.1", 1022 | "fs-minipass": "^1.2.5", 1023 | "minipass": "^2.8.6", 1024 | "minizlib": "^1.2.1", 1025 | "mkdirp": "^0.5.0", 1026 | "safe-buffer": "^5.1.2", 1027 | "yallist": "^3.0.3" 1028 | }, 1029 | "engines": { 1030 | "node": ">=4.5" 1031 | } 1032 | }, 1033 | "node_modules/tweetnacl": { 1034 | "version": "1.0.3", 1035 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-1.0.3.tgz", 1036 | "integrity": "sha512-6rt+RN7aOi1nGMyC4Xa5DdYiukl2UWCbcJft7YhxReBGQD7OAM8Pbxw6YMo4r2diNEA8FEmu32YOn9rhaiE5yw==" 1037 | }, 1038 | "node_modules/twemoji": { 1039 | "version": "13.0.1", 1040 | "resolved": "https://registry.npmjs.org/twemoji/-/twemoji-13.0.1.tgz", 1041 | "integrity": "sha512-mrTBq+XpCLM4zm76NJOjLHoQNV9mHdBt3Cba/T5lS1rxn8ArwpqE47mqTocupNlkvcLxoeZJjYSUW0DU5ZwqZg==", 1042 | "dependencies": { 1043 | "fs-extra": "^8.0.1", 1044 | "jsonfile": "^5.0.0", 1045 | "twemoji-parser": "13.0.0", 1046 | "universalify": "^0.1.2" 1047 | } 1048 | }, 1049 | "node_modules/twemoji-parser": { 1050 | "version": "13.0.0", 1051 | "resolved": "https://registry.npmjs.org/twemoji-parser/-/twemoji-parser-13.0.0.tgz", 1052 | "integrity": "sha512-zMaGdskpH8yKjT2RSE/HwE340R4Fm+fbie4AaqjDa4H/l07YUmAvxkSfNl6awVWNRRQ0zdzLQ8SAJZuY5MgstQ==" 1053 | }, 1054 | "node_modules/universalify": { 1055 | "version": "0.1.2", 1056 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 1057 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", 1058 | "engines": { 1059 | "node": ">= 4.0.0" 1060 | } 1061 | }, 1062 | "node_modules/util-deprecate": { 1063 | "version": "1.0.2", 1064 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1065 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1066 | }, 1067 | "node_modules/wide-align": { 1068 | "version": "1.1.3", 1069 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1070 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1071 | "dependencies": { 1072 | "string-width": "^1.0.2 || 2" 1073 | } 1074 | }, 1075 | "node_modules/wrappy": { 1076 | "version": "1.0.2", 1077 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1078 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1079 | }, 1080 | "node_modules/ws": { 1081 | "version": "7.3.1", 1082 | "resolved": "https://registry.npmjs.org/ws/-/ws-7.3.1.tgz", 1083 | "integrity": "sha512-D3RuNkynyHmEJIpD2qrgVkc9DQ23OrN/moAwZX4L8DfvszsJxpjQuUq3LMx6HoYji9fbIOBY18XWBsAux1ZZUA==", 1084 | "engines": { 1085 | "node": ">=8.3.0" 1086 | } 1087 | }, 1088 | "node_modules/yallist": { 1089 | "version": "3.1.1", 1090 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 1091 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" 1092 | } 1093 | }, 1094 | "dependencies": { 1095 | "@canvacord/assets": { 1096 | "version": "1.0.0", 1097 | "resolved": "https://registry.npmjs.org/@canvacord/assets/-/assets-1.0.0.tgz", 1098 | "integrity": "sha512-iPOJtM3XV8nQNNYW8V2G/+bgI//bzpy/lBfnlddjxnuwVs8fD9Q7Od00twvWrST0SdkBSaf3ndWpiC6CL1a/qg==" 1099 | }, 1100 | "@discordjs/collection": { 1101 | "version": "0.1.6", 1102 | "resolved": "https://registry.npmjs.org/@discordjs/collection/-/collection-0.1.6.tgz", 1103 | "integrity": "sha512-utRNxnd9kSS2qhyivo9lMlt5qgAUasH2gb7BEOn6p0efFh24gjGomHzWKMAPn2hEReOPQZCJaRKoURwRotKucQ==" 1104 | }, 1105 | "@discordjs/form-data": { 1106 | "version": "3.0.1", 1107 | "resolved": "https://registry.npmjs.org/@discordjs/form-data/-/form-data-3.0.1.tgz", 1108 | "integrity": "sha512-ZfFsbgEXW71Rw/6EtBdrP5VxBJy4dthyC0tpQKGKmYFImlmmrykO14Za+BiIVduwjte0jXEBlhSKf0MWbFp9Eg==", 1109 | "requires": { 1110 | "asynckit": "^0.4.0", 1111 | "combined-stream": "^1.0.8", 1112 | "mime-types": "^2.1.12" 1113 | } 1114 | }, 1115 | "@types/bson": { 1116 | "version": "4.0.3", 1117 | "resolved": "https://registry.npmjs.org/@types/bson/-/bson-4.0.3.tgz", 1118 | "integrity": "sha512-mVRvYnTOZJz3ccpxhr3wgxVmSeiYinW+zlzQz3SXWaJmD1DuL05Jeq7nKw3SnbKmbleW5qrLG5vdyWe/A9sXhw==", 1119 | "requires": { 1120 | "@types/node": "*" 1121 | } 1122 | }, 1123 | "@types/mongodb": { 1124 | "version": "3.6.3", 1125 | "resolved": "https://registry.npmjs.org/@types/mongodb/-/mongodb-3.6.3.tgz", 1126 | "integrity": "sha512-6YNqGP1hk5bjUFaim+QoFFuI61WjHiHE1BNeB41TA00Xd2K7zG4lcWyLLq/XtIp36uMavvS5hoAUJ+1u/GcX2Q==", 1127 | "requires": { 1128 | "@types/bson": "*", 1129 | "@types/node": "*" 1130 | } 1131 | }, 1132 | "@types/node": { 1133 | "version": "14.14.14", 1134 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.14.14.tgz", 1135 | "integrity": "sha512-UHnOPWVWV1z+VV8k6L1HhG7UbGBgIdghqF3l9Ny9ApPghbjICXkUJSd/b9gOgQfjM1r+37cipdw/HJ3F6ICEnQ==" 1136 | }, 1137 | "abbrev": { 1138 | "version": "1.1.1", 1139 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 1140 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 1141 | }, 1142 | "abort-controller": { 1143 | "version": "3.0.0", 1144 | "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", 1145 | "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", 1146 | "requires": { 1147 | "event-target-shim": "^5.0.0" 1148 | } 1149 | }, 1150 | "ansi-regex": { 1151 | "version": "2.1.1", 1152 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 1153 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 1154 | }, 1155 | "aproba": { 1156 | "version": "1.2.0", 1157 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 1158 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" 1159 | }, 1160 | "are-we-there-yet": { 1161 | "version": "1.1.5", 1162 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", 1163 | "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", 1164 | "requires": { 1165 | "delegates": "^1.0.0", 1166 | "readable-stream": "^2.0.6" 1167 | } 1168 | }, 1169 | "asynckit": { 1170 | "version": "0.4.0", 1171 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 1172 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 1173 | }, 1174 | "axios": { 1175 | "version": "0.21.0", 1176 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.21.0.tgz", 1177 | "integrity": "sha512-fmkJBknJKoZwem3/IKSSLpkdNXZeBu5Q7GA/aRsr2btgrptmSCxi2oFjZHqGdK9DoTil9PIHlPIZw2EcRJXRvw==", 1178 | "requires": { 1179 | "follow-redirects": "^1.10.0" 1180 | } 1181 | }, 1182 | "balanced-match": { 1183 | "version": "1.0.0", 1184 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 1185 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 1186 | }, 1187 | "bl": { 1188 | "version": "2.2.1", 1189 | "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.1.tgz", 1190 | "integrity": "sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g==", 1191 | "requires": { 1192 | "readable-stream": "^2.3.5", 1193 | "safe-buffer": "^5.1.1" 1194 | } 1195 | }, 1196 | "bluebird": { 1197 | "version": "3.5.1", 1198 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", 1199 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" 1200 | }, 1201 | "brace-expansion": { 1202 | "version": "1.1.11", 1203 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1204 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1205 | "requires": { 1206 | "balanced-match": "^1.0.0", 1207 | "concat-map": "0.0.1" 1208 | } 1209 | }, 1210 | "bson": { 1211 | "version": "1.1.5", 1212 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.5.tgz", 1213 | "integrity": "sha512-kDuEzldR21lHciPQAIulLs1LZlCXdLziXI6Mb/TDkwXhb//UORJNPXgcRs2CuO4H0DcMkpfT3/ySsP3unoZjBg==" 1214 | }, 1215 | "canvacord": { 1216 | "version": "5.0.8", 1217 | "resolved": "https://registry.npmjs.org/canvacord/-/canvacord-5.0.8.tgz", 1218 | "integrity": "sha512-1/0+p40FHeyc7csAofXuAa0nULBAEnTl+KfN67LarfQFo85hgcEP+y+btJ0h5qSJkD14zZVcugZ/WWZlBX38nA==", 1219 | "requires": { 1220 | "@canvacord/assets": "^1.0.0", 1221 | "canvas": "^2.6.1", 1222 | "gifencoder": "^2.0.1", 1223 | "moment": "^2.29.0", 1224 | "moment-duration-format": "^2.3.2", 1225 | "node-canvas-with-twemoji-and-discord-emoji": "^1.1.4" 1226 | } 1227 | }, 1228 | "canvas": { 1229 | "version": "2.6.1", 1230 | "resolved": "https://registry.npmjs.org/canvas/-/canvas-2.6.1.tgz", 1231 | "integrity": "sha512-S98rKsPcuhfTcYbtF53UIJhcbgIAK533d1kJKMwsMwAIFgfd58MOyxRud3kktlzWiEkFliaJtvyZCBtud/XVEA==", 1232 | "requires": { 1233 | "nan": "^2.14.0", 1234 | "node-pre-gyp": "^0.11.0", 1235 | "simple-get": "^3.0.3" 1236 | } 1237 | }, 1238 | "chownr": { 1239 | "version": "1.1.4", 1240 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", 1241 | "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==" 1242 | }, 1243 | "code-point-at": { 1244 | "version": "1.1.0", 1245 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 1246 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 1247 | }, 1248 | "combined-stream": { 1249 | "version": "1.0.8", 1250 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 1251 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 1252 | "requires": { 1253 | "delayed-stream": "~1.0.0" 1254 | } 1255 | }, 1256 | "concat-map": { 1257 | "version": "0.0.1", 1258 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1259 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 1260 | }, 1261 | "console-control-strings": { 1262 | "version": "1.1.0", 1263 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 1264 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" 1265 | }, 1266 | "core-util-is": { 1267 | "version": "1.0.2", 1268 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 1269 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 1270 | }, 1271 | "debug": { 1272 | "version": "3.2.7", 1273 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1274 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1275 | "requires": { 1276 | "ms": "^2.1.1" 1277 | } 1278 | }, 1279 | "decompress-response": { 1280 | "version": "4.2.1", 1281 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-4.2.1.tgz", 1282 | "integrity": "sha512-jOSne2qbyE+/r8G1VU+G/82LBs2Fs4LAsTiLSHOCOMZQl2OKZ6i8i4IyHemTe+/yIXOtTcRQMzPcgyhoFlqPkw==", 1283 | "requires": { 1284 | "mimic-response": "^2.0.0" 1285 | } 1286 | }, 1287 | "deep-extend": { 1288 | "version": "0.6.0", 1289 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 1290 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==" 1291 | }, 1292 | "delayed-stream": { 1293 | "version": "1.0.0", 1294 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 1295 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 1296 | }, 1297 | "delegates": { 1298 | "version": "1.0.0", 1299 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 1300 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" 1301 | }, 1302 | "denque": { 1303 | "version": "1.4.1", 1304 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.4.1.tgz", 1305 | "integrity": "sha512-OfzPuSZKGcgr96rf1oODnfjqBFmr1DVoc/TrItj3Ohe0Ah1C5WX5Baquw/9U9KovnQ88EqmJbD66rKYUQYN1tQ==" 1306 | }, 1307 | "detect-libc": { 1308 | "version": "1.0.3", 1309 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz", 1310 | "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=" 1311 | }, 1312 | "discord.js": { 1313 | "version": "12.4.1", 1314 | "resolved": "https://registry.npmjs.org/discord.js/-/discord.js-12.4.1.tgz", 1315 | "integrity": "sha512-KxOB8LOAN3GmrvkD6a6Fr1nlfArIFZ+q7Uqg4T/5duB90GZy9a0/Py2E+Y+eHKP6ZUCR2mbNMLCcHGjahiaNqA==", 1316 | "requires": { 1317 | "@discordjs/collection": "^0.1.6", 1318 | "@discordjs/form-data": "^3.0.1", 1319 | "abort-controller": "^3.0.0", 1320 | "node-fetch": "^2.6.1", 1321 | "prism-media": "^1.2.2", 1322 | "setimmediate": "^1.0.5", 1323 | "tweetnacl": "^1.0.3", 1324 | "ws": "^7.3.1" 1325 | } 1326 | }, 1327 | "event-target-shim": { 1328 | "version": "5.0.1", 1329 | "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz", 1330 | "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==" 1331 | }, 1332 | "follow-redirects": { 1333 | "version": "1.13.0", 1334 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.13.0.tgz", 1335 | "integrity": "sha512-aq6gF1BEKje4a9i9+5jimNFIpq4Q1WiwBToeRK5NvZBd/TRsmW8BsJfOEGkr76TbOyPVD3OVDN910EcUNtRYEA==" 1336 | }, 1337 | "fs": { 1338 | "version": "0.0.1-security", 1339 | "resolved": "https://registry.npmjs.org/fs/-/fs-0.0.1-security.tgz", 1340 | "integrity": "sha1-invTcYa23d84E/I4WLV+yq9eQdQ=" 1341 | }, 1342 | "fs-extra": { 1343 | "version": "8.1.0", 1344 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", 1345 | "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", 1346 | "requires": { 1347 | "graceful-fs": "^4.2.0", 1348 | "jsonfile": "^4.0.0", 1349 | "universalify": "^0.1.0" 1350 | }, 1351 | "dependencies": { 1352 | "jsonfile": { 1353 | "version": "4.0.0", 1354 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 1355 | "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", 1356 | "requires": { 1357 | "graceful-fs": "^4.1.6" 1358 | } 1359 | } 1360 | } 1361 | }, 1362 | "fs-minipass": { 1363 | "version": "1.2.7", 1364 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.7.tgz", 1365 | "integrity": "sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA==", 1366 | "requires": { 1367 | "minipass": "^2.6.0" 1368 | } 1369 | }, 1370 | "fs.realpath": { 1371 | "version": "1.0.0", 1372 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1373 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 1374 | }, 1375 | "gauge": { 1376 | "version": "2.7.4", 1377 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 1378 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 1379 | "requires": { 1380 | "aproba": "^1.0.3", 1381 | "console-control-strings": "^1.0.0", 1382 | "has-unicode": "^2.0.0", 1383 | "object-assign": "^4.1.0", 1384 | "signal-exit": "^3.0.0", 1385 | "string-width": "^1.0.1", 1386 | "strip-ansi": "^3.0.1", 1387 | "wide-align": "^1.1.0" 1388 | } 1389 | }, 1390 | "gifencoder": { 1391 | "version": "2.0.1", 1392 | "resolved": "https://registry.npmjs.org/gifencoder/-/gifencoder-2.0.1.tgz", 1393 | "integrity": "sha512-x19DcyWY10SkshBpokqFOo/HBht9GB75evRYvaLMbez9p+yB/o+kt0fK9AwW59nFiAMs2UUQsjv1lX/hvu9Ong==", 1394 | "requires": { 1395 | "canvas": "^2.2.0" 1396 | } 1397 | }, 1398 | "glob": { 1399 | "version": "7.1.6", 1400 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1401 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1402 | "requires": { 1403 | "fs.realpath": "^1.0.0", 1404 | "inflight": "^1.0.4", 1405 | "inherits": "2", 1406 | "minimatch": "^3.0.4", 1407 | "once": "^1.3.0", 1408 | "path-is-absolute": "^1.0.0" 1409 | } 1410 | }, 1411 | "graceful-fs": { 1412 | "version": "4.2.4", 1413 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 1414 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==" 1415 | }, 1416 | "has-unicode": { 1417 | "version": "2.0.1", 1418 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 1419 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" 1420 | }, 1421 | "iconv-lite": { 1422 | "version": "0.4.24", 1423 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1424 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1425 | "requires": { 1426 | "safer-buffer": ">= 2.1.2 < 3" 1427 | } 1428 | }, 1429 | "ignore-walk": { 1430 | "version": "3.0.3", 1431 | "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.3.tgz", 1432 | "integrity": "sha512-m7o6xuOaT1aqheYHKf8W6J5pYH85ZI9w077erOzLje3JsB1gkafkAhHHY19dqjulgIZHFm32Cp5uNZgcQqdJKw==", 1433 | "requires": { 1434 | "minimatch": "^3.0.4" 1435 | } 1436 | }, 1437 | "inflight": { 1438 | "version": "1.0.6", 1439 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1440 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1441 | "requires": { 1442 | "once": "^1.3.0", 1443 | "wrappy": "1" 1444 | } 1445 | }, 1446 | "inherits": { 1447 | "version": "2.0.4", 1448 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1449 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1450 | }, 1451 | "ini": { 1452 | "version": "1.3.5", 1453 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 1454 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==" 1455 | }, 1456 | "is-fullwidth-code-point": { 1457 | "version": "1.0.0", 1458 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 1459 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 1460 | "requires": { 1461 | "number-is-nan": "^1.0.0" 1462 | } 1463 | }, 1464 | "isarray": { 1465 | "version": "1.0.0", 1466 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1467 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 1468 | }, 1469 | "jsonfile": { 1470 | "version": "5.0.0", 1471 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-5.0.0.tgz", 1472 | "integrity": "sha512-NQRZ5CRo74MhMMC3/3r5g2k4fjodJ/wh8MxjFbCViWKFjxrnudWSY5vomh+23ZaXzAS7J3fBZIR2dV6WbmfM0w==", 1473 | "requires": { 1474 | "graceful-fs": "^4.1.6", 1475 | "universalify": "^0.1.2" 1476 | } 1477 | }, 1478 | "kareem": { 1479 | "version": "2.3.2", 1480 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.2.tgz", 1481 | "integrity": "sha512-STHz9P7X2L4Kwn72fA4rGyqyXdmrMSdxqHx9IXon/FXluXieaFA6KJ2upcHAHxQPQ0LeM/OjLrhFxifHewOALQ==" 1482 | }, 1483 | "memory-pager": { 1484 | "version": "1.5.0", 1485 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1486 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 1487 | "optional": true 1488 | }, 1489 | "mime-db": { 1490 | "version": "1.44.0", 1491 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.44.0.tgz", 1492 | "integrity": "sha512-/NOTfLrsPBVeH7YtFPgsVWveuL+4SjjYxaQ1xtM1KMFj7HdxlBlxeyNLzhyJVx7r4rZGJAZ/6lkKCitSc/Nmpg==" 1493 | }, 1494 | "mime-types": { 1495 | "version": "2.1.27", 1496 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.27.tgz", 1497 | "integrity": "sha512-JIhqnCasI9yD+SsmkquHBxTSEuZdQX5BuQnS2Vc7puQQQ+8yiP5AY5uWhpdv4YL4VM5c6iliiYWPgJ/nJQLp7w==", 1498 | "requires": { 1499 | "mime-db": "1.44.0" 1500 | } 1501 | }, 1502 | "mimic-response": { 1503 | "version": "2.1.0", 1504 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-2.1.0.tgz", 1505 | "integrity": "sha512-wXqjST+SLt7R009ySCglWBCFpjUygmCIfD790/kVbiGmUgfYGuB14PiTd5DwVxSV4NcYHjzMkoj5LjQZwTQLEA==" 1506 | }, 1507 | "minimatch": { 1508 | "version": "3.0.4", 1509 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1510 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1511 | "requires": { 1512 | "brace-expansion": "^1.1.7" 1513 | } 1514 | }, 1515 | "minimist": { 1516 | "version": "1.2.5", 1517 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1518 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 1519 | }, 1520 | "minipass": { 1521 | "version": "2.9.0", 1522 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.9.0.tgz", 1523 | "integrity": "sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg==", 1524 | "requires": { 1525 | "safe-buffer": "^5.1.2", 1526 | "yallist": "^3.0.0" 1527 | } 1528 | }, 1529 | "minizlib": { 1530 | "version": "1.3.3", 1531 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.3.3.tgz", 1532 | "integrity": "sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q==", 1533 | "requires": { 1534 | "minipass": "^2.9.0" 1535 | } 1536 | }, 1537 | "mkdirp": { 1538 | "version": "0.5.5", 1539 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1540 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1541 | "requires": { 1542 | "minimist": "^1.2.5" 1543 | } 1544 | }, 1545 | "moment": { 1546 | "version": "2.29.1", 1547 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz", 1548 | "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ==" 1549 | }, 1550 | "moment-duration-format": { 1551 | "version": "2.3.2", 1552 | "resolved": "https://registry.npmjs.org/moment-duration-format/-/moment-duration-format-2.3.2.tgz", 1553 | "integrity": "sha512-cBMXjSW+fjOb4tyaVHuaVE/A5TqkukDWiOfxxAjY+PEqmmBQlLwn+8OzwPiG3brouXKY5Un4pBjAeB6UToXHaQ==" 1554 | }, 1555 | "mongodb": { 1556 | "version": "3.6.3", 1557 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.6.3.tgz", 1558 | "integrity": "sha512-rOZuR0QkodZiM+UbQE5kDsJykBqWi0CL4Ec2i1nrGrUI3KO11r6Fbxskqmq3JK2NH7aW4dcccBuUujAP0ERl5w==", 1559 | "requires": { 1560 | "bl": "^2.2.1", 1561 | "bson": "^1.1.4", 1562 | "denque": "^1.4.1", 1563 | "require_optional": "^1.0.1", 1564 | "safe-buffer": "^5.1.2", 1565 | "saslprep": "^1.0.0" 1566 | } 1567 | }, 1568 | "mongoose": { 1569 | "version": "5.11.8", 1570 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.11.8.tgz", 1571 | "integrity": "sha512-RRfrYLg7pyuyx7xu5hwadjIZZJB9W2jqIMkL1CkTmk/uOCX3MX2tl4BVIi2rJUtgMNwn6dy3wBD3soB8I9Nlog==", 1572 | "requires": { 1573 | "@types/mongodb": "^3.5.27", 1574 | "bson": "^1.1.4", 1575 | "kareem": "2.3.2", 1576 | "mongodb": "3.6.3", 1577 | "mongoose-legacy-pluralize": "1.0.2", 1578 | "mpath": "0.8.1", 1579 | "mquery": "3.2.3", 1580 | "ms": "2.1.2", 1581 | "regexp-clone": "1.0.0", 1582 | "safe-buffer": "5.2.1", 1583 | "sift": "7.0.1", 1584 | "sliced": "1.0.1" 1585 | }, 1586 | "dependencies": { 1587 | "safe-buffer": { 1588 | "version": "5.2.1", 1589 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1590 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 1591 | } 1592 | } 1593 | }, 1594 | "mongoose-legacy-pluralize": { 1595 | "version": "1.0.2", 1596 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz", 1597 | "integrity": "sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ==" 1598 | }, 1599 | "mpath": { 1600 | "version": "0.8.1", 1601 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.8.1.tgz", 1602 | "integrity": "sha512-norEinle9aFc05McBawVPwqgFZ7npkts9yu17ztIVLwPwO9rq0OTp89kGVTqvv5rNLMz96E5iWHpVORjI411vA==" 1603 | }, 1604 | "mquery": { 1605 | "version": "3.2.3", 1606 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.2.3.tgz", 1607 | "integrity": "sha512-cIfbP4TyMYX+SkaQ2MntD+F2XbqaBHUYWk3j+kqdDztPWok3tgyssOZxMHMtzbV1w9DaSlvEea0Iocuro41A4g==", 1608 | "requires": { 1609 | "bluebird": "3.5.1", 1610 | "debug": "3.1.0", 1611 | "regexp-clone": "^1.0.0", 1612 | "safe-buffer": "5.1.2", 1613 | "sliced": "1.0.1" 1614 | }, 1615 | "dependencies": { 1616 | "debug": { 1617 | "version": "3.1.0", 1618 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1619 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1620 | "requires": { 1621 | "ms": "2.0.0" 1622 | } 1623 | }, 1624 | "ms": { 1625 | "version": "2.0.0", 1626 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1627 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1628 | } 1629 | } 1630 | }, 1631 | "ms": { 1632 | "version": "2.1.2", 1633 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1634 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1635 | }, 1636 | "nan": { 1637 | "version": "2.14.2", 1638 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.2.tgz", 1639 | "integrity": "sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ==" 1640 | }, 1641 | "needle": { 1642 | "version": "2.5.2", 1643 | "resolved": "https://registry.npmjs.org/needle/-/needle-2.5.2.tgz", 1644 | "integrity": "sha512-LbRIwS9BfkPvNwNHlsA41Q29kL2L/6VaOJ0qisM5lLWsTV3nP15abO5ITL6L81zqFhzjRKDAYjpcBcwM0AVvLQ==", 1645 | "requires": { 1646 | "debug": "^3.2.6", 1647 | "iconv-lite": "^0.4.4", 1648 | "sax": "^1.2.4" 1649 | } 1650 | }, 1651 | "node-canvas-with-twemoji-and-discord-emoji": { 1652 | "version": "1.1.6", 1653 | "resolved": "https://registry.npmjs.org/node-canvas-with-twemoji-and-discord-emoji/-/node-canvas-with-twemoji-and-discord-emoji-1.1.6.tgz", 1654 | "integrity": "sha512-tZ5fx0TeMp8d30d2XOKWVIt2Nz9mjFG6Ws3GUoChsJfoTSul82+nKpnbZ7mAqe+jWKdKAoAZzfF6qYMxr5rypA==", 1655 | "requires": { 1656 | "canvas": "^2.6.1", 1657 | "twemoji": "^13.0.1" 1658 | } 1659 | }, 1660 | "node-fetch": { 1661 | "version": "2.6.1", 1662 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.1.tgz", 1663 | "integrity": "sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw==" 1664 | }, 1665 | "node-pre-gyp": { 1666 | "version": "0.11.0", 1667 | "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.11.0.tgz", 1668 | "integrity": "sha512-TwWAOZb0j7e9eGaf9esRx3ZcLaE5tQ2lvYy1pb5IAaG1a2e2Kv5Lms1Y4hpj+ciXJRofIxxlt5haeQ/2ANeE0Q==", 1669 | "requires": { 1670 | "detect-libc": "^1.0.2", 1671 | "mkdirp": "^0.5.1", 1672 | "needle": "^2.2.1", 1673 | "nopt": "^4.0.1", 1674 | "npm-packlist": "^1.1.6", 1675 | "npmlog": "^4.0.2", 1676 | "rc": "^1.2.7", 1677 | "rimraf": "^2.6.1", 1678 | "semver": "^5.3.0", 1679 | "tar": "^4" 1680 | } 1681 | }, 1682 | "nodemailer": { 1683 | "version": "6.4.16", 1684 | "resolved": "https://registry.npmjs.org/nodemailer/-/nodemailer-6.4.16.tgz", 1685 | "integrity": "sha512-68K0LgZ6hmZ7PVmwL78gzNdjpj5viqBdFqKrTtr9bZbJYj6BRj5W6WGkxXrEnUl3Co3CBXi3CZBUlpV/foGnOQ==" 1686 | }, 1687 | "nopt": { 1688 | "version": "4.0.3", 1689 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.3.tgz", 1690 | "integrity": "sha512-CvaGwVMztSMJLOeXPrez7fyfObdZqNUK1cPAEzLHrTybIua9pMdmmPR5YwtfNftIOMv3DPUhFaxsZMNTQO20Kg==", 1691 | "requires": { 1692 | "abbrev": "1", 1693 | "osenv": "^0.1.4" 1694 | } 1695 | }, 1696 | "npm-bundled": { 1697 | "version": "1.1.1", 1698 | "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.1.1.tgz", 1699 | "integrity": "sha512-gqkfgGePhTpAEgUsGEgcq1rqPXA+tv/aVBlgEzfXwA1yiUJF7xtEt3CtVwOjNYQOVknDk0F20w58Fnm3EtG0fA==", 1700 | "requires": { 1701 | "npm-normalize-package-bin": "^1.0.1" 1702 | } 1703 | }, 1704 | "npm-normalize-package-bin": { 1705 | "version": "1.0.1", 1706 | "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-1.0.1.tgz", 1707 | "integrity": "sha512-EPfafl6JL5/rU+ot6P3gRSCpPDW5VmIzX959Ob1+ySFUuuYHWHekXpwdUZcKP5C+DS4GEtdJluwBjnsNDl+fSA==" 1708 | }, 1709 | "npm-packlist": { 1710 | "version": "1.4.8", 1711 | "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.4.8.tgz", 1712 | "integrity": "sha512-5+AZgwru5IevF5ZdnFglB5wNlHG1AOOuw28WhUq8/8emhBmLv6jX5by4WJCh7lW0uSYZYS6DXqIsyZVIXRZU9A==", 1713 | "requires": { 1714 | "ignore-walk": "^3.0.1", 1715 | "npm-bundled": "^1.0.1", 1716 | "npm-normalize-package-bin": "^1.0.1" 1717 | } 1718 | }, 1719 | "npmlog": { 1720 | "version": "4.1.2", 1721 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 1722 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 1723 | "requires": { 1724 | "are-we-there-yet": "~1.1.2", 1725 | "console-control-strings": "~1.1.0", 1726 | "gauge": "~2.7.3", 1727 | "set-blocking": "~2.0.0" 1728 | } 1729 | }, 1730 | "number-is-nan": { 1731 | "version": "1.0.1", 1732 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1733 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 1734 | }, 1735 | "object-assign": { 1736 | "version": "4.1.1", 1737 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1738 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1739 | }, 1740 | "once": { 1741 | "version": "1.4.0", 1742 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1743 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1744 | "requires": { 1745 | "wrappy": "1" 1746 | } 1747 | }, 1748 | "os-homedir": { 1749 | "version": "1.0.2", 1750 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1751 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" 1752 | }, 1753 | "os-tmpdir": { 1754 | "version": "1.0.2", 1755 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1756 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 1757 | }, 1758 | "osenv": { 1759 | "version": "0.1.5", 1760 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", 1761 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", 1762 | "requires": { 1763 | "os-homedir": "^1.0.0", 1764 | "os-tmpdir": "^1.0.0" 1765 | } 1766 | }, 1767 | "path-is-absolute": { 1768 | "version": "1.0.1", 1769 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1770 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1771 | }, 1772 | "prism-media": { 1773 | "version": "1.2.2", 1774 | "resolved": "https://registry.npmjs.org/prism-media/-/prism-media-1.2.2.tgz", 1775 | "integrity": "sha512-I+nkWY212lJ500jLe4tN9tWO7nRiBAVdMv76P9kffZjYhw20raMlW1HSSvS+MLXC9MmbNZCazMrAr+5jEEgTuw==" 1776 | }, 1777 | "process-nextick-args": { 1778 | "version": "2.0.1", 1779 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1780 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 1781 | }, 1782 | "rc": { 1783 | "version": "1.2.8", 1784 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1785 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1786 | "requires": { 1787 | "deep-extend": "^0.6.0", 1788 | "ini": "~1.3.0", 1789 | "minimist": "^1.2.0", 1790 | "strip-json-comments": "~2.0.1" 1791 | } 1792 | }, 1793 | "readable-stream": { 1794 | "version": "2.3.7", 1795 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 1796 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 1797 | "requires": { 1798 | "core-util-is": "~1.0.0", 1799 | "inherits": "~2.0.3", 1800 | "isarray": "~1.0.0", 1801 | "process-nextick-args": "~2.0.0", 1802 | "safe-buffer": "~5.1.1", 1803 | "string_decoder": "~1.1.1", 1804 | "util-deprecate": "~1.0.1" 1805 | } 1806 | }, 1807 | "regexp-clone": { 1808 | "version": "1.0.0", 1809 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-1.0.0.tgz", 1810 | "integrity": "sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw==" 1811 | }, 1812 | "require_optional": { 1813 | "version": "1.0.1", 1814 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 1815 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 1816 | "requires": { 1817 | "resolve-from": "^2.0.0", 1818 | "semver": "^5.1.0" 1819 | } 1820 | }, 1821 | "resolve-from": { 1822 | "version": "2.0.0", 1823 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 1824 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=" 1825 | }, 1826 | "rimraf": { 1827 | "version": "2.7.1", 1828 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1829 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1830 | "requires": { 1831 | "glob": "^7.1.3" 1832 | } 1833 | }, 1834 | "safe-buffer": { 1835 | "version": "5.1.2", 1836 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1837 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1838 | }, 1839 | "safer-buffer": { 1840 | "version": "2.1.2", 1841 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1842 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1843 | }, 1844 | "saslprep": { 1845 | "version": "1.0.3", 1846 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 1847 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 1848 | "optional": true, 1849 | "requires": { 1850 | "sparse-bitfield": "^3.0.3" 1851 | } 1852 | }, 1853 | "sax": { 1854 | "version": "1.2.4", 1855 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 1856 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" 1857 | }, 1858 | "semver": { 1859 | "version": "5.7.1", 1860 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1861 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 1862 | }, 1863 | "set-blocking": { 1864 | "version": "2.0.0", 1865 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1866 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 1867 | }, 1868 | "setimmediate": { 1869 | "version": "1.0.5", 1870 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", 1871 | "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=" 1872 | }, 1873 | "sift": { 1874 | "version": "7.0.1", 1875 | "resolved": "https://registry.npmjs.org/sift/-/sift-7.0.1.tgz", 1876 | "integrity": "sha512-oqD7PMJ+uO6jV9EQCl0LrRw1OwsiPsiFQR5AR30heR+4Dl7jBBbDLnNvWiak20tzZlSE1H7RB30SX/1j/YYT7g==" 1877 | }, 1878 | "signal-exit": { 1879 | "version": "3.0.3", 1880 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 1881 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==" 1882 | }, 1883 | "simple-concat": { 1884 | "version": "1.0.1", 1885 | "resolved": "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.1.tgz", 1886 | "integrity": "sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q==" 1887 | }, 1888 | "simple-get": { 1889 | "version": "3.1.0", 1890 | "resolved": "https://registry.npmjs.org/simple-get/-/simple-get-3.1.0.tgz", 1891 | "integrity": "sha512-bCR6cP+aTdScaQCnQKbPKtJOKDp/hj9EDLJo3Nw4y1QksqaovlW/bnptB6/c1e+qmNIDHRK+oXFDdEqBT8WzUA==", 1892 | "requires": { 1893 | "decompress-response": "^4.2.0", 1894 | "once": "^1.3.1", 1895 | "simple-concat": "^1.0.0" 1896 | } 1897 | }, 1898 | "sliced": { 1899 | "version": "1.0.1", 1900 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", 1901 | "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E=" 1902 | }, 1903 | "sparse-bitfield": { 1904 | "version": "3.0.3", 1905 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 1906 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 1907 | "optional": true, 1908 | "requires": { 1909 | "memory-pager": "^1.0.2" 1910 | } 1911 | }, 1912 | "string_decoder": { 1913 | "version": "1.1.1", 1914 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1915 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1916 | "requires": { 1917 | "safe-buffer": "~5.1.0" 1918 | } 1919 | }, 1920 | "string-width": { 1921 | "version": "1.0.2", 1922 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 1923 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 1924 | "requires": { 1925 | "code-point-at": "^1.0.0", 1926 | "is-fullwidth-code-point": "^1.0.0", 1927 | "strip-ansi": "^3.0.0" 1928 | } 1929 | }, 1930 | "strip-ansi": { 1931 | "version": "3.0.1", 1932 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 1933 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 1934 | "requires": { 1935 | "ansi-regex": "^2.0.0" 1936 | } 1937 | }, 1938 | "strip-json-comments": { 1939 | "version": "2.0.1", 1940 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1941 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 1942 | }, 1943 | "tar": { 1944 | "version": "4.4.13", 1945 | "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.13.tgz", 1946 | "integrity": "sha512-w2VwSrBoHa5BsSyH+KxEqeQBAllHhccyMFVHtGtdMpF4W7IRWfZjFiQceJPChOeTsSDVUpER2T8FA93pr0L+QA==", 1947 | "requires": { 1948 | "chownr": "^1.1.1", 1949 | "fs-minipass": "^1.2.5", 1950 | "minipass": "^2.8.6", 1951 | "minizlib": "^1.2.1", 1952 | "mkdirp": "^0.5.0", 1953 | "safe-buffer": "^5.1.2", 1954 | "yallist": "^3.0.3" 1955 | } 1956 | }, 1957 | "tweetnacl": { 1958 | "version": "1.0.3", 1959 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-1.0.3.tgz", 1960 | "integrity": "sha512-6rt+RN7aOi1nGMyC4Xa5DdYiukl2UWCbcJft7YhxReBGQD7OAM8Pbxw6YMo4r2diNEA8FEmu32YOn9rhaiE5yw==" 1961 | }, 1962 | "twemoji": { 1963 | "version": "13.0.1", 1964 | "resolved": "https://registry.npmjs.org/twemoji/-/twemoji-13.0.1.tgz", 1965 | "integrity": "sha512-mrTBq+XpCLM4zm76NJOjLHoQNV9mHdBt3Cba/T5lS1rxn8ArwpqE47mqTocupNlkvcLxoeZJjYSUW0DU5ZwqZg==", 1966 | "requires": { 1967 | "fs-extra": "^8.0.1", 1968 | "jsonfile": "^5.0.0", 1969 | "twemoji-parser": "13.0.0", 1970 | "universalify": "^0.1.2" 1971 | } 1972 | }, 1973 | "twemoji-parser": { 1974 | "version": "13.0.0", 1975 | "resolved": "https://registry.npmjs.org/twemoji-parser/-/twemoji-parser-13.0.0.tgz", 1976 | "integrity": "sha512-zMaGdskpH8yKjT2RSE/HwE340R4Fm+fbie4AaqjDa4H/l07YUmAvxkSfNl6awVWNRRQ0zdzLQ8SAJZuY5MgstQ==" 1977 | }, 1978 | "universalify": { 1979 | "version": "0.1.2", 1980 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 1981 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==" 1982 | }, 1983 | "util-deprecate": { 1984 | "version": "1.0.2", 1985 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1986 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1987 | }, 1988 | "wide-align": { 1989 | "version": "1.1.3", 1990 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1991 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1992 | "requires": { 1993 | "string-width": "^1.0.2 || 2" 1994 | } 1995 | }, 1996 | "wrappy": { 1997 | "version": "1.0.2", 1998 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1999 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 2000 | }, 2001 | "ws": { 2002 | "version": "7.3.1", 2003 | "resolved": "https://registry.npmjs.org/ws/-/ws-7.3.1.tgz", 2004 | "integrity": "sha512-D3RuNkynyHmEJIpD2qrgVkc9DQ23OrN/moAwZX4L8DfvszsJxpjQuUq3LMx6HoYji9fbIOBY18XWBsAux1ZZUA==" 2005 | }, 2006 | "yallist": { 2007 | "version": "3.1.1", 2008 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 2009 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" 2010 | } 2011 | } 2012 | } 2013 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "fnr-assaist", 3 | "version": "1.0.0", 4 | "description": "Bot for developing", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "axios": "^0.21.0", 13 | "canvacord": "^5.0.8", 14 | "discord.js": "^12.4.1", 15 | "fs": "0.0.1-security", 16 | "mongoose": "^5.11.8", 17 | "ms": "^2.1.2", 18 | "nodemailer": "^6.4.16" 19 | } 20 | } 21 | --------------------------------------------------------------------------------