├── .envexample
├── .gitignore
├── backend
├── config
│ └── db.js
├── controllers
│ ├── goalController.js
│ └── userController.js
├── middleware
│ ├── authMiddleware.js
│ └── errorMiddleware.js
├── models
│ ├── goalModel.js
│ └── userModel.js
├── routes
│ ├── goalRoutes.js
│ └── userRoutes.js
└── server.js
├── frontend
├── .gitignore
├── README.md
├── package-lock.json
├── package.json
├── public
│ ├── favicon.ico
│ ├── index.html
│ ├── logo192.png
│ ├── logo512.png
│ ├── manifest.json
│ └── robots.txt
└── src
│ ├── App.js
│ ├── App.test.js
│ ├── app
│ └── store.js
│ ├── components
│ ├── GoalForm.jsx
│ ├── GoalItem.jsx
│ ├── Header.jsx
│ └── Spinner.jsx
│ ├── features
│ ├── auth
│ │ ├── authService.js
│ │ └── authSlice.js
│ └── goals
│ │ ├── goalService.js
│ │ └── goalSlice.js
│ ├── index.css
│ ├── index.js
│ ├── pages
│ ├── Dashboard.jsx
│ ├── Login.jsx
│ └── Register.jsx
│ ├── serviceWorker.js
│ └── setupTests.js
├── package-lock.json
├── package.json
└── readme.md
/.envexample:
--------------------------------------------------------------------------------
1 | NODE_ENV = development
2 | PORT = 5000
3 | MONGO_URI = mongodb+srv://YOURMONGOURI
4 | JWT_SECRET = abc123
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | node_modules
2 | .env
--------------------------------------------------------------------------------
/backend/config/db.js:
--------------------------------------------------------------------------------
1 | const mongoose = require('mongoose')
2 |
3 | const connectDB = async () => {
4 | try {
5 | const conn = await mongoose.connect(process.env.MONGO_URI)
6 |
7 | console.log(`MongoDB Connected: ${conn.connection.host}`.cyan.underline)
8 | } catch (error) {
9 | console.log(error)
10 | process.exit(1)
11 | }
12 | }
13 |
14 | module.exports = connectDB
15 |
--------------------------------------------------------------------------------
/backend/controllers/goalController.js:
--------------------------------------------------------------------------------
1 | const asyncHandler = require('express-async-handler')
2 |
3 | const Goal = require('../models/goalModel')
4 | const User = require('../models/userModel')
5 |
6 | // @desc Get goals
7 | // @route GET /api/goals
8 | // @access Private
9 | const getGoals = asyncHandler(async (req, res) => {
10 | const goals = await Goal.find({ user: req.user.id })
11 |
12 | res.status(200).json(goals)
13 | })
14 |
15 | // @desc Set goal
16 | // @route POST /api/goals
17 | // @access Private
18 | const setGoal = asyncHandler(async (req, res) => {
19 | if (!req.body.text) {
20 | res.status(400)
21 | throw new Error('Please add a text field')
22 | }
23 |
24 | const goal = await Goal.create({
25 | text: req.body.text,
26 | user: req.user.id,
27 | })
28 |
29 | res.status(200).json(goal)
30 | })
31 |
32 | // @desc Update goal
33 | // @route PUT /api/goals/:id
34 | // @access Private
35 | const updateGoal = asyncHandler(async (req, res) => {
36 | const goal = await Goal.findById(req.params.id)
37 |
38 | if (!goal) {
39 | res.status(400)
40 | throw new Error('Goal not found')
41 | }
42 |
43 | // Check for user
44 | if (!req.user) {
45 | res.status(401)
46 | throw new Error('User not found')
47 | }
48 |
49 | // Make sure the logged in user matches the goal user
50 | if (goal.user.toString() !== req.user.id) {
51 | res.status(401)
52 | throw new Error('User not authorized')
53 | }
54 |
55 | const updatedGoal = await Goal.findByIdAndUpdate(req.params.id, req.body, {
56 | new: true,
57 | })
58 |
59 | res.status(200).json(updatedGoal)
60 | })
61 |
62 | // @desc Delete goal
63 | // @route DELETE /api/goals/:id
64 | // @access Private
65 | const deleteGoal = asyncHandler(async (req, res) => {
66 | const goal = await Goal.findById(req.params.id)
67 |
68 | if (!goal) {
69 | res.status(400)
70 | throw new Error('Goal not found')
71 | }
72 |
73 | // Check for user
74 | if (!req.user) {
75 | res.status(401)
76 | throw new Error('User not found')
77 | }
78 |
79 | // Make sure the logged in user matches the goal user
80 | if (goal.user.toString() !== req.user.id) {
81 | res.status(401)
82 | throw new Error('User not authorized')
83 | }
84 |
85 | await goal.remove()
86 |
87 | res.status(200).json({ id: req.params.id })
88 | })
89 |
90 | module.exports = {
91 | getGoals,
92 | setGoal,
93 | updateGoal,
94 | deleteGoal,
95 | }
96 |
--------------------------------------------------------------------------------
/backend/controllers/userController.js:
--------------------------------------------------------------------------------
1 | const jwt = require('jsonwebtoken')
2 | const bcrypt = require('bcryptjs')
3 | const asyncHandler = require('express-async-handler')
4 | const User = require('../models/userModel')
5 |
6 | // @desc Register new user
7 | // @route POST /api/users
8 | // @access Public
9 | const registerUser = asyncHandler(async (req, res) => {
10 | const { name, email, password } = req.body
11 |
12 | if (!name || !email || !password) {
13 | res.status(400)
14 | throw new Error('Please add all fields')
15 | }
16 |
17 | // Check if user exists
18 | const userExists = await User.findOne({ email })
19 |
20 | if (userExists) {
21 | res.status(400)
22 | throw new Error('User already exists')
23 | }
24 |
25 | // Hash password
26 | const salt = await bcrypt.genSalt(10)
27 | const hashedPassword = await bcrypt.hash(password, salt)
28 |
29 | // Create user
30 | const user = await User.create({
31 | name,
32 | email,
33 | password: hashedPassword,
34 | })
35 |
36 | if (user) {
37 | res.status(201).json({
38 | _id: user.id,
39 | name: user.name,
40 | email: user.email,
41 | token: generateToken(user._id),
42 | })
43 | } else {
44 | res.status(400)
45 | throw new Error('Invalid user data')
46 | }
47 | })
48 |
49 | // @desc Authenticate a user
50 | // @route POST /api/users/login
51 | // @access Public
52 | const loginUser = asyncHandler(async (req, res) => {
53 | const { email, password } = req.body
54 |
55 | // Check for user email
56 | const user = await User.findOne({ email })
57 |
58 | if (user && (await bcrypt.compare(password, user.password))) {
59 | res.json({
60 | _id: user.id,
61 | name: user.name,
62 | email: user.email,
63 | token: generateToken(user._id),
64 | })
65 | } else {
66 | res.status(400)
67 | throw new Error('Invalid credentials')
68 | }
69 | })
70 |
71 | // @desc Get user data
72 | // @route GET /api/users/me
73 | // @access Private
74 | const getMe = asyncHandler(async (req, res) => {
75 | res.status(200).json(req.user)
76 | })
77 |
78 | // Generate JWT
79 | const generateToken = (id) => {
80 | return jwt.sign({ id }, process.env.JWT_SECRET, {
81 | expiresIn: '30d',
82 | })
83 | }
84 |
85 | module.exports = {
86 | registerUser,
87 | loginUser,
88 | getMe,
89 | }
90 |
--------------------------------------------------------------------------------
/backend/middleware/authMiddleware.js:
--------------------------------------------------------------------------------
1 | const jwt = require('jsonwebtoken')
2 | const asyncHandler = require('express-async-handler')
3 | const User = require('../models/userModel')
4 |
5 | const protect = asyncHandler(async (req, res, next) => {
6 | let token
7 |
8 | if (
9 | req.headers.authorization &&
10 | req.headers.authorization.startsWith('Bearer')
11 | ) {
12 | try {
13 | // Get token from header
14 | token = req.headers.authorization.split(' ')[1]
15 |
16 | // Verify token
17 | const decoded = jwt.verify(token, process.env.JWT_SECRET)
18 |
19 | // Get user from the token
20 | req.user = await User.findById(decoded.id).select('-password')
21 |
22 | next()
23 | } catch (error) {
24 | console.log(error)
25 | res.status(401)
26 | throw new Error('Not authorized')
27 | }
28 | }
29 |
30 | if (!token) {
31 | res.status(401)
32 | throw new Error('Not authorized, no token')
33 | }
34 | })
35 |
36 | module.exports = { protect }
37 |
--------------------------------------------------------------------------------
/backend/middleware/errorMiddleware.js:
--------------------------------------------------------------------------------
1 | const errorHandler = (err, req, res, next) => {
2 | const statusCode = res.statusCode ? res.statusCode : 500
3 |
4 | res.status(statusCode)
5 |
6 | res.json({
7 | message: err.message,
8 | stack: process.env.NODE_ENV === 'production' ? null : err.stack,
9 | })
10 | }
11 |
12 | module.exports = {
13 | errorHandler,
14 | }
15 |
--------------------------------------------------------------------------------
/backend/models/goalModel.js:
--------------------------------------------------------------------------------
1 | const mongoose = require('mongoose')
2 |
3 | const goalSchema = mongoose.Schema(
4 | {
5 | user: {
6 | type: mongoose.Schema.Types.ObjectId,
7 | required: true,
8 | ref: 'User',
9 | },
10 | text: {
11 | type: String,
12 | required: [true, 'Please add a text value'],
13 | },
14 | },
15 | {
16 | timestamps: true,
17 | }
18 | )
19 |
20 | module.exports = mongoose.model('Goal', goalSchema)
21 |
--------------------------------------------------------------------------------
/backend/models/userModel.js:
--------------------------------------------------------------------------------
1 | const mongoose = require('mongoose')
2 |
3 | const userSchema = mongoose.Schema(
4 | {
5 | name: {
6 | type: String,
7 | required: [true, 'Please add a name'],
8 | },
9 | email: {
10 | type: String,
11 | required: [true, 'Please add an email'],
12 | unique: true,
13 | },
14 | password: {
15 | type: String,
16 | required: [true, 'Please add a password'],
17 | },
18 | },
19 | {
20 | timestamps: true,
21 | }
22 | )
23 |
24 | module.exports = mongoose.model('User', userSchema)
25 |
--------------------------------------------------------------------------------
/backend/routes/goalRoutes.js:
--------------------------------------------------------------------------------
1 | const express = require('express')
2 | const router = express.Router()
3 | const {
4 | getGoals,
5 | setGoal,
6 | updateGoal,
7 | deleteGoal,
8 | } = require('../controllers/goalController')
9 |
10 | const { protect } = require('../middleware/authMiddleware')
11 |
12 | router.route('/').get(protect, getGoals).post(protect, setGoal)
13 | router.route('/:id').delete(protect, deleteGoal).put(protect, updateGoal)
14 |
15 | module.exports = router
16 |
--------------------------------------------------------------------------------
/backend/routes/userRoutes.js:
--------------------------------------------------------------------------------
1 | const express = require('express')
2 | const router = express.Router()
3 | const {
4 | registerUser,
5 | loginUser,
6 | getMe,
7 | } = require('../controllers/userController')
8 | const { protect } = require('../middleware/authMiddleware')
9 |
10 | router.post('/', registerUser)
11 | router.post('/login', loginUser)
12 | router.get('/me', protect, getMe)
13 |
14 | module.exports = router
15 |
--------------------------------------------------------------------------------
/backend/server.js:
--------------------------------------------------------------------------------
1 | const path = require('path');
2 | const express = require('express');
3 | const colors = require('colors');
4 | const dotenv = require('dotenv').config();
5 | const { errorHandler } = require('./middleware/errorMiddleware');
6 | const connectDB = require('./config/db');
7 | const port = process.env.PORT || 5000;
8 |
9 | connectDB();
10 |
11 | const app = express();
12 |
13 | app.use(express.json());
14 | app.use(express.urlencoded({ extended: false }));
15 |
16 | app.use('/api/goals', require('./routes/goalRoutes'));
17 | app.use('/api/users', require('./routes/userRoutes'));
18 |
19 | // Serve frontend
20 | if (process.env.NODE_ENV === 'production') {
21 | app.use(express.static(path.join(__dirname, '../frontend/build')));
22 |
23 | app.get('*', (req, res) =>
24 | res.sendFile(
25 | path.resolve(__dirname, '../', 'frontend', 'build', 'index.html')
26 | )
27 | );
28 | } else {
29 | app.get('/', (req, res) => res.send('Please set to production'));
30 | }
31 |
32 | app.use(errorHandler);
33 |
34 | app.listen(port, () => console.log(`Server started on port ${port}`));
35 |
--------------------------------------------------------------------------------
/frontend/.gitignore:
--------------------------------------------------------------------------------
1 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
2 |
3 | # dependencies
4 | /node_modules
5 | /.pnp
6 | .pnp.js
7 |
8 | # testing
9 | /coverage
10 |
11 | # production
12 | /build
13 |
14 | # misc
15 | .DS_Store
16 | .env.local
17 | .env.development.local
18 | .env.test.local
19 | .env.production.local
20 |
21 | npm-debug.log*
22 | yarn-debug.log*
23 | yarn-error.log*
24 |
--------------------------------------------------------------------------------
/frontend/README.md:
--------------------------------------------------------------------------------
1 | This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app), using the [Redux](https://redux.js.org/) and [Redux Toolkit](https://redux-toolkit.js.org/) template.
2 |
3 | ## Available Scripts
4 |
5 | In the project directory, you can run:
6 |
7 | ### `npm start`
8 |
9 | Runs the app in the development mode.
10 | Open [http://localhost:3000](http://localhost:3000) to view it in the browser.
11 |
12 | The page will reload if you make edits.
13 | You will also see any lint errors in the console.
14 |
15 | ### `npm test`
16 |
17 | Launches the test runner in the interactive watch mode.
18 | See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information.
19 |
20 | ### `npm run build`
21 |
22 | Builds the app for production to the `build` folder.
23 | It correctly bundles React in production mode and optimizes the build for the best performance.
24 |
25 | The build is minified and the filenames include the hashes.
26 | Your app is ready to be deployed!
27 |
28 | See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information.
29 |
30 | ### `npm run eject`
31 |
32 | **Note: this is a one-way operation. Once you `eject`, you can’t go back!**
33 |
34 | If you aren’t satisfied with the build tool and configuration choices, you can `eject` at any time. This command will remove the single build dependency from your project.
35 |
36 | Instead, it will copy all the configuration files and the transitive dependencies (Webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except `eject` will still work, but they will point to the copied scripts so you can tweak them. At this point you’re on your own.
37 |
38 | You don’t have to ever use `eject`. The curated feature set is suitable for small and middle deployments, and you shouldn’t feel obligated to use this feature. However we understand that this tool wouldn’t be useful if you couldn’t customize it when you are ready for it.
39 |
40 | ## Learn More
41 |
42 | You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started).
43 |
44 | To learn React, check out the [React documentation](https://reactjs.org/).
45 |
--------------------------------------------------------------------------------
/frontend/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "frontend",
3 | "version": "0.1.0",
4 | "proxy": "http://localhost:5000",
5 | "private": true,
6 | "dependencies": {
7 | "@reduxjs/toolkit": "^1.7.2",
8 | "@testing-library/jest-dom": "^4.2.4",
9 | "@testing-library/react": "^9.5.0",
10 | "@testing-library/user-event": "^7.2.1",
11 | "axios": "^0.25.0",
12 | "react": "^17.0.2",
13 | "react-dom": "^17.0.2",
14 | "react-icons": "^4.3.1",
15 | "react-redux": "^7.2.6",
16 | "react-router-dom": "^6.2.1",
17 | "react-scripts": "5.0.0",
18 | "react-toastify": "^8.1.1"
19 | },
20 | "scripts": {
21 | "start": "react-scripts start",
22 | "build": "react-scripts build",
23 | "test": "react-scripts test",
24 | "eject": "react-scripts eject"
25 | },
26 | "eslintConfig": {
27 | "extends": "react-app"
28 | },
29 | "browserslist": {
30 | "production": [
31 | ">0.2%",
32 | "not dead",
33 | "not op_mini all"
34 | ],
35 | "development": [
36 | "last 1 chrome version",
37 | "last 1 firefox version",
38 | "last 1 safari version"
39 | ]
40 | }
41 | }
42 |
--------------------------------------------------------------------------------
/frontend/public/favicon.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/bradtraversy/mern-tutorial/25809696ae370155977593b49ba2c33b92d7b33b/frontend/public/favicon.ico
--------------------------------------------------------------------------------
/frontend/public/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
12 |
13 |
17 |
18 |
27 | Goalsetter App
28 |
29 |
30 |
31 |
32 |
42 |
43 |
44 |
--------------------------------------------------------------------------------
/frontend/public/logo192.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/bradtraversy/mern-tutorial/25809696ae370155977593b49ba2c33b92d7b33b/frontend/public/logo192.png
--------------------------------------------------------------------------------
/frontend/public/logo512.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/bradtraversy/mern-tutorial/25809696ae370155977593b49ba2c33b92d7b33b/frontend/public/logo512.png
--------------------------------------------------------------------------------
/frontend/public/manifest.json:
--------------------------------------------------------------------------------
1 | {
2 | "short_name": "React App",
3 | "name": "Create React App Sample",
4 | "icons": [
5 | {
6 | "src": "favicon.ico",
7 | "sizes": "64x64 32x32 24x24 16x16",
8 | "type": "image/x-icon"
9 | },
10 | {
11 | "src": "logo192.png",
12 | "type": "image/png",
13 | "sizes": "192x192"
14 | },
15 | {
16 | "src": "logo512.png",
17 | "type": "image/png",
18 | "sizes": "512x512"
19 | }
20 | ],
21 | "start_url": ".",
22 | "display": "standalone",
23 | "theme_color": "#000000",
24 | "background_color": "#ffffff"
25 | }
26 |
--------------------------------------------------------------------------------
/frontend/public/robots.txt:
--------------------------------------------------------------------------------
1 | # https://www.robotstxt.org/robotstxt.html
2 | User-agent: *
3 |
--------------------------------------------------------------------------------
/frontend/src/App.js:
--------------------------------------------------------------------------------
1 | import { BrowserRouter as Router, Routes, Route } from 'react-router-dom'
2 | import { ToastContainer } from 'react-toastify'
3 | import 'react-toastify/dist/ReactToastify.css'
4 | import Header from './components/Header'
5 | import Dashboard from './pages/Dashboard'
6 | import Login from './pages/Login'
7 | import Register from './pages/Register'
8 |
9 | function App() {
10 | return (
11 | <>
12 |
13 |
14 |
15 |
16 | } />
17 | } />
18 | } />
19 |
20 |
21 |
22 |
23 | >
24 | )
25 | }
26 |
27 | export default App
28 |
--------------------------------------------------------------------------------
/frontend/src/App.test.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import { render } from '@testing-library/react';
3 | import { Provider } from 'react-redux';
4 | import { store } from './app/store';
5 | import App from './App';
6 |
7 | test('renders learn react link', () => {
8 | const { getByText } = render(
9 |
10 |
11 |
12 | );
13 |
14 | expect(getByText(/learn/i)).toBeInTheDocument();
15 | });
16 |
--------------------------------------------------------------------------------
/frontend/src/app/store.js:
--------------------------------------------------------------------------------
1 | import { configureStore } from '@reduxjs/toolkit'
2 | import authReducer from '../features/auth/authSlice'
3 | import goalReducer from '../features/goals/goalSlice'
4 |
5 | export const store = configureStore({
6 | reducer: {
7 | auth: authReducer,
8 | goals: goalReducer,
9 | },
10 | })
11 |
--------------------------------------------------------------------------------
/frontend/src/components/GoalForm.jsx:
--------------------------------------------------------------------------------
1 | import { useState } from 'react'
2 | import { useDispatch } from 'react-redux'
3 | import { createGoal } from '../features/goals/goalSlice'
4 |
5 | function GoalForm() {
6 | const [text, setText] = useState('')
7 |
8 | const dispatch = useDispatch()
9 |
10 | const onSubmit = (e) => {
11 | e.preventDefault()
12 |
13 | dispatch(createGoal({ text }))
14 | setText('')
15 | }
16 |
17 | return (
18 |
37 | )
38 | }
39 |
40 | export default GoalForm
41 |
--------------------------------------------------------------------------------
/frontend/src/components/GoalItem.jsx:
--------------------------------------------------------------------------------
1 | import { useDispatch } from 'react-redux'
2 | import { deleteGoal } from '../features/goals/goalSlice'
3 |
4 | function GoalItem({ goal }) {
5 | const dispatch = useDispatch()
6 |
7 | return (
8 |
9 |
{new Date(goal.createdAt).toLocaleString('en-US')}
10 |
{goal.text}
11 |
14 |
15 | )
16 | }
17 |
18 | export default GoalItem
19 |
--------------------------------------------------------------------------------
/frontend/src/components/Header.jsx:
--------------------------------------------------------------------------------
1 | import { FaSignInAlt, FaSignOutAlt, FaUser } from 'react-icons/fa'
2 | import { Link, useNavigate } from 'react-router-dom'
3 | import { useSelector, useDispatch } from 'react-redux'
4 | import { logout, reset } from '../features/auth/authSlice'
5 |
6 | function Header() {
7 | const navigate = useNavigate()
8 | const dispatch = useDispatch()
9 | const { user } = useSelector((state) => state.auth)
10 |
11 | const onLogout = () => {
12 | dispatch(logout())
13 | dispatch(reset())
14 | navigate('/')
15 | }
16 |
17 | return (
18 |
19 |
20 | GoalSetter
21 |
22 |
23 | {user ? (
24 | -
25 |
28 |
29 | ) : (
30 | <>
31 | -
32 |
33 | Login
34 |
35 |
36 | -
37 |
38 | Register
39 |
40 |
41 | >
42 | )}
43 |
44 |
45 | )
46 | }
47 |
48 | export default Header
49 |
--------------------------------------------------------------------------------
/frontend/src/components/Spinner.jsx:
--------------------------------------------------------------------------------
1 | function Spinner() {
2 | return (
3 |
6 | )
7 | }
8 |
9 | export default Spinner
10 |
--------------------------------------------------------------------------------
/frontend/src/features/auth/authService.js:
--------------------------------------------------------------------------------
1 | import axios from 'axios'
2 |
3 | const API_URL = '/api/users/'
4 |
5 | // Register user
6 | const register = async (userData) => {
7 | const response = await axios.post(API_URL, userData)
8 |
9 | if (response.data) {
10 | localStorage.setItem('user', JSON.stringify(response.data))
11 | }
12 |
13 | return response.data
14 | }
15 |
16 | // Login user
17 | const login = async (userData) => {
18 | const response = await axios.post(API_URL + 'login', userData)
19 |
20 | if (response.data) {
21 | localStorage.setItem('user', JSON.stringify(response.data))
22 | }
23 |
24 | return response.data
25 | }
26 |
27 | // Logout user
28 | const logout = () => {
29 | localStorage.removeItem('user')
30 | }
31 |
32 | const authService = {
33 | register,
34 | logout,
35 | login,
36 | }
37 |
38 | export default authService
39 |
--------------------------------------------------------------------------------
/frontend/src/features/auth/authSlice.js:
--------------------------------------------------------------------------------
1 | import { createSlice, createAsyncThunk } from '@reduxjs/toolkit'
2 | import authService from './authService'
3 |
4 | // Get user from localStorage
5 | const user = JSON.parse(localStorage.getItem('user'))
6 |
7 | const initialState = {
8 | user: user ? user : null,
9 | isError: false,
10 | isSuccess: false,
11 | isLoading: false,
12 | message: '',
13 | }
14 |
15 | // Register user
16 | export const register = createAsyncThunk(
17 | 'auth/register',
18 | async (user, thunkAPI) => {
19 | try {
20 | return await authService.register(user)
21 | } catch (error) {
22 | const message =
23 | (error.response &&
24 | error.response.data &&
25 | error.response.data.message) ||
26 | error.message ||
27 | error.toString()
28 | return thunkAPI.rejectWithValue(message)
29 | }
30 | }
31 | )
32 |
33 | // Login user
34 | export const login = createAsyncThunk('auth/login', async (user, thunkAPI) => {
35 | try {
36 | return await authService.login(user)
37 | } catch (error) {
38 | const message =
39 | (error.response && error.response.data && error.response.data.message) ||
40 | error.message ||
41 | error.toString()
42 | return thunkAPI.rejectWithValue(message)
43 | }
44 | })
45 |
46 | export const logout = createAsyncThunk('auth/logout', async () => {
47 | await authService.logout()
48 | })
49 |
50 | export const authSlice = createSlice({
51 | name: 'auth',
52 | initialState,
53 | reducers: {
54 | reset: (state) => {
55 | state.isLoading = false
56 | state.isSuccess = false
57 | state.isError = false
58 | state.message = ''
59 | },
60 | },
61 | extraReducers: (builder) => {
62 | builder
63 | .addCase(register.pending, (state) => {
64 | state.isLoading = true
65 | })
66 | .addCase(register.fulfilled, (state, action) => {
67 | state.isLoading = false
68 | state.isSuccess = true
69 | state.user = action.payload
70 | })
71 | .addCase(register.rejected, (state, action) => {
72 | state.isLoading = false
73 | state.isError = true
74 | state.message = action.payload
75 | state.user = null
76 | })
77 | .addCase(login.pending, (state) => {
78 | state.isLoading = true
79 | })
80 | .addCase(login.fulfilled, (state, action) => {
81 | state.isLoading = false
82 | state.isSuccess = true
83 | state.user = action.payload
84 | })
85 | .addCase(login.rejected, (state, action) => {
86 | state.isLoading = false
87 | state.isError = true
88 | state.message = action.payload
89 | state.user = null
90 | })
91 | .addCase(logout.fulfilled, (state) => {
92 | state.user = null
93 | })
94 | },
95 | })
96 |
97 | export const { reset } = authSlice.actions
98 | export default authSlice.reducer
99 |
--------------------------------------------------------------------------------
/frontend/src/features/goals/goalService.js:
--------------------------------------------------------------------------------
1 | import axios from 'axios'
2 |
3 | const API_URL = '/api/goals/'
4 |
5 | // Create new goal
6 | const createGoal = async (goalData, token) => {
7 | const config = {
8 | headers: {
9 | Authorization: `Bearer ${token}`,
10 | },
11 | }
12 |
13 | const response = await axios.post(API_URL, goalData, config)
14 |
15 | return response.data
16 | }
17 |
18 | // Get user goals
19 | const getGoals = async (token) => {
20 | const config = {
21 | headers: {
22 | Authorization: `Bearer ${token}`,
23 | },
24 | }
25 |
26 | const response = await axios.get(API_URL, config)
27 |
28 | return response.data
29 | }
30 |
31 | // Delete user goal
32 | const deleteGoal = async (goalId, token) => {
33 | const config = {
34 | headers: {
35 | Authorization: `Bearer ${token}`,
36 | },
37 | }
38 |
39 | const response = await axios.delete(API_URL + goalId, config)
40 |
41 | return response.data
42 | }
43 |
44 | const goalService = {
45 | createGoal,
46 | getGoals,
47 | deleteGoal,
48 | }
49 |
50 | export default goalService
51 |
--------------------------------------------------------------------------------
/frontend/src/features/goals/goalSlice.js:
--------------------------------------------------------------------------------
1 | import { createSlice, createAsyncThunk } from '@reduxjs/toolkit'
2 | import goalService from './goalService'
3 |
4 | const initialState = {
5 | goals: [],
6 | isError: false,
7 | isSuccess: false,
8 | isLoading: false,
9 | message: '',
10 | }
11 |
12 | // Create new goal
13 | export const createGoal = createAsyncThunk(
14 | 'goals/create',
15 | async (goalData, thunkAPI) => {
16 | try {
17 | const token = thunkAPI.getState().auth.user.token
18 | return await goalService.createGoal(goalData, token)
19 | } catch (error) {
20 | const message =
21 | (error.response &&
22 | error.response.data &&
23 | error.response.data.message) ||
24 | error.message ||
25 | error.toString()
26 | return thunkAPI.rejectWithValue(message)
27 | }
28 | }
29 | )
30 |
31 | // Get user goals
32 | export const getGoals = createAsyncThunk(
33 | 'goals/getAll',
34 | async (_, thunkAPI) => {
35 | try {
36 | const token = thunkAPI.getState().auth.user.token
37 | return await goalService.getGoals(token)
38 | } catch (error) {
39 | const message =
40 | (error.response &&
41 | error.response.data &&
42 | error.response.data.message) ||
43 | error.message ||
44 | error.toString()
45 | return thunkAPI.rejectWithValue(message)
46 | }
47 | }
48 | )
49 |
50 | // Delete user goal
51 | export const deleteGoal = createAsyncThunk(
52 | 'goals/delete',
53 | async (id, thunkAPI) => {
54 | try {
55 | const token = thunkAPI.getState().auth.user.token
56 | return await goalService.deleteGoal(id, token)
57 | } catch (error) {
58 | const message =
59 | (error.response &&
60 | error.response.data &&
61 | error.response.data.message) ||
62 | error.message ||
63 | error.toString()
64 | return thunkAPI.rejectWithValue(message)
65 | }
66 | }
67 | )
68 |
69 | export const goalSlice = createSlice({
70 | name: 'goal',
71 | initialState,
72 | reducers: {
73 | reset: (state) => initialState,
74 | },
75 | extraReducers: (builder) => {
76 | builder
77 | .addCase(createGoal.pending, (state) => {
78 | state.isLoading = true
79 | })
80 | .addCase(createGoal.fulfilled, (state, action) => {
81 | state.isLoading = false
82 | state.isSuccess = true
83 | state.goals.push(action.payload)
84 | })
85 | .addCase(createGoal.rejected, (state, action) => {
86 | state.isLoading = false
87 | state.isError = true
88 | state.message = action.payload
89 | })
90 | .addCase(getGoals.pending, (state) => {
91 | state.isLoading = true
92 | })
93 | .addCase(getGoals.fulfilled, (state, action) => {
94 | state.isLoading = false
95 | state.isSuccess = true
96 | state.goals = action.payload
97 | })
98 | .addCase(getGoals.rejected, (state, action) => {
99 | state.isLoading = false
100 | state.isError = true
101 | state.message = action.payload
102 | })
103 | .addCase(deleteGoal.pending, (state) => {
104 | state.isLoading = true
105 | })
106 | .addCase(deleteGoal.fulfilled, (state, action) => {
107 | state.isLoading = false
108 | state.isSuccess = true
109 | state.goals = state.goals.filter(
110 | (goal) => goal._id !== action.payload.id
111 | )
112 | })
113 | .addCase(deleteGoal.rejected, (state, action) => {
114 | state.isLoading = false
115 | state.isError = true
116 | state.message = action.payload
117 | })
118 | },
119 | })
120 |
121 | export const { reset } = goalSlice.actions
122 | export default goalSlice.reducer
123 |
--------------------------------------------------------------------------------
/frontend/src/index.css:
--------------------------------------------------------------------------------
1 | @import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600;700&display=swap');
2 |
3 | * {
4 | margin: 0;
5 | padding: 0;
6 | box-sizing: border-box;
7 | }
8 |
9 | body {
10 | font-family: 'Poppins', sans-serif;
11 | height: 100vh;
12 | }
13 |
14 | a {
15 | text-decoration: none;
16 | color: #000;
17 | }
18 |
19 | p {
20 | line-height: 1.7;
21 | }
22 |
23 | ul {
24 | list-style: none;
25 | }
26 |
27 | li {
28 | line-height: 2.2;
29 | }
30 |
31 | h1,
32 | h2,
33 | h3 {
34 | font-weight: 600;
35 | margin-bottom: 10px;
36 | }
37 |
38 | .container {
39 | width: 100%;
40 | max-width: 960px;
41 | margin: 0 auto;
42 | padding: 0 20px;
43 | text-align: center;
44 | }
45 |
46 | .header {
47 | display: flex;
48 | justify-content: space-between;
49 | align-items: center;
50 | padding: 20px 0;
51 | border-bottom: 1px solid #e6e6e6;
52 | margin-bottom: 60px;
53 | }
54 |
55 | .header ul {
56 | display: flex;
57 | align-items: center;
58 | justify-content: space-between;
59 | }
60 |
61 | .header ul li {
62 | margin-left: 20px;
63 | }
64 |
65 | .header ul li a {
66 | display: flex;
67 | align-items: center;
68 | }
69 |
70 | .header ul li a:hover {
71 | color: #777;
72 | }
73 |
74 | .header ul li a svg {
75 | margin-right: 5px;
76 | }
77 |
78 | .heading {
79 | font-size: 2rem;
80 | font-weight: 700;
81 | margin-bottom: 50px;
82 | padding: 0 20px;
83 | }
84 |
85 | .heading p {
86 | color: #828282;
87 | }
88 |
89 | .goals {
90 | display: grid;
91 | grid-template-columns: repeat(2, 1fr);
92 | gap: 10px;
93 | }
94 |
95 | .goal {
96 | background-color: #f4f4f4;
97 | margin: 10px 0;
98 | padding: 20px 0 10px;
99 | position: relative;
100 | }
101 |
102 | .goal .close {
103 | position: absolute;
104 | top: 10px;
105 | right: 15px;
106 | cursor: pointer;
107 | border: none;
108 | background: none;
109 | }
110 |
111 | .form,
112 | .content {
113 | width: 70%;
114 | margin: 0 auto;
115 | }
116 |
117 | .form-group {
118 | margin-bottom: 10px;
119 | }
120 |
121 | .form-group input,
122 | .form-group textarea,
123 | .form-group select {
124 | width: 100%;
125 | padding: 10px;
126 | border: 1px solid #e6e6e6;
127 | border-radius: 5px;
128 | margin-bottom: 10px;
129 | font-family: inherit;
130 | }
131 |
132 | .form-group label {
133 | text-align: left;
134 | display: block;
135 | margin: 0 0 5px 3px;
136 | }
137 |
138 | .btn {
139 | padding: 10px 20px;
140 | border: 1px solid #000;
141 | border-radius: 5px;
142 | background: #000;
143 | color: #fff;
144 | font-size: 16px;
145 | font-weight: 700;
146 | cursor: pointer;
147 | text-align: center;
148 | appearance: button;
149 | display: flex;
150 | align-items: center;
151 | justify-content: center;
152 | }
153 |
154 | .btn svg {
155 | margin-right: 8px;
156 | }
157 |
158 | .btn-reverse {
159 | background: #fff;
160 | color: #000;
161 | }
162 |
163 | .btn-block {
164 | width: 100%;
165 | margin-bottom: 20px;
166 | }
167 |
168 | .btn:hover {
169 | transform: scale(0.98);
170 | }
171 |
172 | .loadingSpinnerContainer {
173 | position: fixed;
174 | top: 0;
175 | right: 0;
176 | bottom: 0;
177 | left: 0;
178 | background-color: rgba(0, 0, 0, 0.5);
179 | z-index: 5000;
180 | display: flex;
181 | justify-content: center;
182 | align-items: center;
183 | }
184 |
185 | .loadingSpinner {
186 | width: 64px;
187 | height: 64px;
188 | border: 8px solid;
189 | border-color: #000 transparent #555 transparent;
190 | border-radius: 50%;
191 | animation: spin 1.2s linear infinite;
192 | }
193 |
194 | @keyframes spin {
195 | 0% {
196 | transform: rotate(0deg);
197 | }
198 | 100% {
199 | transform: rotate(360deg);
200 | }
201 | }
202 |
203 | @media (max-width: 600px) {
204 | .form {
205 | width: 90%;
206 | }
207 |
208 | .heading h1 {
209 | font-size: 2rem;
210 | }
211 |
212 | .heading p {
213 | font-size: 1.5rem;
214 | }
215 | }
216 |
--------------------------------------------------------------------------------
/frontend/src/index.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import ReactDOM from 'react-dom';
3 | import './index.css';
4 | import App from './App';
5 | import { store } from './app/store';
6 | import { Provider } from 'react-redux';
7 | import * as serviceWorker from './serviceWorker';
8 |
9 | ReactDOM.render(
10 |
11 |
12 |
13 |
14 | ,
15 | document.getElementById('root')
16 | );
17 |
18 | // If you want your app to work offline and load faster, you can change
19 | // unregister() to register() below. Note this comes with some pitfalls.
20 | // Learn more about service workers: https://bit.ly/CRA-PWA
21 | serviceWorker.unregister();
22 |
--------------------------------------------------------------------------------
/frontend/src/pages/Dashboard.jsx:
--------------------------------------------------------------------------------
1 | import { useEffect } from 'react'
2 | import { useNavigate } from 'react-router-dom'
3 | import { useSelector, useDispatch } from 'react-redux'
4 | import GoalForm from '../components/GoalForm'
5 | import GoalItem from '../components/GoalItem'
6 | import Spinner from '../components/Spinner'
7 | import { getGoals, reset } from '../features/goals/goalSlice'
8 |
9 | function Dashboard() {
10 | const navigate = useNavigate()
11 | const dispatch = useDispatch()
12 |
13 | const { user } = useSelector((state) => state.auth)
14 | const { goals, isLoading, isError, message } = useSelector(
15 | (state) => state.goals
16 | )
17 |
18 | useEffect(() => {
19 | if (isError) {
20 | console.log(message)
21 | }
22 |
23 | if (!user) {
24 | navigate('/login')
25 | }
26 |
27 | dispatch(getGoals())
28 |
29 | return () => {
30 | dispatch(reset())
31 | }
32 | }, [user, navigate, isError, message, dispatch])
33 |
34 | if (isLoading) {
35 | return
36 | }
37 |
38 | return (
39 | <>
40 |
41 | Welcome {user && user.name}
42 | Goals Dashboard
43 |
44 |
45 |
46 |
47 |
48 | {goals.length > 0 ? (
49 |
50 | {goals.map((goal) => (
51 |
52 | ))}
53 |
54 | ) : (
55 | You have not set any goals
56 | )}
57 |
58 | >
59 | )
60 | }
61 |
62 | export default Dashboard
63 |
--------------------------------------------------------------------------------
/frontend/src/pages/Login.jsx:
--------------------------------------------------------------------------------
1 | import { useState, useEffect } from 'react'
2 | import { FaSignInAlt } from 'react-icons/fa'
3 | import { useSelector, useDispatch } from 'react-redux'
4 | import { useNavigate } from 'react-router-dom'
5 | import { toast } from 'react-toastify'
6 | import { login, reset } from '../features/auth/authSlice'
7 | import Spinner from '../components/Spinner'
8 |
9 | function Login() {
10 | const [formData, setFormData] = useState({
11 | email: '',
12 | password: '',
13 | })
14 |
15 | const { email, password } = formData
16 |
17 | const navigate = useNavigate()
18 | const dispatch = useDispatch()
19 |
20 | const { user, isLoading, isError, isSuccess, message } = useSelector(
21 | (state) => state.auth
22 | )
23 |
24 | useEffect(() => {
25 | if (isError) {
26 | toast.error(message)
27 | }
28 |
29 | if (isSuccess || user) {
30 | navigate('/')
31 | }
32 |
33 | dispatch(reset())
34 | }, [user, isError, isSuccess, message, navigate, dispatch])
35 |
36 | const onChange = (e) => {
37 | setFormData((prevState) => ({
38 | ...prevState,
39 | [e.target.name]: e.target.value,
40 | }))
41 | }
42 |
43 | const onSubmit = (e) => {
44 | e.preventDefault()
45 |
46 | const userData = {
47 | email,
48 | password,
49 | }
50 |
51 | dispatch(login(userData))
52 | }
53 |
54 | if (isLoading) {
55 | return
56 | }
57 |
58 | return (
59 | <>
60 |
61 |
62 | Login
63 |
64 | Login and start setting goals
65 |
66 |
67 |
99 | >
100 | )
101 | }
102 |
103 | export default Login
104 |
--------------------------------------------------------------------------------
/frontend/src/pages/Register.jsx:
--------------------------------------------------------------------------------
1 | import { useState, useEffect } from 'react'
2 | import { useSelector, useDispatch } from 'react-redux'
3 | import { useNavigate } from 'react-router-dom'
4 | import { toast } from 'react-toastify'
5 | import { FaUser } from 'react-icons/fa'
6 | import { register, reset } from '../features/auth/authSlice'
7 | import Spinner from '../components/Spinner'
8 |
9 | function Register() {
10 | const [formData, setFormData] = useState({
11 | name: '',
12 | email: '',
13 | password: '',
14 | password2: '',
15 | })
16 |
17 | const { name, email, password, password2 } = formData
18 |
19 | const navigate = useNavigate()
20 | const dispatch = useDispatch()
21 |
22 | const { user, isLoading, isError, isSuccess, message } = useSelector(
23 | (state) => state.auth
24 | )
25 |
26 | useEffect(() => {
27 | if (isError) {
28 | toast.error(message)
29 | }
30 |
31 | if (isSuccess || user) {
32 | navigate('/')
33 | }
34 |
35 | dispatch(reset())
36 | }, [user, isError, isSuccess, message, navigate, dispatch])
37 |
38 | const onChange = (e) => {
39 | setFormData((prevState) => ({
40 | ...prevState,
41 | [e.target.name]: e.target.value,
42 | }))
43 | }
44 |
45 | const onSubmit = (e) => {
46 | e.preventDefault()
47 |
48 | if (password !== password2) {
49 | toast.error('Passwords do not match')
50 | } else {
51 | const userData = {
52 | name,
53 | email,
54 | password,
55 | }
56 |
57 | dispatch(register(userData))
58 | }
59 | }
60 |
61 | if (isLoading) {
62 | return
63 | }
64 |
65 | return (
66 | <>
67 |
68 |
69 | Register
70 |
71 | Please create an account
72 |
73 |
74 |
127 | >
128 | )
129 | }
130 |
131 | export default Register
132 |
--------------------------------------------------------------------------------
/frontend/src/serviceWorker.js:
--------------------------------------------------------------------------------
1 | // This optional code is used to register a service worker.
2 | // register() is not called by default.
3 |
4 | // This lets the app load faster on subsequent visits in production, and gives
5 | // it offline capabilities. However, it also means that developers (and users)
6 | // will only see deployed updates on subsequent visits to a page, after all the
7 | // existing tabs open on the page have been closed, since previously cached
8 | // resources are updated in the background.
9 |
10 | // To learn more about the benefits of this model and instructions on how to
11 | // opt-in, read https://bit.ly/CRA-PWA
12 |
13 | const isLocalhost = Boolean(
14 | window.location.hostname === 'localhost' ||
15 | // [::1] is the IPv6 localhost address.
16 | window.location.hostname === '[::1]' ||
17 | // 127.0.0.0/8 are considered localhost for IPv4.
18 | window.location.hostname.match(
19 | /^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/
20 | )
21 | );
22 |
23 | export function register(config) {
24 | if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {
25 | // The URL constructor is available in all browsers that support SW.
26 | const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);
27 | if (publicUrl.origin !== window.location.origin) {
28 | // Our service worker won't work if PUBLIC_URL is on a different origin
29 | // from what our page is served on. This might happen if a CDN is used to
30 | // serve assets; see https://github.com/facebook/create-react-app/issues/2374
31 | return;
32 | }
33 |
34 | window.addEventListener('load', () => {
35 | const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;
36 |
37 | if (isLocalhost) {
38 | // This is running on localhost. Let's check if a service worker still exists or not.
39 | checkValidServiceWorker(swUrl, config);
40 |
41 | // Add some additional logging to localhost, pointing developers to the
42 | // service worker/PWA documentation.
43 | navigator.serviceWorker.ready.then(() => {
44 | console.log(
45 | 'This web app is being served cache-first by a service ' +
46 | 'worker. To learn more, visit https://bit.ly/CRA-PWA'
47 | );
48 | });
49 | } else {
50 | // Is not localhost. Just register service worker
51 | registerValidSW(swUrl, config);
52 | }
53 | });
54 | }
55 | }
56 |
57 | function registerValidSW(swUrl, config) {
58 | navigator.serviceWorker
59 | .register(swUrl)
60 | .then((registration) => {
61 | registration.onupdatefound = () => {
62 | const installingWorker = registration.installing;
63 | if (installingWorker == null) {
64 | return;
65 | }
66 | installingWorker.onstatechange = () => {
67 | if (installingWorker.state === 'installed') {
68 | if (navigator.serviceWorker.controller) {
69 | // At this point, the updated precached content has been fetched,
70 | // but the previous service worker will still serve the older
71 | // content until all client tabs are closed.
72 | console.log(
73 | 'New content is available and will be used when all ' +
74 | 'tabs for this page are closed. See https://bit.ly/CRA-PWA.'
75 | );
76 |
77 | // Execute callback
78 | if (config && config.onUpdate) {
79 | config.onUpdate(registration);
80 | }
81 | } else {
82 | // At this point, everything has been precached.
83 | // It's the perfect time to display a
84 | // "Content is cached for offline use." message.
85 | console.log('Content is cached for offline use.');
86 |
87 | // Execute callback
88 | if (config && config.onSuccess) {
89 | config.onSuccess(registration);
90 | }
91 | }
92 | }
93 | };
94 | };
95 | })
96 | .catch((error) => {
97 | console.error('Error during service worker registration:', error);
98 | });
99 | }
100 |
101 | function checkValidServiceWorker(swUrl, config) {
102 | // Check if the service worker can be found. If it can't reload the page.
103 | fetch(swUrl, {
104 | headers: { 'Service-Worker': 'script' },
105 | })
106 | .then((response) => {
107 | // Ensure service worker exists, and that we really are getting a JS file.
108 | const contentType = response.headers.get('content-type');
109 | if (
110 | response.status === 404 ||
111 | (contentType != null && contentType.indexOf('javascript') === -1)
112 | ) {
113 | // No service worker found. Probably a different app. Reload the page.
114 | navigator.serviceWorker.ready.then((registration) => {
115 | registration.unregister().then(() => {
116 | window.location.reload();
117 | });
118 | });
119 | } else {
120 | // Service worker found. Proceed as normal.
121 | registerValidSW(swUrl, config);
122 | }
123 | })
124 | .catch(() => {
125 | console.log(
126 | 'No internet connection found. App is running in offline mode.'
127 | );
128 | });
129 | }
130 |
131 | export function unregister() {
132 | if ('serviceWorker' in navigator) {
133 | navigator.serviceWorker.ready.then((registration) => {
134 | registration.unregister();
135 | });
136 | }
137 | }
138 |
--------------------------------------------------------------------------------
/frontend/src/setupTests.js:
--------------------------------------------------------------------------------
1 | // jest-dom adds custom jest matchers for asserting on DOM nodes.
2 | // allows you to do things like:
3 | // expect(element).toHaveTextContent(/react/i)
4 | // learn more: https://github.com/testing-library/jest-dom
5 | import '@testing-library/jest-dom/extend-expect';
6 |
--------------------------------------------------------------------------------
/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "mern-tutorial",
3 | "version": "1.0.0",
4 | "lockfileVersion": 2,
5 | "requires": true,
6 | "packages": {
7 | "": {
8 | "version": "1.0.0",
9 | "license": "MIT",
10 | "dependencies": {
11 | "bcryptjs": "^2.4.3",
12 | "colors": "^1.4.0",
13 | "dotenv": "^15.0.0",
14 | "express": "^4.17.2",
15 | "express-async-handler": "^1.2.0",
16 | "jsonwebtoken": "^8.5.1",
17 | "mongoose": "^6.1.9"
18 | },
19 | "devDependencies": {
20 | "concurrently": "^7.0.0",
21 | "nodemon": "^2.0.15"
22 | }
23 | },
24 | "node_modules/@sindresorhus/is": {
25 | "version": "0.14.0",
26 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz",
27 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==",
28 | "dev": true,
29 | "engines": {
30 | "node": ">=6"
31 | }
32 | },
33 | "node_modules/@szmarczak/http-timer": {
34 | "version": "1.1.2",
35 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz",
36 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==",
37 | "dev": true,
38 | "dependencies": {
39 | "defer-to-connect": "^1.0.1"
40 | },
41 | "engines": {
42 | "node": ">=6"
43 | }
44 | },
45 | "node_modules/@types/node": {
46 | "version": "17.0.5",
47 | "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.5.tgz",
48 | "integrity": "sha512-w3mrvNXLeDYV1GKTZorGJQivK6XLCoGwpnyJFbJVK/aTBQUxOCaa/GlFAAN3OTDFcb7h5tiFG+YXCO2By+riZw=="
49 | },
50 | "node_modules/@types/webidl-conversions": {
51 | "version": "6.1.1",
52 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-6.1.1.tgz",
53 | "integrity": "sha512-XAahCdThVuCFDQLT7R7Pk/vqeObFNL3YqRyFZg+AqAP/W1/w3xHaIxuW7WszQqTbIBOPRcItYJIou3i/mppu3Q=="
54 | },
55 | "node_modules/@types/whatwg-url": {
56 | "version": "8.2.1",
57 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-8.2.1.tgz",
58 | "integrity": "sha512-2YubE1sjj5ifxievI5Ge1sckb9k/Er66HyR2c+3+I6VDUUg1TLPdYYTEbQ+DjRkS4nTxMJhgWfSfMRD2sl2EYQ==",
59 | "dependencies": {
60 | "@types/node": "*",
61 | "@types/webidl-conversions": "*"
62 | }
63 | },
64 | "node_modules/abbrev": {
65 | "version": "1.1.1",
66 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz",
67 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==",
68 | "dev": true
69 | },
70 | "node_modules/accepts": {
71 | "version": "1.3.7",
72 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz",
73 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==",
74 | "dependencies": {
75 | "mime-types": "~2.1.24",
76 | "negotiator": "0.6.2"
77 | },
78 | "engines": {
79 | "node": ">= 0.6"
80 | }
81 | },
82 | "node_modules/ansi-align": {
83 | "version": "3.0.1",
84 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.1.tgz",
85 | "integrity": "sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w==",
86 | "dev": true,
87 | "dependencies": {
88 | "string-width": "^4.1.0"
89 | }
90 | },
91 | "node_modules/ansi-regex": {
92 | "version": "5.0.1",
93 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
94 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
95 | "dev": true,
96 | "engines": {
97 | "node": ">=8"
98 | }
99 | },
100 | "node_modules/ansi-styles": {
101 | "version": "4.3.0",
102 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
103 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
104 | "dev": true,
105 | "dependencies": {
106 | "color-convert": "^2.0.1"
107 | },
108 | "engines": {
109 | "node": ">=8"
110 | },
111 | "funding": {
112 | "url": "https://github.com/chalk/ansi-styles?sponsor=1"
113 | }
114 | },
115 | "node_modules/anymatch": {
116 | "version": "3.1.2",
117 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz",
118 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==",
119 | "dev": true,
120 | "dependencies": {
121 | "normalize-path": "^3.0.0",
122 | "picomatch": "^2.0.4"
123 | },
124 | "engines": {
125 | "node": ">= 8"
126 | }
127 | },
128 | "node_modules/array-flatten": {
129 | "version": "1.1.1",
130 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
131 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI="
132 | },
133 | "node_modules/balanced-match": {
134 | "version": "1.0.2",
135 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
136 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
137 | "dev": true
138 | },
139 | "node_modules/base64-js": {
140 | "version": "1.5.1",
141 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz",
142 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==",
143 | "funding": [
144 | {
145 | "type": "github",
146 | "url": "https://github.com/sponsors/feross"
147 | },
148 | {
149 | "type": "patreon",
150 | "url": "https://www.patreon.com/feross"
151 | },
152 | {
153 | "type": "consulting",
154 | "url": "https://feross.org/support"
155 | }
156 | ]
157 | },
158 | "node_modules/bcryptjs": {
159 | "version": "2.4.3",
160 | "resolved": "https://registry.npmjs.org/bcryptjs/-/bcryptjs-2.4.3.tgz",
161 | "integrity": "sha1-mrVie5PmBiH/fNrF2pczAn3x0Ms="
162 | },
163 | "node_modules/binary-extensions": {
164 | "version": "2.2.0",
165 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
166 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
167 | "dev": true,
168 | "engines": {
169 | "node": ">=8"
170 | }
171 | },
172 | "node_modules/body-parser": {
173 | "version": "1.19.1",
174 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.1.tgz",
175 | "integrity": "sha512-8ljfQi5eBk8EJfECMrgqNGWPEY5jWP+1IzkzkGdFFEwFQZZyaZ21UqdaHktgiMlH0xLHqIFtE/u2OYE5dOtViA==",
176 | "dependencies": {
177 | "bytes": "3.1.1",
178 | "content-type": "~1.0.4",
179 | "debug": "2.6.9",
180 | "depd": "~1.1.2",
181 | "http-errors": "1.8.1",
182 | "iconv-lite": "0.4.24",
183 | "on-finished": "~2.3.0",
184 | "qs": "6.9.6",
185 | "raw-body": "2.4.2",
186 | "type-is": "~1.6.18"
187 | },
188 | "engines": {
189 | "node": ">= 0.8"
190 | }
191 | },
192 | "node_modules/boxen": {
193 | "version": "5.1.2",
194 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-5.1.2.tgz",
195 | "integrity": "sha512-9gYgQKXx+1nP8mP7CzFyaUARhg7D3n1dF/FnErWmu9l6JvGpNUN278h0aSb+QjoiKSWG+iZ3uHrcqk0qrY9RQQ==",
196 | "dev": true,
197 | "dependencies": {
198 | "ansi-align": "^3.0.0",
199 | "camelcase": "^6.2.0",
200 | "chalk": "^4.1.0",
201 | "cli-boxes": "^2.2.1",
202 | "string-width": "^4.2.2",
203 | "type-fest": "^0.20.2",
204 | "widest-line": "^3.1.0",
205 | "wrap-ansi": "^7.0.0"
206 | },
207 | "engines": {
208 | "node": ">=10"
209 | },
210 | "funding": {
211 | "url": "https://github.com/sponsors/sindresorhus"
212 | }
213 | },
214 | "node_modules/brace-expansion": {
215 | "version": "1.1.11",
216 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
217 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
218 | "dev": true,
219 | "dependencies": {
220 | "balanced-match": "^1.0.0",
221 | "concat-map": "0.0.1"
222 | }
223 | },
224 | "node_modules/braces": {
225 | "version": "3.0.2",
226 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
227 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
228 | "dev": true,
229 | "dependencies": {
230 | "fill-range": "^7.0.1"
231 | },
232 | "engines": {
233 | "node": ">=8"
234 | }
235 | },
236 | "node_modules/bson": {
237 | "version": "4.6.1",
238 | "resolved": "https://registry.npmjs.org/bson/-/bson-4.6.1.tgz",
239 | "integrity": "sha512-I1LQ7Hz5zgwR4QquilLNZwbhPw0Apx7i7X9kGMBTsqPdml/03Q9NBtD9nt/19ahjlphktQImrnderxqpzeVDjw==",
240 | "dependencies": {
241 | "buffer": "^5.6.0"
242 | },
243 | "engines": {
244 | "node": ">=6.9.0"
245 | }
246 | },
247 | "node_modules/buffer": {
248 | "version": "5.7.1",
249 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz",
250 | "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==",
251 | "funding": [
252 | {
253 | "type": "github",
254 | "url": "https://github.com/sponsors/feross"
255 | },
256 | {
257 | "type": "patreon",
258 | "url": "https://www.patreon.com/feross"
259 | },
260 | {
261 | "type": "consulting",
262 | "url": "https://feross.org/support"
263 | }
264 | ],
265 | "dependencies": {
266 | "base64-js": "^1.3.1",
267 | "ieee754": "^1.1.13"
268 | }
269 | },
270 | "node_modules/buffer-equal-constant-time": {
271 | "version": "1.0.1",
272 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz",
273 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk="
274 | },
275 | "node_modules/bytes": {
276 | "version": "3.1.1",
277 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.1.tgz",
278 | "integrity": "sha512-dWe4nWO/ruEOY7HkUJ5gFt1DCFV9zPRoJr8pV0/ASQermOZjtq8jMjOprC0Kd10GLN+l7xaUPvxzJFWtxGu8Fg==",
279 | "engines": {
280 | "node": ">= 0.8"
281 | }
282 | },
283 | "node_modules/cacheable-request": {
284 | "version": "6.1.0",
285 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz",
286 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==",
287 | "dev": true,
288 | "dependencies": {
289 | "clone-response": "^1.0.2",
290 | "get-stream": "^5.1.0",
291 | "http-cache-semantics": "^4.0.0",
292 | "keyv": "^3.0.0",
293 | "lowercase-keys": "^2.0.0",
294 | "normalize-url": "^4.1.0",
295 | "responselike": "^1.0.2"
296 | },
297 | "engines": {
298 | "node": ">=8"
299 | }
300 | },
301 | "node_modules/cacheable-request/node_modules/get-stream": {
302 | "version": "5.2.0",
303 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz",
304 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==",
305 | "dev": true,
306 | "dependencies": {
307 | "pump": "^3.0.0"
308 | },
309 | "engines": {
310 | "node": ">=8"
311 | },
312 | "funding": {
313 | "url": "https://github.com/sponsors/sindresorhus"
314 | }
315 | },
316 | "node_modules/cacheable-request/node_modules/lowercase-keys": {
317 | "version": "2.0.0",
318 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz",
319 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==",
320 | "dev": true,
321 | "engines": {
322 | "node": ">=8"
323 | }
324 | },
325 | "node_modules/camelcase": {
326 | "version": "6.3.0",
327 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz",
328 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==",
329 | "dev": true,
330 | "engines": {
331 | "node": ">=10"
332 | },
333 | "funding": {
334 | "url": "https://github.com/sponsors/sindresorhus"
335 | }
336 | },
337 | "node_modules/chalk": {
338 | "version": "4.1.2",
339 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
340 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
341 | "dev": true,
342 | "dependencies": {
343 | "ansi-styles": "^4.1.0",
344 | "supports-color": "^7.1.0"
345 | },
346 | "engines": {
347 | "node": ">=10"
348 | },
349 | "funding": {
350 | "url": "https://github.com/chalk/chalk?sponsor=1"
351 | }
352 | },
353 | "node_modules/chalk/node_modules/has-flag": {
354 | "version": "4.0.0",
355 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
356 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
357 | "dev": true,
358 | "engines": {
359 | "node": ">=8"
360 | }
361 | },
362 | "node_modules/chalk/node_modules/supports-color": {
363 | "version": "7.2.0",
364 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
365 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
366 | "dev": true,
367 | "dependencies": {
368 | "has-flag": "^4.0.0"
369 | },
370 | "engines": {
371 | "node": ">=8"
372 | }
373 | },
374 | "node_modules/chokidar": {
375 | "version": "3.5.3",
376 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz",
377 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==",
378 | "dev": true,
379 | "funding": [
380 | {
381 | "type": "individual",
382 | "url": "https://paulmillr.com/funding/"
383 | }
384 | ],
385 | "dependencies": {
386 | "anymatch": "~3.1.2",
387 | "braces": "~3.0.2",
388 | "glob-parent": "~5.1.2",
389 | "is-binary-path": "~2.1.0",
390 | "is-glob": "~4.0.1",
391 | "normalize-path": "~3.0.0",
392 | "readdirp": "~3.6.0"
393 | },
394 | "engines": {
395 | "node": ">= 8.10.0"
396 | },
397 | "optionalDependencies": {
398 | "fsevents": "~2.3.2"
399 | }
400 | },
401 | "node_modules/ci-info": {
402 | "version": "2.0.0",
403 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz",
404 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==",
405 | "dev": true
406 | },
407 | "node_modules/cli-boxes": {
408 | "version": "2.2.1",
409 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz",
410 | "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==",
411 | "dev": true,
412 | "engines": {
413 | "node": ">=6"
414 | },
415 | "funding": {
416 | "url": "https://github.com/sponsors/sindresorhus"
417 | }
418 | },
419 | "node_modules/cliui": {
420 | "version": "7.0.4",
421 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz",
422 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==",
423 | "dev": true,
424 | "dependencies": {
425 | "string-width": "^4.2.0",
426 | "strip-ansi": "^6.0.0",
427 | "wrap-ansi": "^7.0.0"
428 | }
429 | },
430 | "node_modules/clone-response": {
431 | "version": "1.0.2",
432 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz",
433 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=",
434 | "dev": true,
435 | "dependencies": {
436 | "mimic-response": "^1.0.0"
437 | }
438 | },
439 | "node_modules/color-convert": {
440 | "version": "2.0.1",
441 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
442 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
443 | "dev": true,
444 | "dependencies": {
445 | "color-name": "~1.1.4"
446 | },
447 | "engines": {
448 | "node": ">=7.0.0"
449 | }
450 | },
451 | "node_modules/color-name": {
452 | "version": "1.1.4",
453 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
454 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
455 | "dev": true
456 | },
457 | "node_modules/colors": {
458 | "version": "1.4.0",
459 | "resolved": "https://registry.npmjs.org/colors/-/colors-1.4.0.tgz",
460 | "integrity": "sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA==",
461 | "engines": {
462 | "node": ">=0.1.90"
463 | }
464 | },
465 | "node_modules/concat-map": {
466 | "version": "0.0.1",
467 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
468 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
469 | "dev": true
470 | },
471 | "node_modules/concurrently": {
472 | "version": "7.0.0",
473 | "resolved": "https://registry.npmjs.org/concurrently/-/concurrently-7.0.0.tgz",
474 | "integrity": "sha512-WKM7PUsI8wyXpF80H+zjHP32fsgsHNQfPLw/e70Z5dYkV7hF+rf8q3D+ScWJIEr57CpkO3OWBko6hwhQLPR8Pw==",
475 | "dev": true,
476 | "dependencies": {
477 | "chalk": "^4.1.0",
478 | "date-fns": "^2.16.1",
479 | "lodash": "^4.17.21",
480 | "rxjs": "^6.6.3",
481 | "spawn-command": "^0.0.2-1",
482 | "supports-color": "^8.1.0",
483 | "tree-kill": "^1.2.2",
484 | "yargs": "^16.2.0"
485 | },
486 | "bin": {
487 | "concurrently": "dist/bin/concurrently.js"
488 | },
489 | "engines": {
490 | "node": "^12.20.0 || ^14.13.0 || >=16.0.0"
491 | }
492 | },
493 | "node_modules/concurrently/node_modules/has-flag": {
494 | "version": "4.0.0",
495 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
496 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
497 | "dev": true,
498 | "engines": {
499 | "node": ">=8"
500 | }
501 | },
502 | "node_modules/concurrently/node_modules/supports-color": {
503 | "version": "8.1.1",
504 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz",
505 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==",
506 | "dev": true,
507 | "dependencies": {
508 | "has-flag": "^4.0.0"
509 | },
510 | "engines": {
511 | "node": ">=10"
512 | },
513 | "funding": {
514 | "url": "https://github.com/chalk/supports-color?sponsor=1"
515 | }
516 | },
517 | "node_modules/configstore": {
518 | "version": "5.0.1",
519 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz",
520 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==",
521 | "dev": true,
522 | "dependencies": {
523 | "dot-prop": "^5.2.0",
524 | "graceful-fs": "^4.1.2",
525 | "make-dir": "^3.0.0",
526 | "unique-string": "^2.0.0",
527 | "write-file-atomic": "^3.0.0",
528 | "xdg-basedir": "^4.0.0"
529 | },
530 | "engines": {
531 | "node": ">=8"
532 | }
533 | },
534 | "node_modules/content-disposition": {
535 | "version": "0.5.4",
536 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz",
537 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==",
538 | "dependencies": {
539 | "safe-buffer": "5.2.1"
540 | },
541 | "engines": {
542 | "node": ">= 0.6"
543 | }
544 | },
545 | "node_modules/content-type": {
546 | "version": "1.0.4",
547 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz",
548 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==",
549 | "engines": {
550 | "node": ">= 0.6"
551 | }
552 | },
553 | "node_modules/cookie": {
554 | "version": "0.4.1",
555 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz",
556 | "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA==",
557 | "engines": {
558 | "node": ">= 0.6"
559 | }
560 | },
561 | "node_modules/cookie-signature": {
562 | "version": "1.0.6",
563 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
564 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw="
565 | },
566 | "node_modules/crypto-random-string": {
567 | "version": "2.0.0",
568 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz",
569 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==",
570 | "dev": true,
571 | "engines": {
572 | "node": ">=8"
573 | }
574 | },
575 | "node_modules/date-fns": {
576 | "version": "2.28.0",
577 | "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-2.28.0.tgz",
578 | "integrity": "sha512-8d35hViGYx/QH0icHYCeLmsLmMUheMmTyV9Fcm6gvNwdw31yXXH+O85sOBJ+OLnLQMKZowvpKb6FgMIQjcpvQw==",
579 | "dev": true,
580 | "engines": {
581 | "node": ">=0.11"
582 | },
583 | "funding": {
584 | "type": "opencollective",
585 | "url": "https://opencollective.com/date-fns"
586 | }
587 | },
588 | "node_modules/debug": {
589 | "version": "2.6.9",
590 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
591 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
592 | "dependencies": {
593 | "ms": "2.0.0"
594 | }
595 | },
596 | "node_modules/decompress-response": {
597 | "version": "3.3.0",
598 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz",
599 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=",
600 | "dev": true,
601 | "dependencies": {
602 | "mimic-response": "^1.0.0"
603 | },
604 | "engines": {
605 | "node": ">=4"
606 | }
607 | },
608 | "node_modules/deep-extend": {
609 | "version": "0.6.0",
610 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz",
611 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==",
612 | "dev": true,
613 | "engines": {
614 | "node": ">=4.0.0"
615 | }
616 | },
617 | "node_modules/defer-to-connect": {
618 | "version": "1.1.3",
619 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz",
620 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==",
621 | "dev": true
622 | },
623 | "node_modules/denque": {
624 | "version": "2.0.1",
625 | "resolved": "https://registry.npmjs.org/denque/-/denque-2.0.1.tgz",
626 | "integrity": "sha512-tfiWc6BQLXNLpNiR5iGd0Ocu3P3VpxfzFiqubLgMfhfOw9WyvgJBd46CClNn9k3qfbjvT//0cf7AlYRX/OslMQ==",
627 | "engines": {
628 | "node": ">=0.10"
629 | }
630 | },
631 | "node_modules/depd": {
632 | "version": "1.1.2",
633 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz",
634 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=",
635 | "engines": {
636 | "node": ">= 0.6"
637 | }
638 | },
639 | "node_modules/destroy": {
640 | "version": "1.0.4",
641 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz",
642 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA="
643 | },
644 | "node_modules/dot-prop": {
645 | "version": "5.3.0",
646 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz",
647 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==",
648 | "dev": true,
649 | "dependencies": {
650 | "is-obj": "^2.0.0"
651 | },
652 | "engines": {
653 | "node": ">=8"
654 | }
655 | },
656 | "node_modules/dotenv": {
657 | "version": "15.0.0",
658 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-15.0.0.tgz",
659 | "integrity": "sha512-/l1sXXm79ry34KwwS0y4oVZjB468iw/6u9g1W26dtexKcIJAnVL2pMF+hxQwzZ7LutxOwEgtym9eIxvX33CMKg==",
660 | "engines": {
661 | "node": ">=12"
662 | }
663 | },
664 | "node_modules/duplexer3": {
665 | "version": "0.1.4",
666 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz",
667 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=",
668 | "dev": true
669 | },
670 | "node_modules/ecdsa-sig-formatter": {
671 | "version": "1.0.11",
672 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz",
673 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==",
674 | "dependencies": {
675 | "safe-buffer": "^5.0.1"
676 | }
677 | },
678 | "node_modules/ee-first": {
679 | "version": "1.1.1",
680 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
681 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0="
682 | },
683 | "node_modules/emoji-regex": {
684 | "version": "8.0.0",
685 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
686 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
687 | "dev": true
688 | },
689 | "node_modules/encodeurl": {
690 | "version": "1.0.2",
691 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
692 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=",
693 | "engines": {
694 | "node": ">= 0.8"
695 | }
696 | },
697 | "node_modules/end-of-stream": {
698 | "version": "1.4.4",
699 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz",
700 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==",
701 | "dev": true,
702 | "dependencies": {
703 | "once": "^1.4.0"
704 | }
705 | },
706 | "node_modules/escalade": {
707 | "version": "3.1.1",
708 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz",
709 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==",
710 | "dev": true,
711 | "engines": {
712 | "node": ">=6"
713 | }
714 | },
715 | "node_modules/escape-goat": {
716 | "version": "2.1.1",
717 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz",
718 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==",
719 | "dev": true,
720 | "engines": {
721 | "node": ">=8"
722 | }
723 | },
724 | "node_modules/escape-html": {
725 | "version": "1.0.3",
726 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
727 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg="
728 | },
729 | "node_modules/etag": {
730 | "version": "1.8.1",
731 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
732 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=",
733 | "engines": {
734 | "node": ">= 0.6"
735 | }
736 | },
737 | "node_modules/express": {
738 | "version": "4.17.2",
739 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.2.tgz",
740 | "integrity": "sha512-oxlxJxcQlYwqPWKVJJtvQiwHgosH/LrLSPA+H4UxpyvSS6jC5aH+5MoHFM+KABgTOt0APue4w66Ha8jCUo9QGg==",
741 | "dependencies": {
742 | "accepts": "~1.3.7",
743 | "array-flatten": "1.1.1",
744 | "body-parser": "1.19.1",
745 | "content-disposition": "0.5.4",
746 | "content-type": "~1.0.4",
747 | "cookie": "0.4.1",
748 | "cookie-signature": "1.0.6",
749 | "debug": "2.6.9",
750 | "depd": "~1.1.2",
751 | "encodeurl": "~1.0.2",
752 | "escape-html": "~1.0.3",
753 | "etag": "~1.8.1",
754 | "finalhandler": "~1.1.2",
755 | "fresh": "0.5.2",
756 | "merge-descriptors": "1.0.1",
757 | "methods": "~1.1.2",
758 | "on-finished": "~2.3.0",
759 | "parseurl": "~1.3.3",
760 | "path-to-regexp": "0.1.7",
761 | "proxy-addr": "~2.0.7",
762 | "qs": "6.9.6",
763 | "range-parser": "~1.2.1",
764 | "safe-buffer": "5.2.1",
765 | "send": "0.17.2",
766 | "serve-static": "1.14.2",
767 | "setprototypeof": "1.2.0",
768 | "statuses": "~1.5.0",
769 | "type-is": "~1.6.18",
770 | "utils-merge": "1.0.1",
771 | "vary": "~1.1.2"
772 | },
773 | "engines": {
774 | "node": ">= 0.10.0"
775 | }
776 | },
777 | "node_modules/express-async-handler": {
778 | "version": "1.2.0",
779 | "resolved": "https://registry.npmjs.org/express-async-handler/-/express-async-handler-1.2.0.tgz",
780 | "integrity": "sha512-rCSVtPXRmQSW8rmik/AIb2P0op6l7r1fMW538yyvTMltCO4xQEWMmobfrIxN2V1/mVrgxB8Az3reYF6yUZw37w=="
781 | },
782 | "node_modules/fill-range": {
783 | "version": "7.0.1",
784 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
785 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
786 | "dev": true,
787 | "dependencies": {
788 | "to-regex-range": "^5.0.1"
789 | },
790 | "engines": {
791 | "node": ">=8"
792 | }
793 | },
794 | "node_modules/finalhandler": {
795 | "version": "1.1.2",
796 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz",
797 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==",
798 | "dependencies": {
799 | "debug": "2.6.9",
800 | "encodeurl": "~1.0.2",
801 | "escape-html": "~1.0.3",
802 | "on-finished": "~2.3.0",
803 | "parseurl": "~1.3.3",
804 | "statuses": "~1.5.0",
805 | "unpipe": "~1.0.0"
806 | },
807 | "engines": {
808 | "node": ">= 0.8"
809 | }
810 | },
811 | "node_modules/forwarded": {
812 | "version": "0.2.0",
813 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz",
814 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==",
815 | "engines": {
816 | "node": ">= 0.6"
817 | }
818 | },
819 | "node_modules/fresh": {
820 | "version": "0.5.2",
821 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
822 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=",
823 | "engines": {
824 | "node": ">= 0.6"
825 | }
826 | },
827 | "node_modules/fsevents": {
828 | "version": "2.3.2",
829 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
830 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
831 | "dev": true,
832 | "hasInstallScript": true,
833 | "optional": true,
834 | "os": [
835 | "darwin"
836 | ],
837 | "engines": {
838 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
839 | }
840 | },
841 | "node_modules/get-caller-file": {
842 | "version": "2.0.5",
843 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz",
844 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==",
845 | "dev": true,
846 | "engines": {
847 | "node": "6.* || 8.* || >= 10.*"
848 | }
849 | },
850 | "node_modules/get-stream": {
851 | "version": "4.1.0",
852 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz",
853 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==",
854 | "dev": true,
855 | "dependencies": {
856 | "pump": "^3.0.0"
857 | },
858 | "engines": {
859 | "node": ">=6"
860 | }
861 | },
862 | "node_modules/glob-parent": {
863 | "version": "5.1.2",
864 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
865 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
866 | "dev": true,
867 | "dependencies": {
868 | "is-glob": "^4.0.1"
869 | },
870 | "engines": {
871 | "node": ">= 6"
872 | }
873 | },
874 | "node_modules/global-dirs": {
875 | "version": "3.0.0",
876 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-3.0.0.tgz",
877 | "integrity": "sha512-v8ho2DS5RiCjftj1nD9NmnfaOzTdud7RRnVd9kFNOjqZbISlx5DQ+OrTkywgd0dIt7oFCvKetZSHoHcP3sDdiA==",
878 | "dev": true,
879 | "dependencies": {
880 | "ini": "2.0.0"
881 | },
882 | "engines": {
883 | "node": ">=10"
884 | },
885 | "funding": {
886 | "url": "https://github.com/sponsors/sindresorhus"
887 | }
888 | },
889 | "node_modules/got": {
890 | "version": "9.6.0",
891 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz",
892 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==",
893 | "dev": true,
894 | "dependencies": {
895 | "@sindresorhus/is": "^0.14.0",
896 | "@szmarczak/http-timer": "^1.1.2",
897 | "cacheable-request": "^6.0.0",
898 | "decompress-response": "^3.3.0",
899 | "duplexer3": "^0.1.4",
900 | "get-stream": "^4.1.0",
901 | "lowercase-keys": "^1.0.1",
902 | "mimic-response": "^1.0.1",
903 | "p-cancelable": "^1.0.0",
904 | "to-readable-stream": "^1.0.0",
905 | "url-parse-lax": "^3.0.0"
906 | },
907 | "engines": {
908 | "node": ">=8.6"
909 | }
910 | },
911 | "node_modules/graceful-fs": {
912 | "version": "4.2.9",
913 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz",
914 | "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==",
915 | "dev": true
916 | },
917 | "node_modules/has-flag": {
918 | "version": "3.0.0",
919 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
920 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=",
921 | "dev": true,
922 | "engines": {
923 | "node": ">=4"
924 | }
925 | },
926 | "node_modules/has-yarn": {
927 | "version": "2.1.0",
928 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz",
929 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==",
930 | "dev": true,
931 | "engines": {
932 | "node": ">=8"
933 | }
934 | },
935 | "node_modules/http-cache-semantics": {
936 | "version": "4.1.0",
937 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz",
938 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==",
939 | "dev": true
940 | },
941 | "node_modules/http-errors": {
942 | "version": "1.8.1",
943 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz",
944 | "integrity": "sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g==",
945 | "dependencies": {
946 | "depd": "~1.1.2",
947 | "inherits": "2.0.4",
948 | "setprototypeof": "1.2.0",
949 | "statuses": ">= 1.5.0 < 2",
950 | "toidentifier": "1.0.1"
951 | },
952 | "engines": {
953 | "node": ">= 0.6"
954 | }
955 | },
956 | "node_modules/iconv-lite": {
957 | "version": "0.4.24",
958 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
959 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
960 | "dependencies": {
961 | "safer-buffer": ">= 2.1.2 < 3"
962 | },
963 | "engines": {
964 | "node": ">=0.10.0"
965 | }
966 | },
967 | "node_modules/ieee754": {
968 | "version": "1.2.1",
969 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz",
970 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==",
971 | "funding": [
972 | {
973 | "type": "github",
974 | "url": "https://github.com/sponsors/feross"
975 | },
976 | {
977 | "type": "patreon",
978 | "url": "https://www.patreon.com/feross"
979 | },
980 | {
981 | "type": "consulting",
982 | "url": "https://feross.org/support"
983 | }
984 | ]
985 | },
986 | "node_modules/ignore-by-default": {
987 | "version": "1.0.1",
988 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz",
989 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=",
990 | "dev": true
991 | },
992 | "node_modules/import-lazy": {
993 | "version": "2.1.0",
994 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz",
995 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=",
996 | "dev": true,
997 | "engines": {
998 | "node": ">=4"
999 | }
1000 | },
1001 | "node_modules/imurmurhash": {
1002 | "version": "0.1.4",
1003 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
1004 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=",
1005 | "dev": true,
1006 | "engines": {
1007 | "node": ">=0.8.19"
1008 | }
1009 | },
1010 | "node_modules/inherits": {
1011 | "version": "2.0.4",
1012 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
1013 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
1014 | },
1015 | "node_modules/ini": {
1016 | "version": "2.0.0",
1017 | "resolved": "https://registry.npmjs.org/ini/-/ini-2.0.0.tgz",
1018 | "integrity": "sha512-7PnF4oN3CvZF23ADhA5wRaYEQpJ8qygSkbtTXWBeXWXmEVRXK+1ITciHWwHhsjv1TmW0MgacIv6hEi5pX5NQdA==",
1019 | "dev": true,
1020 | "engines": {
1021 | "node": ">=10"
1022 | }
1023 | },
1024 | "node_modules/ipaddr.js": {
1025 | "version": "1.9.1",
1026 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz",
1027 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==",
1028 | "engines": {
1029 | "node": ">= 0.10"
1030 | }
1031 | },
1032 | "node_modules/is-binary-path": {
1033 | "version": "2.1.0",
1034 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
1035 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
1036 | "dev": true,
1037 | "dependencies": {
1038 | "binary-extensions": "^2.0.0"
1039 | },
1040 | "engines": {
1041 | "node": ">=8"
1042 | }
1043 | },
1044 | "node_modules/is-ci": {
1045 | "version": "2.0.0",
1046 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz",
1047 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==",
1048 | "dev": true,
1049 | "dependencies": {
1050 | "ci-info": "^2.0.0"
1051 | },
1052 | "bin": {
1053 | "is-ci": "bin.js"
1054 | }
1055 | },
1056 | "node_modules/is-extglob": {
1057 | "version": "2.1.1",
1058 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
1059 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
1060 | "dev": true,
1061 | "engines": {
1062 | "node": ">=0.10.0"
1063 | }
1064 | },
1065 | "node_modules/is-fullwidth-code-point": {
1066 | "version": "3.0.0",
1067 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
1068 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
1069 | "dev": true,
1070 | "engines": {
1071 | "node": ">=8"
1072 | }
1073 | },
1074 | "node_modules/is-glob": {
1075 | "version": "4.0.3",
1076 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
1077 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
1078 | "dev": true,
1079 | "dependencies": {
1080 | "is-extglob": "^2.1.1"
1081 | },
1082 | "engines": {
1083 | "node": ">=0.10.0"
1084 | }
1085 | },
1086 | "node_modules/is-installed-globally": {
1087 | "version": "0.4.0",
1088 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.4.0.tgz",
1089 | "integrity": "sha512-iwGqO3J21aaSkC7jWnHP/difazwS7SFeIqxv6wEtLU8Y5KlzFTjyqcSIT0d8s4+dDhKytsk9PJZ2BkS5eZwQRQ==",
1090 | "dev": true,
1091 | "dependencies": {
1092 | "global-dirs": "^3.0.0",
1093 | "is-path-inside": "^3.0.2"
1094 | },
1095 | "engines": {
1096 | "node": ">=10"
1097 | },
1098 | "funding": {
1099 | "url": "https://github.com/sponsors/sindresorhus"
1100 | }
1101 | },
1102 | "node_modules/is-npm": {
1103 | "version": "5.0.0",
1104 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-5.0.0.tgz",
1105 | "integrity": "sha512-WW/rQLOazUq+ST/bCAVBp/2oMERWLsR7OrKyt052dNDk4DHcDE0/7QSXITlmi+VBcV13DfIbysG3tZJm5RfdBA==",
1106 | "dev": true,
1107 | "engines": {
1108 | "node": ">=10"
1109 | },
1110 | "funding": {
1111 | "url": "https://github.com/sponsors/sindresorhus"
1112 | }
1113 | },
1114 | "node_modules/is-number": {
1115 | "version": "7.0.0",
1116 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
1117 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
1118 | "dev": true,
1119 | "engines": {
1120 | "node": ">=0.12.0"
1121 | }
1122 | },
1123 | "node_modules/is-obj": {
1124 | "version": "2.0.0",
1125 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz",
1126 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==",
1127 | "dev": true,
1128 | "engines": {
1129 | "node": ">=8"
1130 | }
1131 | },
1132 | "node_modules/is-path-inside": {
1133 | "version": "3.0.3",
1134 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz",
1135 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==",
1136 | "dev": true,
1137 | "engines": {
1138 | "node": ">=8"
1139 | }
1140 | },
1141 | "node_modules/is-typedarray": {
1142 | "version": "1.0.0",
1143 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz",
1144 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=",
1145 | "dev": true
1146 | },
1147 | "node_modules/is-yarn-global": {
1148 | "version": "0.3.0",
1149 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz",
1150 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==",
1151 | "dev": true
1152 | },
1153 | "node_modules/json-buffer": {
1154 | "version": "3.0.0",
1155 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz",
1156 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=",
1157 | "dev": true
1158 | },
1159 | "node_modules/jsonwebtoken": {
1160 | "version": "8.5.1",
1161 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz",
1162 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==",
1163 | "dependencies": {
1164 | "jws": "^3.2.2",
1165 | "lodash.includes": "^4.3.0",
1166 | "lodash.isboolean": "^3.0.3",
1167 | "lodash.isinteger": "^4.0.4",
1168 | "lodash.isnumber": "^3.0.3",
1169 | "lodash.isplainobject": "^4.0.6",
1170 | "lodash.isstring": "^4.0.1",
1171 | "lodash.once": "^4.0.0",
1172 | "ms": "^2.1.1",
1173 | "semver": "^5.6.0"
1174 | },
1175 | "engines": {
1176 | "node": ">=4",
1177 | "npm": ">=1.4.28"
1178 | }
1179 | },
1180 | "node_modules/jsonwebtoken/node_modules/ms": {
1181 | "version": "2.1.3",
1182 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
1183 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
1184 | },
1185 | "node_modules/jwa": {
1186 | "version": "1.4.1",
1187 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz",
1188 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==",
1189 | "dependencies": {
1190 | "buffer-equal-constant-time": "1.0.1",
1191 | "ecdsa-sig-formatter": "1.0.11",
1192 | "safe-buffer": "^5.0.1"
1193 | }
1194 | },
1195 | "node_modules/jws": {
1196 | "version": "3.2.2",
1197 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz",
1198 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==",
1199 | "dependencies": {
1200 | "jwa": "^1.4.1",
1201 | "safe-buffer": "^5.0.1"
1202 | }
1203 | },
1204 | "node_modules/kareem": {
1205 | "version": "2.3.3",
1206 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.3.tgz",
1207 | "integrity": "sha512-uESCXM2KdtOQ8LOvKyTUXEeg0MkYp4wGglTIpGcYHvjJcS5sn2Wkfrfit8m4xSbaNDAw2KdI9elgkOxZbrFYbg=="
1208 | },
1209 | "node_modules/keyv": {
1210 | "version": "3.1.0",
1211 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz",
1212 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==",
1213 | "dev": true,
1214 | "dependencies": {
1215 | "json-buffer": "3.0.0"
1216 | }
1217 | },
1218 | "node_modules/latest-version": {
1219 | "version": "5.1.0",
1220 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz",
1221 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==",
1222 | "dev": true,
1223 | "dependencies": {
1224 | "package-json": "^6.3.0"
1225 | },
1226 | "engines": {
1227 | "node": ">=8"
1228 | }
1229 | },
1230 | "node_modules/lodash": {
1231 | "version": "4.17.21",
1232 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz",
1233 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==",
1234 | "dev": true
1235 | },
1236 | "node_modules/lodash.includes": {
1237 | "version": "4.3.0",
1238 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz",
1239 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8="
1240 | },
1241 | "node_modules/lodash.isboolean": {
1242 | "version": "3.0.3",
1243 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz",
1244 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY="
1245 | },
1246 | "node_modules/lodash.isinteger": {
1247 | "version": "4.0.4",
1248 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz",
1249 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M="
1250 | },
1251 | "node_modules/lodash.isnumber": {
1252 | "version": "3.0.3",
1253 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz",
1254 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w="
1255 | },
1256 | "node_modules/lodash.isplainobject": {
1257 | "version": "4.0.6",
1258 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz",
1259 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs="
1260 | },
1261 | "node_modules/lodash.isstring": {
1262 | "version": "4.0.1",
1263 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz",
1264 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE="
1265 | },
1266 | "node_modules/lodash.once": {
1267 | "version": "4.1.1",
1268 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz",
1269 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w="
1270 | },
1271 | "node_modules/lowercase-keys": {
1272 | "version": "1.0.1",
1273 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz",
1274 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==",
1275 | "dev": true,
1276 | "engines": {
1277 | "node": ">=0.10.0"
1278 | }
1279 | },
1280 | "node_modules/lru-cache": {
1281 | "version": "6.0.0",
1282 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
1283 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
1284 | "dev": true,
1285 | "dependencies": {
1286 | "yallist": "^4.0.0"
1287 | },
1288 | "engines": {
1289 | "node": ">=10"
1290 | }
1291 | },
1292 | "node_modules/make-dir": {
1293 | "version": "3.1.0",
1294 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz",
1295 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==",
1296 | "dev": true,
1297 | "dependencies": {
1298 | "semver": "^6.0.0"
1299 | },
1300 | "engines": {
1301 | "node": ">=8"
1302 | },
1303 | "funding": {
1304 | "url": "https://github.com/sponsors/sindresorhus"
1305 | }
1306 | },
1307 | "node_modules/make-dir/node_modules/semver": {
1308 | "version": "6.3.0",
1309 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
1310 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
1311 | "dev": true,
1312 | "bin": {
1313 | "semver": "bin/semver.js"
1314 | }
1315 | },
1316 | "node_modules/media-typer": {
1317 | "version": "0.3.0",
1318 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
1319 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=",
1320 | "engines": {
1321 | "node": ">= 0.6"
1322 | }
1323 | },
1324 | "node_modules/memory-pager": {
1325 | "version": "1.5.0",
1326 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz",
1327 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==",
1328 | "optional": true
1329 | },
1330 | "node_modules/merge-descriptors": {
1331 | "version": "1.0.1",
1332 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
1333 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E="
1334 | },
1335 | "node_modules/methods": {
1336 | "version": "1.1.2",
1337 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
1338 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=",
1339 | "engines": {
1340 | "node": ">= 0.6"
1341 | }
1342 | },
1343 | "node_modules/mime": {
1344 | "version": "1.6.0",
1345 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
1346 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
1347 | "bin": {
1348 | "mime": "cli.js"
1349 | },
1350 | "engines": {
1351 | "node": ">=4"
1352 | }
1353 | },
1354 | "node_modules/mime-db": {
1355 | "version": "1.51.0",
1356 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.51.0.tgz",
1357 | "integrity": "sha512-5y8A56jg7XVQx2mbv1lu49NR4dokRnhZYTtL+KGfaa27uq4pSTXkwQkFJl4pkRMyNFz/EtYDSkiiEHx3F7UN6g==",
1358 | "engines": {
1359 | "node": ">= 0.6"
1360 | }
1361 | },
1362 | "node_modules/mime-types": {
1363 | "version": "2.1.34",
1364 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.34.tgz",
1365 | "integrity": "sha512-6cP692WwGIs9XXdOO4++N+7qjqv0rqxxVvJ3VHPh/Sc9mVZcQP+ZGhkKiTvWMQRr2tbHkJP/Yn7Y0npb3ZBs4A==",
1366 | "dependencies": {
1367 | "mime-db": "1.51.0"
1368 | },
1369 | "engines": {
1370 | "node": ">= 0.6"
1371 | }
1372 | },
1373 | "node_modules/mimic-response": {
1374 | "version": "1.0.1",
1375 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz",
1376 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==",
1377 | "dev": true,
1378 | "engines": {
1379 | "node": ">=4"
1380 | }
1381 | },
1382 | "node_modules/minimatch": {
1383 | "version": "3.0.4",
1384 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
1385 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
1386 | "dev": true,
1387 | "dependencies": {
1388 | "brace-expansion": "^1.1.7"
1389 | },
1390 | "engines": {
1391 | "node": "*"
1392 | }
1393 | },
1394 | "node_modules/minimist": {
1395 | "version": "1.2.5",
1396 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
1397 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
1398 | "dev": true
1399 | },
1400 | "node_modules/mongodb": {
1401 | "version": "4.2.2",
1402 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-4.2.2.tgz",
1403 | "integrity": "sha512-zt8rCTnTKyMQppyt63qMnrLM5dbADgUk18ORPF1XbtHLIYCyc9hattaYHi0pqMvNxDpgGgUofSVzS+UQErgTug==",
1404 | "dependencies": {
1405 | "bson": "^4.6.0",
1406 | "denque": "^2.0.1",
1407 | "mongodb-connection-string-url": "^2.3.2"
1408 | },
1409 | "engines": {
1410 | "node": ">=12.9.0"
1411 | },
1412 | "optionalDependencies": {
1413 | "saslprep": "^1.0.3"
1414 | }
1415 | },
1416 | "node_modules/mongodb-connection-string-url": {
1417 | "version": "2.4.1",
1418 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-2.4.1.tgz",
1419 | "integrity": "sha512-d5Kd2bVsKcSA7YI/yo57fSTtMwRQdFkvc5IZwod1RRxJtECeWPPSo7zqcUGJELifRA//Igs4spVtYAmvFCatug==",
1420 | "dependencies": {
1421 | "@types/whatwg-url": "^8.2.1",
1422 | "whatwg-url": "^11.0.0"
1423 | }
1424 | },
1425 | "node_modules/mongoose": {
1426 | "version": "6.1.9",
1427 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-6.1.9.tgz",
1428 | "integrity": "sha512-dh6ZeYNGUAW4Gc4MxxgPwU+0d1tZZgse6xTejDjFwyXJArBcyI4xLqNrO9W6Umu2iQzlT701RTtN+iJ0gipM4A==",
1429 | "dependencies": {
1430 | "@types/node": "< 17.0.6",
1431 | "bson": "^4.2.2",
1432 | "kareem": "2.3.3",
1433 | "mongodb": "4.2.2",
1434 | "mpath": "0.8.4",
1435 | "mquery": "4.0.2",
1436 | "ms": "2.1.2",
1437 | "regexp-clone": "1.0.0",
1438 | "sift": "13.5.2"
1439 | },
1440 | "engines": {
1441 | "node": ">=12.0.0"
1442 | },
1443 | "funding": {
1444 | "type": "opencollective",
1445 | "url": "https://opencollective.com/mongoose"
1446 | }
1447 | },
1448 | "node_modules/mongoose/node_modules/ms": {
1449 | "version": "2.1.2",
1450 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
1451 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
1452 | },
1453 | "node_modules/mpath": {
1454 | "version": "0.8.4",
1455 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.8.4.tgz",
1456 | "integrity": "sha512-DTxNZomBcTWlrMW76jy1wvV37X/cNNxPW1y2Jzd4DZkAaC5ZGsm8bfGfNOthcDuRJujXLqiuS6o3Tpy0JEoh7g==",
1457 | "engines": {
1458 | "node": ">=4.0.0"
1459 | }
1460 | },
1461 | "node_modules/mquery": {
1462 | "version": "4.0.2",
1463 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-4.0.2.tgz",
1464 | "integrity": "sha512-oAVF0Nil1mT3rxty6Zln4YiD6x6QsUWYz927jZzjMxOK2aqmhEz5JQ7xmrKK7xRFA2dwV+YaOpKU/S+vfNqKxA==",
1465 | "dependencies": {
1466 | "debug": "4.x"
1467 | },
1468 | "engines": {
1469 | "node": ">=12.0.0"
1470 | }
1471 | },
1472 | "node_modules/mquery/node_modules/debug": {
1473 | "version": "4.3.3",
1474 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz",
1475 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==",
1476 | "dependencies": {
1477 | "ms": "2.1.2"
1478 | },
1479 | "engines": {
1480 | "node": ">=6.0"
1481 | },
1482 | "peerDependenciesMeta": {
1483 | "supports-color": {
1484 | "optional": true
1485 | }
1486 | }
1487 | },
1488 | "node_modules/mquery/node_modules/ms": {
1489 | "version": "2.1.2",
1490 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
1491 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
1492 | },
1493 | "node_modules/ms": {
1494 | "version": "2.0.0",
1495 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
1496 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g="
1497 | },
1498 | "node_modules/negotiator": {
1499 | "version": "0.6.2",
1500 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz",
1501 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==",
1502 | "engines": {
1503 | "node": ">= 0.6"
1504 | }
1505 | },
1506 | "node_modules/nodemon": {
1507 | "version": "2.0.15",
1508 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.15.tgz",
1509 | "integrity": "sha512-gdHMNx47Gw7b3kWxJV64NI+Q5nfl0y5DgDbiVtShiwa7Z0IZ07Ll4RLFo6AjrhzMtoEZn5PDE3/c2AbVsiCkpA==",
1510 | "dev": true,
1511 | "hasInstallScript": true,
1512 | "dependencies": {
1513 | "chokidar": "^3.5.2",
1514 | "debug": "^3.2.7",
1515 | "ignore-by-default": "^1.0.1",
1516 | "minimatch": "^3.0.4",
1517 | "pstree.remy": "^1.1.8",
1518 | "semver": "^5.7.1",
1519 | "supports-color": "^5.5.0",
1520 | "touch": "^3.1.0",
1521 | "undefsafe": "^2.0.5",
1522 | "update-notifier": "^5.1.0"
1523 | },
1524 | "bin": {
1525 | "nodemon": "bin/nodemon.js"
1526 | },
1527 | "engines": {
1528 | "node": ">=8.10.0"
1529 | },
1530 | "funding": {
1531 | "type": "opencollective",
1532 | "url": "https://opencollective.com/nodemon"
1533 | }
1534 | },
1535 | "node_modules/nodemon/node_modules/debug": {
1536 | "version": "3.2.7",
1537 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz",
1538 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==",
1539 | "dev": true,
1540 | "dependencies": {
1541 | "ms": "^2.1.1"
1542 | }
1543 | },
1544 | "node_modules/nodemon/node_modules/ms": {
1545 | "version": "2.1.3",
1546 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
1547 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
1548 | "dev": true
1549 | },
1550 | "node_modules/nopt": {
1551 | "version": "1.0.10",
1552 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz",
1553 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=",
1554 | "dev": true,
1555 | "dependencies": {
1556 | "abbrev": "1"
1557 | },
1558 | "bin": {
1559 | "nopt": "bin/nopt.js"
1560 | },
1561 | "engines": {
1562 | "node": "*"
1563 | }
1564 | },
1565 | "node_modules/normalize-path": {
1566 | "version": "3.0.0",
1567 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
1568 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
1569 | "dev": true,
1570 | "engines": {
1571 | "node": ">=0.10.0"
1572 | }
1573 | },
1574 | "node_modules/normalize-url": {
1575 | "version": "4.5.1",
1576 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.1.tgz",
1577 | "integrity": "sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA==",
1578 | "dev": true,
1579 | "engines": {
1580 | "node": ">=8"
1581 | }
1582 | },
1583 | "node_modules/on-finished": {
1584 | "version": "2.3.0",
1585 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz",
1586 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=",
1587 | "dependencies": {
1588 | "ee-first": "1.1.1"
1589 | },
1590 | "engines": {
1591 | "node": ">= 0.8"
1592 | }
1593 | },
1594 | "node_modules/once": {
1595 | "version": "1.4.0",
1596 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
1597 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
1598 | "dev": true,
1599 | "dependencies": {
1600 | "wrappy": "1"
1601 | }
1602 | },
1603 | "node_modules/p-cancelable": {
1604 | "version": "1.1.0",
1605 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz",
1606 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==",
1607 | "dev": true,
1608 | "engines": {
1609 | "node": ">=6"
1610 | }
1611 | },
1612 | "node_modules/package-json": {
1613 | "version": "6.5.0",
1614 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz",
1615 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==",
1616 | "dev": true,
1617 | "dependencies": {
1618 | "got": "^9.6.0",
1619 | "registry-auth-token": "^4.0.0",
1620 | "registry-url": "^5.0.0",
1621 | "semver": "^6.2.0"
1622 | },
1623 | "engines": {
1624 | "node": ">=8"
1625 | }
1626 | },
1627 | "node_modules/package-json/node_modules/semver": {
1628 | "version": "6.3.0",
1629 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
1630 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
1631 | "dev": true,
1632 | "bin": {
1633 | "semver": "bin/semver.js"
1634 | }
1635 | },
1636 | "node_modules/parseurl": {
1637 | "version": "1.3.3",
1638 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
1639 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==",
1640 | "engines": {
1641 | "node": ">= 0.8"
1642 | }
1643 | },
1644 | "node_modules/path-to-regexp": {
1645 | "version": "0.1.7",
1646 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
1647 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w="
1648 | },
1649 | "node_modules/picomatch": {
1650 | "version": "2.3.1",
1651 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
1652 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
1653 | "dev": true,
1654 | "engines": {
1655 | "node": ">=8.6"
1656 | },
1657 | "funding": {
1658 | "url": "https://github.com/sponsors/jonschlinkert"
1659 | }
1660 | },
1661 | "node_modules/prepend-http": {
1662 | "version": "2.0.0",
1663 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz",
1664 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=",
1665 | "dev": true,
1666 | "engines": {
1667 | "node": ">=4"
1668 | }
1669 | },
1670 | "node_modules/proxy-addr": {
1671 | "version": "2.0.7",
1672 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz",
1673 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==",
1674 | "dependencies": {
1675 | "forwarded": "0.2.0",
1676 | "ipaddr.js": "1.9.1"
1677 | },
1678 | "engines": {
1679 | "node": ">= 0.10"
1680 | }
1681 | },
1682 | "node_modules/pstree.remy": {
1683 | "version": "1.1.8",
1684 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz",
1685 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==",
1686 | "dev": true
1687 | },
1688 | "node_modules/pump": {
1689 | "version": "3.0.0",
1690 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz",
1691 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==",
1692 | "dev": true,
1693 | "dependencies": {
1694 | "end-of-stream": "^1.1.0",
1695 | "once": "^1.3.1"
1696 | }
1697 | },
1698 | "node_modules/punycode": {
1699 | "version": "2.1.1",
1700 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz",
1701 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==",
1702 | "engines": {
1703 | "node": ">=6"
1704 | }
1705 | },
1706 | "node_modules/pupa": {
1707 | "version": "2.1.1",
1708 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz",
1709 | "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==",
1710 | "dev": true,
1711 | "dependencies": {
1712 | "escape-goat": "^2.0.0"
1713 | },
1714 | "engines": {
1715 | "node": ">=8"
1716 | }
1717 | },
1718 | "node_modules/qs": {
1719 | "version": "6.9.6",
1720 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.9.6.tgz",
1721 | "integrity": "sha512-TIRk4aqYLNoJUbd+g2lEdz5kLWIuTMRagAXxl78Q0RiVjAOugHmeKNGdd3cwo/ktpf9aL9epCfFqWDEKysUlLQ==",
1722 | "engines": {
1723 | "node": ">=0.6"
1724 | },
1725 | "funding": {
1726 | "url": "https://github.com/sponsors/ljharb"
1727 | }
1728 | },
1729 | "node_modules/range-parser": {
1730 | "version": "1.2.1",
1731 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
1732 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==",
1733 | "engines": {
1734 | "node": ">= 0.6"
1735 | }
1736 | },
1737 | "node_modules/raw-body": {
1738 | "version": "2.4.2",
1739 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.2.tgz",
1740 | "integrity": "sha512-RPMAFUJP19WIet/99ngh6Iv8fzAbqum4Li7AD6DtGaW2RpMB/11xDoalPiJMTbu6I3hkbMVkATvZrqb9EEqeeQ==",
1741 | "dependencies": {
1742 | "bytes": "3.1.1",
1743 | "http-errors": "1.8.1",
1744 | "iconv-lite": "0.4.24",
1745 | "unpipe": "1.0.0"
1746 | },
1747 | "engines": {
1748 | "node": ">= 0.8"
1749 | }
1750 | },
1751 | "node_modules/rc": {
1752 | "version": "1.2.8",
1753 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz",
1754 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==",
1755 | "dev": true,
1756 | "dependencies": {
1757 | "deep-extend": "^0.6.0",
1758 | "ini": "~1.3.0",
1759 | "minimist": "^1.2.0",
1760 | "strip-json-comments": "~2.0.1"
1761 | },
1762 | "bin": {
1763 | "rc": "cli.js"
1764 | }
1765 | },
1766 | "node_modules/rc/node_modules/ini": {
1767 | "version": "1.3.8",
1768 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz",
1769 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==",
1770 | "dev": true
1771 | },
1772 | "node_modules/readdirp": {
1773 | "version": "3.6.0",
1774 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
1775 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
1776 | "dev": true,
1777 | "dependencies": {
1778 | "picomatch": "^2.2.1"
1779 | },
1780 | "engines": {
1781 | "node": ">=8.10.0"
1782 | }
1783 | },
1784 | "node_modules/regexp-clone": {
1785 | "version": "1.0.0",
1786 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-1.0.0.tgz",
1787 | "integrity": "sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw=="
1788 | },
1789 | "node_modules/registry-auth-token": {
1790 | "version": "4.2.1",
1791 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.1.tgz",
1792 | "integrity": "sha512-6gkSb4U6aWJB4SF2ZvLb76yCBjcvufXBqvvEx1HbmKPkutswjW1xNVRY0+daljIYRbogN7O0etYSlbiaEQyMyw==",
1793 | "dev": true,
1794 | "dependencies": {
1795 | "rc": "^1.2.8"
1796 | },
1797 | "engines": {
1798 | "node": ">=6.0.0"
1799 | }
1800 | },
1801 | "node_modules/registry-url": {
1802 | "version": "5.1.0",
1803 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz",
1804 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==",
1805 | "dev": true,
1806 | "dependencies": {
1807 | "rc": "^1.2.8"
1808 | },
1809 | "engines": {
1810 | "node": ">=8"
1811 | }
1812 | },
1813 | "node_modules/require-directory": {
1814 | "version": "2.1.1",
1815 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
1816 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=",
1817 | "dev": true,
1818 | "engines": {
1819 | "node": ">=0.10.0"
1820 | }
1821 | },
1822 | "node_modules/responselike": {
1823 | "version": "1.0.2",
1824 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz",
1825 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=",
1826 | "dev": true,
1827 | "dependencies": {
1828 | "lowercase-keys": "^1.0.0"
1829 | }
1830 | },
1831 | "node_modules/rxjs": {
1832 | "version": "6.6.7",
1833 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.6.7.tgz",
1834 | "integrity": "sha512-hTdwr+7yYNIT5n4AMYp85KA6yw2Va0FLa3Rguvbpa4W3I5xynaBZo41cM3XM+4Q6fRMj3sBYIR1VAmZMXYJvRQ==",
1835 | "dev": true,
1836 | "dependencies": {
1837 | "tslib": "^1.9.0"
1838 | },
1839 | "engines": {
1840 | "npm": ">=2.0.0"
1841 | }
1842 | },
1843 | "node_modules/safe-buffer": {
1844 | "version": "5.2.1",
1845 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
1846 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
1847 | "funding": [
1848 | {
1849 | "type": "github",
1850 | "url": "https://github.com/sponsors/feross"
1851 | },
1852 | {
1853 | "type": "patreon",
1854 | "url": "https://www.patreon.com/feross"
1855 | },
1856 | {
1857 | "type": "consulting",
1858 | "url": "https://feross.org/support"
1859 | }
1860 | ]
1861 | },
1862 | "node_modules/safer-buffer": {
1863 | "version": "2.1.2",
1864 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
1865 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
1866 | },
1867 | "node_modules/saslprep": {
1868 | "version": "1.0.3",
1869 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz",
1870 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==",
1871 | "optional": true,
1872 | "dependencies": {
1873 | "sparse-bitfield": "^3.0.3"
1874 | },
1875 | "engines": {
1876 | "node": ">=6"
1877 | }
1878 | },
1879 | "node_modules/semver": {
1880 | "version": "5.7.1",
1881 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
1882 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==",
1883 | "bin": {
1884 | "semver": "bin/semver"
1885 | }
1886 | },
1887 | "node_modules/semver-diff": {
1888 | "version": "3.1.1",
1889 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz",
1890 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==",
1891 | "dev": true,
1892 | "dependencies": {
1893 | "semver": "^6.3.0"
1894 | },
1895 | "engines": {
1896 | "node": ">=8"
1897 | }
1898 | },
1899 | "node_modules/semver-diff/node_modules/semver": {
1900 | "version": "6.3.0",
1901 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
1902 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
1903 | "dev": true,
1904 | "bin": {
1905 | "semver": "bin/semver.js"
1906 | }
1907 | },
1908 | "node_modules/send": {
1909 | "version": "0.17.2",
1910 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.2.tgz",
1911 | "integrity": "sha512-UJYB6wFSJE3G00nEivR5rgWp8c2xXvJ3OPWPhmuteU0IKj8nKbG3DrjiOmLwpnHGYWAVwA69zmTm++YG0Hmwww==",
1912 | "dependencies": {
1913 | "debug": "2.6.9",
1914 | "depd": "~1.1.2",
1915 | "destroy": "~1.0.4",
1916 | "encodeurl": "~1.0.2",
1917 | "escape-html": "~1.0.3",
1918 | "etag": "~1.8.1",
1919 | "fresh": "0.5.2",
1920 | "http-errors": "1.8.1",
1921 | "mime": "1.6.0",
1922 | "ms": "2.1.3",
1923 | "on-finished": "~2.3.0",
1924 | "range-parser": "~1.2.1",
1925 | "statuses": "~1.5.0"
1926 | },
1927 | "engines": {
1928 | "node": ">= 0.8.0"
1929 | }
1930 | },
1931 | "node_modules/send/node_modules/ms": {
1932 | "version": "2.1.3",
1933 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
1934 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
1935 | },
1936 | "node_modules/serve-static": {
1937 | "version": "1.14.2",
1938 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.2.tgz",
1939 | "integrity": "sha512-+TMNA9AFxUEGuC0z2mevogSnn9MXKb4fa7ngeRMJaaGv8vTwnIEkKi+QGvPt33HSnf8pRS+WGM0EbMtCJLKMBQ==",
1940 | "dependencies": {
1941 | "encodeurl": "~1.0.2",
1942 | "escape-html": "~1.0.3",
1943 | "parseurl": "~1.3.3",
1944 | "send": "0.17.2"
1945 | },
1946 | "engines": {
1947 | "node": ">= 0.8.0"
1948 | }
1949 | },
1950 | "node_modules/setprototypeof": {
1951 | "version": "1.2.0",
1952 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz",
1953 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw=="
1954 | },
1955 | "node_modules/sift": {
1956 | "version": "13.5.2",
1957 | "resolved": "https://registry.npmjs.org/sift/-/sift-13.5.2.tgz",
1958 | "integrity": "sha512-+gxdEOMA2J+AI+fVsCqeNn7Tgx3M9ZN9jdi95939l1IJ8cZsqS8sqpJyOkic2SJk+1+98Uwryt/gL6XDaV+UZA=="
1959 | },
1960 | "node_modules/signal-exit": {
1961 | "version": "3.0.6",
1962 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.6.tgz",
1963 | "integrity": "sha512-sDl4qMFpijcGw22U5w63KmD3cZJfBuFlVNbVMKje2keoKML7X2UzWbc4XrmEbDwg0NXJc3yv4/ox7b+JWb57kQ==",
1964 | "dev": true
1965 | },
1966 | "node_modules/sparse-bitfield": {
1967 | "version": "3.0.3",
1968 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz",
1969 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=",
1970 | "optional": true,
1971 | "dependencies": {
1972 | "memory-pager": "^1.0.2"
1973 | }
1974 | },
1975 | "node_modules/spawn-command": {
1976 | "version": "0.0.2-1",
1977 | "resolved": "https://registry.npmjs.org/spawn-command/-/spawn-command-0.0.2-1.tgz",
1978 | "integrity": "sha1-YvXpRmmBwbeW3Fkpk34RycaSG9A=",
1979 | "dev": true
1980 | },
1981 | "node_modules/statuses": {
1982 | "version": "1.5.0",
1983 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz",
1984 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=",
1985 | "engines": {
1986 | "node": ">= 0.6"
1987 | }
1988 | },
1989 | "node_modules/string-width": {
1990 | "version": "4.2.3",
1991 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
1992 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
1993 | "dev": true,
1994 | "dependencies": {
1995 | "emoji-regex": "^8.0.0",
1996 | "is-fullwidth-code-point": "^3.0.0",
1997 | "strip-ansi": "^6.0.1"
1998 | },
1999 | "engines": {
2000 | "node": ">=8"
2001 | }
2002 | },
2003 | "node_modules/strip-ansi": {
2004 | "version": "6.0.1",
2005 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
2006 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
2007 | "dev": true,
2008 | "dependencies": {
2009 | "ansi-regex": "^5.0.1"
2010 | },
2011 | "engines": {
2012 | "node": ">=8"
2013 | }
2014 | },
2015 | "node_modules/strip-json-comments": {
2016 | "version": "2.0.1",
2017 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz",
2018 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=",
2019 | "dev": true,
2020 | "engines": {
2021 | "node": ">=0.10.0"
2022 | }
2023 | },
2024 | "node_modules/supports-color": {
2025 | "version": "5.5.0",
2026 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
2027 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
2028 | "dev": true,
2029 | "dependencies": {
2030 | "has-flag": "^3.0.0"
2031 | },
2032 | "engines": {
2033 | "node": ">=4"
2034 | }
2035 | },
2036 | "node_modules/to-readable-stream": {
2037 | "version": "1.0.0",
2038 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz",
2039 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==",
2040 | "dev": true,
2041 | "engines": {
2042 | "node": ">=6"
2043 | }
2044 | },
2045 | "node_modules/to-regex-range": {
2046 | "version": "5.0.1",
2047 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
2048 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
2049 | "dev": true,
2050 | "dependencies": {
2051 | "is-number": "^7.0.0"
2052 | },
2053 | "engines": {
2054 | "node": ">=8.0"
2055 | }
2056 | },
2057 | "node_modules/toidentifier": {
2058 | "version": "1.0.1",
2059 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz",
2060 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==",
2061 | "engines": {
2062 | "node": ">=0.6"
2063 | }
2064 | },
2065 | "node_modules/touch": {
2066 | "version": "3.1.0",
2067 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz",
2068 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==",
2069 | "dev": true,
2070 | "dependencies": {
2071 | "nopt": "~1.0.10"
2072 | },
2073 | "bin": {
2074 | "nodetouch": "bin/nodetouch.js"
2075 | }
2076 | },
2077 | "node_modules/tr46": {
2078 | "version": "3.0.0",
2079 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz",
2080 | "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==",
2081 | "dependencies": {
2082 | "punycode": "^2.1.1"
2083 | },
2084 | "engines": {
2085 | "node": ">=12"
2086 | }
2087 | },
2088 | "node_modules/tree-kill": {
2089 | "version": "1.2.2",
2090 | "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz",
2091 | "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==",
2092 | "dev": true,
2093 | "bin": {
2094 | "tree-kill": "cli.js"
2095 | }
2096 | },
2097 | "node_modules/tslib": {
2098 | "version": "1.14.1",
2099 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz",
2100 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==",
2101 | "dev": true
2102 | },
2103 | "node_modules/type-fest": {
2104 | "version": "0.20.2",
2105 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz",
2106 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==",
2107 | "dev": true,
2108 | "engines": {
2109 | "node": ">=10"
2110 | },
2111 | "funding": {
2112 | "url": "https://github.com/sponsors/sindresorhus"
2113 | }
2114 | },
2115 | "node_modules/type-is": {
2116 | "version": "1.6.18",
2117 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
2118 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
2119 | "dependencies": {
2120 | "media-typer": "0.3.0",
2121 | "mime-types": "~2.1.24"
2122 | },
2123 | "engines": {
2124 | "node": ">= 0.6"
2125 | }
2126 | },
2127 | "node_modules/typedarray-to-buffer": {
2128 | "version": "3.1.5",
2129 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz",
2130 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==",
2131 | "dev": true,
2132 | "dependencies": {
2133 | "is-typedarray": "^1.0.0"
2134 | }
2135 | },
2136 | "node_modules/undefsafe": {
2137 | "version": "2.0.5",
2138 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz",
2139 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==",
2140 | "dev": true
2141 | },
2142 | "node_modules/unique-string": {
2143 | "version": "2.0.0",
2144 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz",
2145 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==",
2146 | "dev": true,
2147 | "dependencies": {
2148 | "crypto-random-string": "^2.0.0"
2149 | },
2150 | "engines": {
2151 | "node": ">=8"
2152 | }
2153 | },
2154 | "node_modules/unpipe": {
2155 | "version": "1.0.0",
2156 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
2157 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=",
2158 | "engines": {
2159 | "node": ">= 0.8"
2160 | }
2161 | },
2162 | "node_modules/update-notifier": {
2163 | "version": "5.1.0",
2164 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-5.1.0.tgz",
2165 | "integrity": "sha512-ItnICHbeMh9GqUy31hFPrD1kcuZ3rpxDZbf4KUDavXwS0bW5m7SLbDQpGX3UYr072cbrF5hFUs3r5tUsPwjfHw==",
2166 | "dev": true,
2167 | "dependencies": {
2168 | "boxen": "^5.0.0",
2169 | "chalk": "^4.1.0",
2170 | "configstore": "^5.0.1",
2171 | "has-yarn": "^2.1.0",
2172 | "import-lazy": "^2.1.0",
2173 | "is-ci": "^2.0.0",
2174 | "is-installed-globally": "^0.4.0",
2175 | "is-npm": "^5.0.0",
2176 | "is-yarn-global": "^0.3.0",
2177 | "latest-version": "^5.1.0",
2178 | "pupa": "^2.1.1",
2179 | "semver": "^7.3.4",
2180 | "semver-diff": "^3.1.1",
2181 | "xdg-basedir": "^4.0.0"
2182 | },
2183 | "engines": {
2184 | "node": ">=10"
2185 | },
2186 | "funding": {
2187 | "url": "https://github.com/yeoman/update-notifier?sponsor=1"
2188 | }
2189 | },
2190 | "node_modules/update-notifier/node_modules/semver": {
2191 | "version": "7.3.5",
2192 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz",
2193 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==",
2194 | "dev": true,
2195 | "dependencies": {
2196 | "lru-cache": "^6.0.0"
2197 | },
2198 | "bin": {
2199 | "semver": "bin/semver.js"
2200 | },
2201 | "engines": {
2202 | "node": ">=10"
2203 | }
2204 | },
2205 | "node_modules/url-parse-lax": {
2206 | "version": "3.0.0",
2207 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz",
2208 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=",
2209 | "dev": true,
2210 | "dependencies": {
2211 | "prepend-http": "^2.0.0"
2212 | },
2213 | "engines": {
2214 | "node": ">=4"
2215 | }
2216 | },
2217 | "node_modules/utils-merge": {
2218 | "version": "1.0.1",
2219 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
2220 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=",
2221 | "engines": {
2222 | "node": ">= 0.4.0"
2223 | }
2224 | },
2225 | "node_modules/vary": {
2226 | "version": "1.1.2",
2227 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
2228 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=",
2229 | "engines": {
2230 | "node": ">= 0.8"
2231 | }
2232 | },
2233 | "node_modules/webidl-conversions": {
2234 | "version": "7.0.0",
2235 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz",
2236 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==",
2237 | "engines": {
2238 | "node": ">=12"
2239 | }
2240 | },
2241 | "node_modules/whatwg-url": {
2242 | "version": "11.0.0",
2243 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz",
2244 | "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==",
2245 | "dependencies": {
2246 | "tr46": "^3.0.0",
2247 | "webidl-conversions": "^7.0.0"
2248 | },
2249 | "engines": {
2250 | "node": ">=12"
2251 | }
2252 | },
2253 | "node_modules/widest-line": {
2254 | "version": "3.1.0",
2255 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz",
2256 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==",
2257 | "dev": true,
2258 | "dependencies": {
2259 | "string-width": "^4.0.0"
2260 | },
2261 | "engines": {
2262 | "node": ">=8"
2263 | }
2264 | },
2265 | "node_modules/wrap-ansi": {
2266 | "version": "7.0.0",
2267 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
2268 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
2269 | "dev": true,
2270 | "dependencies": {
2271 | "ansi-styles": "^4.0.0",
2272 | "string-width": "^4.1.0",
2273 | "strip-ansi": "^6.0.0"
2274 | },
2275 | "engines": {
2276 | "node": ">=10"
2277 | },
2278 | "funding": {
2279 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
2280 | }
2281 | },
2282 | "node_modules/wrappy": {
2283 | "version": "1.0.2",
2284 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
2285 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=",
2286 | "dev": true
2287 | },
2288 | "node_modules/write-file-atomic": {
2289 | "version": "3.0.3",
2290 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz",
2291 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==",
2292 | "dev": true,
2293 | "dependencies": {
2294 | "imurmurhash": "^0.1.4",
2295 | "is-typedarray": "^1.0.0",
2296 | "signal-exit": "^3.0.2",
2297 | "typedarray-to-buffer": "^3.1.5"
2298 | }
2299 | },
2300 | "node_modules/xdg-basedir": {
2301 | "version": "4.0.0",
2302 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz",
2303 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==",
2304 | "dev": true,
2305 | "engines": {
2306 | "node": ">=8"
2307 | }
2308 | },
2309 | "node_modules/y18n": {
2310 | "version": "5.0.8",
2311 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz",
2312 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==",
2313 | "dev": true,
2314 | "engines": {
2315 | "node": ">=10"
2316 | }
2317 | },
2318 | "node_modules/yallist": {
2319 | "version": "4.0.0",
2320 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
2321 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
2322 | "dev": true
2323 | },
2324 | "node_modules/yargs": {
2325 | "version": "16.2.0",
2326 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz",
2327 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==",
2328 | "dev": true,
2329 | "dependencies": {
2330 | "cliui": "^7.0.2",
2331 | "escalade": "^3.1.1",
2332 | "get-caller-file": "^2.0.5",
2333 | "require-directory": "^2.1.1",
2334 | "string-width": "^4.2.0",
2335 | "y18n": "^5.0.5",
2336 | "yargs-parser": "^20.2.2"
2337 | },
2338 | "engines": {
2339 | "node": ">=10"
2340 | }
2341 | },
2342 | "node_modules/yargs-parser": {
2343 | "version": "20.2.9",
2344 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz",
2345 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==",
2346 | "dev": true,
2347 | "engines": {
2348 | "node": ">=10"
2349 | }
2350 | }
2351 | },
2352 | "dependencies": {
2353 | "@sindresorhus/is": {
2354 | "version": "0.14.0",
2355 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz",
2356 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==",
2357 | "dev": true
2358 | },
2359 | "@szmarczak/http-timer": {
2360 | "version": "1.1.2",
2361 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz",
2362 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==",
2363 | "dev": true,
2364 | "requires": {
2365 | "defer-to-connect": "^1.0.1"
2366 | }
2367 | },
2368 | "@types/node": {
2369 | "version": "17.0.5",
2370 | "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.5.tgz",
2371 | "integrity": "sha512-w3mrvNXLeDYV1GKTZorGJQivK6XLCoGwpnyJFbJVK/aTBQUxOCaa/GlFAAN3OTDFcb7h5tiFG+YXCO2By+riZw=="
2372 | },
2373 | "@types/webidl-conversions": {
2374 | "version": "6.1.1",
2375 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-6.1.1.tgz",
2376 | "integrity": "sha512-XAahCdThVuCFDQLT7R7Pk/vqeObFNL3YqRyFZg+AqAP/W1/w3xHaIxuW7WszQqTbIBOPRcItYJIou3i/mppu3Q=="
2377 | },
2378 | "@types/whatwg-url": {
2379 | "version": "8.2.1",
2380 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-8.2.1.tgz",
2381 | "integrity": "sha512-2YubE1sjj5ifxievI5Ge1sckb9k/Er66HyR2c+3+I6VDUUg1TLPdYYTEbQ+DjRkS4nTxMJhgWfSfMRD2sl2EYQ==",
2382 | "requires": {
2383 | "@types/node": "*",
2384 | "@types/webidl-conversions": "*"
2385 | }
2386 | },
2387 | "abbrev": {
2388 | "version": "1.1.1",
2389 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz",
2390 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==",
2391 | "dev": true
2392 | },
2393 | "accepts": {
2394 | "version": "1.3.7",
2395 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz",
2396 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==",
2397 | "requires": {
2398 | "mime-types": "~2.1.24",
2399 | "negotiator": "0.6.2"
2400 | }
2401 | },
2402 | "ansi-align": {
2403 | "version": "3.0.1",
2404 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.1.tgz",
2405 | "integrity": "sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w==",
2406 | "dev": true,
2407 | "requires": {
2408 | "string-width": "^4.1.0"
2409 | }
2410 | },
2411 | "ansi-regex": {
2412 | "version": "5.0.1",
2413 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
2414 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
2415 | "dev": true
2416 | },
2417 | "ansi-styles": {
2418 | "version": "4.3.0",
2419 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
2420 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
2421 | "dev": true,
2422 | "requires": {
2423 | "color-convert": "^2.0.1"
2424 | }
2425 | },
2426 | "anymatch": {
2427 | "version": "3.1.2",
2428 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz",
2429 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==",
2430 | "dev": true,
2431 | "requires": {
2432 | "normalize-path": "^3.0.0",
2433 | "picomatch": "^2.0.4"
2434 | }
2435 | },
2436 | "array-flatten": {
2437 | "version": "1.1.1",
2438 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
2439 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI="
2440 | },
2441 | "balanced-match": {
2442 | "version": "1.0.2",
2443 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
2444 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
2445 | "dev": true
2446 | },
2447 | "base64-js": {
2448 | "version": "1.5.1",
2449 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz",
2450 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA=="
2451 | },
2452 | "bcryptjs": {
2453 | "version": "2.4.3",
2454 | "resolved": "https://registry.npmjs.org/bcryptjs/-/bcryptjs-2.4.3.tgz",
2455 | "integrity": "sha1-mrVie5PmBiH/fNrF2pczAn3x0Ms="
2456 | },
2457 | "binary-extensions": {
2458 | "version": "2.2.0",
2459 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
2460 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
2461 | "dev": true
2462 | },
2463 | "body-parser": {
2464 | "version": "1.19.1",
2465 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.1.tgz",
2466 | "integrity": "sha512-8ljfQi5eBk8EJfECMrgqNGWPEY5jWP+1IzkzkGdFFEwFQZZyaZ21UqdaHktgiMlH0xLHqIFtE/u2OYE5dOtViA==",
2467 | "requires": {
2468 | "bytes": "3.1.1",
2469 | "content-type": "~1.0.4",
2470 | "debug": "2.6.9",
2471 | "depd": "~1.1.2",
2472 | "http-errors": "1.8.1",
2473 | "iconv-lite": "0.4.24",
2474 | "on-finished": "~2.3.0",
2475 | "qs": "6.9.6",
2476 | "raw-body": "2.4.2",
2477 | "type-is": "~1.6.18"
2478 | }
2479 | },
2480 | "boxen": {
2481 | "version": "5.1.2",
2482 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-5.1.2.tgz",
2483 | "integrity": "sha512-9gYgQKXx+1nP8mP7CzFyaUARhg7D3n1dF/FnErWmu9l6JvGpNUN278h0aSb+QjoiKSWG+iZ3uHrcqk0qrY9RQQ==",
2484 | "dev": true,
2485 | "requires": {
2486 | "ansi-align": "^3.0.0",
2487 | "camelcase": "^6.2.0",
2488 | "chalk": "^4.1.0",
2489 | "cli-boxes": "^2.2.1",
2490 | "string-width": "^4.2.2",
2491 | "type-fest": "^0.20.2",
2492 | "widest-line": "^3.1.0",
2493 | "wrap-ansi": "^7.0.0"
2494 | }
2495 | },
2496 | "brace-expansion": {
2497 | "version": "1.1.11",
2498 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
2499 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
2500 | "dev": true,
2501 | "requires": {
2502 | "balanced-match": "^1.0.0",
2503 | "concat-map": "0.0.1"
2504 | }
2505 | },
2506 | "braces": {
2507 | "version": "3.0.2",
2508 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
2509 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
2510 | "dev": true,
2511 | "requires": {
2512 | "fill-range": "^7.0.1"
2513 | }
2514 | },
2515 | "bson": {
2516 | "version": "4.6.1",
2517 | "resolved": "https://registry.npmjs.org/bson/-/bson-4.6.1.tgz",
2518 | "integrity": "sha512-I1LQ7Hz5zgwR4QquilLNZwbhPw0Apx7i7X9kGMBTsqPdml/03Q9NBtD9nt/19ahjlphktQImrnderxqpzeVDjw==",
2519 | "requires": {
2520 | "buffer": "^5.6.0"
2521 | }
2522 | },
2523 | "buffer": {
2524 | "version": "5.7.1",
2525 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz",
2526 | "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==",
2527 | "requires": {
2528 | "base64-js": "^1.3.1",
2529 | "ieee754": "^1.1.13"
2530 | }
2531 | },
2532 | "buffer-equal-constant-time": {
2533 | "version": "1.0.1",
2534 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz",
2535 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk="
2536 | },
2537 | "bytes": {
2538 | "version": "3.1.1",
2539 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.1.tgz",
2540 | "integrity": "sha512-dWe4nWO/ruEOY7HkUJ5gFt1DCFV9zPRoJr8pV0/ASQermOZjtq8jMjOprC0Kd10GLN+l7xaUPvxzJFWtxGu8Fg=="
2541 | },
2542 | "cacheable-request": {
2543 | "version": "6.1.0",
2544 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz",
2545 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==",
2546 | "dev": true,
2547 | "requires": {
2548 | "clone-response": "^1.0.2",
2549 | "get-stream": "^5.1.0",
2550 | "http-cache-semantics": "^4.0.0",
2551 | "keyv": "^3.0.0",
2552 | "lowercase-keys": "^2.0.0",
2553 | "normalize-url": "^4.1.0",
2554 | "responselike": "^1.0.2"
2555 | },
2556 | "dependencies": {
2557 | "get-stream": {
2558 | "version": "5.2.0",
2559 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz",
2560 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==",
2561 | "dev": true,
2562 | "requires": {
2563 | "pump": "^3.0.0"
2564 | }
2565 | },
2566 | "lowercase-keys": {
2567 | "version": "2.0.0",
2568 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz",
2569 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==",
2570 | "dev": true
2571 | }
2572 | }
2573 | },
2574 | "camelcase": {
2575 | "version": "6.3.0",
2576 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz",
2577 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==",
2578 | "dev": true
2579 | },
2580 | "chalk": {
2581 | "version": "4.1.2",
2582 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
2583 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
2584 | "dev": true,
2585 | "requires": {
2586 | "ansi-styles": "^4.1.0",
2587 | "supports-color": "^7.1.0"
2588 | },
2589 | "dependencies": {
2590 | "has-flag": {
2591 | "version": "4.0.0",
2592 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
2593 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
2594 | "dev": true
2595 | },
2596 | "supports-color": {
2597 | "version": "7.2.0",
2598 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
2599 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
2600 | "dev": true,
2601 | "requires": {
2602 | "has-flag": "^4.0.0"
2603 | }
2604 | }
2605 | }
2606 | },
2607 | "chokidar": {
2608 | "version": "3.5.3",
2609 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz",
2610 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==",
2611 | "dev": true,
2612 | "requires": {
2613 | "anymatch": "~3.1.2",
2614 | "braces": "~3.0.2",
2615 | "fsevents": "~2.3.2",
2616 | "glob-parent": "~5.1.2",
2617 | "is-binary-path": "~2.1.0",
2618 | "is-glob": "~4.0.1",
2619 | "normalize-path": "~3.0.0",
2620 | "readdirp": "~3.6.0"
2621 | }
2622 | },
2623 | "ci-info": {
2624 | "version": "2.0.0",
2625 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz",
2626 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==",
2627 | "dev": true
2628 | },
2629 | "cli-boxes": {
2630 | "version": "2.2.1",
2631 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz",
2632 | "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==",
2633 | "dev": true
2634 | },
2635 | "cliui": {
2636 | "version": "7.0.4",
2637 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz",
2638 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==",
2639 | "dev": true,
2640 | "requires": {
2641 | "string-width": "^4.2.0",
2642 | "strip-ansi": "^6.0.0",
2643 | "wrap-ansi": "^7.0.0"
2644 | }
2645 | },
2646 | "clone-response": {
2647 | "version": "1.0.2",
2648 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz",
2649 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=",
2650 | "dev": true,
2651 | "requires": {
2652 | "mimic-response": "^1.0.0"
2653 | }
2654 | },
2655 | "color-convert": {
2656 | "version": "2.0.1",
2657 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
2658 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
2659 | "dev": true,
2660 | "requires": {
2661 | "color-name": "~1.1.4"
2662 | }
2663 | },
2664 | "color-name": {
2665 | "version": "1.1.4",
2666 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
2667 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
2668 | "dev": true
2669 | },
2670 | "colors": {
2671 | "version": "1.4.0",
2672 | "resolved": "https://registry.npmjs.org/colors/-/colors-1.4.0.tgz",
2673 | "integrity": "sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA=="
2674 | },
2675 | "concat-map": {
2676 | "version": "0.0.1",
2677 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
2678 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
2679 | "dev": true
2680 | },
2681 | "concurrently": {
2682 | "version": "7.0.0",
2683 | "resolved": "https://registry.npmjs.org/concurrently/-/concurrently-7.0.0.tgz",
2684 | "integrity": "sha512-WKM7PUsI8wyXpF80H+zjHP32fsgsHNQfPLw/e70Z5dYkV7hF+rf8q3D+ScWJIEr57CpkO3OWBko6hwhQLPR8Pw==",
2685 | "dev": true,
2686 | "requires": {
2687 | "chalk": "^4.1.0",
2688 | "date-fns": "^2.16.1",
2689 | "lodash": "^4.17.21",
2690 | "rxjs": "^6.6.3",
2691 | "spawn-command": "^0.0.2-1",
2692 | "supports-color": "^8.1.0",
2693 | "tree-kill": "^1.2.2",
2694 | "yargs": "^16.2.0"
2695 | },
2696 | "dependencies": {
2697 | "has-flag": {
2698 | "version": "4.0.0",
2699 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
2700 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
2701 | "dev": true
2702 | },
2703 | "supports-color": {
2704 | "version": "8.1.1",
2705 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz",
2706 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==",
2707 | "dev": true,
2708 | "requires": {
2709 | "has-flag": "^4.0.0"
2710 | }
2711 | }
2712 | }
2713 | },
2714 | "configstore": {
2715 | "version": "5.0.1",
2716 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz",
2717 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==",
2718 | "dev": true,
2719 | "requires": {
2720 | "dot-prop": "^5.2.0",
2721 | "graceful-fs": "^4.1.2",
2722 | "make-dir": "^3.0.0",
2723 | "unique-string": "^2.0.0",
2724 | "write-file-atomic": "^3.0.0",
2725 | "xdg-basedir": "^4.0.0"
2726 | }
2727 | },
2728 | "content-disposition": {
2729 | "version": "0.5.4",
2730 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz",
2731 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==",
2732 | "requires": {
2733 | "safe-buffer": "5.2.1"
2734 | }
2735 | },
2736 | "content-type": {
2737 | "version": "1.0.4",
2738 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz",
2739 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA=="
2740 | },
2741 | "cookie": {
2742 | "version": "0.4.1",
2743 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz",
2744 | "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA=="
2745 | },
2746 | "cookie-signature": {
2747 | "version": "1.0.6",
2748 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
2749 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw="
2750 | },
2751 | "crypto-random-string": {
2752 | "version": "2.0.0",
2753 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz",
2754 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==",
2755 | "dev": true
2756 | },
2757 | "date-fns": {
2758 | "version": "2.28.0",
2759 | "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-2.28.0.tgz",
2760 | "integrity": "sha512-8d35hViGYx/QH0icHYCeLmsLmMUheMmTyV9Fcm6gvNwdw31yXXH+O85sOBJ+OLnLQMKZowvpKb6FgMIQjcpvQw==",
2761 | "dev": true
2762 | },
2763 | "debug": {
2764 | "version": "2.6.9",
2765 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
2766 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
2767 | "requires": {
2768 | "ms": "2.0.0"
2769 | }
2770 | },
2771 | "decompress-response": {
2772 | "version": "3.3.0",
2773 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz",
2774 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=",
2775 | "dev": true,
2776 | "requires": {
2777 | "mimic-response": "^1.0.0"
2778 | }
2779 | },
2780 | "deep-extend": {
2781 | "version": "0.6.0",
2782 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz",
2783 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==",
2784 | "dev": true
2785 | },
2786 | "defer-to-connect": {
2787 | "version": "1.1.3",
2788 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz",
2789 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==",
2790 | "dev": true
2791 | },
2792 | "denque": {
2793 | "version": "2.0.1",
2794 | "resolved": "https://registry.npmjs.org/denque/-/denque-2.0.1.tgz",
2795 | "integrity": "sha512-tfiWc6BQLXNLpNiR5iGd0Ocu3P3VpxfzFiqubLgMfhfOw9WyvgJBd46CClNn9k3qfbjvT//0cf7AlYRX/OslMQ=="
2796 | },
2797 | "depd": {
2798 | "version": "1.1.2",
2799 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz",
2800 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak="
2801 | },
2802 | "destroy": {
2803 | "version": "1.0.4",
2804 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz",
2805 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA="
2806 | },
2807 | "dot-prop": {
2808 | "version": "5.3.0",
2809 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz",
2810 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==",
2811 | "dev": true,
2812 | "requires": {
2813 | "is-obj": "^2.0.0"
2814 | }
2815 | },
2816 | "dotenv": {
2817 | "version": "15.0.0",
2818 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-15.0.0.tgz",
2819 | "integrity": "sha512-/l1sXXm79ry34KwwS0y4oVZjB468iw/6u9g1W26dtexKcIJAnVL2pMF+hxQwzZ7LutxOwEgtym9eIxvX33CMKg=="
2820 | },
2821 | "duplexer3": {
2822 | "version": "0.1.4",
2823 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz",
2824 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=",
2825 | "dev": true
2826 | },
2827 | "ecdsa-sig-formatter": {
2828 | "version": "1.0.11",
2829 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz",
2830 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==",
2831 | "requires": {
2832 | "safe-buffer": "^5.0.1"
2833 | }
2834 | },
2835 | "ee-first": {
2836 | "version": "1.1.1",
2837 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
2838 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0="
2839 | },
2840 | "emoji-regex": {
2841 | "version": "8.0.0",
2842 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
2843 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
2844 | "dev": true
2845 | },
2846 | "encodeurl": {
2847 | "version": "1.0.2",
2848 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
2849 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k="
2850 | },
2851 | "end-of-stream": {
2852 | "version": "1.4.4",
2853 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz",
2854 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==",
2855 | "dev": true,
2856 | "requires": {
2857 | "once": "^1.4.0"
2858 | }
2859 | },
2860 | "escalade": {
2861 | "version": "3.1.1",
2862 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz",
2863 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==",
2864 | "dev": true
2865 | },
2866 | "escape-goat": {
2867 | "version": "2.1.1",
2868 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz",
2869 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==",
2870 | "dev": true
2871 | },
2872 | "escape-html": {
2873 | "version": "1.0.3",
2874 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
2875 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg="
2876 | },
2877 | "etag": {
2878 | "version": "1.8.1",
2879 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
2880 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc="
2881 | },
2882 | "express": {
2883 | "version": "4.17.2",
2884 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.2.tgz",
2885 | "integrity": "sha512-oxlxJxcQlYwqPWKVJJtvQiwHgosH/LrLSPA+H4UxpyvSS6jC5aH+5MoHFM+KABgTOt0APue4w66Ha8jCUo9QGg==",
2886 | "requires": {
2887 | "accepts": "~1.3.7",
2888 | "array-flatten": "1.1.1",
2889 | "body-parser": "1.19.1",
2890 | "content-disposition": "0.5.4",
2891 | "content-type": "~1.0.4",
2892 | "cookie": "0.4.1",
2893 | "cookie-signature": "1.0.6",
2894 | "debug": "2.6.9",
2895 | "depd": "~1.1.2",
2896 | "encodeurl": "~1.0.2",
2897 | "escape-html": "~1.0.3",
2898 | "etag": "~1.8.1",
2899 | "finalhandler": "~1.1.2",
2900 | "fresh": "0.5.2",
2901 | "merge-descriptors": "1.0.1",
2902 | "methods": "~1.1.2",
2903 | "on-finished": "~2.3.0",
2904 | "parseurl": "~1.3.3",
2905 | "path-to-regexp": "0.1.7",
2906 | "proxy-addr": "~2.0.7",
2907 | "qs": "6.9.6",
2908 | "range-parser": "~1.2.1",
2909 | "safe-buffer": "5.2.1",
2910 | "send": "0.17.2",
2911 | "serve-static": "1.14.2",
2912 | "setprototypeof": "1.2.0",
2913 | "statuses": "~1.5.0",
2914 | "type-is": "~1.6.18",
2915 | "utils-merge": "1.0.1",
2916 | "vary": "~1.1.2"
2917 | }
2918 | },
2919 | "express-async-handler": {
2920 | "version": "1.2.0",
2921 | "resolved": "https://registry.npmjs.org/express-async-handler/-/express-async-handler-1.2.0.tgz",
2922 | "integrity": "sha512-rCSVtPXRmQSW8rmik/AIb2P0op6l7r1fMW538yyvTMltCO4xQEWMmobfrIxN2V1/mVrgxB8Az3reYF6yUZw37w=="
2923 | },
2924 | "fill-range": {
2925 | "version": "7.0.1",
2926 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
2927 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
2928 | "dev": true,
2929 | "requires": {
2930 | "to-regex-range": "^5.0.1"
2931 | }
2932 | },
2933 | "finalhandler": {
2934 | "version": "1.1.2",
2935 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz",
2936 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==",
2937 | "requires": {
2938 | "debug": "2.6.9",
2939 | "encodeurl": "~1.0.2",
2940 | "escape-html": "~1.0.3",
2941 | "on-finished": "~2.3.0",
2942 | "parseurl": "~1.3.3",
2943 | "statuses": "~1.5.0",
2944 | "unpipe": "~1.0.0"
2945 | }
2946 | },
2947 | "forwarded": {
2948 | "version": "0.2.0",
2949 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz",
2950 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow=="
2951 | },
2952 | "fresh": {
2953 | "version": "0.5.2",
2954 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
2955 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac="
2956 | },
2957 | "fsevents": {
2958 | "version": "2.3.2",
2959 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
2960 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
2961 | "dev": true,
2962 | "optional": true
2963 | },
2964 | "get-caller-file": {
2965 | "version": "2.0.5",
2966 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz",
2967 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==",
2968 | "dev": true
2969 | },
2970 | "get-stream": {
2971 | "version": "4.1.0",
2972 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz",
2973 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==",
2974 | "dev": true,
2975 | "requires": {
2976 | "pump": "^3.0.0"
2977 | }
2978 | },
2979 | "glob-parent": {
2980 | "version": "5.1.2",
2981 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
2982 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
2983 | "dev": true,
2984 | "requires": {
2985 | "is-glob": "^4.0.1"
2986 | }
2987 | },
2988 | "global-dirs": {
2989 | "version": "3.0.0",
2990 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-3.0.0.tgz",
2991 | "integrity": "sha512-v8ho2DS5RiCjftj1nD9NmnfaOzTdud7RRnVd9kFNOjqZbISlx5DQ+OrTkywgd0dIt7oFCvKetZSHoHcP3sDdiA==",
2992 | "dev": true,
2993 | "requires": {
2994 | "ini": "2.0.0"
2995 | }
2996 | },
2997 | "got": {
2998 | "version": "9.6.0",
2999 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz",
3000 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==",
3001 | "dev": true,
3002 | "requires": {
3003 | "@sindresorhus/is": "^0.14.0",
3004 | "@szmarczak/http-timer": "^1.1.2",
3005 | "cacheable-request": "^6.0.0",
3006 | "decompress-response": "^3.3.0",
3007 | "duplexer3": "^0.1.4",
3008 | "get-stream": "^4.1.0",
3009 | "lowercase-keys": "^1.0.1",
3010 | "mimic-response": "^1.0.1",
3011 | "p-cancelable": "^1.0.0",
3012 | "to-readable-stream": "^1.0.0",
3013 | "url-parse-lax": "^3.0.0"
3014 | }
3015 | },
3016 | "graceful-fs": {
3017 | "version": "4.2.9",
3018 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz",
3019 | "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==",
3020 | "dev": true
3021 | },
3022 | "has-flag": {
3023 | "version": "3.0.0",
3024 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
3025 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=",
3026 | "dev": true
3027 | },
3028 | "has-yarn": {
3029 | "version": "2.1.0",
3030 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz",
3031 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==",
3032 | "dev": true
3033 | },
3034 | "http-cache-semantics": {
3035 | "version": "4.1.0",
3036 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz",
3037 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==",
3038 | "dev": true
3039 | },
3040 | "http-errors": {
3041 | "version": "1.8.1",
3042 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz",
3043 | "integrity": "sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g==",
3044 | "requires": {
3045 | "depd": "~1.1.2",
3046 | "inherits": "2.0.4",
3047 | "setprototypeof": "1.2.0",
3048 | "statuses": ">= 1.5.0 < 2",
3049 | "toidentifier": "1.0.1"
3050 | }
3051 | },
3052 | "iconv-lite": {
3053 | "version": "0.4.24",
3054 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
3055 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
3056 | "requires": {
3057 | "safer-buffer": ">= 2.1.2 < 3"
3058 | }
3059 | },
3060 | "ieee754": {
3061 | "version": "1.2.1",
3062 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz",
3063 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA=="
3064 | },
3065 | "ignore-by-default": {
3066 | "version": "1.0.1",
3067 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz",
3068 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=",
3069 | "dev": true
3070 | },
3071 | "import-lazy": {
3072 | "version": "2.1.0",
3073 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz",
3074 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=",
3075 | "dev": true
3076 | },
3077 | "imurmurhash": {
3078 | "version": "0.1.4",
3079 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
3080 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=",
3081 | "dev": true
3082 | },
3083 | "inherits": {
3084 | "version": "2.0.4",
3085 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
3086 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
3087 | },
3088 | "ini": {
3089 | "version": "2.0.0",
3090 | "resolved": "https://registry.npmjs.org/ini/-/ini-2.0.0.tgz",
3091 | "integrity": "sha512-7PnF4oN3CvZF23ADhA5wRaYEQpJ8qygSkbtTXWBeXWXmEVRXK+1ITciHWwHhsjv1TmW0MgacIv6hEi5pX5NQdA==",
3092 | "dev": true
3093 | },
3094 | "ipaddr.js": {
3095 | "version": "1.9.1",
3096 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz",
3097 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g=="
3098 | },
3099 | "is-binary-path": {
3100 | "version": "2.1.0",
3101 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
3102 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
3103 | "dev": true,
3104 | "requires": {
3105 | "binary-extensions": "^2.0.0"
3106 | }
3107 | },
3108 | "is-ci": {
3109 | "version": "2.0.0",
3110 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz",
3111 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==",
3112 | "dev": true,
3113 | "requires": {
3114 | "ci-info": "^2.0.0"
3115 | }
3116 | },
3117 | "is-extglob": {
3118 | "version": "2.1.1",
3119 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
3120 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
3121 | "dev": true
3122 | },
3123 | "is-fullwidth-code-point": {
3124 | "version": "3.0.0",
3125 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
3126 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
3127 | "dev": true
3128 | },
3129 | "is-glob": {
3130 | "version": "4.0.3",
3131 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
3132 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
3133 | "dev": true,
3134 | "requires": {
3135 | "is-extglob": "^2.1.1"
3136 | }
3137 | },
3138 | "is-installed-globally": {
3139 | "version": "0.4.0",
3140 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.4.0.tgz",
3141 | "integrity": "sha512-iwGqO3J21aaSkC7jWnHP/difazwS7SFeIqxv6wEtLU8Y5KlzFTjyqcSIT0d8s4+dDhKytsk9PJZ2BkS5eZwQRQ==",
3142 | "dev": true,
3143 | "requires": {
3144 | "global-dirs": "^3.0.0",
3145 | "is-path-inside": "^3.0.2"
3146 | }
3147 | },
3148 | "is-npm": {
3149 | "version": "5.0.0",
3150 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-5.0.0.tgz",
3151 | "integrity": "sha512-WW/rQLOazUq+ST/bCAVBp/2oMERWLsR7OrKyt052dNDk4DHcDE0/7QSXITlmi+VBcV13DfIbysG3tZJm5RfdBA==",
3152 | "dev": true
3153 | },
3154 | "is-number": {
3155 | "version": "7.0.0",
3156 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
3157 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
3158 | "dev": true
3159 | },
3160 | "is-obj": {
3161 | "version": "2.0.0",
3162 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz",
3163 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==",
3164 | "dev": true
3165 | },
3166 | "is-path-inside": {
3167 | "version": "3.0.3",
3168 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz",
3169 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==",
3170 | "dev": true
3171 | },
3172 | "is-typedarray": {
3173 | "version": "1.0.0",
3174 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz",
3175 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=",
3176 | "dev": true
3177 | },
3178 | "is-yarn-global": {
3179 | "version": "0.3.0",
3180 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz",
3181 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==",
3182 | "dev": true
3183 | },
3184 | "json-buffer": {
3185 | "version": "3.0.0",
3186 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz",
3187 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=",
3188 | "dev": true
3189 | },
3190 | "jsonwebtoken": {
3191 | "version": "8.5.1",
3192 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz",
3193 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==",
3194 | "requires": {
3195 | "jws": "^3.2.2",
3196 | "lodash.includes": "^4.3.0",
3197 | "lodash.isboolean": "^3.0.3",
3198 | "lodash.isinteger": "^4.0.4",
3199 | "lodash.isnumber": "^3.0.3",
3200 | "lodash.isplainobject": "^4.0.6",
3201 | "lodash.isstring": "^4.0.1",
3202 | "lodash.once": "^4.0.0",
3203 | "ms": "^2.1.1",
3204 | "semver": "^5.6.0"
3205 | },
3206 | "dependencies": {
3207 | "ms": {
3208 | "version": "2.1.3",
3209 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
3210 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
3211 | }
3212 | }
3213 | },
3214 | "jwa": {
3215 | "version": "1.4.1",
3216 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz",
3217 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==",
3218 | "requires": {
3219 | "buffer-equal-constant-time": "1.0.1",
3220 | "ecdsa-sig-formatter": "1.0.11",
3221 | "safe-buffer": "^5.0.1"
3222 | }
3223 | },
3224 | "jws": {
3225 | "version": "3.2.2",
3226 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz",
3227 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==",
3228 | "requires": {
3229 | "jwa": "^1.4.1",
3230 | "safe-buffer": "^5.0.1"
3231 | }
3232 | },
3233 | "kareem": {
3234 | "version": "2.3.3",
3235 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.3.tgz",
3236 | "integrity": "sha512-uESCXM2KdtOQ8LOvKyTUXEeg0MkYp4wGglTIpGcYHvjJcS5sn2Wkfrfit8m4xSbaNDAw2KdI9elgkOxZbrFYbg=="
3237 | },
3238 | "keyv": {
3239 | "version": "3.1.0",
3240 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz",
3241 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==",
3242 | "dev": true,
3243 | "requires": {
3244 | "json-buffer": "3.0.0"
3245 | }
3246 | },
3247 | "latest-version": {
3248 | "version": "5.1.0",
3249 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz",
3250 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==",
3251 | "dev": true,
3252 | "requires": {
3253 | "package-json": "^6.3.0"
3254 | }
3255 | },
3256 | "lodash": {
3257 | "version": "4.17.21",
3258 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz",
3259 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==",
3260 | "dev": true
3261 | },
3262 | "lodash.includes": {
3263 | "version": "4.3.0",
3264 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz",
3265 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8="
3266 | },
3267 | "lodash.isboolean": {
3268 | "version": "3.0.3",
3269 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz",
3270 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY="
3271 | },
3272 | "lodash.isinteger": {
3273 | "version": "4.0.4",
3274 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz",
3275 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M="
3276 | },
3277 | "lodash.isnumber": {
3278 | "version": "3.0.3",
3279 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz",
3280 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w="
3281 | },
3282 | "lodash.isplainobject": {
3283 | "version": "4.0.6",
3284 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz",
3285 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs="
3286 | },
3287 | "lodash.isstring": {
3288 | "version": "4.0.1",
3289 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz",
3290 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE="
3291 | },
3292 | "lodash.once": {
3293 | "version": "4.1.1",
3294 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz",
3295 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w="
3296 | },
3297 | "lowercase-keys": {
3298 | "version": "1.0.1",
3299 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz",
3300 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==",
3301 | "dev": true
3302 | },
3303 | "lru-cache": {
3304 | "version": "6.0.0",
3305 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
3306 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
3307 | "dev": true,
3308 | "requires": {
3309 | "yallist": "^4.0.0"
3310 | }
3311 | },
3312 | "make-dir": {
3313 | "version": "3.1.0",
3314 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz",
3315 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==",
3316 | "dev": true,
3317 | "requires": {
3318 | "semver": "^6.0.0"
3319 | },
3320 | "dependencies": {
3321 | "semver": {
3322 | "version": "6.3.0",
3323 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
3324 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
3325 | "dev": true
3326 | }
3327 | }
3328 | },
3329 | "media-typer": {
3330 | "version": "0.3.0",
3331 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
3332 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g="
3333 | },
3334 | "memory-pager": {
3335 | "version": "1.5.0",
3336 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz",
3337 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==",
3338 | "optional": true
3339 | },
3340 | "merge-descriptors": {
3341 | "version": "1.0.1",
3342 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
3343 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E="
3344 | },
3345 | "methods": {
3346 | "version": "1.1.2",
3347 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
3348 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4="
3349 | },
3350 | "mime": {
3351 | "version": "1.6.0",
3352 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
3353 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg=="
3354 | },
3355 | "mime-db": {
3356 | "version": "1.51.0",
3357 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.51.0.tgz",
3358 | "integrity": "sha512-5y8A56jg7XVQx2mbv1lu49NR4dokRnhZYTtL+KGfaa27uq4pSTXkwQkFJl4pkRMyNFz/EtYDSkiiEHx3F7UN6g=="
3359 | },
3360 | "mime-types": {
3361 | "version": "2.1.34",
3362 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.34.tgz",
3363 | "integrity": "sha512-6cP692WwGIs9XXdOO4++N+7qjqv0rqxxVvJ3VHPh/Sc9mVZcQP+ZGhkKiTvWMQRr2tbHkJP/Yn7Y0npb3ZBs4A==",
3364 | "requires": {
3365 | "mime-db": "1.51.0"
3366 | }
3367 | },
3368 | "mimic-response": {
3369 | "version": "1.0.1",
3370 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz",
3371 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==",
3372 | "dev": true
3373 | },
3374 | "minimatch": {
3375 | "version": "3.0.4",
3376 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
3377 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
3378 | "dev": true,
3379 | "requires": {
3380 | "brace-expansion": "^1.1.7"
3381 | }
3382 | },
3383 | "minimist": {
3384 | "version": "1.2.5",
3385 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
3386 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
3387 | "dev": true
3388 | },
3389 | "mongodb": {
3390 | "version": "4.2.2",
3391 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-4.2.2.tgz",
3392 | "integrity": "sha512-zt8rCTnTKyMQppyt63qMnrLM5dbADgUk18ORPF1XbtHLIYCyc9hattaYHi0pqMvNxDpgGgUofSVzS+UQErgTug==",
3393 | "requires": {
3394 | "bson": "^4.6.0",
3395 | "denque": "^2.0.1",
3396 | "mongodb-connection-string-url": "^2.3.2",
3397 | "saslprep": "^1.0.3"
3398 | }
3399 | },
3400 | "mongodb-connection-string-url": {
3401 | "version": "2.4.1",
3402 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-2.4.1.tgz",
3403 | "integrity": "sha512-d5Kd2bVsKcSA7YI/yo57fSTtMwRQdFkvc5IZwod1RRxJtECeWPPSo7zqcUGJELifRA//Igs4spVtYAmvFCatug==",
3404 | "requires": {
3405 | "@types/whatwg-url": "^8.2.1",
3406 | "whatwg-url": "^11.0.0"
3407 | }
3408 | },
3409 | "mongoose": {
3410 | "version": "6.1.9",
3411 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-6.1.9.tgz",
3412 | "integrity": "sha512-dh6ZeYNGUAW4Gc4MxxgPwU+0d1tZZgse6xTejDjFwyXJArBcyI4xLqNrO9W6Umu2iQzlT701RTtN+iJ0gipM4A==",
3413 | "requires": {
3414 | "@types/node": "< 17.0.6",
3415 | "bson": "^4.2.2",
3416 | "kareem": "2.3.3",
3417 | "mongodb": "4.2.2",
3418 | "mpath": "0.8.4",
3419 | "mquery": "4.0.2",
3420 | "ms": "2.1.2",
3421 | "regexp-clone": "1.0.0",
3422 | "sift": "13.5.2"
3423 | },
3424 | "dependencies": {
3425 | "ms": {
3426 | "version": "2.1.2",
3427 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
3428 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
3429 | }
3430 | }
3431 | },
3432 | "mpath": {
3433 | "version": "0.8.4",
3434 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.8.4.tgz",
3435 | "integrity": "sha512-DTxNZomBcTWlrMW76jy1wvV37X/cNNxPW1y2Jzd4DZkAaC5ZGsm8bfGfNOthcDuRJujXLqiuS6o3Tpy0JEoh7g=="
3436 | },
3437 | "mquery": {
3438 | "version": "4.0.2",
3439 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-4.0.2.tgz",
3440 | "integrity": "sha512-oAVF0Nil1mT3rxty6Zln4YiD6x6QsUWYz927jZzjMxOK2aqmhEz5JQ7xmrKK7xRFA2dwV+YaOpKU/S+vfNqKxA==",
3441 | "requires": {
3442 | "debug": "4.x"
3443 | },
3444 | "dependencies": {
3445 | "debug": {
3446 | "version": "4.3.3",
3447 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz",
3448 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==",
3449 | "requires": {
3450 | "ms": "2.1.2"
3451 | }
3452 | },
3453 | "ms": {
3454 | "version": "2.1.2",
3455 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
3456 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
3457 | }
3458 | }
3459 | },
3460 | "ms": {
3461 | "version": "2.0.0",
3462 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
3463 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g="
3464 | },
3465 | "negotiator": {
3466 | "version": "0.6.2",
3467 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz",
3468 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw=="
3469 | },
3470 | "nodemon": {
3471 | "version": "2.0.15",
3472 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.15.tgz",
3473 | "integrity": "sha512-gdHMNx47Gw7b3kWxJV64NI+Q5nfl0y5DgDbiVtShiwa7Z0IZ07Ll4RLFo6AjrhzMtoEZn5PDE3/c2AbVsiCkpA==",
3474 | "dev": true,
3475 | "requires": {
3476 | "chokidar": "^3.5.2",
3477 | "debug": "^3.2.7",
3478 | "ignore-by-default": "^1.0.1",
3479 | "minimatch": "^3.0.4",
3480 | "pstree.remy": "^1.1.8",
3481 | "semver": "^5.7.1",
3482 | "supports-color": "^5.5.0",
3483 | "touch": "^3.1.0",
3484 | "undefsafe": "^2.0.5",
3485 | "update-notifier": "^5.1.0"
3486 | },
3487 | "dependencies": {
3488 | "debug": {
3489 | "version": "3.2.7",
3490 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz",
3491 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==",
3492 | "dev": true,
3493 | "requires": {
3494 | "ms": "^2.1.1"
3495 | }
3496 | },
3497 | "ms": {
3498 | "version": "2.1.3",
3499 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
3500 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
3501 | "dev": true
3502 | }
3503 | }
3504 | },
3505 | "nopt": {
3506 | "version": "1.0.10",
3507 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz",
3508 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=",
3509 | "dev": true,
3510 | "requires": {
3511 | "abbrev": "1"
3512 | }
3513 | },
3514 | "normalize-path": {
3515 | "version": "3.0.0",
3516 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
3517 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
3518 | "dev": true
3519 | },
3520 | "normalize-url": {
3521 | "version": "4.5.1",
3522 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.1.tgz",
3523 | "integrity": "sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA==",
3524 | "dev": true
3525 | },
3526 | "on-finished": {
3527 | "version": "2.3.0",
3528 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz",
3529 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=",
3530 | "requires": {
3531 | "ee-first": "1.1.1"
3532 | }
3533 | },
3534 | "once": {
3535 | "version": "1.4.0",
3536 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
3537 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
3538 | "dev": true,
3539 | "requires": {
3540 | "wrappy": "1"
3541 | }
3542 | },
3543 | "p-cancelable": {
3544 | "version": "1.1.0",
3545 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz",
3546 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==",
3547 | "dev": true
3548 | },
3549 | "package-json": {
3550 | "version": "6.5.0",
3551 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz",
3552 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==",
3553 | "dev": true,
3554 | "requires": {
3555 | "got": "^9.6.0",
3556 | "registry-auth-token": "^4.0.0",
3557 | "registry-url": "^5.0.0",
3558 | "semver": "^6.2.0"
3559 | },
3560 | "dependencies": {
3561 | "semver": {
3562 | "version": "6.3.0",
3563 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
3564 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
3565 | "dev": true
3566 | }
3567 | }
3568 | },
3569 | "parseurl": {
3570 | "version": "1.3.3",
3571 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
3572 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ=="
3573 | },
3574 | "path-to-regexp": {
3575 | "version": "0.1.7",
3576 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
3577 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w="
3578 | },
3579 | "picomatch": {
3580 | "version": "2.3.1",
3581 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
3582 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
3583 | "dev": true
3584 | },
3585 | "prepend-http": {
3586 | "version": "2.0.0",
3587 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz",
3588 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=",
3589 | "dev": true
3590 | },
3591 | "proxy-addr": {
3592 | "version": "2.0.7",
3593 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz",
3594 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==",
3595 | "requires": {
3596 | "forwarded": "0.2.0",
3597 | "ipaddr.js": "1.9.1"
3598 | }
3599 | },
3600 | "pstree.remy": {
3601 | "version": "1.1.8",
3602 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz",
3603 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==",
3604 | "dev": true
3605 | },
3606 | "pump": {
3607 | "version": "3.0.0",
3608 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz",
3609 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==",
3610 | "dev": true,
3611 | "requires": {
3612 | "end-of-stream": "^1.1.0",
3613 | "once": "^1.3.1"
3614 | }
3615 | },
3616 | "punycode": {
3617 | "version": "2.1.1",
3618 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz",
3619 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A=="
3620 | },
3621 | "pupa": {
3622 | "version": "2.1.1",
3623 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz",
3624 | "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==",
3625 | "dev": true,
3626 | "requires": {
3627 | "escape-goat": "^2.0.0"
3628 | }
3629 | },
3630 | "qs": {
3631 | "version": "6.9.6",
3632 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.9.6.tgz",
3633 | "integrity": "sha512-TIRk4aqYLNoJUbd+g2lEdz5kLWIuTMRagAXxl78Q0RiVjAOugHmeKNGdd3cwo/ktpf9aL9epCfFqWDEKysUlLQ=="
3634 | },
3635 | "range-parser": {
3636 | "version": "1.2.1",
3637 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
3638 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg=="
3639 | },
3640 | "raw-body": {
3641 | "version": "2.4.2",
3642 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.2.tgz",
3643 | "integrity": "sha512-RPMAFUJP19WIet/99ngh6Iv8fzAbqum4Li7AD6DtGaW2RpMB/11xDoalPiJMTbu6I3hkbMVkATvZrqb9EEqeeQ==",
3644 | "requires": {
3645 | "bytes": "3.1.1",
3646 | "http-errors": "1.8.1",
3647 | "iconv-lite": "0.4.24",
3648 | "unpipe": "1.0.0"
3649 | }
3650 | },
3651 | "rc": {
3652 | "version": "1.2.8",
3653 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz",
3654 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==",
3655 | "dev": true,
3656 | "requires": {
3657 | "deep-extend": "^0.6.0",
3658 | "ini": "~1.3.0",
3659 | "minimist": "^1.2.0",
3660 | "strip-json-comments": "~2.0.1"
3661 | },
3662 | "dependencies": {
3663 | "ini": {
3664 | "version": "1.3.8",
3665 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz",
3666 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==",
3667 | "dev": true
3668 | }
3669 | }
3670 | },
3671 | "readdirp": {
3672 | "version": "3.6.0",
3673 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
3674 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
3675 | "dev": true,
3676 | "requires": {
3677 | "picomatch": "^2.2.1"
3678 | }
3679 | },
3680 | "regexp-clone": {
3681 | "version": "1.0.0",
3682 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-1.0.0.tgz",
3683 | "integrity": "sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw=="
3684 | },
3685 | "registry-auth-token": {
3686 | "version": "4.2.1",
3687 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.1.tgz",
3688 | "integrity": "sha512-6gkSb4U6aWJB4SF2ZvLb76yCBjcvufXBqvvEx1HbmKPkutswjW1xNVRY0+daljIYRbogN7O0etYSlbiaEQyMyw==",
3689 | "dev": true,
3690 | "requires": {
3691 | "rc": "^1.2.8"
3692 | }
3693 | },
3694 | "registry-url": {
3695 | "version": "5.1.0",
3696 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz",
3697 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==",
3698 | "dev": true,
3699 | "requires": {
3700 | "rc": "^1.2.8"
3701 | }
3702 | },
3703 | "require-directory": {
3704 | "version": "2.1.1",
3705 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
3706 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=",
3707 | "dev": true
3708 | },
3709 | "responselike": {
3710 | "version": "1.0.2",
3711 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz",
3712 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=",
3713 | "dev": true,
3714 | "requires": {
3715 | "lowercase-keys": "^1.0.0"
3716 | }
3717 | },
3718 | "rxjs": {
3719 | "version": "6.6.7",
3720 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.6.7.tgz",
3721 | "integrity": "sha512-hTdwr+7yYNIT5n4AMYp85KA6yw2Va0FLa3Rguvbpa4W3I5xynaBZo41cM3XM+4Q6fRMj3sBYIR1VAmZMXYJvRQ==",
3722 | "dev": true,
3723 | "requires": {
3724 | "tslib": "^1.9.0"
3725 | }
3726 | },
3727 | "safe-buffer": {
3728 | "version": "5.2.1",
3729 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
3730 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ=="
3731 | },
3732 | "safer-buffer": {
3733 | "version": "2.1.2",
3734 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
3735 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
3736 | },
3737 | "saslprep": {
3738 | "version": "1.0.3",
3739 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz",
3740 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==",
3741 | "optional": true,
3742 | "requires": {
3743 | "sparse-bitfield": "^3.0.3"
3744 | }
3745 | },
3746 | "semver": {
3747 | "version": "5.7.1",
3748 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
3749 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ=="
3750 | },
3751 | "semver-diff": {
3752 | "version": "3.1.1",
3753 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz",
3754 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==",
3755 | "dev": true,
3756 | "requires": {
3757 | "semver": "^6.3.0"
3758 | },
3759 | "dependencies": {
3760 | "semver": {
3761 | "version": "6.3.0",
3762 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
3763 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
3764 | "dev": true
3765 | }
3766 | }
3767 | },
3768 | "send": {
3769 | "version": "0.17.2",
3770 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.2.tgz",
3771 | "integrity": "sha512-UJYB6wFSJE3G00nEivR5rgWp8c2xXvJ3OPWPhmuteU0IKj8nKbG3DrjiOmLwpnHGYWAVwA69zmTm++YG0Hmwww==",
3772 | "requires": {
3773 | "debug": "2.6.9",
3774 | "depd": "~1.1.2",
3775 | "destroy": "~1.0.4",
3776 | "encodeurl": "~1.0.2",
3777 | "escape-html": "~1.0.3",
3778 | "etag": "~1.8.1",
3779 | "fresh": "0.5.2",
3780 | "http-errors": "1.8.1",
3781 | "mime": "1.6.0",
3782 | "ms": "2.1.3",
3783 | "on-finished": "~2.3.0",
3784 | "range-parser": "~1.2.1",
3785 | "statuses": "~1.5.0"
3786 | },
3787 | "dependencies": {
3788 | "ms": {
3789 | "version": "2.1.3",
3790 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
3791 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
3792 | }
3793 | }
3794 | },
3795 | "serve-static": {
3796 | "version": "1.14.2",
3797 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.2.tgz",
3798 | "integrity": "sha512-+TMNA9AFxUEGuC0z2mevogSnn9MXKb4fa7ngeRMJaaGv8vTwnIEkKi+QGvPt33HSnf8pRS+WGM0EbMtCJLKMBQ==",
3799 | "requires": {
3800 | "encodeurl": "~1.0.2",
3801 | "escape-html": "~1.0.3",
3802 | "parseurl": "~1.3.3",
3803 | "send": "0.17.2"
3804 | }
3805 | },
3806 | "setprototypeof": {
3807 | "version": "1.2.0",
3808 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz",
3809 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw=="
3810 | },
3811 | "sift": {
3812 | "version": "13.5.2",
3813 | "resolved": "https://registry.npmjs.org/sift/-/sift-13.5.2.tgz",
3814 | "integrity": "sha512-+gxdEOMA2J+AI+fVsCqeNn7Tgx3M9ZN9jdi95939l1IJ8cZsqS8sqpJyOkic2SJk+1+98Uwryt/gL6XDaV+UZA=="
3815 | },
3816 | "signal-exit": {
3817 | "version": "3.0.6",
3818 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.6.tgz",
3819 | "integrity": "sha512-sDl4qMFpijcGw22U5w63KmD3cZJfBuFlVNbVMKje2keoKML7X2UzWbc4XrmEbDwg0NXJc3yv4/ox7b+JWb57kQ==",
3820 | "dev": true
3821 | },
3822 | "sparse-bitfield": {
3823 | "version": "3.0.3",
3824 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz",
3825 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=",
3826 | "optional": true,
3827 | "requires": {
3828 | "memory-pager": "^1.0.2"
3829 | }
3830 | },
3831 | "spawn-command": {
3832 | "version": "0.0.2-1",
3833 | "resolved": "https://registry.npmjs.org/spawn-command/-/spawn-command-0.0.2-1.tgz",
3834 | "integrity": "sha1-YvXpRmmBwbeW3Fkpk34RycaSG9A=",
3835 | "dev": true
3836 | },
3837 | "statuses": {
3838 | "version": "1.5.0",
3839 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz",
3840 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow="
3841 | },
3842 | "string-width": {
3843 | "version": "4.2.3",
3844 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
3845 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
3846 | "dev": true,
3847 | "requires": {
3848 | "emoji-regex": "^8.0.0",
3849 | "is-fullwidth-code-point": "^3.0.0",
3850 | "strip-ansi": "^6.0.1"
3851 | }
3852 | },
3853 | "strip-ansi": {
3854 | "version": "6.0.1",
3855 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
3856 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
3857 | "dev": true,
3858 | "requires": {
3859 | "ansi-regex": "^5.0.1"
3860 | }
3861 | },
3862 | "strip-json-comments": {
3863 | "version": "2.0.1",
3864 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz",
3865 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=",
3866 | "dev": true
3867 | },
3868 | "supports-color": {
3869 | "version": "5.5.0",
3870 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
3871 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
3872 | "dev": true,
3873 | "requires": {
3874 | "has-flag": "^3.0.0"
3875 | }
3876 | },
3877 | "to-readable-stream": {
3878 | "version": "1.0.0",
3879 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz",
3880 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==",
3881 | "dev": true
3882 | },
3883 | "to-regex-range": {
3884 | "version": "5.0.1",
3885 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
3886 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
3887 | "dev": true,
3888 | "requires": {
3889 | "is-number": "^7.0.0"
3890 | }
3891 | },
3892 | "toidentifier": {
3893 | "version": "1.0.1",
3894 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz",
3895 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA=="
3896 | },
3897 | "touch": {
3898 | "version": "3.1.0",
3899 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz",
3900 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==",
3901 | "dev": true,
3902 | "requires": {
3903 | "nopt": "~1.0.10"
3904 | }
3905 | },
3906 | "tr46": {
3907 | "version": "3.0.0",
3908 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz",
3909 | "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==",
3910 | "requires": {
3911 | "punycode": "^2.1.1"
3912 | }
3913 | },
3914 | "tree-kill": {
3915 | "version": "1.2.2",
3916 | "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz",
3917 | "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==",
3918 | "dev": true
3919 | },
3920 | "tslib": {
3921 | "version": "1.14.1",
3922 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz",
3923 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==",
3924 | "dev": true
3925 | },
3926 | "type-fest": {
3927 | "version": "0.20.2",
3928 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz",
3929 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==",
3930 | "dev": true
3931 | },
3932 | "type-is": {
3933 | "version": "1.6.18",
3934 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
3935 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
3936 | "requires": {
3937 | "media-typer": "0.3.0",
3938 | "mime-types": "~2.1.24"
3939 | }
3940 | },
3941 | "typedarray-to-buffer": {
3942 | "version": "3.1.5",
3943 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz",
3944 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==",
3945 | "dev": true,
3946 | "requires": {
3947 | "is-typedarray": "^1.0.0"
3948 | }
3949 | },
3950 | "undefsafe": {
3951 | "version": "2.0.5",
3952 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz",
3953 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==",
3954 | "dev": true
3955 | },
3956 | "unique-string": {
3957 | "version": "2.0.0",
3958 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz",
3959 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==",
3960 | "dev": true,
3961 | "requires": {
3962 | "crypto-random-string": "^2.0.0"
3963 | }
3964 | },
3965 | "unpipe": {
3966 | "version": "1.0.0",
3967 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
3968 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw="
3969 | },
3970 | "update-notifier": {
3971 | "version": "5.1.0",
3972 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-5.1.0.tgz",
3973 | "integrity": "sha512-ItnICHbeMh9GqUy31hFPrD1kcuZ3rpxDZbf4KUDavXwS0bW5m7SLbDQpGX3UYr072cbrF5hFUs3r5tUsPwjfHw==",
3974 | "dev": true,
3975 | "requires": {
3976 | "boxen": "^5.0.0",
3977 | "chalk": "^4.1.0",
3978 | "configstore": "^5.0.1",
3979 | "has-yarn": "^2.1.0",
3980 | "import-lazy": "^2.1.0",
3981 | "is-ci": "^2.0.0",
3982 | "is-installed-globally": "^0.4.0",
3983 | "is-npm": "^5.0.0",
3984 | "is-yarn-global": "^0.3.0",
3985 | "latest-version": "^5.1.0",
3986 | "pupa": "^2.1.1",
3987 | "semver": "^7.3.4",
3988 | "semver-diff": "^3.1.1",
3989 | "xdg-basedir": "^4.0.0"
3990 | },
3991 | "dependencies": {
3992 | "semver": {
3993 | "version": "7.3.5",
3994 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz",
3995 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==",
3996 | "dev": true,
3997 | "requires": {
3998 | "lru-cache": "^6.0.0"
3999 | }
4000 | }
4001 | }
4002 | },
4003 | "url-parse-lax": {
4004 | "version": "3.0.0",
4005 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz",
4006 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=",
4007 | "dev": true,
4008 | "requires": {
4009 | "prepend-http": "^2.0.0"
4010 | }
4011 | },
4012 | "utils-merge": {
4013 | "version": "1.0.1",
4014 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
4015 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM="
4016 | },
4017 | "vary": {
4018 | "version": "1.1.2",
4019 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
4020 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw="
4021 | },
4022 | "webidl-conversions": {
4023 | "version": "7.0.0",
4024 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz",
4025 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g=="
4026 | },
4027 | "whatwg-url": {
4028 | "version": "11.0.0",
4029 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz",
4030 | "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==",
4031 | "requires": {
4032 | "tr46": "^3.0.0",
4033 | "webidl-conversions": "^7.0.0"
4034 | }
4035 | },
4036 | "widest-line": {
4037 | "version": "3.1.0",
4038 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz",
4039 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==",
4040 | "dev": true,
4041 | "requires": {
4042 | "string-width": "^4.0.0"
4043 | }
4044 | },
4045 | "wrap-ansi": {
4046 | "version": "7.0.0",
4047 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
4048 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
4049 | "dev": true,
4050 | "requires": {
4051 | "ansi-styles": "^4.0.0",
4052 | "string-width": "^4.1.0",
4053 | "strip-ansi": "^6.0.0"
4054 | }
4055 | },
4056 | "wrappy": {
4057 | "version": "1.0.2",
4058 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
4059 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=",
4060 | "dev": true
4061 | },
4062 | "write-file-atomic": {
4063 | "version": "3.0.3",
4064 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz",
4065 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==",
4066 | "dev": true,
4067 | "requires": {
4068 | "imurmurhash": "^0.1.4",
4069 | "is-typedarray": "^1.0.0",
4070 | "signal-exit": "^3.0.2",
4071 | "typedarray-to-buffer": "^3.1.5"
4072 | }
4073 | },
4074 | "xdg-basedir": {
4075 | "version": "4.0.0",
4076 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz",
4077 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==",
4078 | "dev": true
4079 | },
4080 | "y18n": {
4081 | "version": "5.0.8",
4082 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz",
4083 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==",
4084 | "dev": true
4085 | },
4086 | "yallist": {
4087 | "version": "4.0.0",
4088 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
4089 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
4090 | "dev": true
4091 | },
4092 | "yargs": {
4093 | "version": "16.2.0",
4094 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz",
4095 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==",
4096 | "dev": true,
4097 | "requires": {
4098 | "cliui": "^7.0.2",
4099 | "escalade": "^3.1.1",
4100 | "get-caller-file": "^2.0.5",
4101 | "require-directory": "^2.1.1",
4102 | "string-width": "^4.2.0",
4103 | "y18n": "^5.0.5",
4104 | "yargs-parser": "^20.2.2"
4105 | }
4106 | },
4107 | "yargs-parser": {
4108 | "version": "20.2.9",
4109 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz",
4110 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==",
4111 | "dev": true
4112 | }
4113 | }
4114 | }
4115 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "mern-tutorial",
3 | "version": "1.0.0",
4 | "description": "Goalsetter app for youtube tutorial",
5 | "main": "server.js",
6 | "scripts": {
7 | "start": "node backend/server.js",
8 | "server": "nodemon backend/server.js",
9 | "client": "npm start --prefix frontend",
10 | "dev": "concurrently \"npm run server\" \"npm run client\"",
11 | "heroku-postbuild": "NPM_CONFIG_PRODUCTION=false npm install --prefix frontend && npm run build --prefix frontend"
12 | },
13 | "author": "Brad Traversy",
14 | "license": "MIT",
15 | "dependencies": {
16 | "bcryptjs": "^2.4.3",
17 | "colors": "^1.4.0",
18 | "dotenv": "^15.0.0",
19 | "express": "^4.17.2",
20 | "express-async-handler": "^1.2.0",
21 | "jsonwebtoken": "^8.5.1",
22 | "mongoose": "^6.1.9"
23 | },
24 | "devDependencies": {
25 | "concurrently": "^7.0.0",
26 | "nodemon": "^2.0.15"
27 | }
28 | }
29 |
--------------------------------------------------------------------------------
/readme.md:
--------------------------------------------------------------------------------
1 | # Goalsetter MERN app
2 |
3 | This is the goalsetter app from the [Learn the MERN Stack](https://www.youtube.com/watch?v=-0exw-9YJBo) series on YouTube.
4 |
5 | ## Usage
6 |
7 | Rename the .envexample to .env and add your MONGO_URI
8 |
9 | ### Install dependencies
10 |
11 | ```
12 | # Backend deps
13 | npm install
14 |
15 | # Frontend deps
16 | cd frontend
17 | npm install
18 | ```
19 |
20 | ### Run Server
21 |
22 | ```
23 | npm run server
24 | ```
25 |
26 | ## Demo
27 |
28 | I am not sure how long this will be up
29 |
30 | https://mernappbrad.herokuapp.com/
31 |
--------------------------------------------------------------------------------