├── client ├── .env ├── .firebaserc ├── public │ ├── robots.txt │ ├── favicon.ico │ ├── logo192.png │ ├── logo512.png │ ├── manifest.json │ └── index.html ├── src │ ├── configurations │ │ └── index.js │ ├── actions │ │ ├── types.js │ │ └── index.js │ ├── reducers │ │ ├── index.js │ │ ├── national.js │ │ └── security.js │ ├── security │ │ └── setJWT.js │ ├── views │ │ ├── DefaultLayout.js │ │ └── NationalityList.js │ ├── components │ │ ├── NationCard.js │ │ └── Form.js │ ├── App.js │ └── index.js ├── firebase.json ├── .gitignore ├── package.json ├── .firebase │ └── hosting.YnVpbGQ.cache └── README.md ├── server ├── configurations │ ├── constant.js │ └── response.js ├── routes │ ├── index.js │ ├── security.js │ └── nationality.js ├── .gitignore ├── package.json ├── utils │ └── logger.js ├── middlewares │ └── auth.js ├── server.js ├── api-docs │ └── Project-Rhino.postman_collection.json └── package-lock.json └── README.md /client/.env: -------------------------------------------------------------------------------- 1 | REACT_APP_API_URL=http://localhost:4000 2 | -------------------------------------------------------------------------------- /client/.firebaserc: -------------------------------------------------------------------------------- 1 | { 2 | "projects": { 3 | "default": "findyournationality" 4 | } 5 | } 6 | -------------------------------------------------------------------------------- /client/public/robots.txt: -------------------------------------------------------------------------------- 1 | # https://www.robotstxt.org/robotstxt.html 2 | User-agent: * 3 | Disallow: 4 | -------------------------------------------------------------------------------- /client/src/configurations/index.js: -------------------------------------------------------------------------------- 1 | export const BASE_URL = 'https://findyournationality.herokuapp.com'; 2 | -------------------------------------------------------------------------------- /client/public/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/gimnathperera/Find-your-nationality/HEAD/client/public/favicon.ico -------------------------------------------------------------------------------- /client/public/logo192.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/gimnathperera/Find-your-nationality/HEAD/client/public/logo192.png -------------------------------------------------------------------------------- /client/public/logo512.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/gimnathperera/Find-your-nationality/HEAD/client/public/logo512.png -------------------------------------------------------------------------------- /client/src/actions/types.js: -------------------------------------------------------------------------------- 1 | export const GET_NATIONALITY_LIST = 'GET_NATIONALITY_LIST'; 2 | export const SET_ACCESS_TOKEN = 'SET_ACCESS_TOKEN'; 3 | -------------------------------------------------------------------------------- /client/firebase.json: -------------------------------------------------------------------------------- 1 | { 2 | "hosting": { 3 | "public": "build", 4 | "ignore": ["firebase.json", "**/.*", "**/node_modules/**"], 5 | "rewrites": [ 6 | { 7 | "source": "**", 8 | "destination": "/index.html" 9 | } 10 | ] 11 | } 12 | } 13 | -------------------------------------------------------------------------------- /server/configurations/constant.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | //JWT constants 3 | JWT: { 4 | PAYLOAD: { 5 | ID: 1, 6 | EMAIL: 'test@gmail.com' 7 | }, 8 | EXPIRE_TIME: 3600 9 | }, 10 | ENDPOINTS: { 11 | GET_COUNTRY_DATA: 'rest/v2/alpha' 12 | } 13 | }; 14 | -------------------------------------------------------------------------------- /client/src/reducers/index.js: -------------------------------------------------------------------------------- 1 | import { combineReducers } from 'redux'; 2 | import { reducer as toastr } from 'react-redux-toastr'; 3 | 4 | import security from './security'; 5 | import national from './national'; 6 | 7 | export default combineReducers({ 8 | toastr, 9 | security, 10 | national 11 | }); 12 | -------------------------------------------------------------------------------- /client/src/reducers/national.js: -------------------------------------------------------------------------------- 1 | import { GET_NATIONALITY_LIST } from '../actions/types'; 2 | 3 | const national = (state = {}, action) => { 4 | switch (action.type) { 5 | case GET_NATIONALITY_LIST: 6 | return action.payload; 7 | default: 8 | return state; 9 | } 10 | }; 11 | 12 | export default national; 13 | -------------------------------------------------------------------------------- /client/src/security/setJWT.js: -------------------------------------------------------------------------------- 1 | import axios from 'axios'; 2 | 3 | const setJWTToken = (token) => { 4 | if (token) { 5 | axios.defaults.headers.common['Authorization'] = localStorage.getItem('token'); 6 | } else { 7 | delete axios.defaults.headers.common['Authorization']; 8 | } 9 | }; 10 | 11 | export default setJWTToken; 12 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Find-your-nationality 2 | Nationality Finder based on the name of the people. Developed using reactJS and Node Express integrating apis. 3 | 4 | 5 | 6 | 📙 Working demo - https://findyournationality.web.app 7 | 8 | ![image](https://user-images.githubusercontent.com/55834384/128623645-c2d4fca1-31d9-47b6-bee7-11f55d38eea6.png) 9 | 10 | -------------------------------------------------------------------------------- /server/routes/index.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const router = express.Router(); 3 | 4 | const auth = require('../middlewares/auth'); 5 | const nationality = require('./nationality'); 6 | const security = require('./security'); 7 | 8 | router.get('/nationality/:name', auth, nationality.getNationality); 9 | router.get('/token', security.getToken); 10 | 11 | module.exports = router; 12 | -------------------------------------------------------------------------------- /client/.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 | -------------------------------------------------------------------------------- /server/.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 | .env 15 | # misc 16 | .DS_Store 17 | .env.local 18 | .env.development.local 19 | .env.test.local 20 | .env.production.local 21 | 22 | npm-debug.log* 23 | yarn-debug.log* 24 | yarn-error.log* 25 | -------------------------------------------------------------------------------- /server/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "server.js", 6 | "scripts": { 7 | "start": "node server", 8 | "server": "nodemon server" 9 | }, 10 | "author": "Gimnath Perera", 11 | "license": "ISC", 12 | "dependencies": { 13 | "axios": "^0.21.1", 14 | "dotenv": "^8.2.0", 15 | "express": "^4.17.1", 16 | "express-validator": "^6.10.0", 17 | "jsonwebtoken": "^8.5.1", 18 | "npmlog": "^4.1.2" 19 | }, 20 | "devDependencies": { 21 | "nodemon": "^2.0.7" 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /server/utils/logger.js: -------------------------------------------------------------------------------- 1 | const logger = require('npmlog'); 2 | 3 | const log = { 4 | debug: (action, data) => { 5 | logger.warn(`${new Date()} - ${action} - ${JSON.stringify(data)}`); 6 | }, 7 | info: (action, data) => { 8 | logger.info(`${new Date()} - ${action} - ${JSON.stringify(data)}`); 9 | }, 10 | error: (action, data) => { 11 | logger.error(`${new Date()} - ${action} - ${JSON.stringify(data)}`); 12 | }, 13 | req: (action, data) => { 14 | logger.http(`${new Date()} - ${action} - ${JSON.stringify(data)}`); 15 | } 16 | }; 17 | 18 | module.exports = log; 19 | -------------------------------------------------------------------------------- /client/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 | -------------------------------------------------------------------------------- /server/middlewares/auth.js: -------------------------------------------------------------------------------- 1 | const jwt = require('jsonwebtoken'); 2 | require('dotenv').config(); 3 | 4 | const response = require('../configurations/response'); 5 | 6 | module.exports = (req, res, next) => { 7 | const token = req.header('Authorization'); 8 | if (!token) { 9 | return response.fail(req, res, response.message.unauthorized, 'Unauthorized'); 10 | } else { 11 | try { 12 | const decoded = jwt.verify(token, process.env.JWT_SECRET); 13 | 14 | req.user = decoded.user; 15 | next(); 16 | } catch (err) { 17 | return response.fail(req, res, response.message.invalid_token, 'Invalid Token'); 18 | } 19 | } 20 | }; 21 | -------------------------------------------------------------------------------- /client/src/reducers/security.js: -------------------------------------------------------------------------------- 1 | import { SET_ACCESS_TOKEN } from '../actions/types'; 2 | const initialState = { 3 | validToken: false 4 | }; 5 | 6 | const booleanActionPayload = ({ status }) => { 7 | if (status) { 8 | return true; 9 | } else { 10 | return false; 11 | } 12 | }; 13 | 14 | const security = (state = initialState, action) => { 15 | switch (action.type) { 16 | case SET_ACCESS_TOKEN: 17 | return { 18 | ...state, 19 | validToken: booleanActionPayload(action.payload), 20 | token: action.payload.data 21 | }; 22 | default: 23 | return state; 24 | } 25 | }; 26 | 27 | export default security; 28 | -------------------------------------------------------------------------------- /client/src/views/DefaultLayout.js: -------------------------------------------------------------------------------- 1 | import { useEffect } from 'react'; 2 | import { connect } from 'react-redux'; 3 | 4 | import Form from '../components/Form'; 5 | import NationalityList from './NationalityList'; 6 | import { fetchAcessToken } from '../actions'; 7 | 8 | const DefaultLayout = (props) => { 9 | const { fetchAcessToken } = props; 10 | 11 | useEffect(() => { 12 | fetchAcessToken(); 13 | }, [fetchAcessToken]); 14 | 15 | return ( 16 |
17 |
18 |
19 | 20 |
21 |
22 | ); 23 | }; 24 | 25 | export default connect(null, { fetchAcessToken })(DefaultLayout); 26 | -------------------------------------------------------------------------------- /client/src/components/NationCard.js: -------------------------------------------------------------------------------- 1 | const NationCard = ({ country }) => { 2 | return ( 3 |
4 |
5 |
6 |
7 | flag 8 |
9 |
10 |
11 |

{country?.name}

12 |
13 |
14 |

{country?.probability.toFixed(2)}

15 |
16 |
17 |
18 | ); 19 | }; 20 | 21 | export default NationCard; 22 | -------------------------------------------------------------------------------- /client/src/App.js: -------------------------------------------------------------------------------- 1 | import jwt_decode from 'jwt-decode'; 2 | import ReduxToastr from 'react-redux-toastr'; 3 | 4 | import DefaultLayout from './views/DefaultLayout'; 5 | import setJWTToken from './security/setJWT'; 6 | import './App.css'; 7 | const App = () => { 8 | const token = localStorage.getItem('token'); 9 | 10 | if (token) { 11 | setJWTToken(token); 12 | 13 | const decodedToken = jwt_decode(token); 14 | 15 | const current_time = Date.now() / 1000; 16 | 17 | if (decodedToken.exp < current_time) { 18 | localStorage.clear(); 19 | setJWTToken(false); 20 | } 21 | } 22 | 23 | return ( 24 |
25 | 26 | 27 |
28 | ); 29 | }; 30 | 31 | export default App; 32 | -------------------------------------------------------------------------------- /client/src/index.js: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import ReactDOM from 'react-dom'; 3 | import { Provider } from 'react-redux'; 4 | import thunk from 'redux-thunk'; 5 | import { createStore, applyMiddleware, compose } from 'redux'; 6 | import reducers from './reducers'; 7 | 8 | import App from './App'; 9 | import 'bootstrap/dist/css/bootstrap.min.css'; 10 | import 'react-redux-toastr/lib/css/react-redux-toastr.min.css'; 11 | import './assets/css/hover-min.css'; 12 | 13 | const composeEnhancers = window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose; 14 | const store = createStore(reducers, composeEnhancers(applyMiddleware(thunk))); 15 | 16 | ReactDOM.render( 17 | 18 | 19 | , 20 | document.getElementById('root') 21 | ); 22 | -------------------------------------------------------------------------------- /client/src/views/NationalityList.js: -------------------------------------------------------------------------------- 1 | import { connect } from 'react-redux'; 2 | import NationCard from '../components/NationCard'; 3 | 4 | const NationalityList = ({ countries }) => { 5 | const renderCountries = () => { 6 | return ( 7 | countries && 8 | countries.map((country, index) => { 9 | return ; 10 | }) 11 | ); 12 | }; 13 | 14 | return ( 15 |
16 |
17 |
{renderCountries()}
18 |
19 |
20 | ); 21 | }; 22 | const mapStateToProps = (state) => ({ 23 | countries: Object.values(state.national) 24 | }); 25 | export default connect(mapStateToProps)(NationalityList); 26 | -------------------------------------------------------------------------------- /server/routes/security.js: -------------------------------------------------------------------------------- 1 | const jwt = require('jsonwebtoken'); 2 | require('dotenv').config(); 3 | 4 | const response = require('../configurations/response'); 5 | const { JWT } = require('../configurations/constant'); 6 | 7 | const SecurityRoute = { 8 | //@route GET /token 9 | //@desc get a token 10 | //@access Public 11 | getToken: (req, res) => { 12 | try { 13 | const payload = { 14 | user: { 15 | id: JWT.PAYLOAD.ID, 16 | email: JWT.PAYLOAD.EMAIL 17 | } 18 | }; 19 | 20 | jwt.sign(payload, process.env.JWT_SECRET, { expiresIn: JWT.EXPIRE_TIME }, (err, token) => { 21 | if (err) throw err; 22 | return response.success(req, res, token, 'Token received successfully'); 23 | }); 24 | } catch (err) { 25 | console.log('>>===>> >>===>> err', err) 26 | return response.fail(req, res, response.message.server_error, null, err); 27 | } 28 | } 29 | }; 30 | module.exports = SecurityRoute; 31 | -------------------------------------------------------------------------------- /server/server.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const app = express(); 3 | require('dotenv').config(); 4 | 5 | const logger = require('./utils/logger'); 6 | const routes = require('./routes'); 7 | const response = require('./configurations/response'); 8 | 9 | app.use(express.json({ extended: false })); 10 | 11 | app.all('/*', (req, res, next) => { 12 | res.header('Access-Control-Allow-Origin', '*'); 13 | res.header('Access-Control-Allow-Methods', 'GET, PUT, POST, DELETE, OPTIONS'); 14 | res.header('Access-Control-Allow-Headers', 'Content-type, Accept, Authorization, token'); 15 | if (req.method == 'OPTIONS') { 16 | res.status(200).end(); 17 | } else { 18 | let reqData = { 19 | method: req.method, 20 | body: req.body, 21 | query: req.query, 22 | peram: req.peram 23 | }; 24 | logger.req(req.url, reqData); 25 | next(); 26 | } 27 | }); 28 | 29 | app.use('/', routes); 30 | 31 | app.use((req, res) => { 32 | response.fail(req, res, response.message.invalid_url); 33 | return; 34 | }); 35 | 36 | const PORT = process.env.PORT || 4000; 37 | 38 | app.listen(PORT, () => logger.info('APIs Started', { PORT: process.env.PORT })); 39 | -------------------------------------------------------------------------------- /client/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "client", 3 | "version": "0.1.0", 4 | "private": true, 5 | "dependencies": { 6 | "@testing-library/jest-dom": "^5.11.9", 7 | "@testing-library/react": "^11.2.5", 8 | "@testing-library/user-event": "^12.8.3", 9 | "axios": "^0.21.1", 10 | "bootstrap": "^4.6.0", 11 | "jwt-decode": "^3.1.2", 12 | "react": "^17.0.2", 13 | "react-bootstrap": "^1.5.2", 14 | "react-dom": "^17.0.2", 15 | "react-redux": "^7.2.3", 16 | "react-redux-toastr": "^7.6.5", 17 | "react-scripts": "4.0.3", 18 | "redux": "^4.0.5", 19 | "redux-devtools-extension": "^2.13.9", 20 | "redux-thunk": "^2.3.0", 21 | "web-vitals": "^1.1.1" 22 | }, 23 | "scripts": { 24 | "start": "react-scripts start", 25 | "build": "react-scripts build", 26 | "test": "react-scripts test", 27 | "eject": "react-scripts eject" 28 | }, 29 | "eslintConfig": { 30 | "extends": [ 31 | "react-app", 32 | "react-app/jest" 33 | ] 34 | }, 35 | "browserslist": { 36 | "production": [ 37 | ">0.2%", 38 | "not dead", 39 | "not op_mini all" 40 | ], 41 | "development": [ 42 | "last 1 chrome version", 43 | "last 1 firefox version", 44 | "last 1 safari version" 45 | ] 46 | } 47 | } 48 | -------------------------------------------------------------------------------- /client/src/actions/index.js: -------------------------------------------------------------------------------- 1 | import axios from 'axios'; 2 | import { toastr } from 'react-redux-toastr'; 3 | 4 | import { SET_ACCESS_TOKEN, GET_NATIONALITY_LIST } from './types'; 5 | import { BASE_URL } from '../configurations'; 6 | import setJWTToken from '../security/setJWT'; 7 | 8 | axios.defaults.baseURL = BASE_URL; 9 | 10 | export const fetchAcessToken = () => async (dispatch) => { 11 | try { 12 | const response = await axios.get(`/token`); 13 | 14 | response?.data?.data ? localStorage.setItem('token', response.data.data) : localStorage.clear(); 15 | setJWTToken(response?.data?.data); 16 | dispatch({ type: SET_ACCESS_TOKEN, payload: response?.data }); 17 | } catch (err) { 18 | toastr.error('Error', err?.message); 19 | } 20 | }; 21 | 22 | export const fetchNationlities = (name) => async (dispatch) => { 23 | try { 24 | const response = await axios.get(`/nationality/${name}`); 25 | const nationalityList = response?.data?.data; 26 | if (nationalityList.length > 0) { 27 | dispatch({ type: GET_NATIONALITY_LIST, payload: response?.data?.data }); 28 | } else { 29 | toastr.warning('Warning', 'Check your name, try again!'); 30 | dispatch({ type: GET_NATIONALITY_LIST, payload: [] }); 31 | } 32 | } catch (err) { 33 | toastr.error('Error', err?.message || 'Network error'); 34 | } 35 | }; 36 | -------------------------------------------------------------------------------- /server/api-docs/Project-Rhino.postman_collection.json: -------------------------------------------------------------------------------- 1 | { 2 | "info": { 3 | "_postman_id": "cf07103f-5dff-4cda-aaf0-effb0900dd64", 4 | "name": "Project-Rhino", 5 | "schema": "https://schema.getpostman.com/json/collection/v2.1.0/collection.json" 6 | }, 7 | "item": [ 8 | { 9 | "name": "GET token", 10 | "request": { 11 | "method": "GET", 12 | "header": [ 13 | { 14 | "key": "", 15 | "value": "", 16 | "type": "text", 17 | "disabled": true 18 | } 19 | ], 20 | "url": { 21 | "raw": "http://localhost:4000/token", 22 | "protocol": "http", 23 | "host": [ 24 | "localhost" 25 | ], 26 | "port": "4000", 27 | "path": [ 28 | "token" 29 | ], 30 | "query": [ 31 | { 32 | "key": "", 33 | "value": null, 34 | "disabled": true 35 | } 36 | ] 37 | } 38 | }, 39 | "response": [] 40 | }, 41 | { 42 | "name": "GET nationality ", 43 | "request": { 44 | "method": "GET", 45 | "header": [ 46 | { 47 | "key": "Authorization", 48 | "value": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyIjp7ImlkIjoxLCJlbWFpbCI6InRlc3RAZ21haWwuY29tIn0sImlhdCI6MTYxNjc4Mjk5OSwiZXhwIjoxNjE2Nzg2NTk5fQ.XiW_TVoZ0g9jzxZEFBYJMWSi719dpBN1qAD-umvvypw", 49 | "type": "text" 50 | } 51 | ], 52 | "url": { 53 | "raw": "http://localhost:4000/nationality/roxy", 54 | "protocol": "http", 55 | "host": [ 56 | "localhost" 57 | ], 58 | "port": "4000", 59 | "path": [ 60 | "nationality", 61 | "roxy" 62 | ] 63 | } 64 | }, 65 | "response": [] 66 | } 67 | ] 68 | } -------------------------------------------------------------------------------- /server/configurations/response.js: -------------------------------------------------------------------------------- 1 | const logger = require('../utils/logger'); 2 | 3 | const messages = { 4 | invalid_url: { 5 | status: 500, 6 | code: 9001, 7 | message: 'Invalid API URL' 8 | }, 9 | 10 | server_error: { 11 | status: 500, 12 | code: 9003, 13 | message: 'Something went wrong' 14 | }, 15 | 16 | unauthorized: { 17 | status: 401, 18 | code: 401, 19 | message: "You don't have permission" 20 | }, 21 | 22 | invalid_token: { 23 | status: 500, 24 | code: 7003, 25 | message: 'Invalid Token' 26 | }, 27 | invalid_header: { 28 | status: 500, 29 | code: 7004, 30 | message: 'Invalid Header' 31 | } 32 | }; 33 | 34 | const success = (req, res, data = null, friendly_message, count) => { 35 | const resp = { 36 | status: true, 37 | code: 0, 38 | message: 'Success', 39 | friendly_message: 'Success', 40 | data: data, 41 | recordsTotal: count 42 | }; 43 | 44 | if (friendly_message) { 45 | resp.friendly_message = friendly_message; 46 | } 47 | 48 | logger.info(req.url, resp); 49 | res.status(200); 50 | res.json(resp); 51 | return; 52 | }; 53 | 54 | const fail = (req, res, message, friendly_message, data) => { 55 | const resp = { 56 | status: false, 57 | code: message.code, 58 | message: message.message, 59 | friendly_message: message.message, 60 | data: data || {} 61 | }; 62 | 63 | if (friendly_message) { 64 | resp.friendly_message = friendly_message; 65 | } 66 | 67 | logger.error(req.url, resp); 68 | res.status(message.status); 69 | res.json(resp); 70 | return; 71 | }; 72 | 73 | exports.success = success; 74 | exports.fail = fail; 75 | exports.message = messages; 76 | -------------------------------------------------------------------------------- /client/.firebase/hosting.YnVpbGQ.cache: -------------------------------------------------------------------------------- 1 | favicon.ico,499162500000,eae62e993eb980ec8a25058c39d5a51feab118bd2100c4deebb2a9c158ec11f9 2 | logo192.png,499162500000,3ee59515172ee198f3be375979df15ac5345183e656720a381b8872b2a39dc8b 3 | logo512.png,499162500000,ee7e2f3fdb8209c4b6fd7bef6ba50d1b9dba30a25bb5c3126df057e1cb6f5331 4 | manifest.json,499162500000,aff3449bdc238776f5d6d967f19ec491b36aed5fb7f23ccff6500736fd58494a 5 | robots.txt,499162500000,bfe106a3fb878dc83461c86818bf74fc1bdc7f28538ba613cd3e775516ce8b49 6 | asset-manifest.json,1623173064394,3140dd8b781990a6bc9ac81289475576fbdd838effe10ad8d9a81b72f5086cd3 7 | index.html,1623173064394,f841cd177bb8715b13d9161e84d41cdc884eb9d5cbdfdc04702a32690a351d6d 8 | static/js/2.705c18b5.chunk.js.LICENSE.txt,1623173064417,876dd82969b1962bd811d5440f57650f9f113f93ba472d4b4136baf98c259faa 9 | static/js/main.e5ab850f.chunk.js,1623173064418,ca2888e8d19590d65decc8f7ba3ddf4eecbbc9e6f6d9e3204e3f04c496db5dc8 10 | static/js/main.e5ab850f.chunk.js.map,1623173064417,6301325f7970ca04038c5c01117b0da9a5d2c963137312ddd9854a4eae2d88a8 11 | static/js/runtime-main.03887cff.js,1623173064397,8a3b24ebdd29b3dbb1f6da2c8d4ebc69dbc3bc6933ede78b6e5ef9c625984b23 12 | static/js/runtime-main.03887cff.js.map,1623173064417,ebaecb1612a8fd2d05b44fd9c1712b2517ef48ae2b4967a27b7a5d4b2c150e66 13 | static/css/2.18f44ecf.chunk.css,1623173064417,826db86c3005891d672ddc8bfd72c31192d56da912f97cad534bcf09251a23fa 14 | static/css/main.c9e3fc7f.chunk.css,1623173064396,187ffa644a36a6bc52fa63edb1eccf8eb9f457eb4b03bd4b79c82292367a936d 15 | static/js/2.705c18b5.chunk.js,1623173064417,ccdb2c087c864140945a8339843d89dbe5ea8907018fc0489b76f81fa81f7404 16 | static/css/main.c9e3fc7f.chunk.css.map,1623173064417,43eea19db5c2a4d781f0705fc6cb2997535ab62c2e2dd58c602e45a8672ae248 17 | static/css/2.18f44ecf.chunk.css.map,1623173064417,1e1609a498796c9b2939d2e4f1b62b462ed9d5d4b40755a7fdb2a72dac5f1626 18 | static/js/2.705c18b5.chunk.js.map,1623173064418,4057aea8c821c99dc0c8a79f65c5416bd9c5c7f7706c2e6693d549decc1aed40 19 | -------------------------------------------------------------------------------- /server/routes/nationality.js: -------------------------------------------------------------------------------- 1 | const axios = require('axios'); 2 | require('dotenv').config(); 3 | 4 | const response = require('../configurations/response'); 5 | const { ENDPOINTS } = require('../configurations/constant'); 6 | 7 | const NationalityRoutes = { 8 | //@route GET /nationality/:name 9 | //@desc get nationality by name 10 | //@access Private 11 | getNationality: async (req, res) => { 12 | try { 13 | const { name } = req.params; 14 | //get nationality prediction by provided name 15 | const nationalityResponse = await axios.get( 16 | process.env.NATIONALITY_WEB_URL, 17 | { 18 | params: { name }, 19 | } 20 | ); 21 | // console.log(nationalityResponse.data); 22 | if (nationalityResponse.data) { 23 | let countryList = []; 24 | const promises = nationalityResponse.data.country.map( 25 | async (country) => { 26 | //get required country data providing country shortCode 27 | // const countryData = await axios.get( 28 | // `${process.env.REST_COUNTRIES_WEB_URL}/${ENDPOINTS.GET_COUNTRY_DATA}/${country.country_id}` 29 | // ); 30 | 31 | let _data = { 32 | code: country.country_id, 33 | probability: country.probability, 34 | name: country.country_id, 35 | flag: `https://www.countryflags.io/${country.country_id}/flat/64.png`, 36 | }; 37 | 38 | countryList.push(_data); 39 | } 40 | ); 41 | 42 | await Promise.all(promises); 43 | 44 | return response.success( 45 | req, 46 | res, 47 | countryList, 48 | 'Data received successfully' 49 | ); 50 | } else { 51 | return response.fail( 52 | req, 53 | res, 54 | response.message.server_error, 55 | null, 56 | 'Internal server error' 57 | ); 58 | } 59 | } catch (err) { 60 | console.log('>>===>> >>===>> err', err.message); 61 | return response.fail(req, res, response.message.server_error, null, err); 62 | } 63 | }, 64 | }; 65 | module.exports = NationalityRoutes; 66 | -------------------------------------------------------------------------------- /client/src/components/Form.js: -------------------------------------------------------------------------------- 1 | import { useState } from 'react'; 2 | import { connect } from 'react-redux'; 3 | import { Spinner } from 'react-bootstrap'; 4 | import { fetchNationlities } from '../actions'; 5 | 6 | const Form = (props) => { 7 | const [name, setName] = useState(''); 8 | const [error, setError] = useState(''); 9 | const [loading, setLoading] = useState(false); 10 | 11 | const { fetchNationlities } = props; 12 | 13 | const onSubmit = async (event) => { 14 | try { 15 | if (!name) { 16 | return setError('Name is required'); 17 | } else { 18 | event.preventDefault(); 19 | setError(''); 20 | setLoading(true); 21 | 22 | await fetchNationlities(name); 23 | setLoading(false); 24 | } 25 | } catch (err) { 26 | setError('Something went wrong'); 27 | } 28 | }; 29 | 30 | return ( 31 |
32 |
33 |
34 |
35 | 36 |
37 |

Find Your Nationality

38 | 39 |
40 | setName(event.target.value)} 46 | /> 47 |
48 | {error ?

{error}

: ''} 49 |
50 | 71 |
72 | 73 |
74 |
75 |
76 | ); 77 | }; 78 | 79 | export default connect(null, { fetchNationlities })(Form); 80 | -------------------------------------------------------------------------------- /client/public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 15 | 16 | 18 | 19 | 20 | 21 | 30 | React App 31 | 32 | 33 | 34 | 35 |
36 | 46 | 49 | 52 | 55 | 58 | 59 | 60 | -------------------------------------------------------------------------------- /client/README.md: -------------------------------------------------------------------------------- 1 | # Getting Started with Create React App 2 | 3 | This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app). 4 | 5 | ## Available Scripts 6 | 7 | In the project directory, you can run: 8 | 9 | ### `npm start` 10 | 11 | Runs the app in the development mode.\ 12 | Open [http://localhost:3000](http://localhost:3000) to view it in the browser. 13 | 14 | The page will reload if you make edits.\ 15 | You will also see any lint errors in the console. 16 | 17 | ### `npm test` 18 | 19 | Launches the test runner in the interactive watch mode.\ 20 | See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information. 21 | 22 | ### `npm run build` 23 | 24 | Builds the app for production to the `build` folder.\ 25 | It correctly bundles React in production mode and optimizes the build for the best performance. 26 | 27 | The build is minified and the filenames include the hashes.\ 28 | Your app is ready to be deployed! 29 | 30 | See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information. 31 | 32 | ### `npm run eject` 33 | 34 | **Note: this is a one-way operation. Once you `eject`, you can’t go back!** 35 | 36 | 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. 37 | 38 | 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. 39 | 40 | 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. 41 | 42 | ## Learn More 43 | 44 | You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started). 45 | 46 | To learn React, check out the [React documentation](https://reactjs.org/). 47 | 48 | ### Code Splitting 49 | 50 | This section has moved here: [https://facebook.github.io/create-react-app/docs/code-splitting](https://facebook.github.io/create-react-app/docs/code-splitting) 51 | 52 | ### Analyzing the Bundle Size 53 | 54 | This section has moved here: [https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size](https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size) 55 | 56 | ### Making a Progressive Web App 57 | 58 | This section has moved here: [https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app](https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app) 59 | 60 | ### Advanced Configuration 61 | 62 | This section has moved here: [https://facebook.github.io/create-react-app/docs/advanced-configuration](https://facebook.github.io/create-react-app/docs/advanced-configuration) 63 | 64 | ### Deployment 65 | 66 | This section has moved here: [https://facebook.github.io/create-react-app/docs/deployment](https://facebook.github.io/create-react-app/docs/deployment) 67 | 68 | ### `npm run build` fails to minify 69 | 70 | This section has moved here: [https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify](https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify) 71 | -------------------------------------------------------------------------------- /server/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@sindresorhus/is": { 8 | "version": "0.14.0", 9 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz", 10 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==", 11 | "dev": true 12 | }, 13 | "@szmarczak/http-timer": { 14 | "version": "1.1.2", 15 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz", 16 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==", 17 | "dev": true, 18 | "requires": { 19 | "defer-to-connect": "^1.0.1" 20 | } 21 | }, 22 | "abbrev": { 23 | "version": "1.1.1", 24 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 25 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 26 | "dev": true 27 | }, 28 | "accepts": { 29 | "version": "1.3.7", 30 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 31 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 32 | "requires": { 33 | "mime-types": "~2.1.24", 34 | "negotiator": "0.6.2" 35 | } 36 | }, 37 | "ansi-align": { 38 | "version": "3.0.0", 39 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.0.tgz", 40 | "integrity": "sha512-ZpClVKqXN3RGBmKibdfWzqCY4lnjEuoNzU5T0oEFpfd/z5qJHVarukridD4juLO2FXMiwUQxr9WqQtaYa8XRYw==", 41 | "dev": true, 42 | "requires": { 43 | "string-width": "^3.0.0" 44 | }, 45 | "dependencies": { 46 | "string-width": { 47 | "version": "3.1.0", 48 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 49 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 50 | "dev": true, 51 | "requires": { 52 | "emoji-regex": "^7.0.1", 53 | "is-fullwidth-code-point": "^2.0.0", 54 | "strip-ansi": "^5.1.0" 55 | } 56 | } 57 | } 58 | }, 59 | "ansi-regex": { 60 | "version": "4.1.0", 61 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 62 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 63 | "dev": true 64 | }, 65 | "ansi-styles": { 66 | "version": "4.3.0", 67 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 68 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 69 | "dev": true, 70 | "requires": { 71 | "color-convert": "^2.0.1" 72 | } 73 | }, 74 | "anymatch": { 75 | "version": "3.1.1", 76 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", 77 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", 78 | "dev": true, 79 | "requires": { 80 | "normalize-path": "^3.0.0", 81 | "picomatch": "^2.0.4" 82 | } 83 | }, 84 | "aproba": { 85 | "version": "1.2.0", 86 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 87 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" 88 | }, 89 | "are-we-there-yet": { 90 | "version": "1.1.5", 91 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", 92 | "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", 93 | "requires": { 94 | "delegates": "^1.0.0", 95 | "readable-stream": "^2.0.6" 96 | } 97 | }, 98 | "array-flatten": { 99 | "version": "1.1.1", 100 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 101 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 102 | }, 103 | "axios": { 104 | "version": "0.21.1", 105 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.21.1.tgz", 106 | "integrity": "sha512-dKQiRHxGD9PPRIUNIWvZhPTPpl1rf/OxTYKsqKUDjBwYylTvV7SjSHJb9ratfyzM6wCdLCOYLzs73qpg5c4iGA==", 107 | "requires": { 108 | "follow-redirects": "^1.10.0" 109 | } 110 | }, 111 | "balanced-match": { 112 | "version": "1.0.0", 113 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 114 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 115 | "dev": true 116 | }, 117 | "binary-extensions": { 118 | "version": "2.2.0", 119 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 120 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 121 | "dev": true 122 | }, 123 | "body-parser": { 124 | "version": "1.19.0", 125 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 126 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 127 | "requires": { 128 | "bytes": "3.1.0", 129 | "content-type": "~1.0.4", 130 | "debug": "2.6.9", 131 | "depd": "~1.1.2", 132 | "http-errors": "1.7.2", 133 | "iconv-lite": "0.4.24", 134 | "on-finished": "~2.3.0", 135 | "qs": "6.7.0", 136 | "raw-body": "2.4.0", 137 | "type-is": "~1.6.17" 138 | } 139 | }, 140 | "boxen": { 141 | "version": "4.2.0", 142 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-4.2.0.tgz", 143 | "integrity": "sha512-eB4uT9RGzg2odpER62bBwSLvUeGC+WbRjjyyFhGsKnc8wp/m0+hQsMUvUe3H2V0D5vw0nBdO1hCJoZo5mKeuIQ==", 144 | "dev": true, 145 | "requires": { 146 | "ansi-align": "^3.0.0", 147 | "camelcase": "^5.3.1", 148 | "chalk": "^3.0.0", 149 | "cli-boxes": "^2.2.0", 150 | "string-width": "^4.1.0", 151 | "term-size": "^2.1.0", 152 | "type-fest": "^0.8.1", 153 | "widest-line": "^3.1.0" 154 | } 155 | }, 156 | "brace-expansion": { 157 | "version": "1.1.11", 158 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 159 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 160 | "dev": true, 161 | "requires": { 162 | "balanced-match": "^1.0.0", 163 | "concat-map": "0.0.1" 164 | } 165 | }, 166 | "braces": { 167 | "version": "3.0.2", 168 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 169 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 170 | "dev": true, 171 | "requires": { 172 | "fill-range": "^7.0.1" 173 | } 174 | }, 175 | "buffer-equal-constant-time": { 176 | "version": "1.0.1", 177 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 178 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 179 | }, 180 | "bytes": { 181 | "version": "3.1.0", 182 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 183 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 184 | }, 185 | "cacheable-request": { 186 | "version": "6.1.0", 187 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz", 188 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==", 189 | "dev": true, 190 | "requires": { 191 | "clone-response": "^1.0.2", 192 | "get-stream": "^5.1.0", 193 | "http-cache-semantics": "^4.0.0", 194 | "keyv": "^3.0.0", 195 | "lowercase-keys": "^2.0.0", 196 | "normalize-url": "^4.1.0", 197 | "responselike": "^1.0.2" 198 | }, 199 | "dependencies": { 200 | "get-stream": { 201 | "version": "5.2.0", 202 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", 203 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", 204 | "dev": true, 205 | "requires": { 206 | "pump": "^3.0.0" 207 | } 208 | }, 209 | "lowercase-keys": { 210 | "version": "2.0.0", 211 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", 212 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==", 213 | "dev": true 214 | } 215 | } 216 | }, 217 | "camelcase": { 218 | "version": "5.3.1", 219 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 220 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 221 | "dev": true 222 | }, 223 | "chalk": { 224 | "version": "3.0.0", 225 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", 226 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", 227 | "dev": true, 228 | "requires": { 229 | "ansi-styles": "^4.1.0", 230 | "supports-color": "^7.1.0" 231 | }, 232 | "dependencies": { 233 | "has-flag": { 234 | "version": "4.0.0", 235 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 236 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 237 | "dev": true 238 | }, 239 | "supports-color": { 240 | "version": "7.2.0", 241 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 242 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 243 | "dev": true, 244 | "requires": { 245 | "has-flag": "^4.0.0" 246 | } 247 | } 248 | } 249 | }, 250 | "chokidar": { 251 | "version": "3.5.1", 252 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.1.tgz", 253 | "integrity": "sha512-9+s+Od+W0VJJzawDma/gvBNQqkTiqYTWLuZoyAsivsI4AaWTCzHG06/TMjsf1cYe9Cb97UCEhjz7HvnPk2p/tw==", 254 | "dev": true, 255 | "requires": { 256 | "anymatch": "~3.1.1", 257 | "braces": "~3.0.2", 258 | "fsevents": "~2.3.1", 259 | "glob-parent": "~5.1.0", 260 | "is-binary-path": "~2.1.0", 261 | "is-glob": "~4.0.1", 262 | "normalize-path": "~3.0.0", 263 | "readdirp": "~3.5.0" 264 | } 265 | }, 266 | "ci-info": { 267 | "version": "2.0.0", 268 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 269 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", 270 | "dev": true 271 | }, 272 | "cli-boxes": { 273 | "version": "2.2.1", 274 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz", 275 | "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==", 276 | "dev": true 277 | }, 278 | "clone-response": { 279 | "version": "1.0.2", 280 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz", 281 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=", 282 | "dev": true, 283 | "requires": { 284 | "mimic-response": "^1.0.0" 285 | } 286 | }, 287 | "code-point-at": { 288 | "version": "1.1.0", 289 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 290 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 291 | }, 292 | "color-convert": { 293 | "version": "2.0.1", 294 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 295 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 296 | "dev": true, 297 | "requires": { 298 | "color-name": "~1.1.4" 299 | } 300 | }, 301 | "color-name": { 302 | "version": "1.1.4", 303 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 304 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 305 | "dev": true 306 | }, 307 | "concat-map": { 308 | "version": "0.0.1", 309 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 310 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 311 | "dev": true 312 | }, 313 | "configstore": { 314 | "version": "5.0.1", 315 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz", 316 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==", 317 | "dev": true, 318 | "requires": { 319 | "dot-prop": "^5.2.0", 320 | "graceful-fs": "^4.1.2", 321 | "make-dir": "^3.0.0", 322 | "unique-string": "^2.0.0", 323 | "write-file-atomic": "^3.0.0", 324 | "xdg-basedir": "^4.0.0" 325 | } 326 | }, 327 | "console-control-strings": { 328 | "version": "1.1.0", 329 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 330 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" 331 | }, 332 | "content-disposition": { 333 | "version": "0.5.3", 334 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 335 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 336 | "requires": { 337 | "safe-buffer": "5.1.2" 338 | } 339 | }, 340 | "content-type": { 341 | "version": "1.0.4", 342 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 343 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 344 | }, 345 | "cookie": { 346 | "version": "0.4.0", 347 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 348 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 349 | }, 350 | "cookie-signature": { 351 | "version": "1.0.6", 352 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 353 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 354 | }, 355 | "core-util-is": { 356 | "version": "1.0.2", 357 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 358 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 359 | }, 360 | "crypto-random-string": { 361 | "version": "2.0.0", 362 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", 363 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==", 364 | "dev": true 365 | }, 366 | "debug": { 367 | "version": "2.6.9", 368 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 369 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 370 | "requires": { 371 | "ms": "2.0.0" 372 | } 373 | }, 374 | "decompress-response": { 375 | "version": "3.3.0", 376 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz", 377 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=", 378 | "dev": true, 379 | "requires": { 380 | "mimic-response": "^1.0.0" 381 | } 382 | }, 383 | "deep-extend": { 384 | "version": "0.6.0", 385 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 386 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 387 | "dev": true 388 | }, 389 | "defer-to-connect": { 390 | "version": "1.1.3", 391 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz", 392 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==", 393 | "dev": true 394 | }, 395 | "delegates": { 396 | "version": "1.0.0", 397 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 398 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" 399 | }, 400 | "depd": { 401 | "version": "1.1.2", 402 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 403 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 404 | }, 405 | "destroy": { 406 | "version": "1.0.4", 407 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 408 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 409 | }, 410 | "dot-prop": { 411 | "version": "5.3.0", 412 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz", 413 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==", 414 | "dev": true, 415 | "requires": { 416 | "is-obj": "^2.0.0" 417 | } 418 | }, 419 | "dotenv": { 420 | "version": "8.2.0", 421 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz", 422 | "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==" 423 | }, 424 | "duplexer3": { 425 | "version": "0.1.4", 426 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 427 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=", 428 | "dev": true 429 | }, 430 | "ecdsa-sig-formatter": { 431 | "version": "1.0.11", 432 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 433 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 434 | "requires": { 435 | "safe-buffer": "^5.0.1" 436 | } 437 | }, 438 | "ee-first": { 439 | "version": "1.1.1", 440 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 441 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 442 | }, 443 | "emoji-regex": { 444 | "version": "7.0.3", 445 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 446 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 447 | "dev": true 448 | }, 449 | "encodeurl": { 450 | "version": "1.0.2", 451 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 452 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 453 | }, 454 | "end-of-stream": { 455 | "version": "1.4.4", 456 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 457 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 458 | "dev": true, 459 | "requires": { 460 | "once": "^1.4.0" 461 | } 462 | }, 463 | "escape-goat": { 464 | "version": "2.1.1", 465 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz", 466 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==", 467 | "dev": true 468 | }, 469 | "escape-html": { 470 | "version": "1.0.3", 471 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 472 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 473 | }, 474 | "etag": { 475 | "version": "1.8.1", 476 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 477 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 478 | }, 479 | "express": { 480 | "version": "4.17.1", 481 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 482 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 483 | "requires": { 484 | "accepts": "~1.3.7", 485 | "array-flatten": "1.1.1", 486 | "body-parser": "1.19.0", 487 | "content-disposition": "0.5.3", 488 | "content-type": "~1.0.4", 489 | "cookie": "0.4.0", 490 | "cookie-signature": "1.0.6", 491 | "debug": "2.6.9", 492 | "depd": "~1.1.2", 493 | "encodeurl": "~1.0.2", 494 | "escape-html": "~1.0.3", 495 | "etag": "~1.8.1", 496 | "finalhandler": "~1.1.2", 497 | "fresh": "0.5.2", 498 | "merge-descriptors": "1.0.1", 499 | "methods": "~1.1.2", 500 | "on-finished": "~2.3.0", 501 | "parseurl": "~1.3.3", 502 | "path-to-regexp": "0.1.7", 503 | "proxy-addr": "~2.0.5", 504 | "qs": "6.7.0", 505 | "range-parser": "~1.2.1", 506 | "safe-buffer": "5.1.2", 507 | "send": "0.17.1", 508 | "serve-static": "1.14.1", 509 | "setprototypeof": "1.1.1", 510 | "statuses": "~1.5.0", 511 | "type-is": "~1.6.18", 512 | "utils-merge": "1.0.1", 513 | "vary": "~1.1.2" 514 | } 515 | }, 516 | "express-validator": { 517 | "version": "6.10.0", 518 | "resolved": "https://registry.npmjs.org/express-validator/-/express-validator-6.10.0.tgz", 519 | "integrity": "sha512-gDtepU94EpUzgFvKO/8JzjZ4uqIF4xHekjYtcNgFDiBK6Hob3MQhPU8s/c3NaWd1xi5e5nA0oVmOJ0b0ZBO36Q==", 520 | "requires": { 521 | "lodash": "^4.17.20", 522 | "validator": "^13.5.2" 523 | } 524 | }, 525 | "fill-range": { 526 | "version": "7.0.1", 527 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 528 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 529 | "dev": true, 530 | "requires": { 531 | "to-regex-range": "^5.0.1" 532 | } 533 | }, 534 | "finalhandler": { 535 | "version": "1.1.2", 536 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 537 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 538 | "requires": { 539 | "debug": "2.6.9", 540 | "encodeurl": "~1.0.2", 541 | "escape-html": "~1.0.3", 542 | "on-finished": "~2.3.0", 543 | "parseurl": "~1.3.3", 544 | "statuses": "~1.5.0", 545 | "unpipe": "~1.0.0" 546 | } 547 | }, 548 | "follow-redirects": { 549 | "version": "1.13.3", 550 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.13.3.tgz", 551 | "integrity": "sha512-DUgl6+HDzB0iEptNQEXLx/KhTmDb8tZUHSeLqpnjpknR70H0nC2t9N73BK6fN4hOvJ84pKlIQVQ4k5FFlBedKA==" 552 | }, 553 | "forwarded": { 554 | "version": "0.1.2", 555 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 556 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 557 | }, 558 | "fresh": { 559 | "version": "0.5.2", 560 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 561 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 562 | }, 563 | "fsevents": { 564 | "version": "2.3.2", 565 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 566 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 567 | "dev": true, 568 | "optional": true 569 | }, 570 | "gauge": { 571 | "version": "2.7.4", 572 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 573 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 574 | "requires": { 575 | "aproba": "^1.0.3", 576 | "console-control-strings": "^1.0.0", 577 | "has-unicode": "^2.0.0", 578 | "object-assign": "^4.1.0", 579 | "signal-exit": "^3.0.0", 580 | "string-width": "^1.0.1", 581 | "strip-ansi": "^3.0.1", 582 | "wide-align": "^1.1.0" 583 | }, 584 | "dependencies": { 585 | "ansi-regex": { 586 | "version": "2.1.1", 587 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 588 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 589 | }, 590 | "is-fullwidth-code-point": { 591 | "version": "1.0.0", 592 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 593 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 594 | "requires": { 595 | "number-is-nan": "^1.0.0" 596 | } 597 | }, 598 | "string-width": { 599 | "version": "1.0.2", 600 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 601 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 602 | "requires": { 603 | "code-point-at": "^1.0.0", 604 | "is-fullwidth-code-point": "^1.0.0", 605 | "strip-ansi": "^3.0.0" 606 | } 607 | }, 608 | "strip-ansi": { 609 | "version": "3.0.1", 610 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 611 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 612 | "requires": { 613 | "ansi-regex": "^2.0.0" 614 | } 615 | } 616 | } 617 | }, 618 | "get-stream": { 619 | "version": "4.1.0", 620 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 621 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 622 | "dev": true, 623 | "requires": { 624 | "pump": "^3.0.0" 625 | } 626 | }, 627 | "glob-parent": { 628 | "version": "5.1.2", 629 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 630 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 631 | "dev": true, 632 | "requires": { 633 | "is-glob": "^4.0.1" 634 | } 635 | }, 636 | "global-dirs": { 637 | "version": "2.1.0", 638 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-2.1.0.tgz", 639 | "integrity": "sha512-MG6kdOUh/xBnyo9cJFeIKkLEc1AyFq42QTU4XiX51i2NEdxLxLWXIjEjmqKeSuKR7pAZjTqUVoT2b2huxVLgYQ==", 640 | "dev": true, 641 | "requires": { 642 | "ini": "1.3.7" 643 | } 644 | }, 645 | "got": { 646 | "version": "9.6.0", 647 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz", 648 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==", 649 | "dev": true, 650 | "requires": { 651 | "@sindresorhus/is": "^0.14.0", 652 | "@szmarczak/http-timer": "^1.1.2", 653 | "cacheable-request": "^6.0.0", 654 | "decompress-response": "^3.3.0", 655 | "duplexer3": "^0.1.4", 656 | "get-stream": "^4.1.0", 657 | "lowercase-keys": "^1.0.1", 658 | "mimic-response": "^1.0.1", 659 | "p-cancelable": "^1.0.0", 660 | "to-readable-stream": "^1.0.0", 661 | "url-parse-lax": "^3.0.0" 662 | } 663 | }, 664 | "graceful-fs": { 665 | "version": "4.2.6", 666 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.6.tgz", 667 | "integrity": "sha512-nTnJ528pbqxYanhpDYsi4Rd8MAeaBA67+RZ10CM1m3bTAVFEDcd5AuA4a6W5YkGZ1iNXHzZz8T6TBKLeBuNriQ==", 668 | "dev": true 669 | }, 670 | "has-flag": { 671 | "version": "3.0.0", 672 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 673 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 674 | "dev": true 675 | }, 676 | "has-unicode": { 677 | "version": "2.0.1", 678 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 679 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" 680 | }, 681 | "has-yarn": { 682 | "version": "2.1.0", 683 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz", 684 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==", 685 | "dev": true 686 | }, 687 | "http-cache-semantics": { 688 | "version": "4.1.0", 689 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 690 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==", 691 | "dev": true 692 | }, 693 | "http-errors": { 694 | "version": "1.7.2", 695 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 696 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 697 | "requires": { 698 | "depd": "~1.1.2", 699 | "inherits": "2.0.3", 700 | "setprototypeof": "1.1.1", 701 | "statuses": ">= 1.5.0 < 2", 702 | "toidentifier": "1.0.0" 703 | } 704 | }, 705 | "iconv-lite": { 706 | "version": "0.4.24", 707 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 708 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 709 | "requires": { 710 | "safer-buffer": ">= 2.1.2 < 3" 711 | } 712 | }, 713 | "ignore-by-default": { 714 | "version": "1.0.1", 715 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 716 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 717 | "dev": true 718 | }, 719 | "import-lazy": { 720 | "version": "2.1.0", 721 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 722 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=", 723 | "dev": true 724 | }, 725 | "imurmurhash": { 726 | "version": "0.1.4", 727 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 728 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 729 | "dev": true 730 | }, 731 | "inherits": { 732 | "version": "2.0.3", 733 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 734 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 735 | }, 736 | "ini": { 737 | "version": "1.3.7", 738 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.7.tgz", 739 | "integrity": "sha512-iKpRpXP+CrP2jyrxvg1kMUpXDyRUFDWurxbnVT1vQPx+Wz9uCYsMIqYuSBLV+PAaZG/d7kRLKRFc9oDMsH+mFQ==", 740 | "dev": true 741 | }, 742 | "ipaddr.js": { 743 | "version": "1.9.1", 744 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 745 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 746 | }, 747 | "is-binary-path": { 748 | "version": "2.1.0", 749 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 750 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 751 | "dev": true, 752 | "requires": { 753 | "binary-extensions": "^2.0.0" 754 | } 755 | }, 756 | "is-ci": { 757 | "version": "2.0.0", 758 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", 759 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", 760 | "dev": true, 761 | "requires": { 762 | "ci-info": "^2.0.0" 763 | } 764 | }, 765 | "is-extglob": { 766 | "version": "2.1.1", 767 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 768 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 769 | "dev": true 770 | }, 771 | "is-fullwidth-code-point": { 772 | "version": "2.0.0", 773 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 774 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 775 | }, 776 | "is-glob": { 777 | "version": "4.0.1", 778 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 779 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 780 | "dev": true, 781 | "requires": { 782 | "is-extglob": "^2.1.1" 783 | } 784 | }, 785 | "is-installed-globally": { 786 | "version": "0.3.2", 787 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.3.2.tgz", 788 | "integrity": "sha512-wZ8x1js7Ia0kecP/CHM/3ABkAmujX7WPvQk6uu3Fly/Mk44pySulQpnHG46OMjHGXApINnV4QhY3SWnECO2z5g==", 789 | "dev": true, 790 | "requires": { 791 | "global-dirs": "^2.0.1", 792 | "is-path-inside": "^3.0.1" 793 | } 794 | }, 795 | "is-npm": { 796 | "version": "4.0.0", 797 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-4.0.0.tgz", 798 | "integrity": "sha512-96ECIfh9xtDDlPylNPXhzjsykHsMJZ18ASpaWzQyBr4YRTcVjUvzaHayDAES2oU/3KpljhHUjtSRNiDwi0F0ig==", 799 | "dev": true 800 | }, 801 | "is-number": { 802 | "version": "7.0.0", 803 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 804 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 805 | "dev": true 806 | }, 807 | "is-obj": { 808 | "version": "2.0.0", 809 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 810 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==", 811 | "dev": true 812 | }, 813 | "is-path-inside": { 814 | "version": "3.0.3", 815 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 816 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 817 | "dev": true 818 | }, 819 | "is-typedarray": { 820 | "version": "1.0.0", 821 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 822 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 823 | "dev": true 824 | }, 825 | "is-yarn-global": { 826 | "version": "0.3.0", 827 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz", 828 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==", 829 | "dev": true 830 | }, 831 | "isarray": { 832 | "version": "1.0.0", 833 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 834 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 835 | }, 836 | "json-buffer": { 837 | "version": "3.0.0", 838 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz", 839 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=", 840 | "dev": true 841 | }, 842 | "jsonwebtoken": { 843 | "version": "8.5.1", 844 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", 845 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", 846 | "requires": { 847 | "jws": "^3.2.2", 848 | "lodash.includes": "^4.3.0", 849 | "lodash.isboolean": "^3.0.3", 850 | "lodash.isinteger": "^4.0.4", 851 | "lodash.isnumber": "^3.0.3", 852 | "lodash.isplainobject": "^4.0.6", 853 | "lodash.isstring": "^4.0.1", 854 | "lodash.once": "^4.0.0", 855 | "ms": "^2.1.1", 856 | "semver": "^5.6.0" 857 | }, 858 | "dependencies": { 859 | "ms": { 860 | "version": "2.1.3", 861 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 862 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 863 | } 864 | } 865 | }, 866 | "jwa": { 867 | "version": "1.4.1", 868 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 869 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 870 | "requires": { 871 | "buffer-equal-constant-time": "1.0.1", 872 | "ecdsa-sig-formatter": "1.0.11", 873 | "safe-buffer": "^5.0.1" 874 | } 875 | }, 876 | "jws": { 877 | "version": "3.2.2", 878 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 879 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 880 | "requires": { 881 | "jwa": "^1.4.1", 882 | "safe-buffer": "^5.0.1" 883 | } 884 | }, 885 | "keyv": { 886 | "version": "3.1.0", 887 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz", 888 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==", 889 | "dev": true, 890 | "requires": { 891 | "json-buffer": "3.0.0" 892 | } 893 | }, 894 | "latest-version": { 895 | "version": "5.1.0", 896 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz", 897 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==", 898 | "dev": true, 899 | "requires": { 900 | "package-json": "^6.3.0" 901 | } 902 | }, 903 | "lodash": { 904 | "version": "4.17.21", 905 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 906 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 907 | }, 908 | "lodash.includes": { 909 | "version": "4.3.0", 910 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 911 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 912 | }, 913 | "lodash.isboolean": { 914 | "version": "3.0.3", 915 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 916 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 917 | }, 918 | "lodash.isinteger": { 919 | "version": "4.0.4", 920 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 921 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 922 | }, 923 | "lodash.isnumber": { 924 | "version": "3.0.3", 925 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 926 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 927 | }, 928 | "lodash.isplainobject": { 929 | "version": "4.0.6", 930 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 931 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 932 | }, 933 | "lodash.isstring": { 934 | "version": "4.0.1", 935 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 936 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 937 | }, 938 | "lodash.once": { 939 | "version": "4.1.1", 940 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 941 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 942 | }, 943 | "lowercase-keys": { 944 | "version": "1.0.1", 945 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 946 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==", 947 | "dev": true 948 | }, 949 | "make-dir": { 950 | "version": "3.1.0", 951 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 952 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 953 | "dev": true, 954 | "requires": { 955 | "semver": "^6.0.0" 956 | }, 957 | "dependencies": { 958 | "semver": { 959 | "version": "6.3.0", 960 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 961 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 962 | "dev": true 963 | } 964 | } 965 | }, 966 | "media-typer": { 967 | "version": "0.3.0", 968 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 969 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 970 | }, 971 | "merge-descriptors": { 972 | "version": "1.0.1", 973 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 974 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 975 | }, 976 | "methods": { 977 | "version": "1.1.2", 978 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 979 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 980 | }, 981 | "mime": { 982 | "version": "1.6.0", 983 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 984 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 985 | }, 986 | "mime-db": { 987 | "version": "1.46.0", 988 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.46.0.tgz", 989 | "integrity": "sha512-svXaP8UQRZ5K7or+ZmfNhg2xX3yKDMUzqadsSqi4NCH/KomcH75MAMYAGVlvXn4+b/xOPhS3I2uHKRUzvjY7BQ==" 990 | }, 991 | "mime-types": { 992 | "version": "2.1.29", 993 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.29.tgz", 994 | "integrity": "sha512-Y/jMt/S5sR9OaqteJtslsFZKWOIIqMACsJSiHghlCAyhf7jfVYjKBmLiX8OgpWeW+fjJ2b+Az69aPFPkUOY6xQ==", 995 | "requires": { 996 | "mime-db": "1.46.0" 997 | } 998 | }, 999 | "mimic-response": { 1000 | "version": "1.0.1", 1001 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", 1002 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==", 1003 | "dev": true 1004 | }, 1005 | "minimatch": { 1006 | "version": "3.0.4", 1007 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1008 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1009 | "dev": true, 1010 | "requires": { 1011 | "brace-expansion": "^1.1.7" 1012 | } 1013 | }, 1014 | "minimist": { 1015 | "version": "1.2.5", 1016 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1017 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1018 | "dev": true 1019 | }, 1020 | "ms": { 1021 | "version": "2.0.0", 1022 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1023 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1024 | }, 1025 | "negotiator": { 1026 | "version": "0.6.2", 1027 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 1028 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 1029 | }, 1030 | "nodemon": { 1031 | "version": "2.0.7", 1032 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.7.tgz", 1033 | "integrity": "sha512-XHzK69Awgnec9UzHr1kc8EomQh4sjTQ8oRf8TsGrSmHDx9/UmiGG9E/mM3BuTfNeFwdNBvrqQq/RHL0xIeyFOA==", 1034 | "dev": true, 1035 | "requires": { 1036 | "chokidar": "^3.2.2", 1037 | "debug": "^3.2.6", 1038 | "ignore-by-default": "^1.0.1", 1039 | "minimatch": "^3.0.4", 1040 | "pstree.remy": "^1.1.7", 1041 | "semver": "^5.7.1", 1042 | "supports-color": "^5.5.0", 1043 | "touch": "^3.1.0", 1044 | "undefsafe": "^2.0.3", 1045 | "update-notifier": "^4.1.0" 1046 | }, 1047 | "dependencies": { 1048 | "debug": { 1049 | "version": "3.2.7", 1050 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1051 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1052 | "dev": true, 1053 | "requires": { 1054 | "ms": "^2.1.1" 1055 | } 1056 | }, 1057 | "ms": { 1058 | "version": "2.1.3", 1059 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1060 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1061 | "dev": true 1062 | } 1063 | } 1064 | }, 1065 | "nopt": { 1066 | "version": "1.0.10", 1067 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1068 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 1069 | "dev": true, 1070 | "requires": { 1071 | "abbrev": "1" 1072 | } 1073 | }, 1074 | "normalize-path": { 1075 | "version": "3.0.0", 1076 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1077 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1078 | "dev": true 1079 | }, 1080 | "normalize-url": { 1081 | "version": "4.5.0", 1082 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.0.tgz", 1083 | "integrity": "sha512-2s47yzUxdexf1OhyRi4Em83iQk0aPvwTddtFz4hnSSw9dCEsLEGf6SwIO8ss/19S9iBb5sJaOuTvTGDeZI00BQ==", 1084 | "dev": true 1085 | }, 1086 | "npmlog": { 1087 | "version": "4.1.2", 1088 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 1089 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 1090 | "requires": { 1091 | "are-we-there-yet": "~1.1.2", 1092 | "console-control-strings": "~1.1.0", 1093 | "gauge": "~2.7.3", 1094 | "set-blocking": "~2.0.0" 1095 | } 1096 | }, 1097 | "number-is-nan": { 1098 | "version": "1.0.1", 1099 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1100 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 1101 | }, 1102 | "object-assign": { 1103 | "version": "4.1.1", 1104 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1105 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1106 | }, 1107 | "on-finished": { 1108 | "version": "2.3.0", 1109 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1110 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1111 | "requires": { 1112 | "ee-first": "1.1.1" 1113 | } 1114 | }, 1115 | "once": { 1116 | "version": "1.4.0", 1117 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1118 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1119 | "dev": true, 1120 | "requires": { 1121 | "wrappy": "1" 1122 | } 1123 | }, 1124 | "p-cancelable": { 1125 | "version": "1.1.0", 1126 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz", 1127 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==", 1128 | "dev": true 1129 | }, 1130 | "package-json": { 1131 | "version": "6.5.0", 1132 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz", 1133 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==", 1134 | "dev": true, 1135 | "requires": { 1136 | "got": "^9.6.0", 1137 | "registry-auth-token": "^4.0.0", 1138 | "registry-url": "^5.0.0", 1139 | "semver": "^6.2.0" 1140 | }, 1141 | "dependencies": { 1142 | "semver": { 1143 | "version": "6.3.0", 1144 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1145 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1146 | "dev": true 1147 | } 1148 | } 1149 | }, 1150 | "parseurl": { 1151 | "version": "1.3.3", 1152 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1153 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 1154 | }, 1155 | "path-to-regexp": { 1156 | "version": "0.1.7", 1157 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1158 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1159 | }, 1160 | "picomatch": { 1161 | "version": "2.2.2", 1162 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 1163 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 1164 | "dev": true 1165 | }, 1166 | "prepend-http": { 1167 | "version": "2.0.0", 1168 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz", 1169 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=", 1170 | "dev": true 1171 | }, 1172 | "process-nextick-args": { 1173 | "version": "2.0.1", 1174 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1175 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 1176 | }, 1177 | "proxy-addr": { 1178 | "version": "2.0.6", 1179 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz", 1180 | "integrity": "sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw==", 1181 | "requires": { 1182 | "forwarded": "~0.1.2", 1183 | "ipaddr.js": "1.9.1" 1184 | } 1185 | }, 1186 | "pstree.remy": { 1187 | "version": "1.1.8", 1188 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1189 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 1190 | "dev": true 1191 | }, 1192 | "pump": { 1193 | "version": "3.0.0", 1194 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1195 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1196 | "dev": true, 1197 | "requires": { 1198 | "end-of-stream": "^1.1.0", 1199 | "once": "^1.3.1" 1200 | } 1201 | }, 1202 | "pupa": { 1203 | "version": "2.1.1", 1204 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz", 1205 | "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==", 1206 | "dev": true, 1207 | "requires": { 1208 | "escape-goat": "^2.0.0" 1209 | } 1210 | }, 1211 | "qs": { 1212 | "version": "6.7.0", 1213 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 1214 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 1215 | }, 1216 | "range-parser": { 1217 | "version": "1.2.1", 1218 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1219 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 1220 | }, 1221 | "raw-body": { 1222 | "version": "2.4.0", 1223 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 1224 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 1225 | "requires": { 1226 | "bytes": "3.1.0", 1227 | "http-errors": "1.7.2", 1228 | "iconv-lite": "0.4.24", 1229 | "unpipe": "1.0.0" 1230 | } 1231 | }, 1232 | "rc": { 1233 | "version": "1.2.8", 1234 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1235 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1236 | "dev": true, 1237 | "requires": { 1238 | "deep-extend": "^0.6.0", 1239 | "ini": "~1.3.0", 1240 | "minimist": "^1.2.0", 1241 | "strip-json-comments": "~2.0.1" 1242 | } 1243 | }, 1244 | "readable-stream": { 1245 | "version": "2.3.7", 1246 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 1247 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 1248 | "requires": { 1249 | "core-util-is": "~1.0.0", 1250 | "inherits": "~2.0.3", 1251 | "isarray": "~1.0.0", 1252 | "process-nextick-args": "~2.0.0", 1253 | "safe-buffer": "~5.1.1", 1254 | "string_decoder": "~1.1.1", 1255 | "util-deprecate": "~1.0.1" 1256 | } 1257 | }, 1258 | "readdirp": { 1259 | "version": "3.5.0", 1260 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.5.0.tgz", 1261 | "integrity": "sha512-cMhu7c/8rdhkHXWsY+osBhfSy0JikwpHK/5+imo+LpeasTF8ouErHrlYkwT0++njiyuDvc7OFY5T3ukvZ8qmFQ==", 1262 | "dev": true, 1263 | "requires": { 1264 | "picomatch": "^2.2.1" 1265 | } 1266 | }, 1267 | "registry-auth-token": { 1268 | "version": "4.2.1", 1269 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.1.tgz", 1270 | "integrity": "sha512-6gkSb4U6aWJB4SF2ZvLb76yCBjcvufXBqvvEx1HbmKPkutswjW1xNVRY0+daljIYRbogN7O0etYSlbiaEQyMyw==", 1271 | "dev": true, 1272 | "requires": { 1273 | "rc": "^1.2.8" 1274 | } 1275 | }, 1276 | "registry-url": { 1277 | "version": "5.1.0", 1278 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz", 1279 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==", 1280 | "dev": true, 1281 | "requires": { 1282 | "rc": "^1.2.8" 1283 | } 1284 | }, 1285 | "responselike": { 1286 | "version": "1.0.2", 1287 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz", 1288 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=", 1289 | "dev": true, 1290 | "requires": { 1291 | "lowercase-keys": "^1.0.0" 1292 | } 1293 | }, 1294 | "safe-buffer": { 1295 | "version": "5.1.2", 1296 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1297 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1298 | }, 1299 | "safer-buffer": { 1300 | "version": "2.1.2", 1301 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1302 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1303 | }, 1304 | "semver": { 1305 | "version": "5.7.1", 1306 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1307 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 1308 | }, 1309 | "semver-diff": { 1310 | "version": "3.1.1", 1311 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz", 1312 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==", 1313 | "dev": true, 1314 | "requires": { 1315 | "semver": "^6.3.0" 1316 | }, 1317 | "dependencies": { 1318 | "semver": { 1319 | "version": "6.3.0", 1320 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1321 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1322 | "dev": true 1323 | } 1324 | } 1325 | }, 1326 | "send": { 1327 | "version": "0.17.1", 1328 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 1329 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 1330 | "requires": { 1331 | "debug": "2.6.9", 1332 | "depd": "~1.1.2", 1333 | "destroy": "~1.0.4", 1334 | "encodeurl": "~1.0.2", 1335 | "escape-html": "~1.0.3", 1336 | "etag": "~1.8.1", 1337 | "fresh": "0.5.2", 1338 | "http-errors": "~1.7.2", 1339 | "mime": "1.6.0", 1340 | "ms": "2.1.1", 1341 | "on-finished": "~2.3.0", 1342 | "range-parser": "~1.2.1", 1343 | "statuses": "~1.5.0" 1344 | }, 1345 | "dependencies": { 1346 | "ms": { 1347 | "version": "2.1.1", 1348 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1349 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1350 | } 1351 | } 1352 | }, 1353 | "serve-static": { 1354 | "version": "1.14.1", 1355 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 1356 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 1357 | "requires": { 1358 | "encodeurl": "~1.0.2", 1359 | "escape-html": "~1.0.3", 1360 | "parseurl": "~1.3.3", 1361 | "send": "0.17.1" 1362 | } 1363 | }, 1364 | "set-blocking": { 1365 | "version": "2.0.0", 1366 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1367 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 1368 | }, 1369 | "setprototypeof": { 1370 | "version": "1.1.1", 1371 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 1372 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 1373 | }, 1374 | "signal-exit": { 1375 | "version": "3.0.3", 1376 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 1377 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==" 1378 | }, 1379 | "statuses": { 1380 | "version": "1.5.0", 1381 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1382 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 1383 | }, 1384 | "string-width": { 1385 | "version": "4.2.2", 1386 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 1387 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 1388 | "dev": true, 1389 | "requires": { 1390 | "emoji-regex": "^8.0.0", 1391 | "is-fullwidth-code-point": "^3.0.0", 1392 | "strip-ansi": "^6.0.0" 1393 | }, 1394 | "dependencies": { 1395 | "ansi-regex": { 1396 | "version": "5.0.0", 1397 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 1398 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 1399 | "dev": true 1400 | }, 1401 | "emoji-regex": { 1402 | "version": "8.0.0", 1403 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1404 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1405 | "dev": true 1406 | }, 1407 | "is-fullwidth-code-point": { 1408 | "version": "3.0.0", 1409 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1410 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1411 | "dev": true 1412 | }, 1413 | "strip-ansi": { 1414 | "version": "6.0.0", 1415 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1416 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1417 | "dev": true, 1418 | "requires": { 1419 | "ansi-regex": "^5.0.0" 1420 | } 1421 | } 1422 | } 1423 | }, 1424 | "string_decoder": { 1425 | "version": "1.1.1", 1426 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1427 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1428 | "requires": { 1429 | "safe-buffer": "~5.1.0" 1430 | } 1431 | }, 1432 | "strip-ansi": { 1433 | "version": "5.2.0", 1434 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1435 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1436 | "dev": true, 1437 | "requires": { 1438 | "ansi-regex": "^4.1.0" 1439 | } 1440 | }, 1441 | "strip-json-comments": { 1442 | "version": "2.0.1", 1443 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1444 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1445 | "dev": true 1446 | }, 1447 | "supports-color": { 1448 | "version": "5.5.0", 1449 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1450 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1451 | "dev": true, 1452 | "requires": { 1453 | "has-flag": "^3.0.0" 1454 | } 1455 | }, 1456 | "term-size": { 1457 | "version": "2.2.1", 1458 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-2.2.1.tgz", 1459 | "integrity": "sha512-wK0Ri4fOGjv/XPy8SBHZChl8CM7uMc5VML7SqiQ0zG7+J5Vr+RMQDoHa2CNT6KHUnTGIXH34UDMkPzAUyapBZg==", 1460 | "dev": true 1461 | }, 1462 | "to-readable-stream": { 1463 | "version": "1.0.0", 1464 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz", 1465 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==", 1466 | "dev": true 1467 | }, 1468 | "to-regex-range": { 1469 | "version": "5.0.1", 1470 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1471 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1472 | "dev": true, 1473 | "requires": { 1474 | "is-number": "^7.0.0" 1475 | } 1476 | }, 1477 | "toidentifier": { 1478 | "version": "1.0.0", 1479 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 1480 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 1481 | }, 1482 | "touch": { 1483 | "version": "3.1.0", 1484 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1485 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1486 | "dev": true, 1487 | "requires": { 1488 | "nopt": "~1.0.10" 1489 | } 1490 | }, 1491 | "type-fest": { 1492 | "version": "0.8.1", 1493 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1494 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1495 | "dev": true 1496 | }, 1497 | "type-is": { 1498 | "version": "1.6.18", 1499 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1500 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1501 | "requires": { 1502 | "media-typer": "0.3.0", 1503 | "mime-types": "~2.1.24" 1504 | } 1505 | }, 1506 | "typedarray-to-buffer": { 1507 | "version": "3.1.5", 1508 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 1509 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 1510 | "dev": true, 1511 | "requires": { 1512 | "is-typedarray": "^1.0.0" 1513 | } 1514 | }, 1515 | "undefsafe": { 1516 | "version": "2.0.3", 1517 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.3.tgz", 1518 | "integrity": "sha512-nrXZwwXrD/T/JXeygJqdCO6NZZ1L66HrxM/Z7mIq2oPanoN0F1nLx3lwJMu6AwJY69hdixaFQOuoYsMjE5/C2A==", 1519 | "dev": true, 1520 | "requires": { 1521 | "debug": "^2.2.0" 1522 | } 1523 | }, 1524 | "unique-string": { 1525 | "version": "2.0.0", 1526 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", 1527 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", 1528 | "dev": true, 1529 | "requires": { 1530 | "crypto-random-string": "^2.0.0" 1531 | } 1532 | }, 1533 | "unpipe": { 1534 | "version": "1.0.0", 1535 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1536 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 1537 | }, 1538 | "update-notifier": { 1539 | "version": "4.1.3", 1540 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-4.1.3.tgz", 1541 | "integrity": "sha512-Yld6Z0RyCYGB6ckIjffGOSOmHXj1gMeE7aROz4MG+XMkmixBX4jUngrGXNYz7wPKBmtoD4MnBa2Anu7RSKht/A==", 1542 | "dev": true, 1543 | "requires": { 1544 | "boxen": "^4.2.0", 1545 | "chalk": "^3.0.0", 1546 | "configstore": "^5.0.1", 1547 | "has-yarn": "^2.1.0", 1548 | "import-lazy": "^2.1.0", 1549 | "is-ci": "^2.0.0", 1550 | "is-installed-globally": "^0.3.1", 1551 | "is-npm": "^4.0.0", 1552 | "is-yarn-global": "^0.3.0", 1553 | "latest-version": "^5.0.0", 1554 | "pupa": "^2.0.1", 1555 | "semver-diff": "^3.1.1", 1556 | "xdg-basedir": "^4.0.0" 1557 | } 1558 | }, 1559 | "url-parse-lax": { 1560 | "version": "3.0.0", 1561 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz", 1562 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=", 1563 | "dev": true, 1564 | "requires": { 1565 | "prepend-http": "^2.0.0" 1566 | } 1567 | }, 1568 | "util-deprecate": { 1569 | "version": "1.0.2", 1570 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1571 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1572 | }, 1573 | "utils-merge": { 1574 | "version": "1.0.1", 1575 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1576 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 1577 | }, 1578 | "validator": { 1579 | "version": "13.5.2", 1580 | "resolved": "https://registry.npmjs.org/validator/-/validator-13.5.2.tgz", 1581 | "integrity": "sha512-mD45p0rvHVBlY2Zuy3F3ESIe1h5X58GPfAtslBjY7EtTqGquZTj+VX/J4RnHWN8FKq0C9WRVt1oWAcytWRuYLQ==" 1582 | }, 1583 | "vary": { 1584 | "version": "1.1.2", 1585 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1586 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 1587 | }, 1588 | "wide-align": { 1589 | "version": "1.1.3", 1590 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1591 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1592 | "requires": { 1593 | "string-width": "^1.0.2 || 2" 1594 | }, 1595 | "dependencies": { 1596 | "ansi-regex": { 1597 | "version": "3.0.0", 1598 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1599 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 1600 | }, 1601 | "string-width": { 1602 | "version": "2.1.1", 1603 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1604 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1605 | "requires": { 1606 | "is-fullwidth-code-point": "^2.0.0", 1607 | "strip-ansi": "^4.0.0" 1608 | } 1609 | }, 1610 | "strip-ansi": { 1611 | "version": "4.0.0", 1612 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1613 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1614 | "requires": { 1615 | "ansi-regex": "^3.0.0" 1616 | } 1617 | } 1618 | } 1619 | }, 1620 | "widest-line": { 1621 | "version": "3.1.0", 1622 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz", 1623 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==", 1624 | "dev": true, 1625 | "requires": { 1626 | "string-width": "^4.0.0" 1627 | } 1628 | }, 1629 | "wrappy": { 1630 | "version": "1.0.2", 1631 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1632 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1633 | "dev": true 1634 | }, 1635 | "write-file-atomic": { 1636 | "version": "3.0.3", 1637 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 1638 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 1639 | "dev": true, 1640 | "requires": { 1641 | "imurmurhash": "^0.1.4", 1642 | "is-typedarray": "^1.0.0", 1643 | "signal-exit": "^3.0.2", 1644 | "typedarray-to-buffer": "^3.1.5" 1645 | } 1646 | }, 1647 | "xdg-basedir": { 1648 | "version": "4.0.0", 1649 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", 1650 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==", 1651 | "dev": true 1652 | } 1653 | } 1654 | } 1655 | --------------------------------------------------------------------------------