├── .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 |
19 |
20 |
21 | 22 | setText(e.target.value)} 28 | /> 29 |
30 |
31 | 34 |
35 |
36 |
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 | 44 |
45 | ) 46 | } 47 | 48 | export default Header 49 | -------------------------------------------------------------------------------- /frontend/src/components/Spinner.jsx: -------------------------------------------------------------------------------- 1 | function Spinner() { 2 | return ( 3 |
4 |
5 |
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 |
68 |
69 |
70 | 79 |
80 |
81 | 90 |
91 | 92 |
93 | 96 |
97 |
98 |
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 |
75 |
76 |
77 | 86 |
87 |
88 | 97 |
98 |
99 | 108 |
109 |
110 | 119 |
120 |
121 | 124 |
125 |
126 |
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 | --------------------------------------------------------------------------------