├── 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 | 
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 |
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 |

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 |
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 |
--------------------------------------------------------------------------------