├── .dockerignore ├── .env.docker.example ├── .env.example ├── .github ├── ISSUE_TEMPLATE │ ├── bug_report.md │ └── feature_request.md └── workflows │ └── deploy.yml ├── .gitignore ├── CODE_OF_CONDUCT.md ├── CONTRIBUTING.md ├── Dockerfile ├── LICENSE ├── Procfile ├── README.md ├── commands ├── add.js ├── done-list.js ├── done.js ├── help.js ├── list.js ├── ping.js └── undo.js ├── config └── sequelize.js ├── deploy-commands.js ├── docker-compose.yml ├── index.js ├── models └── Task.js ├── package-lock.json ├── package.json └── yarn.lock /.dockerignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | Dockerfile 3 | .git 4 | .env 5 | .env.example 6 | -------------------------------------------------------------------------------- /.env.docker.example: -------------------------------------------------------------------------------- 1 | DISCORD_TOKEN= 2 | DB= 3 | DB_USERNAME= 4 | DB_PASSWORD= 5 | MYSQL_LOCAL_PORT=3306 6 | MYSQL_DOCKER_PORT=3306 7 | -------------------------------------------------------------------------------- /.env.example: -------------------------------------------------------------------------------- 1 | DISCORD_TOKEN= 2 | -------------------------------------------------------------------------------- /.github/ISSUE_TEMPLATE/bug_report.md: -------------------------------------------------------------------------------- 1 | --- 2 | name: Bug report 3 | about: Create a report to help us improve 4 | title: "" 5 | labels: "" 6 | assignees: "" 7 | --- 8 | 9 | **Describe the bug** 10 | A clear and concise description of what the bug is. 11 | 12 | **To Reproduce** 13 | Steps to reproduce the behavior: 14 | 15 | 1. Go to '...' 16 | 2. Click on '....' 17 | 3. Scroll down to '....' 18 | 4. See error 19 | 20 | **Expected behavior** 21 | A clear and concise description of what you expected to happen. 22 | 23 | **Screenshots** 24 | If applicable, add screenshots to help explain your problem. 25 | 26 | **Desktop (please complete the following information):** 27 | 28 | - OS: [e.g. iOS] 29 | - Browser [e.g. chrome, safari] 30 | - Version [e.g. 22] 31 | 32 | **Smartphone (please complete the following information):** 33 | 34 | - Device: [e.g. iPhone6] 35 | - OS: [e.g. iOS8.1] 36 | - Browser [e.g. stock browser, safari] 37 | - Version [e.g. 22] 38 | 39 | **Additional context** 40 | Add any other context about the problem here. 41 | -------------------------------------------------------------------------------- /.github/ISSUE_TEMPLATE/feature_request.md: -------------------------------------------------------------------------------- 1 | --- 2 | name: Feature request 3 | about: Suggest an idea for this project 4 | title: "" 5 | labels: "" 6 | assignees: "" 7 | --- 8 | 9 | **Is your feature request related to a problem? Please describe.** 10 | A clear and concise description of what the problem is. Ex. I'm always frustrated when [...] 11 | 12 | **Describe the solution you'd like** 13 | A clear and concise description of what you want to happen. 14 | 15 | **Describe alternatives you've considered** 16 | A clear and concise description of any alternative solutions or features you've considered. 17 | 18 | **Additional context** 19 | Add any other context or screenshots about the feature request here. 20 | -------------------------------------------------------------------------------- /.github/workflows/deploy.yml: -------------------------------------------------------------------------------- 1 | name: GCP Deploy 2 | 3 | on: 4 | push: 5 | branches: 6 | - master 7 | 8 | jobs: 9 | build: 10 | runs-on: ubuntu-latest 11 | 12 | steps: 13 | - uses: actions/checkout@v2 14 | - name: CD and Pull from Github 15 | uses: fifsky/ssh-action@master 16 | with: 17 | command: | 18 | cd ~/code/discord-task-bot 19 | git pull origin master 20 | pm2 restart dtb 21 | host: ${{ secrets.HOST }} 22 | port: ${{ secrets.PORT }} 23 | user: root 24 | pass: ${{ secrets.HOST_PASSWORD }} 25 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .env 2 | node_modules/ 3 | db 4 | -------------------------------------------------------------------------------- /CODE_OF_CONDUCT.md: -------------------------------------------------------------------------------- 1 | # Contributor Covenant Code of Conduct 2 | 3 | ## Our Pledge 4 | 5 | We as members, contributors, and leaders pledge to make participation in our 6 | community a harassment-free experience for everyone, regardless of age, body 7 | size, visible or invisible disability, ethnicity, sex characteristics, gender 8 | identity and expression, level of experience, education, socio-economic status, 9 | nationality, personal appearance, race, religion, or sexual identity 10 | and orientation. 11 | 12 | We pledge to act and interact in ways that contribute to an open, welcoming, 13 | diverse, inclusive, and healthy community. 14 | 15 | ## Our Standards 16 | 17 | Examples of behavior that contributes to a positive environment for our 18 | community include: 19 | 20 | - Demonstrating empathy and kindness toward other people 21 | - Being respectful of differing opinions, viewpoints, and experiences 22 | - Giving and gracefully accepting constructive feedback 23 | - Accepting responsibility and apologizing to those affected by our mistakes, 24 | and learning from the experience 25 | - Focusing on what is best not just for us as individuals, but for the 26 | overall community 27 | 28 | Examples of unacceptable behavior include: 29 | 30 | - The use of sexualized language or imagery, and sexual attention or 31 | advances of any kind 32 | - Trolling, insulting or derogatory comments, and personal or political attacks 33 | - Public or private harassment 34 | - Publishing others' private information, such as a physical or email 35 | address, without their explicit permission 36 | - Other conduct which could reasonably be considered inappropriate in a 37 | professional setting 38 | 39 | ## Enforcement Responsibilities 40 | 41 | Community leaders are responsible for clarifying and enforcing our standards of 42 | acceptable behavior and will take appropriate and fair corrective action in 43 | response to any behavior that they deem inappropriate, threatening, offensive, 44 | or harmful. 45 | 46 | Community leaders have the right and responsibility to remove, edit, or reject 47 | comments, commits, code, wiki edits, issues, and other contributions that are 48 | not aligned to this Code of Conduct, and will communicate reasons for moderation 49 | decisions when appropriate. 50 | 51 | ## Scope 52 | 53 | This Code of Conduct applies within all community spaces, and also applies when 54 | an individual is officially representing the community in public spaces. 55 | Examples of representing our community include using an official e-mail address, 56 | posting via an official social media account, or acting as an appointed 57 | representative at an online or offline event. 58 | 59 | ## Enforcement 60 | 61 | Instances of abusive, harassing, or otherwise unacceptable behavior may be 62 | reported to the community leaders responsible for enforcement at 63 | mail@kavin.me. 64 | All complaints will be reviewed and investigated promptly and fairly. 65 | 66 | All community leaders are obligated to respect the privacy and security of the 67 | reporter of any incident. 68 | 69 | ## Enforcement Guidelines 70 | 71 | Community leaders will follow these Community Impact Guidelines in determining 72 | the consequences for any action they deem in violation of this Code of Conduct: 73 | 74 | ### 1. Correction 75 | 76 | **Community Impact**: Use of inappropriate language or other behavior deemed 77 | unprofessional or unwelcome in the community. 78 | 79 | **Consequence**: A private, written warning from community leaders, providing 80 | clarity around the nature of the violation and an explanation of why the 81 | behavior was inappropriate. A public apology may be requested. 82 | 83 | ### 2. Warning 84 | 85 | **Community Impact**: A violation through a single incident or series 86 | of actions. 87 | 88 | **Consequence**: A warning with consequences for continued behavior. No 89 | interaction with the people involved, including unsolicited interaction with 90 | those enforcing the Code of Conduct, for a specified period of time. This 91 | includes avoiding interactions in community spaces as well as external channels 92 | like social media. Violating these terms may lead to a temporary or 93 | permanent ban. 94 | 95 | ### 3. Temporary Ban 96 | 97 | **Community Impact**: A serious violation of community standards, including 98 | sustained inappropriate behavior. 99 | 100 | **Consequence**: A temporary ban from any sort of interaction or public 101 | communication with the community for a specified period of time. No public or 102 | private interaction with the people involved, including unsolicited interaction 103 | with those enforcing the Code of Conduct, is allowed during this period. 104 | Violating these terms may lead to a permanent ban. 105 | 106 | ### 4. Permanent Ban 107 | 108 | **Community Impact**: Demonstrating a pattern of violation of community 109 | standards, including sustained inappropriate behavior, harassment of an 110 | individual, or aggression toward or disparagement of classes of individuals. 111 | 112 | **Consequence**: A permanent ban from any sort of public interaction within 113 | the community. 114 | 115 | ## Attribution 116 | 117 | This Code of Conduct is adapted from the [Contributor Covenant][homepage], 118 | version 2.0, available at 119 | https://www.contributor-covenant.org/version/2/0/code_of_conduct.html. 120 | 121 | Community Impact Guidelines were inspired by [Mozilla's code of conduct 122 | enforcement ladder](https://github.com/mozilla/diversity). 123 | 124 | [homepage]: https://www.contributor-covenant.org 125 | 126 | For answers to common questions about this code of conduct, see the FAQ at 127 | https://www.contributor-covenant.org/faq. Translations are available at 128 | https://www.contributor-covenant.org/translations. 129 | -------------------------------------------------------------------------------- /CONTRIBUTING.md: -------------------------------------------------------------------------------- 1 | # How to contribute 2 | 3 | First of all, thanks for taking the time out to contribute! 4 | Make sure to follow the CODE_OF_CONDUCT.md 5 | 6 | ## Testing 7 | 8 | There's no testing in place at the moment. A pull request for the same will be very much appreciated. 9 | 10 | ## How to report a bug or a new feature? 11 | 12 | If you find a bug, or if you're looking for a new feature, create a new `Issue` with proper description. 13 | 14 | ## Beginner? 15 | 16 | Check the Issues labelled as `good-first-issue`. 17 | 18 | ## How to submit changes? 19 | 20 | Create Pull Requests only for existing Issues (which are assigned to you). If you want to be assigned to an issue, comment on the issue 21 | 22 | ### Create a branch 23 | 24 | 1. `git checkout master` from any folder in your local discord-task-bot repository 25 | 2. `git pull origin master` to ensure you have the latest main code 26 | 3. `git checkout -b the-name-of-my-branch` (replacing the-name-of-my-branch with a suitable name) to create a branch 27 | 28 | ### Make the change 29 | 30 | 1. Follow the [Setup](README.md#setup) instructions in the README 31 | 2. Save the files and check in the browser 32 | 3. Test the change (not implemented at the moment) 33 | 34 | ### Push it 35 | 36 | 1. git add -A && git commit -m "My message" (replacing My message with a commit message, such as Fix header logo on Android) to stage and commit your changes 37 | > Note: Have a look at [Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0/) for good commit messages 38 | 2. git push my-fork-name the-name-of-my-branch 39 | 3. Go to the [discord-task-bot](https://kavin25/discord-task-bot) repo and you should see recently pushed branches. 40 | 4. Follow GitHub's instructions. 41 | 5. If possible, include screenshots. 42 | -------------------------------------------------------------------------------- /Dockerfile: -------------------------------------------------------------------------------- 1 | FROM node:16 2 | 3 | RUN apt-get update || : && apt-get install python -y 4 | WORKDIR /app 5 | 6 | COPY package.json . 7 | 8 | RUN npm install 9 | 10 | COPY . . 11 | 12 | CMD npm run server 13 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2021 Kavin Desi Valli 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /Procfile: -------------------------------------------------------------------------------- 1 | worker: node index.js -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Discord Task Manager Bot 2 | 3 | ## Usage 4 | 5 | To use directly, click on this [link](https://discord.com/api/oauth2/authorize?client_id=829723733966979142&permissions=268463184&scope=bot) 6 | 7 | ## How to use? 8 | 9 | Just add, assign(if needed) and mark as done(tick off) 10 | 11 | 1. /add - Add a new task (Mention someone to assign to them) 12 | 2. /list - List all tasks(not done) 13 | 3. /done - Mark a task as done 14 | 4. /done-list - List all tasks(done) 15 | 5. /undo - Unmark a task as done 16 | 17 | ## Setup 18 | 19 | ### With Docker 20 | > Note: This might be outdated and might not work anymore 21 | 1. Clone 22 | 23 | ```sh 24 | git clone git@github.com:Task-Manager-Bot/discord-task-bot.git 25 | ``` 26 | 27 | 2. Install Dependencies 28 | 29 | ```sh 30 | npm install 31 | yarn 32 | ``` 33 | 34 | 3. Fill .env with Discord Bot Token (Developer Portal) 35 | 36 | ```sh 37 | cp .env.docker.example .env 38 | ``` 39 | 40 | 4. Run docker compose 41 | 42 | ```sh 43 | docker-compose up 44 | ``` 45 | 46 | ### Without Docker 47 | 48 | 1. Clone 49 | 50 | ```sh 51 | git clone git@github.com:Task-Manager-Bot/discord-task-bot.git 52 | ``` 53 | 54 | 2. Install Dependencies 55 | 56 | ```sh 57 | npm install 58 | yarn 59 | ``` 60 | 61 | 3. Fill .env with Discord Bot Token (Developer Portal) 62 | 63 | ```sh 64 | cp .env.example .env 65 | ``` 66 | 67 | 4. Change DB host in `db` to `localhost` in `config/sequelize.js` 68 | 69 | 5. Run locally (using nodemon) 70 | 71 | ```sh 72 | npm run dev 73 | yarn dev 74 | ``` 75 | 76 | ## Contributing 77 | 78 | Read the [CONTRIBUTING.md](CONTRIBUTING.md) file 79 | 80 | ## Contributers 81 | [![image of contributors generated by https://contributors-img.web.app/ pulling from https://github.com/Task-Manager-Bot/discord-task-bot/graphs/contributors](https://contributors-img.web.app/image?repo=Task-Manager-Bot/discord-task-bot)](https://github.com/Task-Manager-Bot/discord-task-bot/graphs/contributors) 82 | -------------------------------------------------------------------------------- /commands/add.js: -------------------------------------------------------------------------------- 1 | const Task = require("../models/Task"); 2 | const { SlashCommandBuilder } = require("discord.js"); 3 | 4 | module.exports = { 5 | data: new SlashCommandBuilder() 6 | .setName("add") 7 | .setDescription("Add New Task") 8 | .addStringOption((option) => 9 | option 10 | .setName("text") 11 | .setDescription("The text describing the task") 12 | .setRequired(true) 13 | ) 14 | .addMentionableOption((option) => 15 | option 16 | .setName("assign") 17 | .setDescription("Mention to assign the task to someone.") 18 | ), 19 | async execute(interactions) { 20 | try { 21 | const text = interactions.options.getString("text"); 22 | const taggedUser = interactions.options.getMentionable("assign"); 23 | console.log(taggedUser); 24 | let taggedUserId = ""; 25 | if (taggedUser) { 26 | taggedUserId = taggedUser.id; 27 | } 28 | 29 | const serverId = interactions.guild.id; 30 | 31 | await interactions.reply("Creating task..."); 32 | const newTask = await Task.create({ 33 | text, 34 | serverId, 35 | assignTo: taggedUserId, 36 | }); 37 | 38 | await interactions.followUp(`task ${newTask.text} was added`); 39 | } catch (error) { 40 | console.error(error.toString()); 41 | await interactions.reply(`Something went wrong`); 42 | } 43 | }, 44 | }; 45 | -------------------------------------------------------------------------------- /commands/done-list.js: -------------------------------------------------------------------------------- 1 | const Task = require("../models/Task"); 2 | const { SlashCommandBuilder } = require("discord.js"); 3 | 4 | module.exports = { 5 | data: new SlashCommandBuilder() 6 | .setName("done-list") 7 | .setDescription("List of all the completed tasks"), 8 | async execute(interactions) { 9 | const tasks = await Task.findAll({ 10 | where: { 11 | archive: false, 12 | isDone: true, 13 | serverId: interactions.guild.id, 14 | }, 15 | attributes: ["id", "text", "assignTo"], 16 | }); 17 | console.log(tasks); 18 | // return console.log(tasks); 19 | let messageContent = tasks 20 | .map((task, idx) => { 21 | if (task.assignTo) { 22 | return `${idx + 1}. ${task.text} - <@${task.assignTo}> - ${ 23 | task.id 24 | }\n`; 25 | } else { 26 | return `${idx + 1}. ${task.text} - ${task.id}\n`; 27 | } 28 | }) 29 | .join(""); 30 | 31 | await interactions.reply( 32 | messageContent + 33 | "\n To Add a task back, send `/undo 1`. Replace 1 with the ID(last digit)" 34 | ); 35 | }, 36 | }; 37 | -------------------------------------------------------------------------------- /commands/done.js: -------------------------------------------------------------------------------- 1 | const Task = require("../models/Task"); 2 | const { SlashCommandBuilder } = require("discord.js"); 3 | 4 | module.exports = { 5 | data: new SlashCommandBuilder() 6 | .setName("done") 7 | .setDescription("Done") 8 | .addIntegerOption((option) => 9 | option 10 | .setName("taskid") 11 | .setDescription("ID of the task you want to tick off") 12 | .setRequired(true) 13 | ), 14 | async execute(interactions) { 15 | const id = interactions.options.getInteger("taskid"); 16 | 17 | await interactions.reply("Checking..."); 18 | const task = await Task.findByPk(id); 19 | 20 | if (!task) { 21 | await interactions.followUp("Task does not exist."); 22 | } 23 | 24 | if (task.serverId === interactions.guild.id) { 25 | await Task.update( 26 | { isDone: true }, 27 | { 28 | where: { 29 | id, 30 | }, 31 | } 32 | ); 33 | } else { 34 | await interactions.followUp( 35 | "You can only tick off a task from the current server" 36 | ); 37 | } 38 | 39 | await interactions.followUp( 40 | `Task with id ${id} has been ticked off from your todo list` 41 | ); 42 | }, 43 | }; 44 | -------------------------------------------------------------------------------- /commands/help.js: -------------------------------------------------------------------------------- 1 | const { SlashCommandBuilder, EmbedBuilder } = require("discord.js"); 2 | const fs = require("node:fs"); 3 | const path = require("node:path"); 4 | 5 | module.exports = { 6 | data: new SlashCommandBuilder() 7 | .setName("help") 8 | .addStringOption((option) => 9 | option 10 | .setName("command") 11 | .addChoices( 12 | { 13 | name: "list", 14 | value: "list", 15 | }, 16 | { 17 | name: "done-list", 18 | value: "done-list", 19 | }, 20 | { 21 | name: "add", 22 | value: "add", 23 | }, 24 | { 25 | name: "mention", 26 | value: "mention", 27 | }, 28 | { 29 | name: "done", 30 | value: "done", 31 | }, 32 | { 33 | name: "undo", 34 | value: "undo", 35 | } 36 | ) 37 | .setDescription("The command for which you need the help menu") 38 | ) 39 | .setDescription("List all commands"), 40 | async execute(interactions) { 41 | const commandString = interactions.options.getString("command"); 42 | let command; 43 | const commandsPath = path.join(__dirname, "../commands"); 44 | const commandsFiles = fs 45 | .readdirSync(commandsPath) 46 | .filter((file) => file.endsWith(".js")); 47 | 48 | for (const file of commandsFiles) { 49 | const filePath = path.join(commandsPath, file); 50 | const fileCommand = require(filePath); 51 | if (fileCommand.data.name === commandString) { 52 | command = fileCommand.data; 53 | } 54 | } 55 | 56 | const replyEmbed = new EmbedBuilder() 57 | .setTitle( 58 | "Task Manager Bot's Help Page" + 59 | (commandString ? ` for ${commandString} command` : "") 60 | ) 61 | .setDescription( 62 | "Task Manager is a very simple and easy to use task manager for your server. In order to use the Task Manager Bot, type `/` and checkout the slash commands." 63 | ) 64 | .addFields( 65 | commandString 66 | ? [ 67 | { 68 | name: "Task Name", 69 | value: commandString, 70 | inline: true, 71 | }, 72 | { 73 | name: "Description", 74 | value: command.description, 75 | inline: true, 76 | }, 77 | { 78 | name: "Options", 79 | value: 80 | command.options.length > 0 81 | ? command.options 82 | .map( 83 | (option) => 84 | `**${option.name}** - ${option.description} (${ 85 | option.required ? "Required" : "Optional" 86 | })` 87 | ) 88 | .join("\n") 89 | : "No Options", 90 | }, 91 | ] 92 | : [ 93 | { 94 | name: "🔎 List", 95 | value: "`/list` `/done-list`", 96 | inline: true, 97 | }, 98 | { 99 | name: "📝 Create and Assign", 100 | value: "`/add` `/mention`", 101 | inline: true, 102 | }, 103 | { 104 | name: "✅ Mark Tasks", 105 | value: "`/done` `/undo`", 106 | inline: true, 107 | }, 108 | ] 109 | ) 110 | .addFields([ 111 | { 112 | name: "Links", 113 | value: 114 | "[Invite Me](https://discord.com/api/oauth2/authorize?client_id=829723733966979142&permissions=268462160&scope=bot) - [Visit](https://task-manager-bot.github.io/) - [Vote for Us!](https://top.gg/bot/829723733966979142)", 115 | }, 116 | ]) 117 | .addFields([ 118 | { 119 | name: "\u200B", 120 | value: commandString 121 | ? "To view other commands, type `/help`" 122 | : "For detailed info into a specific command, type `/help commandname`", 123 | }, 124 | ]) 125 | .setThumbnail("https://task-manager-bot.github.io/img/Logo.png") 126 | .setURL("https://task-manager-bot.github.io/"); 127 | 128 | await interactions.reply({ embeds: [replyEmbed] }); 129 | }, 130 | }; 131 | -------------------------------------------------------------------------------- /commands/list.js: -------------------------------------------------------------------------------- 1 | const Task = require("../models/Task"); 2 | const { SlashCommandBuilder } = require("discord.js"); 3 | 4 | module.exports = { 5 | data: new SlashCommandBuilder() 6 | .setName("list") 7 | .setDescription("List of the current tasks"), 8 | async execute(interactions) { 9 | const tasks = await Task.findAll({ 10 | where: { 11 | archive: false, 12 | isDone: false, 13 | serverId: interactions.guild.id, 14 | }, 15 | attributes: ["id", "text", "assignTo"], 16 | }); 17 | 18 | let messageContent = tasks 19 | .map((task, idx) => { 20 | if (task.assignTo) { 21 | return `${idx + 1}. ${task.text} - <@${task.assignTo}> - ${ 22 | task.id 23 | }\n`; 24 | } else { 25 | return `${idx + 1}. ${task.text} - ${task.id}\n`; 26 | } 27 | }) 28 | .join(""); 29 | 30 | await interactions.reply( 31 | messageContent + 32 | "\n To tick off a task, send `/done 1`. Replace 1 with the ID(last digit)" + 33 | "\n To view tasks done, send `/done-list`" 34 | ); 35 | }, 36 | }; 37 | -------------------------------------------------------------------------------- /commands/ping.js: -------------------------------------------------------------------------------- 1 | const { SlashCommandBuilder } = require("discord.js"); 2 | 3 | module.exports = { 4 | data: new SlashCommandBuilder() 5 | .setName("ping") 6 | .setDescription("Replies with Pong!"), 7 | async execute(interaction) { 8 | await interaction.reply("Pong!"); 9 | }, 10 | }; 11 | -------------------------------------------------------------------------------- /commands/undo.js: -------------------------------------------------------------------------------- 1 | const Task = require("../models/Task"); 2 | const { SlashCommandBuilder } = require("discord.js"); 3 | 4 | module.exports = { 5 | data: new SlashCommandBuilder() 6 | .setName("undo") 7 | .setDescription("Undo a done command") 8 | .addIntegerOption((option) => 9 | option 10 | .setName("taskid") 11 | .setDescription("ID of the task you want to undo") 12 | .setRequired(true) 13 | ), 14 | async execute(interactions) { 15 | const id = interactions.options.getInteger("taskid"); 16 | 17 | await interactions.reply("Checking..."); 18 | const task = await Task.findByPk(id); 19 | 20 | if (task.serverId === interactions.guild.id) { 21 | await Task.update( 22 | { isDone: false }, 23 | { 24 | where: { 25 | id, 26 | }, 27 | } 28 | ); 29 | } else { 30 | await interactions.followUp( 31 | "You can only tick off a task from the current server" 32 | ); 33 | } 34 | 35 | await interactions.followUp( 36 | `Task with id ${id} has been added back to your todo list` 37 | ); 38 | }, 39 | }; 40 | -------------------------------------------------------------------------------- /config/sequelize.js: -------------------------------------------------------------------------------- 1 | const Sequelize = require("sequelize"); 2 | 3 | const sequelize = new Sequelize( 4 | process.env.DB, 5 | process.env.DB_USERNAME, 6 | process.env.DB_PASSWORD, 7 | { 8 | host: "db", 9 | port: process.env.MYSQL_DOCKER_PORT, 10 | dialect: "mysql", 11 | } 12 | ); 13 | 14 | module.exports = sequelize; 15 | -------------------------------------------------------------------------------- /deploy-commands.js: -------------------------------------------------------------------------------- 1 | require("dotenv").config(); 2 | const { SlashCommandBuilder, Routes } = require("discord.js"); 3 | const { REST } = require("@discordjs/rest"); 4 | const fs = require("node:fs"); 5 | const path = require("node:path"); 6 | 7 | const commands = []; 8 | const commandsPath = path.join(__dirname, "commands"); 9 | const commandsFiles = fs 10 | .readdirSync(commandsPath) 11 | .filter((file) => file.endsWith(".js")); 12 | 13 | for (const file of commandsFiles) { 14 | const filePath = path.join(commandsPath, file); 15 | const command = require(filePath); 16 | commands.push(command.data.toJSON()); 17 | } 18 | 19 | const rest = new REST({ version: "10" }).setToken(process.env.DISCORD_TOKEN); 20 | 21 | rest 22 | .put(Routes.applicationCommands(process.env.DISCORD_CLIENT_ID), { 23 | body: commands, 24 | }) 25 | .then((data) => 26 | console.log(`Successfully registered ${data.length} application commands.`) 27 | ) 28 | .catch(console.error); 29 | 30 | // rest 31 | // .put( 32 | // Routes.applicationGuildCommands( 33 | // process.env.DISCORD_CLIENT_ID, 34 | // "829566886206373908" 35 | // ), 36 | // { body: [] } 37 | // ) 38 | // .then(() => console.log("Successfully deleted all guild commands.")) 39 | // .catch(console.error); 40 | -------------------------------------------------------------------------------- /docker-compose.yml: -------------------------------------------------------------------------------- 1 | version: '3' 2 | services: 3 | db: 4 | platform: 'linux/x86_64' 5 | image: mysql 6 | restart: always 7 | cap_add: 8 | - SYS_NICE 9 | env_file: ./.env 10 | environment: 11 | MYSQL_ROOT_PASSWORD: $DB_PASSWORD 12 | MYSQL_DATABASE: $DB 13 | MYSQL_USER: $DB_USERNAME 14 | ports: 15 | - $MYSQL_LOCAL_PORT:$MYSQL_DOCKER_PORT 16 | volumes: 17 | - db-config:/etc/mysql 18 | - db-data:/var/lib/mysql 19 | - ./db/backup/files/:/data_backup/data 20 | bot: 21 | build: 22 | context: . 23 | dockerfile: ./Dockerfile 24 | image: task-manager-bot 25 | env_file: ./.env 26 | ports: 27 | - "3000:3000" 28 | depends_on: 29 | - db 30 | links: 31 | - db 32 | stdin_open: true 33 | tty: true 34 | volumes: 35 | - ./:/app/src/. 36 | 37 | volumes: 38 | db-config: 39 | db-data: 40 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | require("dotenv").config(); 2 | const { ActivityType } = require("discord.js"); 3 | const Discord = require("discord.js"); 4 | const fs = require("node:fs"); 5 | const path = require("node:path"); 6 | 7 | const client = new Discord.Client({ 8 | intents: [Discord.GatewayIntentBits.Guilds], 9 | }); 10 | 11 | client.commands = new Discord.Collection(); 12 | 13 | const commandsPath = path.join(__dirname, "commands"); 14 | const commandsFiles = fs 15 | .readdirSync(commandsPath) 16 | .filter((file) => file.endsWith(".js")); 17 | 18 | for (const file of commandsFiles) { 19 | const filePath = path.join(commandsPath, file); 20 | const command = require(filePath); 21 | 22 | client.commands.set(command.data.name, command); 23 | } 24 | 25 | client.once("ready", () => { 26 | client.user.setActivity("/help | task-manager-bot.github.io", { 27 | type: ActivityType.Playing, 28 | }); 29 | console.log("Bot is ready!"); 30 | }); 31 | 32 | client.on("interactionCreate", async (interaction) => { 33 | if (!interaction.isChatInputCommand()) return; 34 | 35 | const command = interaction.client.commands.get(interaction.commandName); 36 | 37 | if (!command) return; 38 | 39 | try { 40 | await command.execute(interaction); 41 | } catch (error) { 42 | console.error(error); 43 | await interaction.reply({ 44 | content: "There was an error while executing this command!", 45 | ephemeral: true, 46 | }); 47 | } 48 | }); 49 | 50 | client.on("error", console.error); 51 | client.login(process.env.DISCORD_TOKEN); 52 | -------------------------------------------------------------------------------- /models/Task.js: -------------------------------------------------------------------------------- 1 | const { DataTypes } = require("sequelize"); 2 | const sequelize = require("../config/sequelize"); 3 | 4 | const Task = sequelize.define("Task", { 5 | text: { 6 | type: DataTypes.STRING, 7 | allowNull: false, 8 | }, 9 | serverId: { 10 | type: DataTypes.STRING, 11 | allowNull: false, 12 | }, 13 | assignTo: { 14 | type: DataTypes.STRING, 15 | defaultValue: false, 16 | }, 17 | isDone: { 18 | type: DataTypes.BOOLEAN, 19 | defaultValue: false, 20 | }, 21 | archive: { 22 | type: DataTypes.BOOLEAN, 23 | defaultValue: false, 24 | }, 25 | dateCreated: { 26 | type: DataTypes.DATE, 27 | defaultValue: DataTypes.NOW, 28 | }, 29 | }); 30 | 31 | Task.sync(); 32 | 33 | module.exports = Task; 34 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "discord-task-bot", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "discord-task-bot", 9 | "version": "1.0.0", 10 | "license": "MIT", 11 | "dependencies": { 12 | "@discordjs/rest": "^1.1.0", 13 | "discord.js": "^14.3.0", 14 | "dotenv": "^8.2.0", 15 | "mysql2": "^2.2.5", 16 | "sequelize": "^6.6.2" 17 | }, 18 | "devDependencies": { 19 | "nodemon": "^2.0.7" 20 | } 21 | }, 22 | "node_modules/@discordjs/builders": { 23 | "version": "1.2.0", 24 | "resolved": "https://registry.npmjs.org/@discordjs/builders/-/builders-1.2.0.tgz", 25 | "integrity": "sha512-ARy4BUTMU+S0ZI6605NDqfWO+qZqV2d/xfY32z3hVSsd9IaAKJBZ1ILTZLy87oIjW8+gUpQmk9Kt0ZP9bmmd8Q==", 26 | "dependencies": { 27 | "@sapphire/shapeshift": "^3.5.1", 28 | "discord-api-types": "^0.37.3", 29 | "fast-deep-equal": "^3.1.3", 30 | "ts-mixer": "^6.0.1", 31 | "tslib": "^2.4.0" 32 | }, 33 | "engines": { 34 | "node": ">=16.9.0" 35 | } 36 | }, 37 | "node_modules/@discordjs/collection": { 38 | "version": "1.1.0", 39 | "resolved": "https://registry.npmjs.org/@discordjs/collection/-/collection-1.1.0.tgz", 40 | "integrity": "sha512-PQ2Bv6pnT7aGPCKWbvvNRww5tYCGpggIQVgpuF9TdDPeR6n6vQYxezXiLVOS9z2B62Dp4c+qepQ15SgJbLYtCQ==", 41 | "engines": { 42 | "node": ">=16.9.0" 43 | } 44 | }, 45 | "node_modules/@discordjs/rest": { 46 | "version": "1.1.0", 47 | "resolved": "https://registry.npmjs.org/@discordjs/rest/-/rest-1.1.0.tgz", 48 | "integrity": "sha512-yCrthRTQeUyNThQEpCk7bvQJlwQmz6kU0tf3dcWBv2WX3Bncl41x7Wc+v5b5OsIxfNYq38PvVtWircu9jtYZug==", 49 | "dependencies": { 50 | "@discordjs/collection": "^1.0.1", 51 | "@sapphire/async-queue": "^1.5.0", 52 | "@sapphire/snowflake": "^3.2.2", 53 | "discord-api-types": "^0.37.3", 54 | "file-type": "^17.1.6", 55 | "tslib": "^2.4.0", 56 | "undici": "^5.9.1" 57 | }, 58 | "engines": { 59 | "node": ">=16.9.0" 60 | } 61 | }, 62 | "node_modules/@sapphire/async-queue": { 63 | "version": "1.5.0", 64 | "resolved": "https://registry.npmjs.org/@sapphire/async-queue/-/async-queue-1.5.0.tgz", 65 | "integrity": "sha512-JkLdIsP8fPAdh9ZZjrbHWR/+mZj0wvKS5ICibcLrRI1j84UmLMshx5n9QmL8b95d4onJ2xxiyugTgSAX7AalmA==", 66 | "engines": { 67 | "node": ">=v14.0.0", 68 | "npm": ">=7.0.0" 69 | } 70 | }, 71 | "node_modules/@sapphire/shapeshift": { 72 | "version": "3.6.0", 73 | "resolved": "https://registry.npmjs.org/@sapphire/shapeshift/-/shapeshift-3.6.0.tgz", 74 | "integrity": "sha512-tu2WLRdo5wotHRvsCkspg3qMiP6ETC3Q1dns1Q5V6zKUki+1itq6AbhMwohF9ZcLoYqg+Y8LkgRRtVxxTQVTBQ==", 75 | "dependencies": { 76 | "fast-deep-equal": "^3.1.3", 77 | "lodash.uniqwith": "^4.5.0" 78 | }, 79 | "engines": { 80 | "node": ">=v14.0.0", 81 | "npm": ">=7.0.0" 82 | } 83 | }, 84 | "node_modules/@sapphire/snowflake": { 85 | "version": "3.2.2", 86 | "resolved": "https://registry.npmjs.org/@sapphire/snowflake/-/snowflake-3.2.2.tgz", 87 | "integrity": "sha512-ula2O0kpSZtX9rKXNeQMrHwNd7E4jPDJYUXmEGTFdMRfyfMw+FPyh04oKMjAiDuOi64bYgVkOV3MjK+loImFhQ==", 88 | "engines": { 89 | "node": ">=v14.0.0", 90 | "npm": ">=7.0.0" 91 | } 92 | }, 93 | "node_modules/@tokenizer/token": { 94 | "version": "0.3.0", 95 | "resolved": "https://registry.npmjs.org/@tokenizer/token/-/token-0.3.0.tgz", 96 | "integrity": "sha512-OvjF+z51L3ov0OyAU0duzsYuvO01PH7x4t6DJx+guahgTnBHkhJdG7soQeTSFLWN3efnHyibZ4Z8l2EuWwJN3A==" 97 | }, 98 | "node_modules/@types/node": { 99 | "version": "16.4.10", 100 | "resolved": "https://registry.npmjs.org/@types/node/-/node-16.4.10.tgz", 101 | "integrity": "sha512-TmVHsm43br64js9BqHWqiDZA+xMtbUpI1MBIA0EyiBmoV9pcEYFOSdj5fr6enZNfh4fChh+AGOLIzGwJnkshyQ==" 102 | }, 103 | "node_modules/@types/ws": { 104 | "version": "8.5.3", 105 | "resolved": "https://registry.npmjs.org/@types/ws/-/ws-8.5.3.tgz", 106 | "integrity": "sha512-6YOoWjruKj1uLf3INHH7D3qTXwFfEsg1kf3c0uDdSBJwfa/llkwIjrAGV7j7mVgGNbzTQ3HiHKKDXl6bJPD97w==", 107 | "dependencies": { 108 | "@types/node": "*" 109 | } 110 | }, 111 | "node_modules/abbrev": { 112 | "version": "1.1.1", 113 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 114 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 115 | "dev": true 116 | }, 117 | "node_modules/any-promise": { 118 | "version": "1.3.0", 119 | "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz", 120 | "integrity": "sha1-q8av7tzqUugJzcA3au0845Y10X8=" 121 | }, 122 | "node_modules/anymatch": { 123 | "version": "3.1.2", 124 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 125 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 126 | "dev": true, 127 | "dependencies": { 128 | "normalize-path": "^3.0.0", 129 | "picomatch": "^2.0.4" 130 | }, 131 | "engines": { 132 | "node": ">= 8" 133 | } 134 | }, 135 | "node_modules/balanced-match": { 136 | "version": "1.0.2", 137 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 138 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 139 | "dev": true 140 | }, 141 | "node_modules/binary-extensions": { 142 | "version": "2.2.0", 143 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 144 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 145 | "dev": true, 146 | "engines": { 147 | "node": ">=8" 148 | } 149 | }, 150 | "node_modules/brace-expansion": { 151 | "version": "1.1.11", 152 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 153 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 154 | "dev": true, 155 | "dependencies": { 156 | "balanced-match": "^1.0.0", 157 | "concat-map": "0.0.1" 158 | } 159 | }, 160 | "node_modules/braces": { 161 | "version": "3.0.2", 162 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 163 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 164 | "dev": true, 165 | "dependencies": { 166 | "fill-range": "^7.0.1" 167 | }, 168 | "engines": { 169 | "node": ">=8" 170 | } 171 | }, 172 | "node_modules/chokidar": { 173 | "version": "3.5.2", 174 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 175 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 176 | "dev": true, 177 | "dependencies": { 178 | "anymatch": "~3.1.2", 179 | "braces": "~3.0.2", 180 | "glob-parent": "~5.1.2", 181 | "is-binary-path": "~2.1.0", 182 | "is-glob": "~4.0.1", 183 | "normalize-path": "~3.0.0", 184 | "readdirp": "~3.6.0" 185 | }, 186 | "engines": { 187 | "node": ">= 8.10.0" 188 | }, 189 | "optionalDependencies": { 190 | "fsevents": "~2.3.2" 191 | } 192 | }, 193 | "node_modules/concat-map": { 194 | "version": "0.0.1", 195 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 196 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 197 | "dev": true 198 | }, 199 | "node_modules/debug": { 200 | "version": "3.2.7", 201 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 202 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 203 | "dev": true, 204 | "dependencies": { 205 | "ms": "^2.1.1" 206 | } 207 | }, 208 | "node_modules/denque": { 209 | "version": "1.5.0", 210 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.5.0.tgz", 211 | "integrity": "sha512-CYiCSgIF1p6EUByQPlGkKnP1M9g0ZV3qMIrqMqZqdwazygIA/YP2vrbcyl1h/WppKJTdl1F85cXIle+394iDAQ==", 212 | "engines": { 213 | "node": ">=0.10" 214 | } 215 | }, 216 | "node_modules/discord-api-types": { 217 | "version": "0.37.5", 218 | "resolved": "https://registry.npmjs.org/discord-api-types/-/discord-api-types-0.37.5.tgz", 219 | "integrity": "sha512-RhzoX02jw2M+n/AU5K74KTM4J8Sn3ZImUJvoA4lh+SDcrqi1ddSjrafciF4bECj4rPc2vHwoyyTNgbUwE8vbpA==" 220 | }, 221 | "node_modules/discord.js": { 222 | "version": "14.3.0", 223 | "resolved": "https://registry.npmjs.org/discord.js/-/discord.js-14.3.0.tgz", 224 | "integrity": "sha512-CpIwoAAuELiHSgVKRMzsCADS6ZlJwAZ9RlvcJYdEgS00aW36dSvXyBgE+S3pigkc7G+jU6BEalMUWIJFveqrBQ==", 225 | "dependencies": { 226 | "@discordjs/builders": "^1.2.0", 227 | "@discordjs/collection": "^1.1.0", 228 | "@discordjs/rest": "^1.1.0", 229 | "@sapphire/snowflake": "^3.2.2", 230 | "@types/ws": "^8.5.3", 231 | "discord-api-types": "^0.37.3", 232 | "fast-deep-equal": "^3.1.3", 233 | "lodash.snakecase": "^4.1.1", 234 | "tslib": "^2.4.0", 235 | "undici": "^5.9.1", 236 | "ws": "^8.8.1" 237 | }, 238 | "engines": { 239 | "node": ">=16.9.0" 240 | } 241 | }, 242 | "node_modules/dotenv": { 243 | "version": "8.6.0", 244 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.6.0.tgz", 245 | "integrity": "sha512-IrPdXQsk2BbzvCBGBOTmmSH5SodmqZNt4ERAZDmW4CT+tL8VtvinqywuANaFu4bOMWki16nqf0e4oC0QIaDr/g==", 246 | "engines": { 247 | "node": ">=10" 248 | } 249 | }, 250 | "node_modules/dottie": { 251 | "version": "2.0.2", 252 | "resolved": "https://registry.npmjs.org/dottie/-/dottie-2.0.2.tgz", 253 | "integrity": "sha512-fmrwR04lsniq/uSr8yikThDTrM7epXHBAAjH9TbeH3rEA8tdCO7mRzB9hdmdGyJCxF8KERo9CITcm3kGuoyMhg==" 254 | }, 255 | "node_modules/fast-deep-equal": { 256 | "version": "3.1.3", 257 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 258 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==" 259 | }, 260 | "node_modules/file-type": { 261 | "version": "17.1.6", 262 | "resolved": "https://registry.npmjs.org/file-type/-/file-type-17.1.6.tgz", 263 | "integrity": "sha512-hlDw5Ev+9e883s0pwUsuuYNu4tD7GgpUnOvykjv1Gya0ZIjuKumthDRua90VUn6/nlRKAjcxLUnHNTIUWwWIiw==", 264 | "dependencies": { 265 | "readable-web-to-node-stream": "^3.0.2", 266 | "strtok3": "^7.0.0-alpha.9", 267 | "token-types": "^5.0.0-alpha.2" 268 | }, 269 | "engines": { 270 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 271 | }, 272 | "funding": { 273 | "url": "https://github.com/sindresorhus/file-type?sponsor=1" 274 | } 275 | }, 276 | "node_modules/fill-range": { 277 | "version": "7.0.1", 278 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 279 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 280 | "dev": true, 281 | "dependencies": { 282 | "to-regex-range": "^5.0.1" 283 | }, 284 | "engines": { 285 | "node": ">=8" 286 | } 287 | }, 288 | "node_modules/fsevents": { 289 | "version": "2.3.2", 290 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 291 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 292 | "dev": true, 293 | "hasInstallScript": true, 294 | "optional": true, 295 | "os": [ 296 | "darwin" 297 | ], 298 | "engines": { 299 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 300 | } 301 | }, 302 | "node_modules/generate-function": { 303 | "version": "2.3.1", 304 | "resolved": "https://registry.npmjs.org/generate-function/-/generate-function-2.3.1.tgz", 305 | "integrity": "sha512-eeB5GfMNeevm/GRYq20ShmsaGcmI81kIX2K9XQx5miC8KdHaC6Jm0qQ8ZNeGOi7wYB8OsdxKs+Y2oVuTFuVwKQ==", 306 | "dependencies": { 307 | "is-property": "^1.0.2" 308 | } 309 | }, 310 | "node_modules/glob-parent": { 311 | "version": "5.1.2", 312 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 313 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 314 | "dev": true, 315 | "dependencies": { 316 | "is-glob": "^4.0.1" 317 | }, 318 | "engines": { 319 | "node": ">= 6" 320 | } 321 | }, 322 | "node_modules/has-flag": { 323 | "version": "3.0.0", 324 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 325 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 326 | "dev": true, 327 | "engines": { 328 | "node": ">=4" 329 | } 330 | }, 331 | "node_modules/iconv-lite": { 332 | "version": "0.6.3", 333 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", 334 | "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", 335 | "dependencies": { 336 | "safer-buffer": ">= 2.1.2 < 3.0.0" 337 | }, 338 | "engines": { 339 | "node": ">=0.10.0" 340 | } 341 | }, 342 | "node_modules/ieee754": { 343 | "version": "1.2.1", 344 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 345 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", 346 | "funding": [ 347 | { 348 | "type": "github", 349 | "url": "https://github.com/sponsors/feross" 350 | }, 351 | { 352 | "type": "patreon", 353 | "url": "https://www.patreon.com/feross" 354 | }, 355 | { 356 | "type": "consulting", 357 | "url": "https://feross.org/support" 358 | } 359 | ] 360 | }, 361 | "node_modules/ignore-by-default": { 362 | "version": "1.0.1", 363 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 364 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 365 | "dev": true 366 | }, 367 | "node_modules/inflection": { 368 | "version": "1.13.1", 369 | "resolved": "https://registry.npmjs.org/inflection/-/inflection-1.13.1.tgz", 370 | "integrity": "sha512-dldYtl2WlN0QDkIDtg8+xFwOS2Tbmp12t1cHa5/YClU6ZQjTFm7B66UcVbh9NQB+HvT5BAd2t5+yKsBkw5pcqA==", 371 | "engines": [ 372 | "node >= 0.4.0" 373 | ] 374 | }, 375 | "node_modules/inherits": { 376 | "version": "2.0.4", 377 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 378 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 379 | }, 380 | "node_modules/is-binary-path": { 381 | "version": "2.1.0", 382 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 383 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 384 | "dev": true, 385 | "dependencies": { 386 | "binary-extensions": "^2.0.0" 387 | }, 388 | "engines": { 389 | "node": ">=8" 390 | } 391 | }, 392 | "node_modules/is-extglob": { 393 | "version": "2.1.1", 394 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 395 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 396 | "dev": true, 397 | "engines": { 398 | "node": ">=0.10.0" 399 | } 400 | }, 401 | "node_modules/is-glob": { 402 | "version": "4.0.1", 403 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 404 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 405 | "dev": true, 406 | "dependencies": { 407 | "is-extglob": "^2.1.1" 408 | }, 409 | "engines": { 410 | "node": ">=0.10.0" 411 | } 412 | }, 413 | "node_modules/is-number": { 414 | "version": "7.0.0", 415 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 416 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 417 | "dev": true, 418 | "engines": { 419 | "node": ">=0.12.0" 420 | } 421 | }, 422 | "node_modules/is-property": { 423 | "version": "1.0.2", 424 | "resolved": "https://registry.npmjs.org/is-property/-/is-property-1.0.2.tgz", 425 | "integrity": "sha1-V/4cTkhHTt1lsJkR8msc1Ald2oQ=" 426 | }, 427 | "node_modules/lodash": { 428 | "version": "4.17.21", 429 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 430 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 431 | }, 432 | "node_modules/lodash.snakecase": { 433 | "version": "4.1.1", 434 | "resolved": "https://registry.npmjs.org/lodash.snakecase/-/lodash.snakecase-4.1.1.tgz", 435 | "integrity": "sha512-QZ1d4xoBHYUeuouhEq3lk3Uq7ldgyFXGBhg04+oRLnIz8o9T65Eh+8YdroUwn846zchkA9yDsDl5CVVaV2nqYw==" 436 | }, 437 | "node_modules/lodash.uniqwith": { 438 | "version": "4.5.0", 439 | "resolved": "https://registry.npmjs.org/lodash.uniqwith/-/lodash.uniqwith-4.5.0.tgz", 440 | "integrity": "sha512-7lYL8bLopMoy4CTICbxygAUq6CdRJ36vFc80DucPueUee+d5NBRxz3FdT9Pes/HEx5mPoT9jwnsEJWz1N7uq7Q==" 441 | }, 442 | "node_modules/long": { 443 | "version": "4.0.0", 444 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 445 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 446 | }, 447 | "node_modules/lru-cache": { 448 | "version": "6.0.0", 449 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 450 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 451 | "dependencies": { 452 | "yallist": "^4.0.0" 453 | }, 454 | "engines": { 455 | "node": ">=10" 456 | } 457 | }, 458 | "node_modules/minimatch": { 459 | "version": "3.0.4", 460 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 461 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 462 | "dev": true, 463 | "dependencies": { 464 | "brace-expansion": "^1.1.7" 465 | }, 466 | "engines": { 467 | "node": "*" 468 | } 469 | }, 470 | "node_modules/moment": { 471 | "version": "2.29.4", 472 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz", 473 | "integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==", 474 | "engines": { 475 | "node": "*" 476 | } 477 | }, 478 | "node_modules/moment-timezone": { 479 | "version": "0.5.37", 480 | "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.37.tgz", 481 | "integrity": "sha512-uEDzDNFhfaywRl+vwXxffjjq1q0Vzr+fcQpQ1bU0kbzorfS7zVtZnCnGc8mhWmF39d4g4YriF6kwA75mJKE/Zg==", 482 | "dependencies": { 483 | "moment": ">= 2.9.0" 484 | }, 485 | "engines": { 486 | "node": "*" 487 | } 488 | }, 489 | "node_modules/ms": { 490 | "version": "2.1.3", 491 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 492 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 493 | "dev": true 494 | }, 495 | "node_modules/mysql2": { 496 | "version": "2.2.5", 497 | "resolved": "https://registry.npmjs.org/mysql2/-/mysql2-2.2.5.tgz", 498 | "integrity": "sha512-XRqPNxcZTpmFdXbJqb+/CtYVLCx14x1RTeNMD4954L331APu75IC74GDqnZMEt1kwaXy6TySo55rF2F3YJS78g==", 499 | "dependencies": { 500 | "denque": "^1.4.1", 501 | "generate-function": "^2.3.1", 502 | "iconv-lite": "^0.6.2", 503 | "long": "^4.0.0", 504 | "lru-cache": "^6.0.0", 505 | "named-placeholders": "^1.1.2", 506 | "seq-queue": "^0.0.5", 507 | "sqlstring": "^2.3.2" 508 | }, 509 | "engines": { 510 | "node": ">= 8.0" 511 | } 512 | }, 513 | "node_modules/named-placeholders": { 514 | "version": "1.1.2", 515 | "resolved": "https://registry.npmjs.org/named-placeholders/-/named-placeholders-1.1.2.tgz", 516 | "integrity": "sha512-wiFWqxoLL3PGVReSZpjLVxyJ1bRqe+KKJVbr4hGs1KWfTZTQyezHFBbuKj9hsizHyGV2ne7EMjHdxEGAybD5SA==", 517 | "dependencies": { 518 | "lru-cache": "^4.1.3" 519 | }, 520 | "engines": { 521 | "node": ">=6.0.0" 522 | } 523 | }, 524 | "node_modules/named-placeholders/node_modules/lru-cache": { 525 | "version": "4.1.5", 526 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", 527 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", 528 | "dependencies": { 529 | "pseudomap": "^1.0.2", 530 | "yallist": "^2.1.2" 531 | } 532 | }, 533 | "node_modules/named-placeholders/node_modules/yallist": { 534 | "version": "2.1.2", 535 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 536 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 537 | }, 538 | "node_modules/nodemon": { 539 | "version": "2.0.19", 540 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.19.tgz", 541 | "integrity": "sha512-4pv1f2bMDj0Eeg/MhGqxrtveeQ5/G/UVe9iO6uTZzjnRluSA4PVWf8CW99LUPwGB3eNIA7zUFoP77YuI7hOc0A==", 542 | "dev": true, 543 | "hasInstallScript": true, 544 | "dependencies": { 545 | "chokidar": "^3.5.2", 546 | "debug": "^3.2.7", 547 | "ignore-by-default": "^1.0.1", 548 | "minimatch": "^3.0.4", 549 | "pstree.remy": "^1.1.8", 550 | "semver": "^5.7.1", 551 | "simple-update-notifier": "^1.0.7", 552 | "supports-color": "^5.5.0", 553 | "touch": "^3.1.0", 554 | "undefsafe": "^2.0.5" 555 | }, 556 | "bin": { 557 | "nodemon": "bin/nodemon.js" 558 | }, 559 | "engines": { 560 | "node": ">=8.10.0" 561 | }, 562 | "funding": { 563 | "type": "opencollective", 564 | "url": "https://opencollective.com/nodemon" 565 | } 566 | }, 567 | "node_modules/nopt": { 568 | "version": "1.0.10", 569 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 570 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 571 | "dev": true, 572 | "dependencies": { 573 | "abbrev": "1" 574 | }, 575 | "bin": { 576 | "nopt": "bin/nopt.js" 577 | }, 578 | "engines": { 579 | "node": "*" 580 | } 581 | }, 582 | "node_modules/normalize-path": { 583 | "version": "3.0.0", 584 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 585 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 586 | "dev": true, 587 | "engines": { 588 | "node": ">=0.10.0" 589 | } 590 | }, 591 | "node_modules/peek-readable": { 592 | "version": "5.0.0", 593 | "resolved": "https://registry.npmjs.org/peek-readable/-/peek-readable-5.0.0.tgz", 594 | "integrity": "sha512-YtCKvLUOvwtMGmrniQPdO7MwPjgkFBtFIrmfSbYmYuq3tKDV/mcfAhBth1+C3ru7uXIZasc/pHnb+YDYNkkj4A==", 595 | "engines": { 596 | "node": ">=14.16" 597 | }, 598 | "funding": { 599 | "type": "github", 600 | "url": "https://github.com/sponsors/Borewit" 601 | } 602 | }, 603 | "node_modules/picomatch": { 604 | "version": "2.3.0", 605 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 606 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 607 | "dev": true, 608 | "engines": { 609 | "node": ">=8.6" 610 | }, 611 | "funding": { 612 | "url": "https://github.com/sponsors/jonschlinkert" 613 | } 614 | }, 615 | "node_modules/pseudomap": { 616 | "version": "1.0.2", 617 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 618 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 619 | }, 620 | "node_modules/pstree.remy": { 621 | "version": "1.1.8", 622 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 623 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 624 | "dev": true 625 | }, 626 | "node_modules/readable-stream": { 627 | "version": "3.6.0", 628 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 629 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 630 | "dependencies": { 631 | "inherits": "^2.0.3", 632 | "string_decoder": "^1.1.1", 633 | "util-deprecate": "^1.0.1" 634 | }, 635 | "engines": { 636 | "node": ">= 6" 637 | } 638 | }, 639 | "node_modules/readable-web-to-node-stream": { 640 | "version": "3.0.2", 641 | "resolved": "https://registry.npmjs.org/readable-web-to-node-stream/-/readable-web-to-node-stream-3.0.2.tgz", 642 | "integrity": "sha512-ePeK6cc1EcKLEhJFt/AebMCLL+GgSKhuygrZ/GLaKZYEecIgIECf4UaUuaByiGtzckwR4ain9VzUh95T1exYGw==", 643 | "dependencies": { 644 | "readable-stream": "^3.6.0" 645 | }, 646 | "engines": { 647 | "node": ">=8" 648 | }, 649 | "funding": { 650 | "type": "github", 651 | "url": "https://github.com/sponsors/Borewit" 652 | } 653 | }, 654 | "node_modules/readdirp": { 655 | "version": "3.6.0", 656 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 657 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 658 | "dev": true, 659 | "dependencies": { 660 | "picomatch": "^2.2.1" 661 | }, 662 | "engines": { 663 | "node": ">=8.10.0" 664 | } 665 | }, 666 | "node_modules/retry-as-promised": { 667 | "version": "3.2.0", 668 | "resolved": "https://registry.npmjs.org/retry-as-promised/-/retry-as-promised-3.2.0.tgz", 669 | "integrity": "sha512-CybGs60B7oYU/qSQ6kuaFmRd9sTZ6oXSc0toqePvV74Ac6/IFZSI1ReFQmtCN+uvW1Mtqdwpvt/LGOiCBAY2Mg==", 670 | "dependencies": { 671 | "any-promise": "^1.3.0" 672 | } 673 | }, 674 | "node_modules/safe-buffer": { 675 | "version": "5.2.1", 676 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 677 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 678 | "funding": [ 679 | { 680 | "type": "github", 681 | "url": "https://github.com/sponsors/feross" 682 | }, 683 | { 684 | "type": "patreon", 685 | "url": "https://www.patreon.com/feross" 686 | }, 687 | { 688 | "type": "consulting", 689 | "url": "https://feross.org/support" 690 | } 691 | ] 692 | }, 693 | "node_modules/safer-buffer": { 694 | "version": "2.1.2", 695 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 696 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 697 | }, 698 | "node_modules/semver": { 699 | "version": "5.7.1", 700 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 701 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 702 | "dev": true, 703 | "bin": { 704 | "semver": "bin/semver" 705 | } 706 | }, 707 | "node_modules/seq-queue": { 708 | "version": "0.0.5", 709 | "resolved": "https://registry.npmjs.org/seq-queue/-/seq-queue-0.0.5.tgz", 710 | "integrity": "sha1-1WgS4cAXpuTnw+Ojeh2m143TyT4=" 711 | }, 712 | "node_modules/sequelize": { 713 | "version": "6.6.5", 714 | "resolved": "https://registry.npmjs.org/sequelize/-/sequelize-6.6.5.tgz", 715 | "integrity": "sha512-QyRrJrDRiwuiILqTMHUA1yWOPIL12KlfmgZ3hnzQwbMvp2vJ6fzu9bYJQB+qPMosck4mBUggY4Cjoc6Et8FBIQ==", 716 | "dependencies": { 717 | "debug": "^4.1.1", 718 | "dottie": "^2.0.0", 719 | "inflection": "1.13.1", 720 | "lodash": "^4.17.20", 721 | "moment": "^2.26.0", 722 | "moment-timezone": "^0.5.31", 723 | "retry-as-promised": "^3.2.0", 724 | "semver": "^7.3.2", 725 | "sequelize-pool": "^6.0.0", 726 | "toposort-class": "^1.0.1", 727 | "uuid": "^8.1.0", 728 | "validator": "^13.6.0", 729 | "wkx": "^0.5.0" 730 | }, 731 | "engines": { 732 | "node": ">=10.0.0" 733 | }, 734 | "peerDependenciesMeta": { 735 | "mariadb": { 736 | "optional": true 737 | }, 738 | "mysql2": { 739 | "optional": true 740 | }, 741 | "pg": { 742 | "optional": true 743 | }, 744 | "pg-hstore": { 745 | "optional": true 746 | }, 747 | "sqlite3": { 748 | "optional": true 749 | }, 750 | "tedious": { 751 | "optional": true 752 | } 753 | } 754 | }, 755 | "node_modules/sequelize-pool": { 756 | "version": "6.1.0", 757 | "resolved": "https://registry.npmjs.org/sequelize-pool/-/sequelize-pool-6.1.0.tgz", 758 | "integrity": "sha512-4YwEw3ZgK/tY/so+GfnSgXkdwIJJ1I32uZJztIEgZeAO6HMgj64OzySbWLgxj+tXhZCJnzRfkY9gINw8Ft8ZMg==", 759 | "engines": { 760 | "node": ">= 10.0.0" 761 | } 762 | }, 763 | "node_modules/sequelize/node_modules/debug": { 764 | "version": "4.3.2", 765 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 766 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 767 | "dependencies": { 768 | "ms": "2.1.2" 769 | }, 770 | "engines": { 771 | "node": ">=6.0" 772 | }, 773 | "peerDependenciesMeta": { 774 | "supports-color": { 775 | "optional": true 776 | } 777 | } 778 | }, 779 | "node_modules/sequelize/node_modules/ms": { 780 | "version": "2.1.2", 781 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 782 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 783 | }, 784 | "node_modules/sequelize/node_modules/semver": { 785 | "version": "7.3.5", 786 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 787 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 788 | "dependencies": { 789 | "lru-cache": "^6.0.0" 790 | }, 791 | "bin": { 792 | "semver": "bin/semver.js" 793 | }, 794 | "engines": { 795 | "node": ">=10" 796 | } 797 | }, 798 | "node_modules/simple-update-notifier": { 799 | "version": "1.0.7", 800 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-1.0.7.tgz", 801 | "integrity": "sha512-BBKgR84BJQJm6WjWFMHgLVuo61FBDSj1z/xSFUIozqO6wO7ii0JxCqlIud7Enr/+LhlbNI0whErq96P2qHNWew==", 802 | "dev": true, 803 | "dependencies": { 804 | "semver": "~7.0.0" 805 | }, 806 | "engines": { 807 | "node": ">=8.10.0" 808 | } 809 | }, 810 | "node_modules/simple-update-notifier/node_modules/semver": { 811 | "version": "7.0.0", 812 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz", 813 | "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==", 814 | "dev": true, 815 | "bin": { 816 | "semver": "bin/semver.js" 817 | } 818 | }, 819 | "node_modules/sqlstring": { 820 | "version": "2.3.2", 821 | "resolved": "https://registry.npmjs.org/sqlstring/-/sqlstring-2.3.2.tgz", 822 | "integrity": "sha512-vF4ZbYdKS8OnoJAWBmMxCQDkiEBkGQYU7UZPtL8flbDRSNkhaXvRJ279ZtI6M+zDaQovVU4tuRgzK5fVhvFAhg==", 823 | "engines": { 824 | "node": ">= 0.6" 825 | } 826 | }, 827 | "node_modules/string_decoder": { 828 | "version": "1.3.0", 829 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 830 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 831 | "dependencies": { 832 | "safe-buffer": "~5.2.0" 833 | } 834 | }, 835 | "node_modules/strtok3": { 836 | "version": "7.0.0", 837 | "resolved": "https://registry.npmjs.org/strtok3/-/strtok3-7.0.0.tgz", 838 | "integrity": "sha512-pQ+V+nYQdC5H3Q7qBZAz/MO6lwGhoC2gOAjuouGf/VO0m7vQRh8QNMl2Uf6SwAtzZ9bOw3UIeBukEGNJl5dtXQ==", 839 | "dependencies": { 840 | "@tokenizer/token": "^0.3.0", 841 | "peek-readable": "^5.0.0" 842 | }, 843 | "engines": { 844 | "node": ">=14.16" 845 | }, 846 | "funding": { 847 | "type": "github", 848 | "url": "https://github.com/sponsors/Borewit" 849 | } 850 | }, 851 | "node_modules/supports-color": { 852 | "version": "5.5.0", 853 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 854 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 855 | "dev": true, 856 | "dependencies": { 857 | "has-flag": "^3.0.0" 858 | }, 859 | "engines": { 860 | "node": ">=4" 861 | } 862 | }, 863 | "node_modules/to-regex-range": { 864 | "version": "5.0.1", 865 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 866 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 867 | "dev": true, 868 | "dependencies": { 869 | "is-number": "^7.0.0" 870 | }, 871 | "engines": { 872 | "node": ">=8.0" 873 | } 874 | }, 875 | "node_modules/token-types": { 876 | "version": "5.0.1", 877 | "resolved": "https://registry.npmjs.org/token-types/-/token-types-5.0.1.tgz", 878 | "integrity": "sha512-Y2fmSnZjQdDb9W4w4r1tswlMHylzWIeOKpx0aZH9BgGtACHhrk3OkT52AzwcuqTRBZtvvnTjDBh8eynMulu8Vg==", 879 | "dependencies": { 880 | "@tokenizer/token": "^0.3.0", 881 | "ieee754": "^1.2.1" 882 | }, 883 | "engines": { 884 | "node": ">=14.16" 885 | }, 886 | "funding": { 887 | "type": "github", 888 | "url": "https://github.com/sponsors/Borewit" 889 | } 890 | }, 891 | "node_modules/toposort-class": { 892 | "version": "1.0.1", 893 | "resolved": "https://registry.npmjs.org/toposort-class/-/toposort-class-1.0.1.tgz", 894 | "integrity": "sha1-f/0feMi+KMO6Rc1OGj9e4ZO9mYg=" 895 | }, 896 | "node_modules/touch": { 897 | "version": "3.1.0", 898 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 899 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 900 | "dev": true, 901 | "dependencies": { 902 | "nopt": "~1.0.10" 903 | }, 904 | "bin": { 905 | "nodetouch": "bin/nodetouch.js" 906 | } 907 | }, 908 | "node_modules/ts-mixer": { 909 | "version": "6.0.1", 910 | "resolved": "https://registry.npmjs.org/ts-mixer/-/ts-mixer-6.0.1.tgz", 911 | "integrity": "sha512-hvE+ZYXuINrx6Ei6D6hz+PTim0Uf++dYbK9FFifLNwQj+RwKquhQpn868yZsCtJYiclZF1u8l6WZxxKi+vv7Rg==" 912 | }, 913 | "node_modules/tslib": { 914 | "version": "2.4.0", 915 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz", 916 | "integrity": "sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==" 917 | }, 918 | "node_modules/undefsafe": { 919 | "version": "2.0.5", 920 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 921 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 922 | "dev": true 923 | }, 924 | "node_modules/undici": { 925 | "version": "5.10.0", 926 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.10.0.tgz", 927 | "integrity": "sha512-c8HsD3IbwmjjbLvoZuRI26TZic+TSEe8FPMLLOkN1AfYRhdjnKBU6yL+IwcSCbdZiX4e5t0lfMDLDCqj4Sq70g==", 928 | "engines": { 929 | "node": ">=12.18" 930 | } 931 | }, 932 | "node_modules/util-deprecate": { 933 | "version": "1.0.2", 934 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 935 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" 936 | }, 937 | "node_modules/uuid": { 938 | "version": "8.3.2", 939 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 940 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", 941 | "bin": { 942 | "uuid": "dist/bin/uuid" 943 | } 944 | }, 945 | "node_modules/validator": { 946 | "version": "13.7.0", 947 | "resolved": "https://registry.npmjs.org/validator/-/validator-13.7.0.tgz", 948 | "integrity": "sha512-nYXQLCBkpJ8X6ltALua9dRrZDHVYxjJ1wgskNt1lH9fzGjs3tgojGSCBjmEPwkWS1y29+DrizMTW19Pr9uB2nw==", 949 | "engines": { 950 | "node": ">= 0.10" 951 | } 952 | }, 953 | "node_modules/wkx": { 954 | "version": "0.5.0", 955 | "resolved": "https://registry.npmjs.org/wkx/-/wkx-0.5.0.tgz", 956 | "integrity": "sha512-Xng/d4Ichh8uN4l0FToV/258EjMGU9MGcA0HV2d9B/ZpZB3lqQm7nkOdZdm5GhKtLLhAE7PiVQwN4eN+2YJJUg==", 957 | "dependencies": { 958 | "@types/node": "*" 959 | } 960 | }, 961 | "node_modules/ws": { 962 | "version": "8.8.1", 963 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.8.1.tgz", 964 | "integrity": "sha512-bGy2JzvzkPowEJV++hF07hAD6niYSr0JzBNo/J29WsB57A2r7Wlc1UFcTR9IzrPvuNVO4B8LGqF8qcpsVOhJCA==", 965 | "engines": { 966 | "node": ">=10.0.0" 967 | }, 968 | "peerDependencies": { 969 | "bufferutil": "^4.0.1", 970 | "utf-8-validate": "^5.0.2" 971 | }, 972 | "peerDependenciesMeta": { 973 | "bufferutil": { 974 | "optional": true 975 | }, 976 | "utf-8-validate": { 977 | "optional": true 978 | } 979 | } 980 | }, 981 | "node_modules/yallist": { 982 | "version": "4.0.0", 983 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 984 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 985 | } 986 | }, 987 | "dependencies": { 988 | "@discordjs/builders": { 989 | "version": "1.2.0", 990 | "resolved": "https://registry.npmjs.org/@discordjs/builders/-/builders-1.2.0.tgz", 991 | "integrity": "sha512-ARy4BUTMU+S0ZI6605NDqfWO+qZqV2d/xfY32z3hVSsd9IaAKJBZ1ILTZLy87oIjW8+gUpQmk9Kt0ZP9bmmd8Q==", 992 | "requires": { 993 | "@sapphire/shapeshift": "^3.5.1", 994 | "discord-api-types": "^0.37.3", 995 | "fast-deep-equal": "^3.1.3", 996 | "ts-mixer": "^6.0.1", 997 | "tslib": "^2.4.0" 998 | } 999 | }, 1000 | "@discordjs/collection": { 1001 | "version": "1.1.0", 1002 | "resolved": "https://registry.npmjs.org/@discordjs/collection/-/collection-1.1.0.tgz", 1003 | "integrity": "sha512-PQ2Bv6pnT7aGPCKWbvvNRww5tYCGpggIQVgpuF9TdDPeR6n6vQYxezXiLVOS9z2B62Dp4c+qepQ15SgJbLYtCQ==" 1004 | }, 1005 | "@discordjs/rest": { 1006 | "version": "1.1.0", 1007 | "resolved": "https://registry.npmjs.org/@discordjs/rest/-/rest-1.1.0.tgz", 1008 | "integrity": "sha512-yCrthRTQeUyNThQEpCk7bvQJlwQmz6kU0tf3dcWBv2WX3Bncl41x7Wc+v5b5OsIxfNYq38PvVtWircu9jtYZug==", 1009 | "requires": { 1010 | "@discordjs/collection": "^1.0.1", 1011 | "@sapphire/async-queue": "^1.5.0", 1012 | "@sapphire/snowflake": "^3.2.2", 1013 | "discord-api-types": "^0.37.3", 1014 | "file-type": "^17.1.6", 1015 | "tslib": "^2.4.0", 1016 | "undici": "^5.9.1" 1017 | } 1018 | }, 1019 | "@sapphire/async-queue": { 1020 | "version": "1.5.0", 1021 | "resolved": "https://registry.npmjs.org/@sapphire/async-queue/-/async-queue-1.5.0.tgz", 1022 | "integrity": "sha512-JkLdIsP8fPAdh9ZZjrbHWR/+mZj0wvKS5ICibcLrRI1j84UmLMshx5n9QmL8b95d4onJ2xxiyugTgSAX7AalmA==" 1023 | }, 1024 | "@sapphire/shapeshift": { 1025 | "version": "3.6.0", 1026 | "resolved": "https://registry.npmjs.org/@sapphire/shapeshift/-/shapeshift-3.6.0.tgz", 1027 | "integrity": "sha512-tu2WLRdo5wotHRvsCkspg3qMiP6ETC3Q1dns1Q5V6zKUki+1itq6AbhMwohF9ZcLoYqg+Y8LkgRRtVxxTQVTBQ==", 1028 | "requires": { 1029 | "fast-deep-equal": "^3.1.3", 1030 | "lodash.uniqwith": "^4.5.0" 1031 | } 1032 | }, 1033 | "@sapphire/snowflake": { 1034 | "version": "3.2.2", 1035 | "resolved": "https://registry.npmjs.org/@sapphire/snowflake/-/snowflake-3.2.2.tgz", 1036 | "integrity": "sha512-ula2O0kpSZtX9rKXNeQMrHwNd7E4jPDJYUXmEGTFdMRfyfMw+FPyh04oKMjAiDuOi64bYgVkOV3MjK+loImFhQ==" 1037 | }, 1038 | "@tokenizer/token": { 1039 | "version": "0.3.0", 1040 | "resolved": "https://registry.npmjs.org/@tokenizer/token/-/token-0.3.0.tgz", 1041 | "integrity": "sha512-OvjF+z51L3ov0OyAU0duzsYuvO01PH7x4t6DJx+guahgTnBHkhJdG7soQeTSFLWN3efnHyibZ4Z8l2EuWwJN3A==" 1042 | }, 1043 | "@types/node": { 1044 | "version": "16.4.10", 1045 | "resolved": "https://registry.npmjs.org/@types/node/-/node-16.4.10.tgz", 1046 | "integrity": "sha512-TmVHsm43br64js9BqHWqiDZA+xMtbUpI1MBIA0EyiBmoV9pcEYFOSdj5fr6enZNfh4fChh+AGOLIzGwJnkshyQ==" 1047 | }, 1048 | "@types/ws": { 1049 | "version": "8.5.3", 1050 | "resolved": "https://registry.npmjs.org/@types/ws/-/ws-8.5.3.tgz", 1051 | "integrity": "sha512-6YOoWjruKj1uLf3INHH7D3qTXwFfEsg1kf3c0uDdSBJwfa/llkwIjrAGV7j7mVgGNbzTQ3HiHKKDXl6bJPD97w==", 1052 | "requires": { 1053 | "@types/node": "*" 1054 | } 1055 | }, 1056 | "abbrev": { 1057 | "version": "1.1.1", 1058 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 1059 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 1060 | "dev": true 1061 | }, 1062 | "any-promise": { 1063 | "version": "1.3.0", 1064 | "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz", 1065 | "integrity": "sha1-q8av7tzqUugJzcA3au0845Y10X8=" 1066 | }, 1067 | "anymatch": { 1068 | "version": "3.1.2", 1069 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 1070 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 1071 | "dev": true, 1072 | "requires": { 1073 | "normalize-path": "^3.0.0", 1074 | "picomatch": "^2.0.4" 1075 | } 1076 | }, 1077 | "balanced-match": { 1078 | "version": "1.0.2", 1079 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1080 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1081 | "dev": true 1082 | }, 1083 | "binary-extensions": { 1084 | "version": "2.2.0", 1085 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 1086 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 1087 | "dev": true 1088 | }, 1089 | "brace-expansion": { 1090 | "version": "1.1.11", 1091 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1092 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1093 | "dev": true, 1094 | "requires": { 1095 | "balanced-match": "^1.0.0", 1096 | "concat-map": "0.0.1" 1097 | } 1098 | }, 1099 | "braces": { 1100 | "version": "3.0.2", 1101 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1102 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1103 | "dev": true, 1104 | "requires": { 1105 | "fill-range": "^7.0.1" 1106 | } 1107 | }, 1108 | "chokidar": { 1109 | "version": "3.5.2", 1110 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 1111 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 1112 | "dev": true, 1113 | "requires": { 1114 | "anymatch": "~3.1.2", 1115 | "braces": "~3.0.2", 1116 | "fsevents": "~2.3.2", 1117 | "glob-parent": "~5.1.2", 1118 | "is-binary-path": "~2.1.0", 1119 | "is-glob": "~4.0.1", 1120 | "normalize-path": "~3.0.0", 1121 | "readdirp": "~3.6.0" 1122 | } 1123 | }, 1124 | "concat-map": { 1125 | "version": "0.0.1", 1126 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1127 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 1128 | "dev": true 1129 | }, 1130 | "debug": { 1131 | "version": "3.2.7", 1132 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1133 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1134 | "dev": true, 1135 | "requires": { 1136 | "ms": "^2.1.1" 1137 | } 1138 | }, 1139 | "denque": { 1140 | "version": "1.5.0", 1141 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.5.0.tgz", 1142 | "integrity": "sha512-CYiCSgIF1p6EUByQPlGkKnP1M9g0ZV3qMIrqMqZqdwazygIA/YP2vrbcyl1h/WppKJTdl1F85cXIle+394iDAQ==" 1143 | }, 1144 | "discord-api-types": { 1145 | "version": "0.37.5", 1146 | "resolved": "https://registry.npmjs.org/discord-api-types/-/discord-api-types-0.37.5.tgz", 1147 | "integrity": "sha512-RhzoX02jw2M+n/AU5K74KTM4J8Sn3ZImUJvoA4lh+SDcrqi1ddSjrafciF4bECj4rPc2vHwoyyTNgbUwE8vbpA==" 1148 | }, 1149 | "discord.js": { 1150 | "version": "14.3.0", 1151 | "resolved": "https://registry.npmjs.org/discord.js/-/discord.js-14.3.0.tgz", 1152 | "integrity": "sha512-CpIwoAAuELiHSgVKRMzsCADS6ZlJwAZ9RlvcJYdEgS00aW36dSvXyBgE+S3pigkc7G+jU6BEalMUWIJFveqrBQ==", 1153 | "requires": { 1154 | "@discordjs/builders": "^1.2.0", 1155 | "@discordjs/collection": "^1.1.0", 1156 | "@discordjs/rest": "^1.1.0", 1157 | "@sapphire/snowflake": "^3.2.2", 1158 | "@types/ws": "^8.5.3", 1159 | "discord-api-types": "^0.37.3", 1160 | "fast-deep-equal": "^3.1.3", 1161 | "lodash.snakecase": "^4.1.1", 1162 | "tslib": "^2.4.0", 1163 | "undici": "^5.9.1", 1164 | "ws": "^8.8.1" 1165 | } 1166 | }, 1167 | "dotenv": { 1168 | "version": "8.6.0", 1169 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.6.0.tgz", 1170 | "integrity": "sha512-IrPdXQsk2BbzvCBGBOTmmSH5SodmqZNt4ERAZDmW4CT+tL8VtvinqywuANaFu4bOMWki16nqf0e4oC0QIaDr/g==" 1171 | }, 1172 | "dottie": { 1173 | "version": "2.0.2", 1174 | "resolved": "https://registry.npmjs.org/dottie/-/dottie-2.0.2.tgz", 1175 | "integrity": "sha512-fmrwR04lsniq/uSr8yikThDTrM7epXHBAAjH9TbeH3rEA8tdCO7mRzB9hdmdGyJCxF8KERo9CITcm3kGuoyMhg==" 1176 | }, 1177 | "fast-deep-equal": { 1178 | "version": "3.1.3", 1179 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1180 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==" 1181 | }, 1182 | "file-type": { 1183 | "version": "17.1.6", 1184 | "resolved": "https://registry.npmjs.org/file-type/-/file-type-17.1.6.tgz", 1185 | "integrity": "sha512-hlDw5Ev+9e883s0pwUsuuYNu4tD7GgpUnOvykjv1Gya0ZIjuKumthDRua90VUn6/nlRKAjcxLUnHNTIUWwWIiw==", 1186 | "requires": { 1187 | "readable-web-to-node-stream": "^3.0.2", 1188 | "strtok3": "^7.0.0-alpha.9", 1189 | "token-types": "^5.0.0-alpha.2" 1190 | } 1191 | }, 1192 | "fill-range": { 1193 | "version": "7.0.1", 1194 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1195 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1196 | "dev": true, 1197 | "requires": { 1198 | "to-regex-range": "^5.0.1" 1199 | } 1200 | }, 1201 | "fsevents": { 1202 | "version": "2.3.2", 1203 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1204 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1205 | "dev": true, 1206 | "optional": true 1207 | }, 1208 | "generate-function": { 1209 | "version": "2.3.1", 1210 | "resolved": "https://registry.npmjs.org/generate-function/-/generate-function-2.3.1.tgz", 1211 | "integrity": "sha512-eeB5GfMNeevm/GRYq20ShmsaGcmI81kIX2K9XQx5miC8KdHaC6Jm0qQ8ZNeGOi7wYB8OsdxKs+Y2oVuTFuVwKQ==", 1212 | "requires": { 1213 | "is-property": "^1.0.2" 1214 | } 1215 | }, 1216 | "glob-parent": { 1217 | "version": "5.1.2", 1218 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1219 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1220 | "dev": true, 1221 | "requires": { 1222 | "is-glob": "^4.0.1" 1223 | } 1224 | }, 1225 | "has-flag": { 1226 | "version": "3.0.0", 1227 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1228 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1229 | "dev": true 1230 | }, 1231 | "iconv-lite": { 1232 | "version": "0.6.3", 1233 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", 1234 | "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", 1235 | "requires": { 1236 | "safer-buffer": ">= 2.1.2 < 3.0.0" 1237 | } 1238 | }, 1239 | "ieee754": { 1240 | "version": "1.2.1", 1241 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 1242 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==" 1243 | }, 1244 | "ignore-by-default": { 1245 | "version": "1.0.1", 1246 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 1247 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 1248 | "dev": true 1249 | }, 1250 | "inflection": { 1251 | "version": "1.13.1", 1252 | "resolved": "https://registry.npmjs.org/inflection/-/inflection-1.13.1.tgz", 1253 | "integrity": "sha512-dldYtl2WlN0QDkIDtg8+xFwOS2Tbmp12t1cHa5/YClU6ZQjTFm7B66UcVbh9NQB+HvT5BAd2t5+yKsBkw5pcqA==" 1254 | }, 1255 | "inherits": { 1256 | "version": "2.0.4", 1257 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1258 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1259 | }, 1260 | "is-binary-path": { 1261 | "version": "2.1.0", 1262 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1263 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1264 | "dev": true, 1265 | "requires": { 1266 | "binary-extensions": "^2.0.0" 1267 | } 1268 | }, 1269 | "is-extglob": { 1270 | "version": "2.1.1", 1271 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1272 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1273 | "dev": true 1274 | }, 1275 | "is-glob": { 1276 | "version": "4.0.1", 1277 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1278 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1279 | "dev": true, 1280 | "requires": { 1281 | "is-extglob": "^2.1.1" 1282 | } 1283 | }, 1284 | "is-number": { 1285 | "version": "7.0.0", 1286 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1287 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1288 | "dev": true 1289 | }, 1290 | "is-property": { 1291 | "version": "1.0.2", 1292 | "resolved": "https://registry.npmjs.org/is-property/-/is-property-1.0.2.tgz", 1293 | "integrity": "sha1-V/4cTkhHTt1lsJkR8msc1Ald2oQ=" 1294 | }, 1295 | "lodash": { 1296 | "version": "4.17.21", 1297 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1298 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 1299 | }, 1300 | "lodash.snakecase": { 1301 | "version": "4.1.1", 1302 | "resolved": "https://registry.npmjs.org/lodash.snakecase/-/lodash.snakecase-4.1.1.tgz", 1303 | "integrity": "sha512-QZ1d4xoBHYUeuouhEq3lk3Uq7ldgyFXGBhg04+oRLnIz8o9T65Eh+8YdroUwn846zchkA9yDsDl5CVVaV2nqYw==" 1304 | }, 1305 | "lodash.uniqwith": { 1306 | "version": "4.5.0", 1307 | "resolved": "https://registry.npmjs.org/lodash.uniqwith/-/lodash.uniqwith-4.5.0.tgz", 1308 | "integrity": "sha512-7lYL8bLopMoy4CTICbxygAUq6CdRJ36vFc80DucPueUee+d5NBRxz3FdT9Pes/HEx5mPoT9jwnsEJWz1N7uq7Q==" 1309 | }, 1310 | "long": { 1311 | "version": "4.0.0", 1312 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 1313 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 1314 | }, 1315 | "lru-cache": { 1316 | "version": "6.0.0", 1317 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1318 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1319 | "requires": { 1320 | "yallist": "^4.0.0" 1321 | } 1322 | }, 1323 | "minimatch": { 1324 | "version": "3.0.4", 1325 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1326 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1327 | "dev": true, 1328 | "requires": { 1329 | "brace-expansion": "^1.1.7" 1330 | } 1331 | }, 1332 | "moment": { 1333 | "version": "2.29.4", 1334 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz", 1335 | "integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==" 1336 | }, 1337 | "moment-timezone": { 1338 | "version": "0.5.37", 1339 | "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.37.tgz", 1340 | "integrity": "sha512-uEDzDNFhfaywRl+vwXxffjjq1q0Vzr+fcQpQ1bU0kbzorfS7zVtZnCnGc8mhWmF39d4g4YriF6kwA75mJKE/Zg==", 1341 | "requires": { 1342 | "moment": ">= 2.9.0" 1343 | } 1344 | }, 1345 | "ms": { 1346 | "version": "2.1.3", 1347 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1348 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1349 | "dev": true 1350 | }, 1351 | "mysql2": { 1352 | "version": "2.2.5", 1353 | "resolved": "https://registry.npmjs.org/mysql2/-/mysql2-2.2.5.tgz", 1354 | "integrity": "sha512-XRqPNxcZTpmFdXbJqb+/CtYVLCx14x1RTeNMD4954L331APu75IC74GDqnZMEt1kwaXy6TySo55rF2F3YJS78g==", 1355 | "requires": { 1356 | "denque": "^1.4.1", 1357 | "generate-function": "^2.3.1", 1358 | "iconv-lite": "^0.6.2", 1359 | "long": "^4.0.0", 1360 | "lru-cache": "^6.0.0", 1361 | "named-placeholders": "^1.1.2", 1362 | "seq-queue": "^0.0.5", 1363 | "sqlstring": "^2.3.2" 1364 | } 1365 | }, 1366 | "named-placeholders": { 1367 | "version": "1.1.2", 1368 | "resolved": "https://registry.npmjs.org/named-placeholders/-/named-placeholders-1.1.2.tgz", 1369 | "integrity": "sha512-wiFWqxoLL3PGVReSZpjLVxyJ1bRqe+KKJVbr4hGs1KWfTZTQyezHFBbuKj9hsizHyGV2ne7EMjHdxEGAybD5SA==", 1370 | "requires": { 1371 | "lru-cache": "^4.1.3" 1372 | }, 1373 | "dependencies": { 1374 | "lru-cache": { 1375 | "version": "4.1.5", 1376 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", 1377 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", 1378 | "requires": { 1379 | "pseudomap": "^1.0.2", 1380 | "yallist": "^2.1.2" 1381 | } 1382 | }, 1383 | "yallist": { 1384 | "version": "2.1.2", 1385 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 1386 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 1387 | } 1388 | } 1389 | }, 1390 | "nodemon": { 1391 | "version": "2.0.19", 1392 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.19.tgz", 1393 | "integrity": "sha512-4pv1f2bMDj0Eeg/MhGqxrtveeQ5/G/UVe9iO6uTZzjnRluSA4PVWf8CW99LUPwGB3eNIA7zUFoP77YuI7hOc0A==", 1394 | "dev": true, 1395 | "requires": { 1396 | "chokidar": "^3.5.2", 1397 | "debug": "^3.2.7", 1398 | "ignore-by-default": "^1.0.1", 1399 | "minimatch": "^3.0.4", 1400 | "pstree.remy": "^1.1.8", 1401 | "semver": "^5.7.1", 1402 | "simple-update-notifier": "^1.0.7", 1403 | "supports-color": "^5.5.0", 1404 | "touch": "^3.1.0", 1405 | "undefsafe": "^2.0.5" 1406 | } 1407 | }, 1408 | "nopt": { 1409 | "version": "1.0.10", 1410 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1411 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 1412 | "dev": true, 1413 | "requires": { 1414 | "abbrev": "1" 1415 | } 1416 | }, 1417 | "normalize-path": { 1418 | "version": "3.0.0", 1419 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1420 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1421 | "dev": true 1422 | }, 1423 | "peek-readable": { 1424 | "version": "5.0.0", 1425 | "resolved": "https://registry.npmjs.org/peek-readable/-/peek-readable-5.0.0.tgz", 1426 | "integrity": "sha512-YtCKvLUOvwtMGmrniQPdO7MwPjgkFBtFIrmfSbYmYuq3tKDV/mcfAhBth1+C3ru7uXIZasc/pHnb+YDYNkkj4A==" 1427 | }, 1428 | "picomatch": { 1429 | "version": "2.3.0", 1430 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 1431 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 1432 | "dev": true 1433 | }, 1434 | "pseudomap": { 1435 | "version": "1.0.2", 1436 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 1437 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 1438 | }, 1439 | "pstree.remy": { 1440 | "version": "1.1.8", 1441 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1442 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 1443 | "dev": true 1444 | }, 1445 | "readable-stream": { 1446 | "version": "3.6.0", 1447 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 1448 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 1449 | "requires": { 1450 | "inherits": "^2.0.3", 1451 | "string_decoder": "^1.1.1", 1452 | "util-deprecate": "^1.0.1" 1453 | } 1454 | }, 1455 | "readable-web-to-node-stream": { 1456 | "version": "3.0.2", 1457 | "resolved": "https://registry.npmjs.org/readable-web-to-node-stream/-/readable-web-to-node-stream-3.0.2.tgz", 1458 | "integrity": "sha512-ePeK6cc1EcKLEhJFt/AebMCLL+GgSKhuygrZ/GLaKZYEecIgIECf4UaUuaByiGtzckwR4ain9VzUh95T1exYGw==", 1459 | "requires": { 1460 | "readable-stream": "^3.6.0" 1461 | } 1462 | }, 1463 | "readdirp": { 1464 | "version": "3.6.0", 1465 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1466 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1467 | "dev": true, 1468 | "requires": { 1469 | "picomatch": "^2.2.1" 1470 | } 1471 | }, 1472 | "retry-as-promised": { 1473 | "version": "3.2.0", 1474 | "resolved": "https://registry.npmjs.org/retry-as-promised/-/retry-as-promised-3.2.0.tgz", 1475 | "integrity": "sha512-CybGs60B7oYU/qSQ6kuaFmRd9sTZ6oXSc0toqePvV74Ac6/IFZSI1ReFQmtCN+uvW1Mtqdwpvt/LGOiCBAY2Mg==", 1476 | "requires": { 1477 | "any-promise": "^1.3.0" 1478 | } 1479 | }, 1480 | "safe-buffer": { 1481 | "version": "5.2.1", 1482 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1483 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 1484 | }, 1485 | "safer-buffer": { 1486 | "version": "2.1.2", 1487 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1488 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1489 | }, 1490 | "semver": { 1491 | "version": "5.7.1", 1492 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1493 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1494 | "dev": true 1495 | }, 1496 | "seq-queue": { 1497 | "version": "0.0.5", 1498 | "resolved": "https://registry.npmjs.org/seq-queue/-/seq-queue-0.0.5.tgz", 1499 | "integrity": "sha1-1WgS4cAXpuTnw+Ojeh2m143TyT4=" 1500 | }, 1501 | "sequelize": { 1502 | "version": "6.6.5", 1503 | "resolved": "https://registry.npmjs.org/sequelize/-/sequelize-6.6.5.tgz", 1504 | "integrity": "sha512-QyRrJrDRiwuiILqTMHUA1yWOPIL12KlfmgZ3hnzQwbMvp2vJ6fzu9bYJQB+qPMosck4mBUggY4Cjoc6Et8FBIQ==", 1505 | "requires": { 1506 | "debug": "^4.1.1", 1507 | "dottie": "^2.0.0", 1508 | "inflection": "1.13.1", 1509 | "lodash": "^4.17.20", 1510 | "moment": "^2.26.0", 1511 | "moment-timezone": "^0.5.31", 1512 | "retry-as-promised": "^3.2.0", 1513 | "semver": "^7.3.2", 1514 | "sequelize-pool": "^6.0.0", 1515 | "toposort-class": "^1.0.1", 1516 | "uuid": "^8.1.0", 1517 | "validator": "^13.6.0", 1518 | "wkx": "^0.5.0" 1519 | }, 1520 | "dependencies": { 1521 | "debug": { 1522 | "version": "4.3.2", 1523 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 1524 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 1525 | "requires": { 1526 | "ms": "2.1.2" 1527 | } 1528 | }, 1529 | "ms": { 1530 | "version": "2.1.2", 1531 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1532 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1533 | }, 1534 | "semver": { 1535 | "version": "7.3.5", 1536 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 1537 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 1538 | "requires": { 1539 | "lru-cache": "^6.0.0" 1540 | } 1541 | } 1542 | } 1543 | }, 1544 | "sequelize-pool": { 1545 | "version": "6.1.0", 1546 | "resolved": "https://registry.npmjs.org/sequelize-pool/-/sequelize-pool-6.1.0.tgz", 1547 | "integrity": "sha512-4YwEw3ZgK/tY/so+GfnSgXkdwIJJ1I32uZJztIEgZeAO6HMgj64OzySbWLgxj+tXhZCJnzRfkY9gINw8Ft8ZMg==" 1548 | }, 1549 | "simple-update-notifier": { 1550 | "version": "1.0.7", 1551 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-1.0.7.tgz", 1552 | "integrity": "sha512-BBKgR84BJQJm6WjWFMHgLVuo61FBDSj1z/xSFUIozqO6wO7ii0JxCqlIud7Enr/+LhlbNI0whErq96P2qHNWew==", 1553 | "dev": true, 1554 | "requires": { 1555 | "semver": "~7.0.0" 1556 | }, 1557 | "dependencies": { 1558 | "semver": { 1559 | "version": "7.0.0", 1560 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz", 1561 | "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==", 1562 | "dev": true 1563 | } 1564 | } 1565 | }, 1566 | "sqlstring": { 1567 | "version": "2.3.2", 1568 | "resolved": "https://registry.npmjs.org/sqlstring/-/sqlstring-2.3.2.tgz", 1569 | "integrity": "sha512-vF4ZbYdKS8OnoJAWBmMxCQDkiEBkGQYU7UZPtL8flbDRSNkhaXvRJ279ZtI6M+zDaQovVU4tuRgzK5fVhvFAhg==" 1570 | }, 1571 | "string_decoder": { 1572 | "version": "1.3.0", 1573 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 1574 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 1575 | "requires": { 1576 | "safe-buffer": "~5.2.0" 1577 | } 1578 | }, 1579 | "strtok3": { 1580 | "version": "7.0.0", 1581 | "resolved": "https://registry.npmjs.org/strtok3/-/strtok3-7.0.0.tgz", 1582 | "integrity": "sha512-pQ+V+nYQdC5H3Q7qBZAz/MO6lwGhoC2gOAjuouGf/VO0m7vQRh8QNMl2Uf6SwAtzZ9bOw3UIeBukEGNJl5dtXQ==", 1583 | "requires": { 1584 | "@tokenizer/token": "^0.3.0", 1585 | "peek-readable": "^5.0.0" 1586 | } 1587 | }, 1588 | "supports-color": { 1589 | "version": "5.5.0", 1590 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1591 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1592 | "dev": true, 1593 | "requires": { 1594 | "has-flag": "^3.0.0" 1595 | } 1596 | }, 1597 | "to-regex-range": { 1598 | "version": "5.0.1", 1599 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1600 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1601 | "dev": true, 1602 | "requires": { 1603 | "is-number": "^7.0.0" 1604 | } 1605 | }, 1606 | "token-types": { 1607 | "version": "5.0.1", 1608 | "resolved": "https://registry.npmjs.org/token-types/-/token-types-5.0.1.tgz", 1609 | "integrity": "sha512-Y2fmSnZjQdDb9W4w4r1tswlMHylzWIeOKpx0aZH9BgGtACHhrk3OkT52AzwcuqTRBZtvvnTjDBh8eynMulu8Vg==", 1610 | "requires": { 1611 | "@tokenizer/token": "^0.3.0", 1612 | "ieee754": "^1.2.1" 1613 | } 1614 | }, 1615 | "toposort-class": { 1616 | "version": "1.0.1", 1617 | "resolved": "https://registry.npmjs.org/toposort-class/-/toposort-class-1.0.1.tgz", 1618 | "integrity": "sha1-f/0feMi+KMO6Rc1OGj9e4ZO9mYg=" 1619 | }, 1620 | "touch": { 1621 | "version": "3.1.0", 1622 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1623 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1624 | "dev": true, 1625 | "requires": { 1626 | "nopt": "~1.0.10" 1627 | } 1628 | }, 1629 | "ts-mixer": { 1630 | "version": "6.0.1", 1631 | "resolved": "https://registry.npmjs.org/ts-mixer/-/ts-mixer-6.0.1.tgz", 1632 | "integrity": "sha512-hvE+ZYXuINrx6Ei6D6hz+PTim0Uf++dYbK9FFifLNwQj+RwKquhQpn868yZsCtJYiclZF1u8l6WZxxKi+vv7Rg==" 1633 | }, 1634 | "tslib": { 1635 | "version": "2.4.0", 1636 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz", 1637 | "integrity": "sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==" 1638 | }, 1639 | "undefsafe": { 1640 | "version": "2.0.5", 1641 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 1642 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 1643 | "dev": true 1644 | }, 1645 | "undici": { 1646 | "version": "5.10.0", 1647 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.10.0.tgz", 1648 | "integrity": "sha512-c8HsD3IbwmjjbLvoZuRI26TZic+TSEe8FPMLLOkN1AfYRhdjnKBU6yL+IwcSCbdZiX4e5t0lfMDLDCqj4Sq70g==" 1649 | }, 1650 | "util-deprecate": { 1651 | "version": "1.0.2", 1652 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1653 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" 1654 | }, 1655 | "uuid": { 1656 | "version": "8.3.2", 1657 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 1658 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==" 1659 | }, 1660 | "validator": { 1661 | "version": "13.7.0", 1662 | "resolved": "https://registry.npmjs.org/validator/-/validator-13.7.0.tgz", 1663 | "integrity": "sha512-nYXQLCBkpJ8X6ltALua9dRrZDHVYxjJ1wgskNt1lH9fzGjs3tgojGSCBjmEPwkWS1y29+DrizMTW19Pr9uB2nw==" 1664 | }, 1665 | "wkx": { 1666 | "version": "0.5.0", 1667 | "resolved": "https://registry.npmjs.org/wkx/-/wkx-0.5.0.tgz", 1668 | "integrity": "sha512-Xng/d4Ichh8uN4l0FToV/258EjMGU9MGcA0HV2d9B/ZpZB3lqQm7nkOdZdm5GhKtLLhAE7PiVQwN4eN+2YJJUg==", 1669 | "requires": { 1670 | "@types/node": "*" 1671 | } 1672 | }, 1673 | "ws": { 1674 | "version": "8.8.1", 1675 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.8.1.tgz", 1676 | "integrity": "sha512-bGy2JzvzkPowEJV++hF07hAD6niYSr0JzBNo/J29WsB57A2r7Wlc1UFcTR9IzrPvuNVO4B8LGqF8qcpsVOhJCA==", 1677 | "requires": {} 1678 | }, 1679 | "yallist": { 1680 | "version": "4.0.0", 1681 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1682 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1683 | } 1684 | } 1685 | } 1686 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "discord-task-bot", 3 | "version": "1.0.0", 4 | "main": "index.js", 5 | "license": "MIT", 6 | "dependencies": { 7 | "@discordjs/rest": "^1.1.0", 8 | "discord.js": "^14.3.0", 9 | "dotenv": "^8.2.0", 10 | "mysql2": "^2.2.5", 11 | "sequelize": "^6.6.2" 12 | }, 13 | "devDependencies": { 14 | "nodemon": "^2.0.7" 15 | }, 16 | "scripts": { 17 | "dev": "nodemon index", 18 | "lint": "prettier --write \"**/*.+(js|ts|json|sql|md)\"", 19 | "start": "node index.js", 20 | "server": "nodemon src/index" 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /yarn.lock: -------------------------------------------------------------------------------- 1 | # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. 2 | # yarn lockfile v1 3 | 4 | 5 | "@discordjs/builders@^1.2.0": 6 | "integrity" "sha512-ARy4BUTMU+S0ZI6605NDqfWO+qZqV2d/xfY32z3hVSsd9IaAKJBZ1ILTZLy87oIjW8+gUpQmk9Kt0ZP9bmmd8Q==" 7 | "resolved" "https://registry.npmjs.org/@discordjs/builders/-/builders-1.2.0.tgz" 8 | "version" "1.2.0" 9 | dependencies: 10 | "@sapphire/shapeshift" "^3.5.1" 11 | "discord-api-types" "^0.37.3" 12 | "fast-deep-equal" "^3.1.3" 13 | "ts-mixer" "^6.0.1" 14 | "tslib" "^2.4.0" 15 | 16 | "@discordjs/collection@^1.0.1", "@discordjs/collection@^1.1.0": 17 | "integrity" "sha512-PQ2Bv6pnT7aGPCKWbvvNRww5tYCGpggIQVgpuF9TdDPeR6n6vQYxezXiLVOS9z2B62Dp4c+qepQ15SgJbLYtCQ==" 18 | "resolved" "https://registry.npmjs.org/@discordjs/collection/-/collection-1.1.0.tgz" 19 | "version" "1.1.0" 20 | 21 | "@discordjs/rest@^1.1.0": 22 | "integrity" "sha512-yCrthRTQeUyNThQEpCk7bvQJlwQmz6kU0tf3dcWBv2WX3Bncl41x7Wc+v5b5OsIxfNYq38PvVtWircu9jtYZug==" 23 | "resolved" "https://registry.npmjs.org/@discordjs/rest/-/rest-1.1.0.tgz" 24 | "version" "1.1.0" 25 | dependencies: 26 | "@discordjs/collection" "^1.0.1" 27 | "@sapphire/async-queue" "^1.5.0" 28 | "@sapphire/snowflake" "^3.2.2" 29 | "discord-api-types" "^0.37.3" 30 | "file-type" "^17.1.6" 31 | "tslib" "^2.4.0" 32 | "undici" "^5.9.1" 33 | 34 | "@sapphire/async-queue@^1.5.0": 35 | "integrity" "sha512-JkLdIsP8fPAdh9ZZjrbHWR/+mZj0wvKS5ICibcLrRI1j84UmLMshx5n9QmL8b95d4onJ2xxiyugTgSAX7AalmA==" 36 | "resolved" "https://registry.npmjs.org/@sapphire/async-queue/-/async-queue-1.5.0.tgz" 37 | "version" "1.5.0" 38 | 39 | "@sapphire/shapeshift@^3.5.1": 40 | "integrity" "sha512-tu2WLRdo5wotHRvsCkspg3qMiP6ETC3Q1dns1Q5V6zKUki+1itq6AbhMwohF9ZcLoYqg+Y8LkgRRtVxxTQVTBQ==" 41 | "resolved" "https://registry.npmjs.org/@sapphire/shapeshift/-/shapeshift-3.6.0.tgz" 42 | "version" "3.6.0" 43 | dependencies: 44 | "fast-deep-equal" "^3.1.3" 45 | "lodash.uniqwith" "^4.5.0" 46 | 47 | "@sapphire/snowflake@^3.2.2": 48 | "integrity" "sha512-ula2O0kpSZtX9rKXNeQMrHwNd7E4jPDJYUXmEGTFdMRfyfMw+FPyh04oKMjAiDuOi64bYgVkOV3MjK+loImFhQ==" 49 | "resolved" "https://registry.npmjs.org/@sapphire/snowflake/-/snowflake-3.2.2.tgz" 50 | "version" "3.2.2" 51 | 52 | "@tokenizer/token@^0.3.0": 53 | "integrity" "sha512-OvjF+z51L3ov0OyAU0duzsYuvO01PH7x4t6DJx+guahgTnBHkhJdG7soQeTSFLWN3efnHyibZ4Z8l2EuWwJN3A==" 54 | "resolved" "https://registry.npmjs.org/@tokenizer/token/-/token-0.3.0.tgz" 55 | "version" "0.3.0" 56 | 57 | "@types/node@*": 58 | "integrity" "sha512-TmVHsm43br64js9BqHWqiDZA+xMtbUpI1MBIA0EyiBmoV9pcEYFOSdj5fr6enZNfh4fChh+AGOLIzGwJnkshyQ==" 59 | "resolved" "https://registry.npmjs.org/@types/node/-/node-16.4.10.tgz" 60 | "version" "16.4.10" 61 | 62 | "@types/ws@^8.5.3": 63 | "integrity" "sha512-6YOoWjruKj1uLf3INHH7D3qTXwFfEsg1kf3c0uDdSBJwfa/llkwIjrAGV7j7mVgGNbzTQ3HiHKKDXl6bJPD97w==" 64 | "resolved" "https://registry.npmjs.org/@types/ws/-/ws-8.5.3.tgz" 65 | "version" "8.5.3" 66 | dependencies: 67 | "@types/node" "*" 68 | 69 | "abbrev@1": 70 | "integrity" "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 71 | "resolved" "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz" 72 | "version" "1.1.1" 73 | 74 | "any-promise@^1.3.0": 75 | "integrity" "sha1-q8av7tzqUugJzcA3au0845Y10X8=" 76 | "resolved" "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz" 77 | "version" "1.3.0" 78 | 79 | "anymatch@~3.1.2": 80 | "integrity" "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==" 81 | "resolved" "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz" 82 | "version" "3.1.2" 83 | dependencies: 84 | "normalize-path" "^3.0.0" 85 | "picomatch" "^2.0.4" 86 | 87 | "balanced-match@^1.0.0": 88 | "integrity" "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 89 | "resolved" "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz" 90 | "version" "1.0.2" 91 | 92 | "binary-extensions@^2.0.0": 93 | "integrity" "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==" 94 | "resolved" "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz" 95 | "version" "2.2.0" 96 | 97 | "brace-expansion@^1.1.7": 98 | "integrity" "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==" 99 | "resolved" "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz" 100 | "version" "1.1.11" 101 | dependencies: 102 | "balanced-match" "^1.0.0" 103 | "concat-map" "0.0.1" 104 | 105 | "braces@~3.0.2": 106 | "integrity" "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==" 107 | "resolved" "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz" 108 | "version" "3.0.2" 109 | dependencies: 110 | "fill-range" "^7.0.1" 111 | 112 | "chokidar@^3.5.2": 113 | "integrity" "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==" 114 | "resolved" "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz" 115 | "version" "3.5.2" 116 | dependencies: 117 | "anymatch" "~3.1.2" 118 | "braces" "~3.0.2" 119 | "glob-parent" "~5.1.2" 120 | "is-binary-path" "~2.1.0" 121 | "is-glob" "~4.0.1" 122 | "normalize-path" "~3.0.0" 123 | "readdirp" "~3.6.0" 124 | optionalDependencies: 125 | "fsevents" "~2.3.2" 126 | 127 | "concat-map@0.0.1": 128 | "integrity" "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 129 | "resolved" "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz" 130 | "version" "0.0.1" 131 | 132 | "debug@^3.2.7": 133 | "integrity" "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==" 134 | "resolved" "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz" 135 | "version" "3.2.7" 136 | dependencies: 137 | "ms" "^2.1.1" 138 | 139 | "debug@^4.1.1": 140 | "integrity" "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==" 141 | "resolved" "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz" 142 | "version" "4.3.2" 143 | dependencies: 144 | "ms" "2.1.2" 145 | 146 | "denque@^1.4.1": 147 | "integrity" "sha512-CYiCSgIF1p6EUByQPlGkKnP1M9g0ZV3qMIrqMqZqdwazygIA/YP2vrbcyl1h/WppKJTdl1F85cXIle+394iDAQ==" 148 | "resolved" "https://registry.npmjs.org/denque/-/denque-1.5.0.tgz" 149 | "version" "1.5.0" 150 | 151 | "discord-api-types@^0.37.3": 152 | "integrity" "sha512-RhzoX02jw2M+n/AU5K74KTM4J8Sn3ZImUJvoA4lh+SDcrqi1ddSjrafciF4bECj4rPc2vHwoyyTNgbUwE8vbpA==" 153 | "resolved" "https://registry.npmjs.org/discord-api-types/-/discord-api-types-0.37.5.tgz" 154 | "version" "0.37.5" 155 | 156 | "discord.js@^14.3.0": 157 | "integrity" "sha512-CpIwoAAuELiHSgVKRMzsCADS6ZlJwAZ9RlvcJYdEgS00aW36dSvXyBgE+S3pigkc7G+jU6BEalMUWIJFveqrBQ==" 158 | "resolved" "https://registry.npmjs.org/discord.js/-/discord.js-14.3.0.tgz" 159 | "version" "14.3.0" 160 | dependencies: 161 | "@discordjs/builders" "^1.2.0" 162 | "@discordjs/collection" "^1.1.0" 163 | "@discordjs/rest" "^1.1.0" 164 | "@sapphire/snowflake" "^3.2.2" 165 | "@types/ws" "^8.5.3" 166 | "discord-api-types" "^0.37.3" 167 | "fast-deep-equal" "^3.1.3" 168 | "lodash.snakecase" "^4.1.1" 169 | "tslib" "^2.4.0" 170 | "undici" "^5.9.1" 171 | "ws" "^8.8.1" 172 | 173 | "dotenv@^8.2.0": 174 | "integrity" "sha512-IrPdXQsk2BbzvCBGBOTmmSH5SodmqZNt4ERAZDmW4CT+tL8VtvinqywuANaFu4bOMWki16nqf0e4oC0QIaDr/g==" 175 | "resolved" "https://registry.npmjs.org/dotenv/-/dotenv-8.6.0.tgz" 176 | "version" "8.6.0" 177 | 178 | "dottie@^2.0.0": 179 | "integrity" "sha512-fmrwR04lsniq/uSr8yikThDTrM7epXHBAAjH9TbeH3rEA8tdCO7mRzB9hdmdGyJCxF8KERo9CITcm3kGuoyMhg==" 180 | "resolved" "https://registry.npmjs.org/dottie/-/dottie-2.0.2.tgz" 181 | "version" "2.0.2" 182 | 183 | "fast-deep-equal@^3.1.3": 184 | "integrity" "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==" 185 | "resolved" "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz" 186 | "version" "3.1.3" 187 | 188 | "file-type@^17.1.6": 189 | "integrity" "sha512-hlDw5Ev+9e883s0pwUsuuYNu4tD7GgpUnOvykjv1Gya0ZIjuKumthDRua90VUn6/nlRKAjcxLUnHNTIUWwWIiw==" 190 | "resolved" "https://registry.npmjs.org/file-type/-/file-type-17.1.6.tgz" 191 | "version" "17.1.6" 192 | dependencies: 193 | "readable-web-to-node-stream" "^3.0.2" 194 | "strtok3" "^7.0.0-alpha.9" 195 | "token-types" "^5.0.0-alpha.2" 196 | 197 | "fill-range@^7.0.1": 198 | "integrity" "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==" 199 | "resolved" "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz" 200 | "version" "7.0.1" 201 | dependencies: 202 | "to-regex-range" "^5.0.1" 203 | 204 | "generate-function@^2.3.1": 205 | "integrity" "sha512-eeB5GfMNeevm/GRYq20ShmsaGcmI81kIX2K9XQx5miC8KdHaC6Jm0qQ8ZNeGOi7wYB8OsdxKs+Y2oVuTFuVwKQ==" 206 | "resolved" "https://registry.npmjs.org/generate-function/-/generate-function-2.3.1.tgz" 207 | "version" "2.3.1" 208 | dependencies: 209 | "is-property" "^1.0.2" 210 | 211 | "glob-parent@~5.1.2": 212 | "integrity" "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==" 213 | "resolved" "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz" 214 | "version" "5.1.2" 215 | dependencies: 216 | "is-glob" "^4.0.1" 217 | 218 | "has-flag@^3.0.0": 219 | "integrity" "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 220 | "resolved" "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz" 221 | "version" "3.0.0" 222 | 223 | "iconv-lite@^0.6.2": 224 | "integrity" "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==" 225 | "resolved" "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz" 226 | "version" "0.6.3" 227 | dependencies: 228 | "safer-buffer" ">= 2.1.2 < 3.0.0" 229 | 230 | "ieee754@^1.2.1": 231 | "integrity" "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==" 232 | "resolved" "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz" 233 | "version" "1.2.1" 234 | 235 | "ignore-by-default@^1.0.1": 236 | "integrity" "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=" 237 | "resolved" "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz" 238 | "version" "1.0.1" 239 | 240 | "inflection@1.13.1": 241 | "integrity" "sha512-dldYtl2WlN0QDkIDtg8+xFwOS2Tbmp12t1cHa5/YClU6ZQjTFm7B66UcVbh9NQB+HvT5BAd2t5+yKsBkw5pcqA==" 242 | "resolved" "https://registry.npmjs.org/inflection/-/inflection-1.13.1.tgz" 243 | "version" "1.13.1" 244 | 245 | "inherits@^2.0.3": 246 | "integrity" "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 247 | "resolved" "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz" 248 | "version" "2.0.4" 249 | 250 | "is-binary-path@~2.1.0": 251 | "integrity" "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==" 252 | "resolved" "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz" 253 | "version" "2.1.0" 254 | dependencies: 255 | "binary-extensions" "^2.0.0" 256 | 257 | "is-extglob@^2.1.1": 258 | "integrity" "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" 259 | "resolved" "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz" 260 | "version" "2.1.1" 261 | 262 | "is-glob@^4.0.1", "is-glob@~4.0.1": 263 | "integrity" "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==" 264 | "resolved" "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz" 265 | "version" "4.0.1" 266 | dependencies: 267 | "is-extglob" "^2.1.1" 268 | 269 | "is-number@^7.0.0": 270 | "integrity" "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==" 271 | "resolved" "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz" 272 | "version" "7.0.0" 273 | 274 | "is-property@^1.0.2": 275 | "integrity" "sha1-V/4cTkhHTt1lsJkR8msc1Ald2oQ=" 276 | "resolved" "https://registry.npmjs.org/is-property/-/is-property-1.0.2.tgz" 277 | "version" "1.0.2" 278 | 279 | "lodash.snakecase@^4.1.1": 280 | "integrity" "sha512-QZ1d4xoBHYUeuouhEq3lk3Uq7ldgyFXGBhg04+oRLnIz8o9T65Eh+8YdroUwn846zchkA9yDsDl5CVVaV2nqYw==" 281 | "resolved" "https://registry.npmjs.org/lodash.snakecase/-/lodash.snakecase-4.1.1.tgz" 282 | "version" "4.1.1" 283 | 284 | "lodash.uniqwith@^4.5.0": 285 | "integrity" "sha512-7lYL8bLopMoy4CTICbxygAUq6CdRJ36vFc80DucPueUee+d5NBRxz3FdT9Pes/HEx5mPoT9jwnsEJWz1N7uq7Q==" 286 | "resolved" "https://registry.npmjs.org/lodash.uniqwith/-/lodash.uniqwith-4.5.0.tgz" 287 | "version" "4.5.0" 288 | 289 | "lodash@^4.17.20": 290 | "integrity" "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 291 | "resolved" "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz" 292 | "version" "4.17.21" 293 | 294 | "long@^4.0.0": 295 | "integrity" "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 296 | "resolved" "https://registry.npmjs.org/long/-/long-4.0.0.tgz" 297 | "version" "4.0.0" 298 | 299 | "lru-cache@^4.1.3": 300 | "integrity" "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==" 301 | "resolved" "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz" 302 | "version" "4.1.5" 303 | dependencies: 304 | "pseudomap" "^1.0.2" 305 | "yallist" "^2.1.2" 306 | 307 | "lru-cache@^6.0.0": 308 | "integrity" "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==" 309 | "resolved" "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz" 310 | "version" "6.0.0" 311 | dependencies: 312 | "yallist" "^4.0.0" 313 | 314 | "minimatch@^3.0.4": 315 | "integrity" "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==" 316 | "resolved" "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz" 317 | "version" "3.0.4" 318 | dependencies: 319 | "brace-expansion" "^1.1.7" 320 | 321 | "moment-timezone@^0.5.31": 322 | "integrity" "sha512-uEDzDNFhfaywRl+vwXxffjjq1q0Vzr+fcQpQ1bU0kbzorfS7zVtZnCnGc8mhWmF39d4g4YriF6kwA75mJKE/Zg==" 323 | "resolved" "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.37.tgz" 324 | "version" "0.5.37" 325 | dependencies: 326 | "moment" ">= 2.9.0" 327 | 328 | "moment@^2.26.0", "moment@>= 2.9.0": 329 | "integrity" "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==" 330 | "resolved" "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz" 331 | "version" "2.29.4" 332 | 333 | "ms@^2.1.1": 334 | "integrity" "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 335 | "resolved" "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" 336 | "version" "2.1.3" 337 | 338 | "ms@2.1.2": 339 | "integrity" "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 340 | "resolved" "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz" 341 | "version" "2.1.2" 342 | 343 | "mysql2@^2.2.5": 344 | "integrity" "sha512-XRqPNxcZTpmFdXbJqb+/CtYVLCx14x1RTeNMD4954L331APu75IC74GDqnZMEt1kwaXy6TySo55rF2F3YJS78g==" 345 | "resolved" "https://registry.npmjs.org/mysql2/-/mysql2-2.2.5.tgz" 346 | "version" "2.2.5" 347 | dependencies: 348 | "denque" "^1.4.1" 349 | "generate-function" "^2.3.1" 350 | "iconv-lite" "^0.6.2" 351 | "long" "^4.0.0" 352 | "lru-cache" "^6.0.0" 353 | "named-placeholders" "^1.1.2" 354 | "seq-queue" "^0.0.5" 355 | "sqlstring" "^2.3.2" 356 | 357 | "named-placeholders@^1.1.2": 358 | "integrity" "sha512-wiFWqxoLL3PGVReSZpjLVxyJ1bRqe+KKJVbr4hGs1KWfTZTQyezHFBbuKj9hsizHyGV2ne7EMjHdxEGAybD5SA==" 359 | "resolved" "https://registry.npmjs.org/named-placeholders/-/named-placeholders-1.1.2.tgz" 360 | "version" "1.1.2" 361 | dependencies: 362 | "lru-cache" "^4.1.3" 363 | 364 | "nodemon@^2.0.7": 365 | "integrity" "sha512-4pv1f2bMDj0Eeg/MhGqxrtveeQ5/G/UVe9iO6uTZzjnRluSA4PVWf8CW99LUPwGB3eNIA7zUFoP77YuI7hOc0A==" 366 | "resolved" "https://registry.npmjs.org/nodemon/-/nodemon-2.0.19.tgz" 367 | "version" "2.0.19" 368 | dependencies: 369 | "chokidar" "^3.5.2" 370 | "debug" "^3.2.7" 371 | "ignore-by-default" "^1.0.1" 372 | "minimatch" "^3.0.4" 373 | "pstree.remy" "^1.1.8" 374 | "semver" "^5.7.1" 375 | "simple-update-notifier" "^1.0.7" 376 | "supports-color" "^5.5.0" 377 | "touch" "^3.1.0" 378 | "undefsafe" "^2.0.5" 379 | 380 | "nopt@~1.0.10": 381 | "integrity" "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=" 382 | "resolved" "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz" 383 | "version" "1.0.10" 384 | dependencies: 385 | "abbrev" "1" 386 | 387 | "normalize-path@^3.0.0", "normalize-path@~3.0.0": 388 | "integrity" "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==" 389 | "resolved" "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz" 390 | "version" "3.0.0" 391 | 392 | "peek-readable@^5.0.0": 393 | "integrity" "sha512-YtCKvLUOvwtMGmrniQPdO7MwPjgkFBtFIrmfSbYmYuq3tKDV/mcfAhBth1+C3ru7uXIZasc/pHnb+YDYNkkj4A==" 394 | "resolved" "https://registry.npmjs.org/peek-readable/-/peek-readable-5.0.0.tgz" 395 | "version" "5.0.0" 396 | 397 | "picomatch@^2.0.4", "picomatch@^2.2.1": 398 | "integrity" "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==" 399 | "resolved" "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz" 400 | "version" "2.3.0" 401 | 402 | "pseudomap@^1.0.2": 403 | "integrity" "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 404 | "resolved" "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz" 405 | "version" "1.0.2" 406 | 407 | "pstree.remy@^1.1.8": 408 | "integrity" "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==" 409 | "resolved" "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz" 410 | "version" "1.1.8" 411 | 412 | "readable-stream@^3.6.0": 413 | "integrity" "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==" 414 | "resolved" "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz" 415 | "version" "3.6.0" 416 | dependencies: 417 | "inherits" "^2.0.3" 418 | "string_decoder" "^1.1.1" 419 | "util-deprecate" "^1.0.1" 420 | 421 | "readable-web-to-node-stream@^3.0.2": 422 | "integrity" "sha512-ePeK6cc1EcKLEhJFt/AebMCLL+GgSKhuygrZ/GLaKZYEecIgIECf4UaUuaByiGtzckwR4ain9VzUh95T1exYGw==" 423 | "resolved" "https://registry.npmjs.org/readable-web-to-node-stream/-/readable-web-to-node-stream-3.0.2.tgz" 424 | "version" "3.0.2" 425 | dependencies: 426 | "readable-stream" "^3.6.0" 427 | 428 | "readdirp@~3.6.0": 429 | "integrity" "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==" 430 | "resolved" "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz" 431 | "version" "3.6.0" 432 | dependencies: 433 | "picomatch" "^2.2.1" 434 | 435 | "retry-as-promised@^3.2.0": 436 | "integrity" "sha512-CybGs60B7oYU/qSQ6kuaFmRd9sTZ6oXSc0toqePvV74Ac6/IFZSI1ReFQmtCN+uvW1Mtqdwpvt/LGOiCBAY2Mg==" 437 | "resolved" "https://registry.npmjs.org/retry-as-promised/-/retry-as-promised-3.2.0.tgz" 438 | "version" "3.2.0" 439 | dependencies: 440 | "any-promise" "^1.3.0" 441 | 442 | "safe-buffer@~5.2.0": 443 | "integrity" "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 444 | "resolved" "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz" 445 | "version" "5.2.1" 446 | 447 | "safer-buffer@>= 2.1.2 < 3.0.0": 448 | "integrity" "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 449 | "resolved" "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz" 450 | "version" "2.1.2" 451 | 452 | "semver@^5.7.1": 453 | "integrity" "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 454 | "resolved" "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz" 455 | "version" "5.7.1" 456 | 457 | "semver@^7.3.2": 458 | "integrity" "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==" 459 | "resolved" "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz" 460 | "version" "7.3.5" 461 | dependencies: 462 | "lru-cache" "^6.0.0" 463 | 464 | "semver@~7.0.0": 465 | "integrity" "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==" 466 | "resolved" "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz" 467 | "version" "7.0.0" 468 | 469 | "seq-queue@^0.0.5": 470 | "integrity" "sha1-1WgS4cAXpuTnw+Ojeh2m143TyT4=" 471 | "resolved" "https://registry.npmjs.org/seq-queue/-/seq-queue-0.0.5.tgz" 472 | "version" "0.0.5" 473 | 474 | "sequelize-pool@^6.0.0": 475 | "integrity" "sha512-4YwEw3ZgK/tY/so+GfnSgXkdwIJJ1I32uZJztIEgZeAO6HMgj64OzySbWLgxj+tXhZCJnzRfkY9gINw8Ft8ZMg==" 476 | "resolved" "https://registry.npmjs.org/sequelize-pool/-/sequelize-pool-6.1.0.tgz" 477 | "version" "6.1.0" 478 | 479 | "sequelize@^6.6.2": 480 | "integrity" "sha512-QyRrJrDRiwuiILqTMHUA1yWOPIL12KlfmgZ3hnzQwbMvp2vJ6fzu9bYJQB+qPMosck4mBUggY4Cjoc6Et8FBIQ==" 481 | "resolved" "https://registry.npmjs.org/sequelize/-/sequelize-6.6.5.tgz" 482 | "version" "6.6.5" 483 | dependencies: 484 | "debug" "^4.1.1" 485 | "dottie" "^2.0.0" 486 | "inflection" "1.13.1" 487 | "lodash" "^4.17.20" 488 | "moment" "^2.26.0" 489 | "moment-timezone" "^0.5.31" 490 | "retry-as-promised" "^3.2.0" 491 | "semver" "^7.3.2" 492 | "sequelize-pool" "^6.0.0" 493 | "toposort-class" "^1.0.1" 494 | "uuid" "^8.1.0" 495 | "validator" "^13.6.0" 496 | "wkx" "^0.5.0" 497 | 498 | "simple-update-notifier@^1.0.7": 499 | "integrity" "sha512-BBKgR84BJQJm6WjWFMHgLVuo61FBDSj1z/xSFUIozqO6wO7ii0JxCqlIud7Enr/+LhlbNI0whErq96P2qHNWew==" 500 | "resolved" "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-1.0.7.tgz" 501 | "version" "1.0.7" 502 | dependencies: 503 | "semver" "~7.0.0" 504 | 505 | "sqlstring@^2.3.2": 506 | "integrity" "sha512-vF4ZbYdKS8OnoJAWBmMxCQDkiEBkGQYU7UZPtL8flbDRSNkhaXvRJ279ZtI6M+zDaQovVU4tuRgzK5fVhvFAhg==" 507 | "resolved" "https://registry.npmjs.org/sqlstring/-/sqlstring-2.3.2.tgz" 508 | "version" "2.3.2" 509 | 510 | "string_decoder@^1.1.1": 511 | "integrity" "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==" 512 | "resolved" "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz" 513 | "version" "1.3.0" 514 | dependencies: 515 | "safe-buffer" "~5.2.0" 516 | 517 | "strtok3@^7.0.0-alpha.9": 518 | "integrity" "sha512-pQ+V+nYQdC5H3Q7qBZAz/MO6lwGhoC2gOAjuouGf/VO0m7vQRh8QNMl2Uf6SwAtzZ9bOw3UIeBukEGNJl5dtXQ==" 519 | "resolved" "https://registry.npmjs.org/strtok3/-/strtok3-7.0.0.tgz" 520 | "version" "7.0.0" 521 | dependencies: 522 | "@tokenizer/token" "^0.3.0" 523 | "peek-readable" "^5.0.0" 524 | 525 | "supports-color@^5.5.0": 526 | "integrity" "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==" 527 | "resolved" "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz" 528 | "version" "5.5.0" 529 | dependencies: 530 | "has-flag" "^3.0.0" 531 | 532 | "to-regex-range@^5.0.1": 533 | "integrity" "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==" 534 | "resolved" "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz" 535 | "version" "5.0.1" 536 | dependencies: 537 | "is-number" "^7.0.0" 538 | 539 | "token-types@^5.0.0-alpha.2": 540 | "integrity" "sha512-Y2fmSnZjQdDb9W4w4r1tswlMHylzWIeOKpx0aZH9BgGtACHhrk3OkT52AzwcuqTRBZtvvnTjDBh8eynMulu8Vg==" 541 | "resolved" "https://registry.npmjs.org/token-types/-/token-types-5.0.1.tgz" 542 | "version" "5.0.1" 543 | dependencies: 544 | "@tokenizer/token" "^0.3.0" 545 | "ieee754" "^1.2.1" 546 | 547 | "toposort-class@^1.0.1": 548 | "integrity" "sha1-f/0feMi+KMO6Rc1OGj9e4ZO9mYg=" 549 | "resolved" "https://registry.npmjs.org/toposort-class/-/toposort-class-1.0.1.tgz" 550 | "version" "1.0.1" 551 | 552 | "touch@^3.1.0": 553 | "integrity" "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==" 554 | "resolved" "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz" 555 | "version" "3.1.0" 556 | dependencies: 557 | "nopt" "~1.0.10" 558 | 559 | "ts-mixer@^6.0.1": 560 | "integrity" "sha512-hvE+ZYXuINrx6Ei6D6hz+PTim0Uf++dYbK9FFifLNwQj+RwKquhQpn868yZsCtJYiclZF1u8l6WZxxKi+vv7Rg==" 561 | "resolved" "https://registry.npmjs.org/ts-mixer/-/ts-mixer-6.0.1.tgz" 562 | "version" "6.0.1" 563 | 564 | "tslib@^2.4.0": 565 | "integrity" "sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==" 566 | "resolved" "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz" 567 | "version" "2.4.0" 568 | 569 | "undefsafe@^2.0.5": 570 | "integrity" "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==" 571 | "resolved" "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz" 572 | "version" "2.0.5" 573 | 574 | "undici@^5.9.1": 575 | "integrity" "sha512-c8HsD3IbwmjjbLvoZuRI26TZic+TSEe8FPMLLOkN1AfYRhdjnKBU6yL+IwcSCbdZiX4e5t0lfMDLDCqj4Sq70g==" 576 | "resolved" "https://registry.npmjs.org/undici/-/undici-5.10.0.tgz" 577 | "version" "5.10.0" 578 | 579 | "util-deprecate@^1.0.1": 580 | "integrity" "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" 581 | "resolved" "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz" 582 | "version" "1.0.2" 583 | 584 | "uuid@^8.1.0": 585 | "integrity" "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==" 586 | "resolved" "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz" 587 | "version" "8.3.2" 588 | 589 | "validator@^13.6.0": 590 | "integrity" "sha512-nYXQLCBkpJ8X6ltALua9dRrZDHVYxjJ1wgskNt1lH9fzGjs3tgojGSCBjmEPwkWS1y29+DrizMTW19Pr9uB2nw==" 591 | "resolved" "https://registry.npmjs.org/validator/-/validator-13.7.0.tgz" 592 | "version" "13.7.0" 593 | 594 | "wkx@^0.5.0": 595 | "integrity" "sha512-Xng/d4Ichh8uN4l0FToV/258EjMGU9MGcA0HV2d9B/ZpZB3lqQm7nkOdZdm5GhKtLLhAE7PiVQwN4eN+2YJJUg==" 596 | "resolved" "https://registry.npmjs.org/wkx/-/wkx-0.5.0.tgz" 597 | "version" "0.5.0" 598 | dependencies: 599 | "@types/node" "*" 600 | 601 | "ws@^8.8.1": 602 | "integrity" "sha512-bGy2JzvzkPowEJV++hF07hAD6niYSr0JzBNo/J29WsB57A2r7Wlc1UFcTR9IzrPvuNVO4B8LGqF8qcpsVOhJCA==" 603 | "resolved" "https://registry.npmjs.org/ws/-/ws-8.8.1.tgz" 604 | "version" "8.8.1" 605 | 606 | "yallist@^2.1.2": 607 | "integrity" "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 608 | "resolved" "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz" 609 | "version" "2.1.2" 610 | 611 | "yallist@^4.0.0": 612 | "integrity" "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 613 | "resolved" "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz" 614 | "version" "4.0.0" 615 | --------------------------------------------------------------------------------