├── README.md
├── frontend
├── README.md
├── package-lock.json
├── package.json
├── public
│ ├── favicon.ico
│ ├── index.html
│ ├── logo192.png
│ ├── logo512.png
│ ├── manifest.json
│ └── robots.txt
├── src
│ ├── .DS_Store
│ ├── App.js
│ ├── components
│ │ ├── Content.js
│ │ ├── Login.js
│ │ ├── Navigation.js
│ │ ├── Protected.js
│ │ └── Register.js
│ ├── index.css
│ └── index.js
└── yarn.lock
└── server
├── package-lock.json
├── package.json
└── src
├── fakeDB.js
├── index.js
├── isAuth.js
└── tokens.js
/README.md:
--------------------------------------------------------------------------------
1 | # jwtToken-react-express
2 | Front- and backend for showing how jwt auth work.
3 |
4 | ## Usage
5 |
6 | ### Backend
7 | First ... create a .env file to store your secrets and port. Something like this:
8 |
9 | ACCESS_TOKEN_SECRET=weibenrules
10 | REFRESH_TOKEN_SECRET=weibenrulesevenmore
11 | PORT=4000
12 |
13 | Run npm install
14 |
15 | ### Frontend
16 |
17 | Run npm install
18 | then npm start
19 |
--------------------------------------------------------------------------------
/frontend/README.md:
--------------------------------------------------------------------------------
1 | This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app).
2 |
3 | ## Available Scripts
4 |
5 | In the project directory, you can run:
6 |
7 | ### `yarn start`
8 |
9 | Runs the app in the development mode.
10 | Open [http://localhost:3000](http://localhost:3000) to view it in the browser.
11 |
12 | The page will reload if you make edits.
13 | You will also see any lint errors in the console.
14 |
15 | ### `yarn test`
16 |
17 | Launches the test runner in the interactive watch mode.
18 | See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information.
19 |
20 | ### `yarn build`
21 |
22 | Builds the app for production to the `build` folder.
23 | It correctly bundles React in production mode and optimizes the build for the best performance.
24 |
25 | The build is minified and the filenames include the hashes.
26 | Your app is ready to be deployed!
27 |
28 | See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information.
29 |
30 | ### `yarn eject`
31 |
32 | **Note: this is a one-way operation. Once you `eject`, you can’t go back!**
33 |
34 | If you aren’t satisfied with the build tool and configuration choices, you can `eject` at any time. This command will remove the single build dependency from your project.
35 |
36 | Instead, it will copy all the configuration files and the transitive dependencies (Webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except `eject` will still work, but they will point to the copied scripts so you can tweak them. At this point you’re on your own.
37 |
38 | You don’t have to ever use `eject`. The curated feature set is suitable for small and middle deployments, and you shouldn’t feel obligated to use this feature. However we understand that this tool wouldn’t be useful if you couldn’t customize it when you are ready for it.
39 |
40 | ## Learn More
41 |
42 | You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started).
43 |
44 | To learn React, check out the [React documentation](https://reactjs.org/).
45 |
46 | ### Code Splitting
47 |
48 | This section has moved here: https://facebook.github.io/create-react-app/docs/code-splitting
49 |
50 | ### Analyzing the Bundle Size
51 |
52 | This section has moved here: https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size
53 |
54 | ### Making a Progressive Web App
55 |
56 | This section has moved here: https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app
57 |
58 | ### Advanced Configuration
59 |
60 | This section has moved here: https://facebook.github.io/create-react-app/docs/advanced-configuration
61 |
62 | ### Deployment
63 |
64 | This section has moved here: https://facebook.github.io/create-react-app/docs/deployment
65 |
66 | ### `yarn build` fails to minify
67 |
68 | This section has moved here: https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify
69 |
--------------------------------------------------------------------------------
/frontend/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "frontend",
3 | "version": "0.1.0",
4 | "private": true,
5 | "dependencies": {
6 | "@reach/router": "^1.2.1",
7 | "eslint-plugin-react-hooks": "^2.1.2",
8 | "react": "^16.10.2",
9 | "react-dom": "^16.10.2",
10 | "react-scripts": "3.2.0"
11 | },
12 | "scripts": {
13 | "start": "react-scripts start",
14 | "build": "react-scripts build",
15 | "test": "react-scripts test",
16 | "eject": "react-scripts eject"
17 | },
18 | "eslintConfig": {
19 | "extends": "react-app"
20 | },
21 | "browserslist": {
22 | "production": [
23 | ">0.2%",
24 | "not dead",
25 | "not op_mini all"
26 | ],
27 | "development": [
28 | "last 1 chrome version",
29 | "last 1 firefox version",
30 | "last 1 safari version"
31 | ]
32 | }
33 | }
34 |
--------------------------------------------------------------------------------
/frontend/public/favicon.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/weibenfalk/jwtToken-react-express/c50b4d7f652114e34dccee02067d0a792c1e063c/frontend/public/favicon.ico
--------------------------------------------------------------------------------
/frontend/public/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
12 |
13 |
17 |
18 |
27 | React App
28 |
29 |
30 | You need to enable JavaScript to run this app.
31 |
32 |
42 |
43 |
44 |
--------------------------------------------------------------------------------
/frontend/public/logo192.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/weibenfalk/jwtToken-react-express/c50b4d7f652114e34dccee02067d0a792c1e063c/frontend/public/logo192.png
--------------------------------------------------------------------------------
/frontend/public/logo512.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/weibenfalk/jwtToken-react-express/c50b4d7f652114e34dccee02067d0a792c1e063c/frontend/public/logo512.png
--------------------------------------------------------------------------------
/frontend/public/manifest.json:
--------------------------------------------------------------------------------
1 | {
2 | "short_name": "React App",
3 | "name": "Create React App Sample",
4 | "icons": [
5 | {
6 | "src": "favicon.ico",
7 | "sizes": "64x64 32x32 24x24 16x16",
8 | "type": "image/x-icon"
9 | },
10 | {
11 | "src": "logo192.png",
12 | "type": "image/png",
13 | "sizes": "192x192"
14 | },
15 | {
16 | "src": "logo512.png",
17 | "type": "image/png",
18 | "sizes": "512x512"
19 | }
20 | ],
21 | "start_url": ".",
22 | "display": "standalone",
23 | "theme_color": "#000000",
24 | "background_color": "#ffffff"
25 | }
26 |
--------------------------------------------------------------------------------
/frontend/public/robots.txt:
--------------------------------------------------------------------------------
1 | # https://www.robotstxt.org/robotstxt.html
2 | User-agent: *
3 |
--------------------------------------------------------------------------------
/frontend/src/.DS_Store:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/weibenfalk/jwtToken-react-express/c50b4d7f652114e34dccee02067d0a792c1e063c/frontend/src/.DS_Store
--------------------------------------------------------------------------------
/frontend/src/App.js:
--------------------------------------------------------------------------------
1 | import React, { useState, useEffect } from 'react';
2 | import { Router, navigate } from '@reach/router';
3 |
4 | import Navigation from './components/Navigation';
5 | import Login from './components/Login';
6 | import Register from './components/Register';
7 | import Protected from './components/Protected';
8 | import Content from './components/Content';
9 |
10 | export const UserContext = React.createContext([]);
11 |
12 | function App() {
13 | const [user, setUser] = useState({});
14 | const [loading, setLoading] = useState(true);
15 |
16 | const logOutCallback = async () => {
17 | await fetch('http://localhost:4000/logout', {
18 | method: 'POST',
19 | credentials: 'include', // Needed to include the cookie
20 | });
21 | // Clear user from context
22 | setUser({});
23 | // Navigate back to startpage
24 | navigate('/');
25 | }
26 |
27 | // First thing, check if a refreshtoken exist
28 | useEffect(() => {
29 | async function checkRefreshToken() {
30 | const result = await (await fetch('http://localhost:4000/refresh_token', {
31 | method: 'POST',
32 | credentials: 'include', // Needed to include the cookie
33 | headers: {
34 | 'Content-Type': 'application/json',
35 | }
36 | })).json();
37 | setUser({
38 | accesstoken: result.accesstoken,
39 | });
40 | setLoading(false);
41 | }
42 | checkRefreshToken();
43 | }, []);
44 |
45 | if (loading) return Loading ...
46 |
47 | return (
48 |
49 |
50 |
51 |
52 |
53 |
54 |
55 |
56 |
57 |
58 |
59 | );
60 | }
61 |
62 | export default App;
63 |
--------------------------------------------------------------------------------
/frontend/src/components/Content.js:
--------------------------------------------------------------------------------
1 | import React, { useContext } from 'react';
2 | import { Redirect } from '@reach/router'
3 | import { UserContext } from '../App';
4 |
5 | const Content = () => {
6 | // Could have something here to check for the time when the accesstoken expires
7 | // and then call the refresh_token endpoint to get a new accesstoken automatically
8 | const [user] = useContext(UserContext);
9 | if (!user.accesstoken) return
10 | return This is the content.
;
11 | }
12 |
13 | export default Content;
--------------------------------------------------------------------------------
/frontend/src/components/Login.js:
--------------------------------------------------------------------------------
1 | import React, { useState, useContext, useEffect } from 'react';
2 | import { navigate } from '@reach/router';
3 | import { UserContext } from '../App';
4 |
5 | const Login = () => {
6 | const [user, setUser] = useContext(UserContext);
7 | const [email, setEmail] = useState('');
8 | const [password, setPassword] = useState('');
9 |
10 | const handleSubmit = async e => {
11 | e.preventDefault();
12 | const result = await (await fetch('http://localhost:4000/login', {
13 | method: 'POST',
14 | credentials: 'include', // Needed to include the cookie
15 | headers: {
16 | 'Content-Type': 'application/json',
17 | },
18 | body: JSON.stringify({
19 | email: email,
20 | password: password,
21 | }),
22 | })).json();
23 |
24 | if (result.accesstoken) {
25 | setUser({
26 | accesstoken: result.accesstoken,
27 | });
28 | navigate('/');
29 | } else {
30 | console.log(result.error);
31 | }
32 | };
33 |
34 | useEffect(() => {
35 | console.log(user)
36 | }, [user])
37 |
38 | const handleChange = e => {
39 | if (e.currentTarget.name === 'email') {
40 | setEmail(e.currentTarget.value);
41 | } else {
42 | setPassword(e.currentTarget.value);
43 | }
44 | };
45 |
46 | return (
47 |
71 | );
72 | };
73 |
74 | export default Login;
75 |
--------------------------------------------------------------------------------
/frontend/src/components/Navigation.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import { Link } from '@reach/router';
3 |
4 | const Navigation = ({ logOutCallback }) => (
5 |
6 | Home
7 | Protected
8 | Register
9 | Log Out
10 |
11 | )
12 |
13 | export default Navigation;
--------------------------------------------------------------------------------
/frontend/src/components/Protected.js:
--------------------------------------------------------------------------------
1 | import React, { useEffect, useState, useContext } from 'react';
2 | import { UserContext } from '../App';
3 |
4 | const Protected = () => {
5 | // Could have something here to check for the time when the accesstoken expires
6 | // and then call the refresh_token endpoint to get a new accesstoken automatically
7 | const [user] = useContext(UserContext);
8 | const [content, setContent] = useState('You need to login');
9 |
10 | useEffect(() => {
11 | async function fetchProtected() {
12 | const result = await (await fetch('http://localhost:4000/protected', {
13 | method: 'POST',
14 | headers: {
15 | 'Content-Type': 'application/json',
16 | authorization: `Bearer ${user.accesstoken}`,
17 | },
18 | })).json();
19 | if (result.data) setContent(result.data)
20 | }
21 | fetchProtected();
22 | }, [user])
23 |
24 | return {content}
;
25 | }
26 |
27 | export default Protected;
--------------------------------------------------------------------------------
/frontend/src/components/Register.js:
--------------------------------------------------------------------------------
1 | import React, { useState } from 'react';
2 | import { navigate } from '@reach/router';
3 |
4 | const Register = () => {
5 | const [email, setEmail] = useState('');
6 | const [password, setPassword] = useState('');
7 |
8 | const handleSubmit = async e => {
9 | e.preventDefault();
10 | const result = await (await fetch('http://localhost:4000/register', {
11 | method: 'POST',
12 | headers: {
13 | 'Content-Type': 'application/json',
14 | },
15 | body: JSON.stringify({
16 | email: email,
17 | password: password,
18 | }),
19 | })).json();
20 | if (!result.error) {
21 | console.log(result.message);
22 | navigate('/');
23 | } else {
24 | console.log(result.error);
25 | }
26 | };
27 |
28 | const handleChange = e => {
29 | if (e.currentTarget.name === 'email') {
30 | setEmail(e.currentTarget.value);
31 | } else {
32 | setPassword(e.currentTarget.value);
33 | }
34 | };
35 |
36 | return (
37 |
61 | );
62 | };
63 |
64 | export default Register;
65 |
--------------------------------------------------------------------------------
/frontend/src/index.css:
--------------------------------------------------------------------------------
1 | body {
2 | background:steelblue ;
3 | font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen",
4 | "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue",
5 | sans-serif;
6 | -webkit-font-smoothing: antialiased;
7 | -moz-osx-font-smoothing: grayscale;
8 | }
9 |
10 | .app {
11 | text-align: center;
12 | min-height: 100vh;
13 | display: flex;
14 | flex-direction: column;
15 | align-items: center;
16 | justify-content: center;
17 | color: #fff;
18 | font-size: 16px;
19 | }
20 |
21 | .login-wrapper {
22 | min-height: 200px;
23 | min-width: 300px;
24 | background: #fff;
25 | padding: 20px;
26 | border-top: 5px lightblue solid;
27 | color: #000;
28 | }
29 |
30 | .login-input button {
31 | background: lightblue;
32 | display: block;
33 | width: 100%;
34 | height: 50px;
35 | }
36 |
37 | .login-input input {
38 | display: block;
39 | padding: 20px;
40 | width: 100%;
41 | height: 50px;
42 | margin: 10px 0;
43 | box-sizing: border-box;
44 | }
45 |
46 | ul {
47 | list-style-type: none;
48 | margin: 40px auto;
49 | width: 300px;
50 | padding: 0;
51 | }
52 |
53 | ul li {
54 | display: inline-block;
55 | margin: 10px;
56 | }
57 |
58 | a {
59 | color: white;
60 | text-decoration: none;
61 | }
--------------------------------------------------------------------------------
/frontend/src/index.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import ReactDOM from 'react-dom';
3 | import './index.css';
4 | import App from './App';
5 |
6 | ReactDOM.render( , document.getElementById('root'));
7 |
--------------------------------------------------------------------------------
/server/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "server",
3 | "version": "1.0.0",
4 | "lockfileVersion": 1,
5 | "requires": true,
6 | "dependencies": {
7 | "abbrev": {
8 | "version": "1.1.1",
9 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz",
10 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==",
11 | "dev": true
12 | },
13 | "accepts": {
14 | "version": "1.3.7",
15 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz",
16 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==",
17 | "requires": {
18 | "mime-types": "~2.1.24",
19 | "negotiator": "0.6.2"
20 | }
21 | },
22 | "ansi-align": {
23 | "version": "2.0.0",
24 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-2.0.0.tgz",
25 | "integrity": "sha1-w2rsy6VjuJzrVW82kPCx2eNUf38=",
26 | "dev": true,
27 | "requires": {
28 | "string-width": "^2.0.0"
29 | }
30 | },
31 | "ansi-regex": {
32 | "version": "3.0.0",
33 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz",
34 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=",
35 | "dev": true
36 | },
37 | "ansi-styles": {
38 | "version": "3.2.1",
39 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
40 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
41 | "dev": true,
42 | "requires": {
43 | "color-convert": "^1.9.0"
44 | }
45 | },
46 | "anymatch": {
47 | "version": "2.0.0",
48 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz",
49 | "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==",
50 | "dev": true,
51 | "requires": {
52 | "micromatch": "^3.1.4",
53 | "normalize-path": "^2.1.1"
54 | },
55 | "dependencies": {
56 | "normalize-path": {
57 | "version": "2.1.1",
58 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz",
59 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=",
60 | "dev": true,
61 | "requires": {
62 | "remove-trailing-separator": "^1.0.1"
63 | }
64 | }
65 | }
66 | },
67 | "arr-diff": {
68 | "version": "4.0.0",
69 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz",
70 | "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=",
71 | "dev": true
72 | },
73 | "arr-flatten": {
74 | "version": "1.1.0",
75 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz",
76 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==",
77 | "dev": true
78 | },
79 | "arr-union": {
80 | "version": "3.1.0",
81 | "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz",
82 | "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=",
83 | "dev": true
84 | },
85 | "array-flatten": {
86 | "version": "1.1.1",
87 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
88 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI="
89 | },
90 | "array-unique": {
91 | "version": "0.3.2",
92 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz",
93 | "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=",
94 | "dev": true
95 | },
96 | "assign-symbols": {
97 | "version": "1.0.0",
98 | "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz",
99 | "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=",
100 | "dev": true
101 | },
102 | "async-each": {
103 | "version": "1.0.3",
104 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz",
105 | "integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==",
106 | "dev": true
107 | },
108 | "atob": {
109 | "version": "2.1.2",
110 | "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz",
111 | "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==",
112 | "dev": true
113 | },
114 | "balanced-match": {
115 | "version": "1.0.0",
116 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz",
117 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=",
118 | "dev": true
119 | },
120 | "base": {
121 | "version": "0.11.2",
122 | "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz",
123 | "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==",
124 | "dev": true,
125 | "requires": {
126 | "cache-base": "^1.0.1",
127 | "class-utils": "^0.3.5",
128 | "component-emitter": "^1.2.1",
129 | "define-property": "^1.0.0",
130 | "isobject": "^3.0.1",
131 | "mixin-deep": "^1.2.0",
132 | "pascalcase": "^0.1.1"
133 | },
134 | "dependencies": {
135 | "define-property": {
136 | "version": "1.0.0",
137 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz",
138 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=",
139 | "dev": true,
140 | "requires": {
141 | "is-descriptor": "^1.0.0"
142 | }
143 | },
144 | "is-accessor-descriptor": {
145 | "version": "1.0.0",
146 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
147 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
148 | "dev": true,
149 | "requires": {
150 | "kind-of": "^6.0.0"
151 | }
152 | },
153 | "is-data-descriptor": {
154 | "version": "1.0.0",
155 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
156 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
157 | "dev": true,
158 | "requires": {
159 | "kind-of": "^6.0.0"
160 | }
161 | },
162 | "is-descriptor": {
163 | "version": "1.0.2",
164 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
165 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
166 | "dev": true,
167 | "requires": {
168 | "is-accessor-descriptor": "^1.0.0",
169 | "is-data-descriptor": "^1.0.0",
170 | "kind-of": "^6.0.2"
171 | }
172 | }
173 | }
174 | },
175 | "bcryptjs": {
176 | "version": "2.4.3",
177 | "resolved": "https://registry.npmjs.org/bcryptjs/-/bcryptjs-2.4.3.tgz",
178 | "integrity": "sha1-mrVie5PmBiH/fNrF2pczAn3x0Ms="
179 | },
180 | "binary-extensions": {
181 | "version": "1.13.1",
182 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz",
183 | "integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==",
184 | "dev": true
185 | },
186 | "body-parser": {
187 | "version": "1.19.0",
188 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz",
189 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==",
190 | "requires": {
191 | "bytes": "3.1.0",
192 | "content-type": "~1.0.4",
193 | "debug": "2.6.9",
194 | "depd": "~1.1.2",
195 | "http-errors": "1.7.2",
196 | "iconv-lite": "0.4.24",
197 | "on-finished": "~2.3.0",
198 | "qs": "6.7.0",
199 | "raw-body": "2.4.0",
200 | "type-is": "~1.6.17"
201 | }
202 | },
203 | "boxen": {
204 | "version": "1.3.0",
205 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-1.3.0.tgz",
206 | "integrity": "sha512-TNPjfTr432qx7yOjQyaXm3dSR0MH9vXp7eT1BFSl/C51g+EFnOR9hTg1IreahGBmDNCehscshe45f+C1TBZbLw==",
207 | "dev": true,
208 | "requires": {
209 | "ansi-align": "^2.0.0",
210 | "camelcase": "^4.0.0",
211 | "chalk": "^2.0.1",
212 | "cli-boxes": "^1.0.0",
213 | "string-width": "^2.0.0",
214 | "term-size": "^1.2.0",
215 | "widest-line": "^2.0.0"
216 | }
217 | },
218 | "brace-expansion": {
219 | "version": "1.1.11",
220 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
221 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
222 | "dev": true,
223 | "requires": {
224 | "balanced-match": "^1.0.0",
225 | "concat-map": "0.0.1"
226 | }
227 | },
228 | "braces": {
229 | "version": "2.3.2",
230 | "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz",
231 | "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==",
232 | "dev": true,
233 | "requires": {
234 | "arr-flatten": "^1.1.0",
235 | "array-unique": "^0.3.2",
236 | "extend-shallow": "^2.0.1",
237 | "fill-range": "^4.0.0",
238 | "isobject": "^3.0.1",
239 | "repeat-element": "^1.1.2",
240 | "snapdragon": "^0.8.1",
241 | "snapdragon-node": "^2.0.1",
242 | "split-string": "^3.0.2",
243 | "to-regex": "^3.0.1"
244 | },
245 | "dependencies": {
246 | "extend-shallow": {
247 | "version": "2.0.1",
248 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
249 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
250 | "dev": true,
251 | "requires": {
252 | "is-extendable": "^0.1.0"
253 | }
254 | }
255 | }
256 | },
257 | "buffer-equal-constant-time": {
258 | "version": "1.0.1",
259 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz",
260 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk="
261 | },
262 | "bytes": {
263 | "version": "3.1.0",
264 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz",
265 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg=="
266 | },
267 | "cache-base": {
268 | "version": "1.0.1",
269 | "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz",
270 | "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==",
271 | "dev": true,
272 | "requires": {
273 | "collection-visit": "^1.0.0",
274 | "component-emitter": "^1.2.1",
275 | "get-value": "^2.0.6",
276 | "has-value": "^1.0.0",
277 | "isobject": "^3.0.1",
278 | "set-value": "^2.0.0",
279 | "to-object-path": "^0.3.0",
280 | "union-value": "^1.0.0",
281 | "unset-value": "^1.0.0"
282 | }
283 | },
284 | "camelcase": {
285 | "version": "4.1.0",
286 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz",
287 | "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=",
288 | "dev": true
289 | },
290 | "capture-stack-trace": {
291 | "version": "1.0.1",
292 | "resolved": "https://registry.npmjs.org/capture-stack-trace/-/capture-stack-trace-1.0.1.tgz",
293 | "integrity": "sha512-mYQLZnx5Qt1JgB1WEiMCf2647plpGeQ2NMR/5L0HNZzGQo4fuSPnK+wjfPnKZV0aiJDgzmWqqkV/g7JD+DW0qw==",
294 | "dev": true
295 | },
296 | "chalk": {
297 | "version": "2.4.2",
298 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
299 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
300 | "dev": true,
301 | "requires": {
302 | "ansi-styles": "^3.2.1",
303 | "escape-string-regexp": "^1.0.5",
304 | "supports-color": "^5.3.0"
305 | }
306 | },
307 | "chokidar": {
308 | "version": "2.1.8",
309 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz",
310 | "integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==",
311 | "dev": true,
312 | "requires": {
313 | "anymatch": "^2.0.0",
314 | "async-each": "^1.0.1",
315 | "braces": "^2.3.2",
316 | "fsevents": "^1.2.7",
317 | "glob-parent": "^3.1.0",
318 | "inherits": "^2.0.3",
319 | "is-binary-path": "^1.0.0",
320 | "is-glob": "^4.0.0",
321 | "normalize-path": "^3.0.0",
322 | "path-is-absolute": "^1.0.0",
323 | "readdirp": "^2.2.1",
324 | "upath": "^1.1.1"
325 | }
326 | },
327 | "ci-info": {
328 | "version": "1.6.0",
329 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-1.6.0.tgz",
330 | "integrity": "sha512-vsGdkwSCDpWmP80ncATX7iea5DWQemg1UgCW5J8tqjU3lYw4FBYuj89J0CTVomA7BEfvSZd84GmHko+MxFQU2A==",
331 | "dev": true
332 | },
333 | "class-utils": {
334 | "version": "0.3.6",
335 | "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz",
336 | "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==",
337 | "dev": true,
338 | "requires": {
339 | "arr-union": "^3.1.0",
340 | "define-property": "^0.2.5",
341 | "isobject": "^3.0.0",
342 | "static-extend": "^0.1.1"
343 | },
344 | "dependencies": {
345 | "define-property": {
346 | "version": "0.2.5",
347 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
348 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
349 | "dev": true,
350 | "requires": {
351 | "is-descriptor": "^0.1.0"
352 | }
353 | }
354 | }
355 | },
356 | "cli-boxes": {
357 | "version": "1.0.0",
358 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-1.0.0.tgz",
359 | "integrity": "sha1-T6kXw+WclKAEzWH47lCdplFocUM=",
360 | "dev": true
361 | },
362 | "collection-visit": {
363 | "version": "1.0.0",
364 | "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz",
365 | "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=",
366 | "dev": true,
367 | "requires": {
368 | "map-visit": "^1.0.0",
369 | "object-visit": "^1.0.0"
370 | }
371 | },
372 | "color-convert": {
373 | "version": "1.9.3",
374 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
375 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
376 | "dev": true,
377 | "requires": {
378 | "color-name": "1.1.3"
379 | }
380 | },
381 | "color-name": {
382 | "version": "1.1.3",
383 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
384 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=",
385 | "dev": true
386 | },
387 | "component-emitter": {
388 | "version": "1.3.0",
389 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz",
390 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==",
391 | "dev": true
392 | },
393 | "concat-map": {
394 | "version": "0.0.1",
395 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
396 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
397 | "dev": true
398 | },
399 | "configstore": {
400 | "version": "3.1.2",
401 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-3.1.2.tgz",
402 | "integrity": "sha512-vtv5HtGjcYUgFrXc6Kx747B83MRRVS5R1VTEQoXvuP+kMI+if6uywV0nDGoiydJRy4yk7h9od5Og0kxx4zUXmw==",
403 | "dev": true,
404 | "requires": {
405 | "dot-prop": "^4.1.0",
406 | "graceful-fs": "^4.1.2",
407 | "make-dir": "^1.0.0",
408 | "unique-string": "^1.0.0",
409 | "write-file-atomic": "^2.0.0",
410 | "xdg-basedir": "^3.0.0"
411 | }
412 | },
413 | "content-disposition": {
414 | "version": "0.5.3",
415 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz",
416 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==",
417 | "requires": {
418 | "safe-buffer": "5.1.2"
419 | }
420 | },
421 | "content-type": {
422 | "version": "1.0.4",
423 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz",
424 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA=="
425 | },
426 | "cookie": {
427 | "version": "0.4.0",
428 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz",
429 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg=="
430 | },
431 | "cookie-parser": {
432 | "version": "1.4.4",
433 | "resolved": "https://registry.npmjs.org/cookie-parser/-/cookie-parser-1.4.4.tgz",
434 | "integrity": "sha512-lo13tqF3JEtFO7FyA49CqbhaFkskRJ0u/UAiINgrIXeRCY41c88/zxtrECl8AKH3B0hj9q10+h3Kt8I7KlW4tw==",
435 | "requires": {
436 | "cookie": "0.3.1",
437 | "cookie-signature": "1.0.6"
438 | },
439 | "dependencies": {
440 | "cookie": {
441 | "version": "0.3.1",
442 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz",
443 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s="
444 | }
445 | }
446 | },
447 | "cookie-signature": {
448 | "version": "1.0.6",
449 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
450 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw="
451 | },
452 | "copy-descriptor": {
453 | "version": "0.1.1",
454 | "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz",
455 | "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=",
456 | "dev": true
457 | },
458 | "core-util-is": {
459 | "version": "1.0.2",
460 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz",
461 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=",
462 | "dev": true
463 | },
464 | "cors": {
465 | "version": "2.8.5",
466 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz",
467 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==",
468 | "requires": {
469 | "object-assign": "^4",
470 | "vary": "^1"
471 | }
472 | },
473 | "create-error-class": {
474 | "version": "3.0.2",
475 | "resolved": "https://registry.npmjs.org/create-error-class/-/create-error-class-3.0.2.tgz",
476 | "integrity": "sha1-Br56vvlHo/FKMP1hBnHUAbyot7Y=",
477 | "dev": true,
478 | "requires": {
479 | "capture-stack-trace": "^1.0.0"
480 | }
481 | },
482 | "cross-spawn": {
483 | "version": "5.1.0",
484 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz",
485 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=",
486 | "dev": true,
487 | "requires": {
488 | "lru-cache": "^4.0.1",
489 | "shebang-command": "^1.2.0",
490 | "which": "^1.2.9"
491 | }
492 | },
493 | "crypto-random-string": {
494 | "version": "1.0.0",
495 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-1.0.0.tgz",
496 | "integrity": "sha1-ojD2T1aDEOFJgAmUB5DsmVRbyn4=",
497 | "dev": true
498 | },
499 | "debug": {
500 | "version": "2.6.9",
501 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
502 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
503 | "requires": {
504 | "ms": "2.0.0"
505 | }
506 | },
507 | "decode-uri-component": {
508 | "version": "0.2.0",
509 | "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz",
510 | "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=",
511 | "dev": true
512 | },
513 | "deep-extend": {
514 | "version": "0.6.0",
515 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz",
516 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==",
517 | "dev": true
518 | },
519 | "define-property": {
520 | "version": "2.0.2",
521 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz",
522 | "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==",
523 | "dev": true,
524 | "requires": {
525 | "is-descriptor": "^1.0.2",
526 | "isobject": "^3.0.1"
527 | },
528 | "dependencies": {
529 | "is-accessor-descriptor": {
530 | "version": "1.0.0",
531 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
532 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
533 | "dev": true,
534 | "requires": {
535 | "kind-of": "^6.0.0"
536 | }
537 | },
538 | "is-data-descriptor": {
539 | "version": "1.0.0",
540 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
541 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
542 | "dev": true,
543 | "requires": {
544 | "kind-of": "^6.0.0"
545 | }
546 | },
547 | "is-descriptor": {
548 | "version": "1.0.2",
549 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
550 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
551 | "dev": true,
552 | "requires": {
553 | "is-accessor-descriptor": "^1.0.0",
554 | "is-data-descriptor": "^1.0.0",
555 | "kind-of": "^6.0.2"
556 | }
557 | }
558 | }
559 | },
560 | "depd": {
561 | "version": "1.1.2",
562 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz",
563 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak="
564 | },
565 | "destroy": {
566 | "version": "1.0.4",
567 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz",
568 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA="
569 | },
570 | "dot-prop": {
571 | "version": "4.2.0",
572 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-4.2.0.tgz",
573 | "integrity": "sha512-tUMXrxlExSW6U2EXiiKGSBVdYgtV8qlHL+C10TsW4PURY/ic+eaysnSkwB4kA/mBlCyy/IKDJ+Lc3wbWeaXtuQ==",
574 | "dev": true,
575 | "requires": {
576 | "is-obj": "^1.0.0"
577 | }
578 | },
579 | "dotenv": {
580 | "version": "8.1.0",
581 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.1.0.tgz",
582 | "integrity": "sha512-GUE3gqcDCaMltj2++g6bRQ5rBJWtkWTmqmD0fo1RnnMuUqHNCt2oTPeDnS9n6fKYvlhn7AeBkb38lymBtWBQdA=="
583 | },
584 | "duplexer3": {
585 | "version": "0.1.4",
586 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz",
587 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=",
588 | "dev": true
589 | },
590 | "ecdsa-sig-formatter": {
591 | "version": "1.0.11",
592 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz",
593 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==",
594 | "requires": {
595 | "safe-buffer": "^5.0.1"
596 | }
597 | },
598 | "ee-first": {
599 | "version": "1.1.1",
600 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
601 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0="
602 | },
603 | "encodeurl": {
604 | "version": "1.0.2",
605 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
606 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k="
607 | },
608 | "escape-html": {
609 | "version": "1.0.3",
610 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
611 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg="
612 | },
613 | "escape-string-regexp": {
614 | "version": "1.0.5",
615 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
616 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=",
617 | "dev": true
618 | },
619 | "etag": {
620 | "version": "1.8.1",
621 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
622 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc="
623 | },
624 | "execa": {
625 | "version": "0.7.0",
626 | "resolved": "https://registry.npmjs.org/execa/-/execa-0.7.0.tgz",
627 | "integrity": "sha1-lEvs00zEHuMqY6n68nrVpl/Fl3c=",
628 | "dev": true,
629 | "requires": {
630 | "cross-spawn": "^5.0.1",
631 | "get-stream": "^3.0.0",
632 | "is-stream": "^1.1.0",
633 | "npm-run-path": "^2.0.0",
634 | "p-finally": "^1.0.0",
635 | "signal-exit": "^3.0.0",
636 | "strip-eof": "^1.0.0"
637 | }
638 | },
639 | "expand-brackets": {
640 | "version": "2.1.4",
641 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz",
642 | "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=",
643 | "dev": true,
644 | "requires": {
645 | "debug": "^2.3.3",
646 | "define-property": "^0.2.5",
647 | "extend-shallow": "^2.0.1",
648 | "posix-character-classes": "^0.1.0",
649 | "regex-not": "^1.0.0",
650 | "snapdragon": "^0.8.1",
651 | "to-regex": "^3.0.1"
652 | },
653 | "dependencies": {
654 | "define-property": {
655 | "version": "0.2.5",
656 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
657 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
658 | "dev": true,
659 | "requires": {
660 | "is-descriptor": "^0.1.0"
661 | }
662 | },
663 | "extend-shallow": {
664 | "version": "2.0.1",
665 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
666 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
667 | "dev": true,
668 | "requires": {
669 | "is-extendable": "^0.1.0"
670 | }
671 | }
672 | }
673 | },
674 | "express": {
675 | "version": "4.17.1",
676 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz",
677 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==",
678 | "requires": {
679 | "accepts": "~1.3.7",
680 | "array-flatten": "1.1.1",
681 | "body-parser": "1.19.0",
682 | "content-disposition": "0.5.3",
683 | "content-type": "~1.0.4",
684 | "cookie": "0.4.0",
685 | "cookie-signature": "1.0.6",
686 | "debug": "2.6.9",
687 | "depd": "~1.1.2",
688 | "encodeurl": "~1.0.2",
689 | "escape-html": "~1.0.3",
690 | "etag": "~1.8.1",
691 | "finalhandler": "~1.1.2",
692 | "fresh": "0.5.2",
693 | "merge-descriptors": "1.0.1",
694 | "methods": "~1.1.2",
695 | "on-finished": "~2.3.0",
696 | "parseurl": "~1.3.3",
697 | "path-to-regexp": "0.1.7",
698 | "proxy-addr": "~2.0.5",
699 | "qs": "6.7.0",
700 | "range-parser": "~1.2.1",
701 | "safe-buffer": "5.1.2",
702 | "send": "0.17.1",
703 | "serve-static": "1.14.1",
704 | "setprototypeof": "1.1.1",
705 | "statuses": "~1.5.0",
706 | "type-is": "~1.6.18",
707 | "utils-merge": "1.0.1",
708 | "vary": "~1.1.2"
709 | }
710 | },
711 | "extend-shallow": {
712 | "version": "3.0.2",
713 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz",
714 | "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=",
715 | "dev": true,
716 | "requires": {
717 | "assign-symbols": "^1.0.0",
718 | "is-extendable": "^1.0.1"
719 | },
720 | "dependencies": {
721 | "is-extendable": {
722 | "version": "1.0.1",
723 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz",
724 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==",
725 | "dev": true,
726 | "requires": {
727 | "is-plain-object": "^2.0.4"
728 | }
729 | }
730 | }
731 | },
732 | "extglob": {
733 | "version": "2.0.4",
734 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz",
735 | "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==",
736 | "dev": true,
737 | "requires": {
738 | "array-unique": "^0.3.2",
739 | "define-property": "^1.0.0",
740 | "expand-brackets": "^2.1.4",
741 | "extend-shallow": "^2.0.1",
742 | "fragment-cache": "^0.2.1",
743 | "regex-not": "^1.0.0",
744 | "snapdragon": "^0.8.1",
745 | "to-regex": "^3.0.1"
746 | },
747 | "dependencies": {
748 | "define-property": {
749 | "version": "1.0.0",
750 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz",
751 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=",
752 | "dev": true,
753 | "requires": {
754 | "is-descriptor": "^1.0.0"
755 | }
756 | },
757 | "extend-shallow": {
758 | "version": "2.0.1",
759 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
760 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
761 | "dev": true,
762 | "requires": {
763 | "is-extendable": "^0.1.0"
764 | }
765 | },
766 | "is-accessor-descriptor": {
767 | "version": "1.0.0",
768 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
769 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
770 | "dev": true,
771 | "requires": {
772 | "kind-of": "^6.0.0"
773 | }
774 | },
775 | "is-data-descriptor": {
776 | "version": "1.0.0",
777 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
778 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
779 | "dev": true,
780 | "requires": {
781 | "kind-of": "^6.0.0"
782 | }
783 | },
784 | "is-descriptor": {
785 | "version": "1.0.2",
786 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
787 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
788 | "dev": true,
789 | "requires": {
790 | "is-accessor-descriptor": "^1.0.0",
791 | "is-data-descriptor": "^1.0.0",
792 | "kind-of": "^6.0.2"
793 | }
794 | }
795 | }
796 | },
797 | "fill-range": {
798 | "version": "4.0.0",
799 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz",
800 | "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=",
801 | "dev": true,
802 | "requires": {
803 | "extend-shallow": "^2.0.1",
804 | "is-number": "^3.0.0",
805 | "repeat-string": "^1.6.1",
806 | "to-regex-range": "^2.1.0"
807 | },
808 | "dependencies": {
809 | "extend-shallow": {
810 | "version": "2.0.1",
811 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
812 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
813 | "dev": true,
814 | "requires": {
815 | "is-extendable": "^0.1.0"
816 | }
817 | }
818 | }
819 | },
820 | "finalhandler": {
821 | "version": "1.1.2",
822 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz",
823 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==",
824 | "requires": {
825 | "debug": "2.6.9",
826 | "encodeurl": "~1.0.2",
827 | "escape-html": "~1.0.3",
828 | "on-finished": "~2.3.0",
829 | "parseurl": "~1.3.3",
830 | "statuses": "~1.5.0",
831 | "unpipe": "~1.0.0"
832 | }
833 | },
834 | "for-in": {
835 | "version": "1.0.2",
836 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz",
837 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=",
838 | "dev": true
839 | },
840 | "forwarded": {
841 | "version": "0.1.2",
842 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz",
843 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ="
844 | },
845 | "fragment-cache": {
846 | "version": "0.2.1",
847 | "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz",
848 | "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=",
849 | "dev": true,
850 | "requires": {
851 | "map-cache": "^0.2.2"
852 | }
853 | },
854 | "fresh": {
855 | "version": "0.5.2",
856 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
857 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac="
858 | },
859 | "fsevents": {
860 | "version": "1.2.9",
861 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.9.tgz",
862 | "integrity": "sha512-oeyj2H3EjjonWcFjD5NvZNE9Rqe4UW+nQBU2HNeKw0koVLEFIhtyETyAakeAM3de7Z/SW5kcA+fZUait9EApnw==",
863 | "dev": true,
864 | "optional": true,
865 | "requires": {
866 | "nan": "^2.12.1",
867 | "node-pre-gyp": "^0.12.0"
868 | },
869 | "dependencies": {
870 | "abbrev": {
871 | "version": "1.1.1",
872 | "bundled": true,
873 | "dev": true,
874 | "optional": true
875 | },
876 | "ansi-regex": {
877 | "version": "2.1.1",
878 | "bundled": true,
879 | "dev": true,
880 | "optional": true
881 | },
882 | "aproba": {
883 | "version": "1.2.0",
884 | "bundled": true,
885 | "dev": true,
886 | "optional": true
887 | },
888 | "are-we-there-yet": {
889 | "version": "1.1.5",
890 | "bundled": true,
891 | "dev": true,
892 | "optional": true,
893 | "requires": {
894 | "delegates": "^1.0.0",
895 | "readable-stream": "^2.0.6"
896 | }
897 | },
898 | "balanced-match": {
899 | "version": "1.0.0",
900 | "bundled": true,
901 | "dev": true,
902 | "optional": true
903 | },
904 | "brace-expansion": {
905 | "version": "1.1.11",
906 | "bundled": true,
907 | "dev": true,
908 | "optional": true,
909 | "requires": {
910 | "balanced-match": "^1.0.0",
911 | "concat-map": "0.0.1"
912 | }
913 | },
914 | "chownr": {
915 | "version": "1.1.1",
916 | "bundled": true,
917 | "dev": true,
918 | "optional": true
919 | },
920 | "code-point-at": {
921 | "version": "1.1.0",
922 | "bundled": true,
923 | "dev": true,
924 | "optional": true
925 | },
926 | "concat-map": {
927 | "version": "0.0.1",
928 | "bundled": true,
929 | "dev": true,
930 | "optional": true
931 | },
932 | "console-control-strings": {
933 | "version": "1.1.0",
934 | "bundled": true,
935 | "dev": true,
936 | "optional": true
937 | },
938 | "core-util-is": {
939 | "version": "1.0.2",
940 | "bundled": true,
941 | "dev": true,
942 | "optional": true
943 | },
944 | "debug": {
945 | "version": "4.1.1",
946 | "bundled": true,
947 | "dev": true,
948 | "optional": true,
949 | "requires": {
950 | "ms": "^2.1.1"
951 | }
952 | },
953 | "deep-extend": {
954 | "version": "0.6.0",
955 | "bundled": true,
956 | "dev": true,
957 | "optional": true
958 | },
959 | "delegates": {
960 | "version": "1.0.0",
961 | "bundled": true,
962 | "dev": true,
963 | "optional": true
964 | },
965 | "detect-libc": {
966 | "version": "1.0.3",
967 | "bundled": true,
968 | "dev": true,
969 | "optional": true
970 | },
971 | "fs-minipass": {
972 | "version": "1.2.5",
973 | "bundled": true,
974 | "dev": true,
975 | "optional": true,
976 | "requires": {
977 | "minipass": "^2.2.1"
978 | }
979 | },
980 | "fs.realpath": {
981 | "version": "1.0.0",
982 | "bundled": true,
983 | "dev": true,
984 | "optional": true
985 | },
986 | "gauge": {
987 | "version": "2.7.4",
988 | "bundled": true,
989 | "dev": true,
990 | "optional": true,
991 | "requires": {
992 | "aproba": "^1.0.3",
993 | "console-control-strings": "^1.0.0",
994 | "has-unicode": "^2.0.0",
995 | "object-assign": "^4.1.0",
996 | "signal-exit": "^3.0.0",
997 | "string-width": "^1.0.1",
998 | "strip-ansi": "^3.0.1",
999 | "wide-align": "^1.1.0"
1000 | }
1001 | },
1002 | "glob": {
1003 | "version": "7.1.3",
1004 | "bundled": true,
1005 | "dev": true,
1006 | "optional": true,
1007 | "requires": {
1008 | "fs.realpath": "^1.0.0",
1009 | "inflight": "^1.0.4",
1010 | "inherits": "2",
1011 | "minimatch": "^3.0.4",
1012 | "once": "^1.3.0",
1013 | "path-is-absolute": "^1.0.0"
1014 | }
1015 | },
1016 | "has-unicode": {
1017 | "version": "2.0.1",
1018 | "bundled": true,
1019 | "dev": true,
1020 | "optional": true
1021 | },
1022 | "iconv-lite": {
1023 | "version": "0.4.24",
1024 | "bundled": true,
1025 | "dev": true,
1026 | "optional": true,
1027 | "requires": {
1028 | "safer-buffer": ">= 2.1.2 < 3"
1029 | }
1030 | },
1031 | "ignore-walk": {
1032 | "version": "3.0.1",
1033 | "bundled": true,
1034 | "dev": true,
1035 | "optional": true,
1036 | "requires": {
1037 | "minimatch": "^3.0.4"
1038 | }
1039 | },
1040 | "inflight": {
1041 | "version": "1.0.6",
1042 | "bundled": true,
1043 | "dev": true,
1044 | "optional": true,
1045 | "requires": {
1046 | "once": "^1.3.0",
1047 | "wrappy": "1"
1048 | }
1049 | },
1050 | "inherits": {
1051 | "version": "2.0.3",
1052 | "bundled": true,
1053 | "dev": true,
1054 | "optional": true
1055 | },
1056 | "ini": {
1057 | "version": "1.3.5",
1058 | "bundled": true,
1059 | "dev": true,
1060 | "optional": true
1061 | },
1062 | "is-fullwidth-code-point": {
1063 | "version": "1.0.0",
1064 | "bundled": true,
1065 | "dev": true,
1066 | "optional": true,
1067 | "requires": {
1068 | "number-is-nan": "^1.0.0"
1069 | }
1070 | },
1071 | "isarray": {
1072 | "version": "1.0.0",
1073 | "bundled": true,
1074 | "dev": true,
1075 | "optional": true
1076 | },
1077 | "minimatch": {
1078 | "version": "3.0.4",
1079 | "bundled": true,
1080 | "dev": true,
1081 | "optional": true,
1082 | "requires": {
1083 | "brace-expansion": "^1.1.7"
1084 | }
1085 | },
1086 | "minimist": {
1087 | "version": "0.0.8",
1088 | "bundled": true,
1089 | "dev": true,
1090 | "optional": true
1091 | },
1092 | "minipass": {
1093 | "version": "2.3.5",
1094 | "bundled": true,
1095 | "dev": true,
1096 | "optional": true,
1097 | "requires": {
1098 | "safe-buffer": "^5.1.2",
1099 | "yallist": "^3.0.0"
1100 | }
1101 | },
1102 | "minizlib": {
1103 | "version": "1.2.1",
1104 | "bundled": true,
1105 | "dev": true,
1106 | "optional": true,
1107 | "requires": {
1108 | "minipass": "^2.2.1"
1109 | }
1110 | },
1111 | "mkdirp": {
1112 | "version": "0.5.1",
1113 | "bundled": true,
1114 | "dev": true,
1115 | "optional": true,
1116 | "requires": {
1117 | "minimist": "0.0.8"
1118 | }
1119 | },
1120 | "ms": {
1121 | "version": "2.1.1",
1122 | "bundled": true,
1123 | "dev": true,
1124 | "optional": true
1125 | },
1126 | "needle": {
1127 | "version": "2.3.0",
1128 | "bundled": true,
1129 | "dev": true,
1130 | "optional": true,
1131 | "requires": {
1132 | "debug": "^4.1.0",
1133 | "iconv-lite": "^0.4.4",
1134 | "sax": "^1.2.4"
1135 | }
1136 | },
1137 | "node-pre-gyp": {
1138 | "version": "0.12.0",
1139 | "bundled": true,
1140 | "dev": true,
1141 | "optional": true,
1142 | "requires": {
1143 | "detect-libc": "^1.0.2",
1144 | "mkdirp": "^0.5.1",
1145 | "needle": "^2.2.1",
1146 | "nopt": "^4.0.1",
1147 | "npm-packlist": "^1.1.6",
1148 | "npmlog": "^4.0.2",
1149 | "rc": "^1.2.7",
1150 | "rimraf": "^2.6.1",
1151 | "semver": "^5.3.0",
1152 | "tar": "^4"
1153 | }
1154 | },
1155 | "nopt": {
1156 | "version": "4.0.1",
1157 | "bundled": true,
1158 | "dev": true,
1159 | "optional": true,
1160 | "requires": {
1161 | "abbrev": "1",
1162 | "osenv": "^0.1.4"
1163 | }
1164 | },
1165 | "npm-bundled": {
1166 | "version": "1.0.6",
1167 | "bundled": true,
1168 | "dev": true,
1169 | "optional": true
1170 | },
1171 | "npm-packlist": {
1172 | "version": "1.4.1",
1173 | "bundled": true,
1174 | "dev": true,
1175 | "optional": true,
1176 | "requires": {
1177 | "ignore-walk": "^3.0.1",
1178 | "npm-bundled": "^1.0.1"
1179 | }
1180 | },
1181 | "npmlog": {
1182 | "version": "4.1.2",
1183 | "bundled": true,
1184 | "dev": true,
1185 | "optional": true,
1186 | "requires": {
1187 | "are-we-there-yet": "~1.1.2",
1188 | "console-control-strings": "~1.1.0",
1189 | "gauge": "~2.7.3",
1190 | "set-blocking": "~2.0.0"
1191 | }
1192 | },
1193 | "number-is-nan": {
1194 | "version": "1.0.1",
1195 | "bundled": true,
1196 | "dev": true,
1197 | "optional": true
1198 | },
1199 | "object-assign": {
1200 | "version": "4.1.1",
1201 | "bundled": true,
1202 | "dev": true,
1203 | "optional": true
1204 | },
1205 | "once": {
1206 | "version": "1.4.0",
1207 | "bundled": true,
1208 | "dev": true,
1209 | "optional": true,
1210 | "requires": {
1211 | "wrappy": "1"
1212 | }
1213 | },
1214 | "os-homedir": {
1215 | "version": "1.0.2",
1216 | "bundled": true,
1217 | "dev": true,
1218 | "optional": true
1219 | },
1220 | "os-tmpdir": {
1221 | "version": "1.0.2",
1222 | "bundled": true,
1223 | "dev": true,
1224 | "optional": true
1225 | },
1226 | "osenv": {
1227 | "version": "0.1.5",
1228 | "bundled": true,
1229 | "dev": true,
1230 | "optional": true,
1231 | "requires": {
1232 | "os-homedir": "^1.0.0",
1233 | "os-tmpdir": "^1.0.0"
1234 | }
1235 | },
1236 | "path-is-absolute": {
1237 | "version": "1.0.1",
1238 | "bundled": true,
1239 | "dev": true,
1240 | "optional": true
1241 | },
1242 | "process-nextick-args": {
1243 | "version": "2.0.0",
1244 | "bundled": true,
1245 | "dev": true,
1246 | "optional": true
1247 | },
1248 | "rc": {
1249 | "version": "1.2.8",
1250 | "bundled": true,
1251 | "dev": true,
1252 | "optional": true,
1253 | "requires": {
1254 | "deep-extend": "^0.6.0",
1255 | "ini": "~1.3.0",
1256 | "minimist": "^1.2.0",
1257 | "strip-json-comments": "~2.0.1"
1258 | },
1259 | "dependencies": {
1260 | "minimist": {
1261 | "version": "1.2.0",
1262 | "bundled": true,
1263 | "dev": true,
1264 | "optional": true
1265 | }
1266 | }
1267 | },
1268 | "readable-stream": {
1269 | "version": "2.3.6",
1270 | "bundled": true,
1271 | "dev": true,
1272 | "optional": true,
1273 | "requires": {
1274 | "core-util-is": "~1.0.0",
1275 | "inherits": "~2.0.3",
1276 | "isarray": "~1.0.0",
1277 | "process-nextick-args": "~2.0.0",
1278 | "safe-buffer": "~5.1.1",
1279 | "string_decoder": "~1.1.1",
1280 | "util-deprecate": "~1.0.1"
1281 | }
1282 | },
1283 | "rimraf": {
1284 | "version": "2.6.3",
1285 | "bundled": true,
1286 | "dev": true,
1287 | "optional": true,
1288 | "requires": {
1289 | "glob": "^7.1.3"
1290 | }
1291 | },
1292 | "safe-buffer": {
1293 | "version": "5.1.2",
1294 | "bundled": true,
1295 | "dev": true,
1296 | "optional": true
1297 | },
1298 | "safer-buffer": {
1299 | "version": "2.1.2",
1300 | "bundled": true,
1301 | "dev": true,
1302 | "optional": true
1303 | },
1304 | "sax": {
1305 | "version": "1.2.4",
1306 | "bundled": true,
1307 | "dev": true,
1308 | "optional": true
1309 | },
1310 | "semver": {
1311 | "version": "5.7.0",
1312 | "bundled": true,
1313 | "dev": true,
1314 | "optional": true
1315 | },
1316 | "set-blocking": {
1317 | "version": "2.0.0",
1318 | "bundled": true,
1319 | "dev": true,
1320 | "optional": true
1321 | },
1322 | "signal-exit": {
1323 | "version": "3.0.2",
1324 | "bundled": true,
1325 | "dev": true,
1326 | "optional": true
1327 | },
1328 | "string-width": {
1329 | "version": "1.0.2",
1330 | "bundled": true,
1331 | "dev": true,
1332 | "optional": true,
1333 | "requires": {
1334 | "code-point-at": "^1.0.0",
1335 | "is-fullwidth-code-point": "^1.0.0",
1336 | "strip-ansi": "^3.0.0"
1337 | }
1338 | },
1339 | "string_decoder": {
1340 | "version": "1.1.1",
1341 | "bundled": true,
1342 | "dev": true,
1343 | "optional": true,
1344 | "requires": {
1345 | "safe-buffer": "~5.1.0"
1346 | }
1347 | },
1348 | "strip-ansi": {
1349 | "version": "3.0.1",
1350 | "bundled": true,
1351 | "dev": true,
1352 | "optional": true,
1353 | "requires": {
1354 | "ansi-regex": "^2.0.0"
1355 | }
1356 | },
1357 | "strip-json-comments": {
1358 | "version": "2.0.1",
1359 | "bundled": true,
1360 | "dev": true,
1361 | "optional": true
1362 | },
1363 | "tar": {
1364 | "version": "4.4.8",
1365 | "bundled": true,
1366 | "dev": true,
1367 | "optional": true,
1368 | "requires": {
1369 | "chownr": "^1.1.1",
1370 | "fs-minipass": "^1.2.5",
1371 | "minipass": "^2.3.4",
1372 | "minizlib": "^1.1.1",
1373 | "mkdirp": "^0.5.0",
1374 | "safe-buffer": "^5.1.2",
1375 | "yallist": "^3.0.2"
1376 | }
1377 | },
1378 | "util-deprecate": {
1379 | "version": "1.0.2",
1380 | "bundled": true,
1381 | "dev": true,
1382 | "optional": true
1383 | },
1384 | "wide-align": {
1385 | "version": "1.1.3",
1386 | "bundled": true,
1387 | "dev": true,
1388 | "optional": true,
1389 | "requires": {
1390 | "string-width": "^1.0.2 || 2"
1391 | }
1392 | },
1393 | "wrappy": {
1394 | "version": "1.0.2",
1395 | "bundled": true,
1396 | "dev": true,
1397 | "optional": true
1398 | },
1399 | "yallist": {
1400 | "version": "3.0.3",
1401 | "bundled": true,
1402 | "dev": true,
1403 | "optional": true
1404 | }
1405 | }
1406 | },
1407 | "get-stream": {
1408 | "version": "3.0.0",
1409 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz",
1410 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=",
1411 | "dev": true
1412 | },
1413 | "get-value": {
1414 | "version": "2.0.6",
1415 | "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz",
1416 | "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=",
1417 | "dev": true
1418 | },
1419 | "glob-parent": {
1420 | "version": "3.1.0",
1421 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz",
1422 | "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=",
1423 | "dev": true,
1424 | "requires": {
1425 | "is-glob": "^3.1.0",
1426 | "path-dirname": "^1.0.0"
1427 | },
1428 | "dependencies": {
1429 | "is-glob": {
1430 | "version": "3.1.0",
1431 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz",
1432 | "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=",
1433 | "dev": true,
1434 | "requires": {
1435 | "is-extglob": "^2.1.0"
1436 | }
1437 | }
1438 | }
1439 | },
1440 | "global-dirs": {
1441 | "version": "0.1.1",
1442 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-0.1.1.tgz",
1443 | "integrity": "sha1-sxnA3UYH81PzvpzKTHL8FIxJ9EU=",
1444 | "dev": true,
1445 | "requires": {
1446 | "ini": "^1.3.4"
1447 | }
1448 | },
1449 | "got": {
1450 | "version": "6.7.1",
1451 | "resolved": "https://registry.npmjs.org/got/-/got-6.7.1.tgz",
1452 | "integrity": "sha1-JAzQV4WpoY5WHcG0S0HHY+8ejbA=",
1453 | "dev": true,
1454 | "requires": {
1455 | "create-error-class": "^3.0.0",
1456 | "duplexer3": "^0.1.4",
1457 | "get-stream": "^3.0.0",
1458 | "is-redirect": "^1.0.0",
1459 | "is-retry-allowed": "^1.0.0",
1460 | "is-stream": "^1.0.0",
1461 | "lowercase-keys": "^1.0.0",
1462 | "safe-buffer": "^5.0.1",
1463 | "timed-out": "^4.0.0",
1464 | "unzip-response": "^2.0.1",
1465 | "url-parse-lax": "^1.0.0"
1466 | }
1467 | },
1468 | "graceful-fs": {
1469 | "version": "4.2.2",
1470 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.2.tgz",
1471 | "integrity": "sha512-IItsdsea19BoLC7ELy13q1iJFNmd7ofZH5+X/pJr90/nRoPEX0DJo1dHDbgtYWOhJhcCgMDTOw84RZ72q6lB+Q==",
1472 | "dev": true
1473 | },
1474 | "has-flag": {
1475 | "version": "3.0.0",
1476 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
1477 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=",
1478 | "dev": true
1479 | },
1480 | "has-value": {
1481 | "version": "1.0.0",
1482 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz",
1483 | "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=",
1484 | "dev": true,
1485 | "requires": {
1486 | "get-value": "^2.0.6",
1487 | "has-values": "^1.0.0",
1488 | "isobject": "^3.0.0"
1489 | }
1490 | },
1491 | "has-values": {
1492 | "version": "1.0.0",
1493 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz",
1494 | "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=",
1495 | "dev": true,
1496 | "requires": {
1497 | "is-number": "^3.0.0",
1498 | "kind-of": "^4.0.0"
1499 | },
1500 | "dependencies": {
1501 | "kind-of": {
1502 | "version": "4.0.0",
1503 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz",
1504 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=",
1505 | "dev": true,
1506 | "requires": {
1507 | "is-buffer": "^1.1.5"
1508 | }
1509 | }
1510 | }
1511 | },
1512 | "http-errors": {
1513 | "version": "1.7.2",
1514 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz",
1515 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==",
1516 | "requires": {
1517 | "depd": "~1.1.2",
1518 | "inherits": "2.0.3",
1519 | "setprototypeof": "1.1.1",
1520 | "statuses": ">= 1.5.0 < 2",
1521 | "toidentifier": "1.0.0"
1522 | }
1523 | },
1524 | "iconv-lite": {
1525 | "version": "0.4.24",
1526 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
1527 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
1528 | "requires": {
1529 | "safer-buffer": ">= 2.1.2 < 3"
1530 | }
1531 | },
1532 | "ignore-by-default": {
1533 | "version": "1.0.1",
1534 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz",
1535 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=",
1536 | "dev": true
1537 | },
1538 | "import-lazy": {
1539 | "version": "2.1.0",
1540 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz",
1541 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=",
1542 | "dev": true
1543 | },
1544 | "imurmurhash": {
1545 | "version": "0.1.4",
1546 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
1547 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=",
1548 | "dev": true
1549 | },
1550 | "inherits": {
1551 | "version": "2.0.3",
1552 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
1553 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4="
1554 | },
1555 | "ini": {
1556 | "version": "1.3.5",
1557 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz",
1558 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==",
1559 | "dev": true
1560 | },
1561 | "ipaddr.js": {
1562 | "version": "1.9.0",
1563 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.0.tgz",
1564 | "integrity": "sha512-M4Sjn6N/+O6/IXSJseKqHoFc+5FdGJ22sXqnjTpdZweHK64MzEPAyQZyEU3R/KRv2GLoa7nNtg/C2Ev6m7z+eA=="
1565 | },
1566 | "is-accessor-descriptor": {
1567 | "version": "0.1.6",
1568 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz",
1569 | "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=",
1570 | "dev": true,
1571 | "requires": {
1572 | "kind-of": "^3.0.2"
1573 | },
1574 | "dependencies": {
1575 | "kind-of": {
1576 | "version": "3.2.2",
1577 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
1578 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
1579 | "dev": true,
1580 | "requires": {
1581 | "is-buffer": "^1.1.5"
1582 | }
1583 | }
1584 | }
1585 | },
1586 | "is-binary-path": {
1587 | "version": "1.0.1",
1588 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz",
1589 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=",
1590 | "dev": true,
1591 | "requires": {
1592 | "binary-extensions": "^1.0.0"
1593 | }
1594 | },
1595 | "is-buffer": {
1596 | "version": "1.1.6",
1597 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz",
1598 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==",
1599 | "dev": true
1600 | },
1601 | "is-ci": {
1602 | "version": "1.2.1",
1603 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-1.2.1.tgz",
1604 | "integrity": "sha512-s6tfsaQaQi3JNciBH6shVqEDvhGut0SUXr31ag8Pd8BBbVVlcGfWhpPmEOoM6RJ5TFhbypvf5yyRw/VXW1IiWg==",
1605 | "dev": true,
1606 | "requires": {
1607 | "ci-info": "^1.5.0"
1608 | }
1609 | },
1610 | "is-data-descriptor": {
1611 | "version": "0.1.4",
1612 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz",
1613 | "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=",
1614 | "dev": true,
1615 | "requires": {
1616 | "kind-of": "^3.0.2"
1617 | },
1618 | "dependencies": {
1619 | "kind-of": {
1620 | "version": "3.2.2",
1621 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
1622 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
1623 | "dev": true,
1624 | "requires": {
1625 | "is-buffer": "^1.1.5"
1626 | }
1627 | }
1628 | }
1629 | },
1630 | "is-descriptor": {
1631 | "version": "0.1.6",
1632 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz",
1633 | "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==",
1634 | "dev": true,
1635 | "requires": {
1636 | "is-accessor-descriptor": "^0.1.6",
1637 | "is-data-descriptor": "^0.1.4",
1638 | "kind-of": "^5.0.0"
1639 | },
1640 | "dependencies": {
1641 | "kind-of": {
1642 | "version": "5.1.0",
1643 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz",
1644 | "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==",
1645 | "dev": true
1646 | }
1647 | }
1648 | },
1649 | "is-extendable": {
1650 | "version": "0.1.1",
1651 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz",
1652 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=",
1653 | "dev": true
1654 | },
1655 | "is-extglob": {
1656 | "version": "2.1.1",
1657 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
1658 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
1659 | "dev": true
1660 | },
1661 | "is-fullwidth-code-point": {
1662 | "version": "2.0.0",
1663 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz",
1664 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=",
1665 | "dev": true
1666 | },
1667 | "is-glob": {
1668 | "version": "4.0.1",
1669 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz",
1670 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==",
1671 | "dev": true,
1672 | "requires": {
1673 | "is-extglob": "^2.1.1"
1674 | }
1675 | },
1676 | "is-installed-globally": {
1677 | "version": "0.1.0",
1678 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.1.0.tgz",
1679 | "integrity": "sha1-Df2Y9akRFxbdU13aZJL2e/PSWoA=",
1680 | "dev": true,
1681 | "requires": {
1682 | "global-dirs": "^0.1.0",
1683 | "is-path-inside": "^1.0.0"
1684 | }
1685 | },
1686 | "is-npm": {
1687 | "version": "1.0.0",
1688 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-1.0.0.tgz",
1689 | "integrity": "sha1-8vtjpl5JBbQGyGBydloaTceTufQ=",
1690 | "dev": true
1691 | },
1692 | "is-number": {
1693 | "version": "3.0.0",
1694 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz",
1695 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=",
1696 | "dev": true,
1697 | "requires": {
1698 | "kind-of": "^3.0.2"
1699 | },
1700 | "dependencies": {
1701 | "kind-of": {
1702 | "version": "3.2.2",
1703 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
1704 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
1705 | "dev": true,
1706 | "requires": {
1707 | "is-buffer": "^1.1.5"
1708 | }
1709 | }
1710 | }
1711 | },
1712 | "is-obj": {
1713 | "version": "1.0.1",
1714 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz",
1715 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=",
1716 | "dev": true
1717 | },
1718 | "is-path-inside": {
1719 | "version": "1.0.1",
1720 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz",
1721 | "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=",
1722 | "dev": true,
1723 | "requires": {
1724 | "path-is-inside": "^1.0.1"
1725 | }
1726 | },
1727 | "is-plain-object": {
1728 | "version": "2.0.4",
1729 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz",
1730 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==",
1731 | "dev": true,
1732 | "requires": {
1733 | "isobject": "^3.0.1"
1734 | }
1735 | },
1736 | "is-redirect": {
1737 | "version": "1.0.0",
1738 | "resolved": "https://registry.npmjs.org/is-redirect/-/is-redirect-1.0.0.tgz",
1739 | "integrity": "sha1-HQPd7VO9jbDzDCbk+V02/HyH3CQ=",
1740 | "dev": true
1741 | },
1742 | "is-retry-allowed": {
1743 | "version": "1.2.0",
1744 | "resolved": "https://registry.npmjs.org/is-retry-allowed/-/is-retry-allowed-1.2.0.tgz",
1745 | "integrity": "sha512-RUbUeKwvm3XG2VYamhJL1xFktgjvPzL0Hq8C+6yrWIswDy3BIXGqCxhxkc30N9jqK311gVU137K8Ei55/zVJRg==",
1746 | "dev": true
1747 | },
1748 | "is-stream": {
1749 | "version": "1.1.0",
1750 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz",
1751 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=",
1752 | "dev": true
1753 | },
1754 | "is-windows": {
1755 | "version": "1.0.2",
1756 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz",
1757 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==",
1758 | "dev": true
1759 | },
1760 | "isarray": {
1761 | "version": "1.0.0",
1762 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
1763 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=",
1764 | "dev": true
1765 | },
1766 | "isexe": {
1767 | "version": "2.0.0",
1768 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
1769 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=",
1770 | "dev": true
1771 | },
1772 | "isobject": {
1773 | "version": "3.0.1",
1774 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz",
1775 | "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=",
1776 | "dev": true
1777 | },
1778 | "jsonwebtoken": {
1779 | "version": "8.5.1",
1780 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz",
1781 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==",
1782 | "requires": {
1783 | "jws": "^3.2.2",
1784 | "lodash.includes": "^4.3.0",
1785 | "lodash.isboolean": "^3.0.3",
1786 | "lodash.isinteger": "^4.0.4",
1787 | "lodash.isnumber": "^3.0.3",
1788 | "lodash.isplainobject": "^4.0.6",
1789 | "lodash.isstring": "^4.0.1",
1790 | "lodash.once": "^4.0.0",
1791 | "ms": "^2.1.1",
1792 | "semver": "^5.6.0"
1793 | },
1794 | "dependencies": {
1795 | "ms": {
1796 | "version": "2.1.2",
1797 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
1798 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
1799 | }
1800 | }
1801 | },
1802 | "jwa": {
1803 | "version": "1.4.1",
1804 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz",
1805 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==",
1806 | "requires": {
1807 | "buffer-equal-constant-time": "1.0.1",
1808 | "ecdsa-sig-formatter": "1.0.11",
1809 | "safe-buffer": "^5.0.1"
1810 | }
1811 | },
1812 | "jws": {
1813 | "version": "3.2.2",
1814 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz",
1815 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==",
1816 | "requires": {
1817 | "jwa": "^1.4.1",
1818 | "safe-buffer": "^5.0.1"
1819 | }
1820 | },
1821 | "kind-of": {
1822 | "version": "6.0.2",
1823 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz",
1824 | "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==",
1825 | "dev": true
1826 | },
1827 | "latest-version": {
1828 | "version": "3.1.0",
1829 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-3.1.0.tgz",
1830 | "integrity": "sha1-ogU4P+oyKzO1rjsYq+4NwvNW7hU=",
1831 | "dev": true,
1832 | "requires": {
1833 | "package-json": "^4.0.0"
1834 | }
1835 | },
1836 | "lodash.includes": {
1837 | "version": "4.3.0",
1838 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz",
1839 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8="
1840 | },
1841 | "lodash.isboolean": {
1842 | "version": "3.0.3",
1843 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz",
1844 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY="
1845 | },
1846 | "lodash.isinteger": {
1847 | "version": "4.0.4",
1848 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz",
1849 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M="
1850 | },
1851 | "lodash.isnumber": {
1852 | "version": "3.0.3",
1853 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz",
1854 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w="
1855 | },
1856 | "lodash.isplainobject": {
1857 | "version": "4.0.6",
1858 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz",
1859 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs="
1860 | },
1861 | "lodash.isstring": {
1862 | "version": "4.0.1",
1863 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz",
1864 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE="
1865 | },
1866 | "lodash.once": {
1867 | "version": "4.1.1",
1868 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz",
1869 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w="
1870 | },
1871 | "lowercase-keys": {
1872 | "version": "1.0.1",
1873 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz",
1874 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==",
1875 | "dev": true
1876 | },
1877 | "lru-cache": {
1878 | "version": "4.1.5",
1879 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz",
1880 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==",
1881 | "dev": true,
1882 | "requires": {
1883 | "pseudomap": "^1.0.2",
1884 | "yallist": "^2.1.2"
1885 | }
1886 | },
1887 | "make-dir": {
1888 | "version": "1.3.0",
1889 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.3.0.tgz",
1890 | "integrity": "sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ==",
1891 | "dev": true,
1892 | "requires": {
1893 | "pify": "^3.0.0"
1894 | }
1895 | },
1896 | "map-cache": {
1897 | "version": "0.2.2",
1898 | "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz",
1899 | "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=",
1900 | "dev": true
1901 | },
1902 | "map-visit": {
1903 | "version": "1.0.0",
1904 | "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz",
1905 | "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=",
1906 | "dev": true,
1907 | "requires": {
1908 | "object-visit": "^1.0.0"
1909 | }
1910 | },
1911 | "media-typer": {
1912 | "version": "0.3.0",
1913 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
1914 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g="
1915 | },
1916 | "merge-descriptors": {
1917 | "version": "1.0.1",
1918 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
1919 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E="
1920 | },
1921 | "methods": {
1922 | "version": "1.1.2",
1923 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
1924 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4="
1925 | },
1926 | "micromatch": {
1927 | "version": "3.1.10",
1928 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz",
1929 | "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==",
1930 | "dev": true,
1931 | "requires": {
1932 | "arr-diff": "^4.0.0",
1933 | "array-unique": "^0.3.2",
1934 | "braces": "^2.3.1",
1935 | "define-property": "^2.0.2",
1936 | "extend-shallow": "^3.0.2",
1937 | "extglob": "^2.0.4",
1938 | "fragment-cache": "^0.2.1",
1939 | "kind-of": "^6.0.2",
1940 | "nanomatch": "^1.2.9",
1941 | "object.pick": "^1.3.0",
1942 | "regex-not": "^1.0.0",
1943 | "snapdragon": "^0.8.1",
1944 | "to-regex": "^3.0.2"
1945 | }
1946 | },
1947 | "mime": {
1948 | "version": "1.6.0",
1949 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
1950 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg=="
1951 | },
1952 | "mime-db": {
1953 | "version": "1.40.0",
1954 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz",
1955 | "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA=="
1956 | },
1957 | "mime-types": {
1958 | "version": "2.1.24",
1959 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz",
1960 | "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==",
1961 | "requires": {
1962 | "mime-db": "1.40.0"
1963 | }
1964 | },
1965 | "minimatch": {
1966 | "version": "3.0.4",
1967 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
1968 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
1969 | "dev": true,
1970 | "requires": {
1971 | "brace-expansion": "^1.1.7"
1972 | }
1973 | },
1974 | "minimist": {
1975 | "version": "1.2.0",
1976 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz",
1977 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=",
1978 | "dev": true
1979 | },
1980 | "mixin-deep": {
1981 | "version": "1.3.2",
1982 | "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.2.tgz",
1983 | "integrity": "sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA==",
1984 | "dev": true,
1985 | "requires": {
1986 | "for-in": "^1.0.2",
1987 | "is-extendable": "^1.0.1"
1988 | },
1989 | "dependencies": {
1990 | "is-extendable": {
1991 | "version": "1.0.1",
1992 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz",
1993 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==",
1994 | "dev": true,
1995 | "requires": {
1996 | "is-plain-object": "^2.0.4"
1997 | }
1998 | }
1999 | }
2000 | },
2001 | "ms": {
2002 | "version": "2.0.0",
2003 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
2004 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g="
2005 | },
2006 | "nan": {
2007 | "version": "2.14.0",
2008 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.0.tgz",
2009 | "integrity": "sha512-INOFj37C7k3AfaNTtX8RhsTw7qRy7eLET14cROi9+5HAVbbHuIWUHEauBv5qT4Av2tWasiTY1Jw6puUNqRJXQg==",
2010 | "dev": true,
2011 | "optional": true
2012 | },
2013 | "nanomatch": {
2014 | "version": "1.2.13",
2015 | "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz",
2016 | "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==",
2017 | "dev": true,
2018 | "requires": {
2019 | "arr-diff": "^4.0.0",
2020 | "array-unique": "^0.3.2",
2021 | "define-property": "^2.0.2",
2022 | "extend-shallow": "^3.0.2",
2023 | "fragment-cache": "^0.2.1",
2024 | "is-windows": "^1.0.2",
2025 | "kind-of": "^6.0.2",
2026 | "object.pick": "^1.3.0",
2027 | "regex-not": "^1.0.0",
2028 | "snapdragon": "^0.8.1",
2029 | "to-regex": "^3.0.1"
2030 | }
2031 | },
2032 | "negotiator": {
2033 | "version": "0.6.2",
2034 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz",
2035 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw=="
2036 | },
2037 | "nodemon": {
2038 | "version": "1.19.2",
2039 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-1.19.2.tgz",
2040 | "integrity": "sha512-hRLYaw5Ihyw9zK7NF+9EUzVyS6Cvgc14yh8CAYr38tPxJa6UrOxwAQ351GwrgoanHCF0FalQFn6w5eoX/LGdJw==",
2041 | "dev": true,
2042 | "requires": {
2043 | "chokidar": "^2.1.5",
2044 | "debug": "^3.1.0",
2045 | "ignore-by-default": "^1.0.1",
2046 | "minimatch": "^3.0.4",
2047 | "pstree.remy": "^1.1.6",
2048 | "semver": "^5.5.0",
2049 | "supports-color": "^5.2.0",
2050 | "touch": "^3.1.0",
2051 | "undefsafe": "^2.0.2",
2052 | "update-notifier": "^2.5.0"
2053 | },
2054 | "dependencies": {
2055 | "debug": {
2056 | "version": "3.2.6",
2057 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz",
2058 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==",
2059 | "dev": true,
2060 | "requires": {
2061 | "ms": "^2.1.1"
2062 | }
2063 | },
2064 | "ms": {
2065 | "version": "2.1.2",
2066 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
2067 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
2068 | "dev": true
2069 | }
2070 | }
2071 | },
2072 | "nopt": {
2073 | "version": "1.0.10",
2074 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz",
2075 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=",
2076 | "dev": true,
2077 | "requires": {
2078 | "abbrev": "1"
2079 | }
2080 | },
2081 | "normalize-path": {
2082 | "version": "3.0.0",
2083 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
2084 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
2085 | "dev": true
2086 | },
2087 | "npm-run-path": {
2088 | "version": "2.0.2",
2089 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz",
2090 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=",
2091 | "dev": true,
2092 | "requires": {
2093 | "path-key": "^2.0.0"
2094 | }
2095 | },
2096 | "object-assign": {
2097 | "version": "4.1.1",
2098 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
2099 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM="
2100 | },
2101 | "object-copy": {
2102 | "version": "0.1.0",
2103 | "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz",
2104 | "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=",
2105 | "dev": true,
2106 | "requires": {
2107 | "copy-descriptor": "^0.1.0",
2108 | "define-property": "^0.2.5",
2109 | "kind-of": "^3.0.3"
2110 | },
2111 | "dependencies": {
2112 | "define-property": {
2113 | "version": "0.2.5",
2114 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
2115 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
2116 | "dev": true,
2117 | "requires": {
2118 | "is-descriptor": "^0.1.0"
2119 | }
2120 | },
2121 | "kind-of": {
2122 | "version": "3.2.2",
2123 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
2124 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
2125 | "dev": true,
2126 | "requires": {
2127 | "is-buffer": "^1.1.5"
2128 | }
2129 | }
2130 | }
2131 | },
2132 | "object-visit": {
2133 | "version": "1.0.1",
2134 | "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz",
2135 | "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=",
2136 | "dev": true,
2137 | "requires": {
2138 | "isobject": "^3.0.0"
2139 | }
2140 | },
2141 | "object.pick": {
2142 | "version": "1.3.0",
2143 | "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz",
2144 | "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=",
2145 | "dev": true,
2146 | "requires": {
2147 | "isobject": "^3.0.1"
2148 | }
2149 | },
2150 | "on-finished": {
2151 | "version": "2.3.0",
2152 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz",
2153 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=",
2154 | "requires": {
2155 | "ee-first": "1.1.1"
2156 | }
2157 | },
2158 | "p-finally": {
2159 | "version": "1.0.0",
2160 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz",
2161 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=",
2162 | "dev": true
2163 | },
2164 | "package-json": {
2165 | "version": "4.0.1",
2166 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-4.0.1.tgz",
2167 | "integrity": "sha1-iGmgQBJTZhxMTKPabCEh7VVfXu0=",
2168 | "dev": true,
2169 | "requires": {
2170 | "got": "^6.7.1",
2171 | "registry-auth-token": "^3.0.1",
2172 | "registry-url": "^3.0.3",
2173 | "semver": "^5.1.0"
2174 | }
2175 | },
2176 | "parseurl": {
2177 | "version": "1.3.3",
2178 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
2179 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ=="
2180 | },
2181 | "pascalcase": {
2182 | "version": "0.1.1",
2183 | "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz",
2184 | "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=",
2185 | "dev": true
2186 | },
2187 | "path-dirname": {
2188 | "version": "1.0.2",
2189 | "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz",
2190 | "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=",
2191 | "dev": true
2192 | },
2193 | "path-is-absolute": {
2194 | "version": "1.0.1",
2195 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
2196 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=",
2197 | "dev": true
2198 | },
2199 | "path-is-inside": {
2200 | "version": "1.0.2",
2201 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz",
2202 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=",
2203 | "dev": true
2204 | },
2205 | "path-key": {
2206 | "version": "2.0.1",
2207 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz",
2208 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=",
2209 | "dev": true
2210 | },
2211 | "path-to-regexp": {
2212 | "version": "0.1.7",
2213 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
2214 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w="
2215 | },
2216 | "pify": {
2217 | "version": "3.0.0",
2218 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz",
2219 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=",
2220 | "dev": true
2221 | },
2222 | "posix-character-classes": {
2223 | "version": "0.1.1",
2224 | "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz",
2225 | "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=",
2226 | "dev": true
2227 | },
2228 | "prepend-http": {
2229 | "version": "1.0.4",
2230 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz",
2231 | "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=",
2232 | "dev": true
2233 | },
2234 | "process-nextick-args": {
2235 | "version": "2.0.1",
2236 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz",
2237 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==",
2238 | "dev": true
2239 | },
2240 | "proxy-addr": {
2241 | "version": "2.0.5",
2242 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.5.tgz",
2243 | "integrity": "sha512-t/7RxHXPH6cJtP0pRG6smSr9QJidhB+3kXu0KgXnbGYMgzEnUxRQ4/LDdfOwZEMyIh3/xHb8PX3t+lfL9z+YVQ==",
2244 | "requires": {
2245 | "forwarded": "~0.1.2",
2246 | "ipaddr.js": "1.9.0"
2247 | }
2248 | },
2249 | "pseudomap": {
2250 | "version": "1.0.2",
2251 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz",
2252 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=",
2253 | "dev": true
2254 | },
2255 | "pstree.remy": {
2256 | "version": "1.1.7",
2257 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.7.tgz",
2258 | "integrity": "sha512-xsMgrUwRpuGskEzBFkH8NmTimbZ5PcPup0LA8JJkHIm2IMUbQcpo3yeLNWVrufEYjh8YwtSVh0xz6UeWc5Oh5A==",
2259 | "dev": true
2260 | },
2261 | "qs": {
2262 | "version": "6.7.0",
2263 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz",
2264 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ=="
2265 | },
2266 | "range-parser": {
2267 | "version": "1.2.1",
2268 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
2269 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg=="
2270 | },
2271 | "raw-body": {
2272 | "version": "2.4.0",
2273 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz",
2274 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==",
2275 | "requires": {
2276 | "bytes": "3.1.0",
2277 | "http-errors": "1.7.2",
2278 | "iconv-lite": "0.4.24",
2279 | "unpipe": "1.0.0"
2280 | }
2281 | },
2282 | "rc": {
2283 | "version": "1.2.8",
2284 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz",
2285 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==",
2286 | "dev": true,
2287 | "requires": {
2288 | "deep-extend": "^0.6.0",
2289 | "ini": "~1.3.0",
2290 | "minimist": "^1.2.0",
2291 | "strip-json-comments": "~2.0.1"
2292 | }
2293 | },
2294 | "readable-stream": {
2295 | "version": "2.3.6",
2296 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz",
2297 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==",
2298 | "dev": true,
2299 | "requires": {
2300 | "core-util-is": "~1.0.0",
2301 | "inherits": "~2.0.3",
2302 | "isarray": "~1.0.0",
2303 | "process-nextick-args": "~2.0.0",
2304 | "safe-buffer": "~5.1.1",
2305 | "string_decoder": "~1.1.1",
2306 | "util-deprecate": "~1.0.1"
2307 | }
2308 | },
2309 | "readdirp": {
2310 | "version": "2.2.1",
2311 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz",
2312 | "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==",
2313 | "dev": true,
2314 | "requires": {
2315 | "graceful-fs": "^4.1.11",
2316 | "micromatch": "^3.1.10",
2317 | "readable-stream": "^2.0.2"
2318 | }
2319 | },
2320 | "regex-not": {
2321 | "version": "1.0.2",
2322 | "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz",
2323 | "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==",
2324 | "dev": true,
2325 | "requires": {
2326 | "extend-shallow": "^3.0.2",
2327 | "safe-regex": "^1.1.0"
2328 | }
2329 | },
2330 | "registry-auth-token": {
2331 | "version": "3.4.0",
2332 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-3.4.0.tgz",
2333 | "integrity": "sha512-4LM6Fw8eBQdwMYcES4yTnn2TqIasbXuwDx3um+QRs7S55aMKCBKBxvPXl2RiUjHwuJLTyYfxSpmfSAjQpcuP+A==",
2334 | "dev": true,
2335 | "requires": {
2336 | "rc": "^1.1.6",
2337 | "safe-buffer": "^5.0.1"
2338 | }
2339 | },
2340 | "registry-url": {
2341 | "version": "3.1.0",
2342 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-3.1.0.tgz",
2343 | "integrity": "sha1-PU74cPc93h138M+aOBQyRE4XSUI=",
2344 | "dev": true,
2345 | "requires": {
2346 | "rc": "^1.0.1"
2347 | }
2348 | },
2349 | "remove-trailing-separator": {
2350 | "version": "1.1.0",
2351 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz",
2352 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=",
2353 | "dev": true
2354 | },
2355 | "repeat-element": {
2356 | "version": "1.1.3",
2357 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz",
2358 | "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==",
2359 | "dev": true
2360 | },
2361 | "repeat-string": {
2362 | "version": "1.6.1",
2363 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz",
2364 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=",
2365 | "dev": true
2366 | },
2367 | "resolve-url": {
2368 | "version": "0.2.1",
2369 | "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz",
2370 | "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=",
2371 | "dev": true
2372 | },
2373 | "ret": {
2374 | "version": "0.1.15",
2375 | "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz",
2376 | "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==",
2377 | "dev": true
2378 | },
2379 | "safe-buffer": {
2380 | "version": "5.1.2",
2381 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
2382 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
2383 | },
2384 | "safe-regex": {
2385 | "version": "1.1.0",
2386 | "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz",
2387 | "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=",
2388 | "dev": true,
2389 | "requires": {
2390 | "ret": "~0.1.10"
2391 | }
2392 | },
2393 | "safer-buffer": {
2394 | "version": "2.1.2",
2395 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
2396 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
2397 | },
2398 | "semver": {
2399 | "version": "5.7.1",
2400 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
2401 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ=="
2402 | },
2403 | "semver-diff": {
2404 | "version": "2.1.0",
2405 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-2.1.0.tgz",
2406 | "integrity": "sha1-S7uEN8jTfksM8aaP1ybsbWRdbTY=",
2407 | "dev": true,
2408 | "requires": {
2409 | "semver": "^5.0.3"
2410 | }
2411 | },
2412 | "send": {
2413 | "version": "0.17.1",
2414 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz",
2415 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==",
2416 | "requires": {
2417 | "debug": "2.6.9",
2418 | "depd": "~1.1.2",
2419 | "destroy": "~1.0.4",
2420 | "encodeurl": "~1.0.2",
2421 | "escape-html": "~1.0.3",
2422 | "etag": "~1.8.1",
2423 | "fresh": "0.5.2",
2424 | "http-errors": "~1.7.2",
2425 | "mime": "1.6.0",
2426 | "ms": "2.1.1",
2427 | "on-finished": "~2.3.0",
2428 | "range-parser": "~1.2.1",
2429 | "statuses": "~1.5.0"
2430 | },
2431 | "dependencies": {
2432 | "ms": {
2433 | "version": "2.1.1",
2434 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz",
2435 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg=="
2436 | }
2437 | }
2438 | },
2439 | "serve-static": {
2440 | "version": "1.14.1",
2441 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz",
2442 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==",
2443 | "requires": {
2444 | "encodeurl": "~1.0.2",
2445 | "escape-html": "~1.0.3",
2446 | "parseurl": "~1.3.3",
2447 | "send": "0.17.1"
2448 | }
2449 | },
2450 | "set-value": {
2451 | "version": "2.0.1",
2452 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.1.tgz",
2453 | "integrity": "sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw==",
2454 | "dev": true,
2455 | "requires": {
2456 | "extend-shallow": "^2.0.1",
2457 | "is-extendable": "^0.1.1",
2458 | "is-plain-object": "^2.0.3",
2459 | "split-string": "^3.0.1"
2460 | },
2461 | "dependencies": {
2462 | "extend-shallow": {
2463 | "version": "2.0.1",
2464 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
2465 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
2466 | "dev": true,
2467 | "requires": {
2468 | "is-extendable": "^0.1.0"
2469 | }
2470 | }
2471 | }
2472 | },
2473 | "setprototypeof": {
2474 | "version": "1.1.1",
2475 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz",
2476 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw=="
2477 | },
2478 | "shebang-command": {
2479 | "version": "1.2.0",
2480 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz",
2481 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=",
2482 | "dev": true,
2483 | "requires": {
2484 | "shebang-regex": "^1.0.0"
2485 | }
2486 | },
2487 | "shebang-regex": {
2488 | "version": "1.0.0",
2489 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz",
2490 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=",
2491 | "dev": true
2492 | },
2493 | "signal-exit": {
2494 | "version": "3.0.2",
2495 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz",
2496 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=",
2497 | "dev": true
2498 | },
2499 | "snapdragon": {
2500 | "version": "0.8.2",
2501 | "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz",
2502 | "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==",
2503 | "dev": true,
2504 | "requires": {
2505 | "base": "^0.11.1",
2506 | "debug": "^2.2.0",
2507 | "define-property": "^0.2.5",
2508 | "extend-shallow": "^2.0.1",
2509 | "map-cache": "^0.2.2",
2510 | "source-map": "^0.5.6",
2511 | "source-map-resolve": "^0.5.0",
2512 | "use": "^3.1.0"
2513 | },
2514 | "dependencies": {
2515 | "define-property": {
2516 | "version": "0.2.5",
2517 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
2518 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
2519 | "dev": true,
2520 | "requires": {
2521 | "is-descriptor": "^0.1.0"
2522 | }
2523 | },
2524 | "extend-shallow": {
2525 | "version": "2.0.1",
2526 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
2527 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
2528 | "dev": true,
2529 | "requires": {
2530 | "is-extendable": "^0.1.0"
2531 | }
2532 | }
2533 | }
2534 | },
2535 | "snapdragon-node": {
2536 | "version": "2.1.1",
2537 | "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz",
2538 | "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==",
2539 | "dev": true,
2540 | "requires": {
2541 | "define-property": "^1.0.0",
2542 | "isobject": "^3.0.0",
2543 | "snapdragon-util": "^3.0.1"
2544 | },
2545 | "dependencies": {
2546 | "define-property": {
2547 | "version": "1.0.0",
2548 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz",
2549 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=",
2550 | "dev": true,
2551 | "requires": {
2552 | "is-descriptor": "^1.0.0"
2553 | }
2554 | },
2555 | "is-accessor-descriptor": {
2556 | "version": "1.0.0",
2557 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
2558 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
2559 | "dev": true,
2560 | "requires": {
2561 | "kind-of": "^6.0.0"
2562 | }
2563 | },
2564 | "is-data-descriptor": {
2565 | "version": "1.0.0",
2566 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
2567 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
2568 | "dev": true,
2569 | "requires": {
2570 | "kind-of": "^6.0.0"
2571 | }
2572 | },
2573 | "is-descriptor": {
2574 | "version": "1.0.2",
2575 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
2576 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
2577 | "dev": true,
2578 | "requires": {
2579 | "is-accessor-descriptor": "^1.0.0",
2580 | "is-data-descriptor": "^1.0.0",
2581 | "kind-of": "^6.0.2"
2582 | }
2583 | }
2584 | }
2585 | },
2586 | "snapdragon-util": {
2587 | "version": "3.0.1",
2588 | "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz",
2589 | "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==",
2590 | "dev": true,
2591 | "requires": {
2592 | "kind-of": "^3.2.0"
2593 | },
2594 | "dependencies": {
2595 | "kind-of": {
2596 | "version": "3.2.2",
2597 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
2598 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
2599 | "dev": true,
2600 | "requires": {
2601 | "is-buffer": "^1.1.5"
2602 | }
2603 | }
2604 | }
2605 | },
2606 | "source-map": {
2607 | "version": "0.5.7",
2608 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz",
2609 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=",
2610 | "dev": true
2611 | },
2612 | "source-map-resolve": {
2613 | "version": "0.5.2",
2614 | "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.2.tgz",
2615 | "integrity": "sha512-MjqsvNwyz1s0k81Goz/9vRBe9SZdB09Bdw+/zYyO+3CuPk6fouTaxscHkgtE8jKvf01kVfl8riHzERQ/kefaSA==",
2616 | "dev": true,
2617 | "requires": {
2618 | "atob": "^2.1.1",
2619 | "decode-uri-component": "^0.2.0",
2620 | "resolve-url": "^0.2.1",
2621 | "source-map-url": "^0.4.0",
2622 | "urix": "^0.1.0"
2623 | }
2624 | },
2625 | "source-map-url": {
2626 | "version": "0.4.0",
2627 | "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz",
2628 | "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=",
2629 | "dev": true
2630 | },
2631 | "split-string": {
2632 | "version": "3.1.0",
2633 | "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz",
2634 | "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==",
2635 | "dev": true,
2636 | "requires": {
2637 | "extend-shallow": "^3.0.0"
2638 | }
2639 | },
2640 | "static-extend": {
2641 | "version": "0.1.2",
2642 | "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz",
2643 | "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=",
2644 | "dev": true,
2645 | "requires": {
2646 | "define-property": "^0.2.5",
2647 | "object-copy": "^0.1.0"
2648 | },
2649 | "dependencies": {
2650 | "define-property": {
2651 | "version": "0.2.5",
2652 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
2653 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
2654 | "dev": true,
2655 | "requires": {
2656 | "is-descriptor": "^0.1.0"
2657 | }
2658 | }
2659 | }
2660 | },
2661 | "statuses": {
2662 | "version": "1.5.0",
2663 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz",
2664 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow="
2665 | },
2666 | "string-width": {
2667 | "version": "2.1.1",
2668 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz",
2669 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==",
2670 | "dev": true,
2671 | "requires": {
2672 | "is-fullwidth-code-point": "^2.0.0",
2673 | "strip-ansi": "^4.0.0"
2674 | }
2675 | },
2676 | "string_decoder": {
2677 | "version": "1.1.1",
2678 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
2679 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
2680 | "dev": true,
2681 | "requires": {
2682 | "safe-buffer": "~5.1.0"
2683 | }
2684 | },
2685 | "strip-ansi": {
2686 | "version": "4.0.0",
2687 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz",
2688 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=",
2689 | "dev": true,
2690 | "requires": {
2691 | "ansi-regex": "^3.0.0"
2692 | }
2693 | },
2694 | "strip-eof": {
2695 | "version": "1.0.0",
2696 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz",
2697 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=",
2698 | "dev": true
2699 | },
2700 | "strip-json-comments": {
2701 | "version": "2.0.1",
2702 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz",
2703 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=",
2704 | "dev": true
2705 | },
2706 | "supports-color": {
2707 | "version": "5.5.0",
2708 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
2709 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
2710 | "dev": true,
2711 | "requires": {
2712 | "has-flag": "^3.0.0"
2713 | }
2714 | },
2715 | "term-size": {
2716 | "version": "1.2.0",
2717 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-1.2.0.tgz",
2718 | "integrity": "sha1-RYuDiH8oj8Vtb/+/rSYuJmOO+mk=",
2719 | "dev": true,
2720 | "requires": {
2721 | "execa": "^0.7.0"
2722 | }
2723 | },
2724 | "timed-out": {
2725 | "version": "4.0.1",
2726 | "resolved": "https://registry.npmjs.org/timed-out/-/timed-out-4.0.1.tgz",
2727 | "integrity": "sha1-8y6srFoXW+ol1/q1Zas+2HQe9W8=",
2728 | "dev": true
2729 | },
2730 | "to-object-path": {
2731 | "version": "0.3.0",
2732 | "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz",
2733 | "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=",
2734 | "dev": true,
2735 | "requires": {
2736 | "kind-of": "^3.0.2"
2737 | },
2738 | "dependencies": {
2739 | "kind-of": {
2740 | "version": "3.2.2",
2741 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
2742 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
2743 | "dev": true,
2744 | "requires": {
2745 | "is-buffer": "^1.1.5"
2746 | }
2747 | }
2748 | }
2749 | },
2750 | "to-regex": {
2751 | "version": "3.0.2",
2752 | "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz",
2753 | "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==",
2754 | "dev": true,
2755 | "requires": {
2756 | "define-property": "^2.0.2",
2757 | "extend-shallow": "^3.0.2",
2758 | "regex-not": "^1.0.2",
2759 | "safe-regex": "^1.1.0"
2760 | }
2761 | },
2762 | "to-regex-range": {
2763 | "version": "2.1.1",
2764 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz",
2765 | "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=",
2766 | "dev": true,
2767 | "requires": {
2768 | "is-number": "^3.0.0",
2769 | "repeat-string": "^1.6.1"
2770 | }
2771 | },
2772 | "toidentifier": {
2773 | "version": "1.0.0",
2774 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz",
2775 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw=="
2776 | },
2777 | "touch": {
2778 | "version": "3.1.0",
2779 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz",
2780 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==",
2781 | "dev": true,
2782 | "requires": {
2783 | "nopt": "~1.0.10"
2784 | }
2785 | },
2786 | "type-is": {
2787 | "version": "1.6.18",
2788 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
2789 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
2790 | "requires": {
2791 | "media-typer": "0.3.0",
2792 | "mime-types": "~2.1.24"
2793 | }
2794 | },
2795 | "undefsafe": {
2796 | "version": "2.0.2",
2797 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.2.tgz",
2798 | "integrity": "sha1-Il9rngM3Zj4Njnz9aG/Cg2zKznY=",
2799 | "dev": true,
2800 | "requires": {
2801 | "debug": "^2.2.0"
2802 | }
2803 | },
2804 | "union-value": {
2805 | "version": "1.0.1",
2806 | "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz",
2807 | "integrity": "sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg==",
2808 | "dev": true,
2809 | "requires": {
2810 | "arr-union": "^3.1.0",
2811 | "get-value": "^2.0.6",
2812 | "is-extendable": "^0.1.1",
2813 | "set-value": "^2.0.1"
2814 | }
2815 | },
2816 | "unique-string": {
2817 | "version": "1.0.0",
2818 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-1.0.0.tgz",
2819 | "integrity": "sha1-nhBXzKhRq7kzmPizOuGHuZyuwRo=",
2820 | "dev": true,
2821 | "requires": {
2822 | "crypto-random-string": "^1.0.0"
2823 | }
2824 | },
2825 | "unpipe": {
2826 | "version": "1.0.0",
2827 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
2828 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw="
2829 | },
2830 | "unset-value": {
2831 | "version": "1.0.0",
2832 | "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz",
2833 | "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=",
2834 | "dev": true,
2835 | "requires": {
2836 | "has-value": "^0.3.1",
2837 | "isobject": "^3.0.0"
2838 | },
2839 | "dependencies": {
2840 | "has-value": {
2841 | "version": "0.3.1",
2842 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz",
2843 | "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=",
2844 | "dev": true,
2845 | "requires": {
2846 | "get-value": "^2.0.3",
2847 | "has-values": "^0.1.4",
2848 | "isobject": "^2.0.0"
2849 | },
2850 | "dependencies": {
2851 | "isobject": {
2852 | "version": "2.1.0",
2853 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz",
2854 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=",
2855 | "dev": true,
2856 | "requires": {
2857 | "isarray": "1.0.0"
2858 | }
2859 | }
2860 | }
2861 | },
2862 | "has-values": {
2863 | "version": "0.1.4",
2864 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz",
2865 | "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=",
2866 | "dev": true
2867 | }
2868 | }
2869 | },
2870 | "unzip-response": {
2871 | "version": "2.0.1",
2872 | "resolved": "https://registry.npmjs.org/unzip-response/-/unzip-response-2.0.1.tgz",
2873 | "integrity": "sha1-0vD3N9FrBhXnKmk17QQhRXLVb5c=",
2874 | "dev": true
2875 | },
2876 | "upath": {
2877 | "version": "1.2.0",
2878 | "resolved": "https://registry.npmjs.org/upath/-/upath-1.2.0.tgz",
2879 | "integrity": "sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg==",
2880 | "dev": true
2881 | },
2882 | "update-notifier": {
2883 | "version": "2.5.0",
2884 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-2.5.0.tgz",
2885 | "integrity": "sha512-gwMdhgJHGuj/+wHJJs9e6PcCszpxR1b236igrOkUofGhqJuG+amlIKwApH1IW1WWl7ovZxsX49lMBWLxSdm5Dw==",
2886 | "dev": true,
2887 | "requires": {
2888 | "boxen": "^1.2.1",
2889 | "chalk": "^2.0.1",
2890 | "configstore": "^3.0.0",
2891 | "import-lazy": "^2.1.0",
2892 | "is-ci": "^1.0.10",
2893 | "is-installed-globally": "^0.1.0",
2894 | "is-npm": "^1.0.0",
2895 | "latest-version": "^3.0.0",
2896 | "semver-diff": "^2.0.0",
2897 | "xdg-basedir": "^3.0.0"
2898 | }
2899 | },
2900 | "urix": {
2901 | "version": "0.1.0",
2902 | "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz",
2903 | "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=",
2904 | "dev": true
2905 | },
2906 | "url-parse-lax": {
2907 | "version": "1.0.0",
2908 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-1.0.0.tgz",
2909 | "integrity": "sha1-evjzA2Rem9eaJy56FKxovAYJ2nM=",
2910 | "dev": true,
2911 | "requires": {
2912 | "prepend-http": "^1.0.1"
2913 | }
2914 | },
2915 | "use": {
2916 | "version": "3.1.1",
2917 | "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz",
2918 | "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==",
2919 | "dev": true
2920 | },
2921 | "util-deprecate": {
2922 | "version": "1.0.2",
2923 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
2924 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=",
2925 | "dev": true
2926 | },
2927 | "utils-merge": {
2928 | "version": "1.0.1",
2929 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
2930 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM="
2931 | },
2932 | "vary": {
2933 | "version": "1.1.2",
2934 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
2935 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw="
2936 | },
2937 | "which": {
2938 | "version": "1.3.1",
2939 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz",
2940 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==",
2941 | "dev": true,
2942 | "requires": {
2943 | "isexe": "^2.0.0"
2944 | }
2945 | },
2946 | "widest-line": {
2947 | "version": "2.0.1",
2948 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-2.0.1.tgz",
2949 | "integrity": "sha512-Ba5m9/Fa4Xt9eb2ELXt77JxVDV8w7qQrH0zS/TWSJdLyAwQjWoOzpzj5lwVftDz6n/EOu3tNACS84v509qwnJA==",
2950 | "dev": true,
2951 | "requires": {
2952 | "string-width": "^2.1.1"
2953 | }
2954 | },
2955 | "write-file-atomic": {
2956 | "version": "2.4.3",
2957 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.4.3.tgz",
2958 | "integrity": "sha512-GaETH5wwsX+GcnzhPgKcKjJ6M2Cq3/iZp1WyY/X1CSqrW+jVNM9Y7D8EC2sM4ZG/V8wZlSniJnCKWPmBYAucRQ==",
2959 | "dev": true,
2960 | "requires": {
2961 | "graceful-fs": "^4.1.11",
2962 | "imurmurhash": "^0.1.4",
2963 | "signal-exit": "^3.0.2"
2964 | }
2965 | },
2966 | "xdg-basedir": {
2967 | "version": "3.0.0",
2968 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-3.0.0.tgz",
2969 | "integrity": "sha1-SWsswQnsqNus/i3HK2A8F8WHCtQ=",
2970 | "dev": true
2971 | },
2972 | "yallist": {
2973 | "version": "2.1.2",
2974 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz",
2975 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=",
2976 | "dev": true
2977 | }
2978 | }
2979 | }
2980 |
--------------------------------------------------------------------------------
/server/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "server",
3 | "version": "1.0.0",
4 | "description": "",
5 | "main": "index.js",
6 | "scripts": {
7 | "start": "nodemon src/index.js",
8 | "test": "echo \"Error: no test specified\" && exit 1"
9 | },
10 | "author": "Thomas Weibenfalk",
11 | "license": "ISC",
12 | "dependencies": {
13 | "bcryptjs": "^2.4.3",
14 | "cookie-parser": "^1.4.4",
15 | "cors": "^2.8.5",
16 | "dotenv": "^8.1.0",
17 | "express": "^4.17.1",
18 | "jsonwebtoken": "^8.5.1"
19 | },
20 | "devDependencies": {
21 | "nodemon": "^1.19.2"
22 | }
23 | }
24 |
--------------------------------------------------------------------------------
/server/src/fakeDB.js:
--------------------------------------------------------------------------------
1 | exports.fakeDB = [
2 | {
3 | id: 0,
4 | email: 'thomas.weibenfalk@gmail.com',
5 | password: '$2a$12$x5S4Bapkrv5YXnghtMqUjusW/lucAJLkO3.IJaajGtBnVrwXQ06u.', // Password: test
6 | },
7 | ];
8 |
--------------------------------------------------------------------------------
/server/src/index.js:
--------------------------------------------------------------------------------
1 | require('dotenv/config');
2 | const express = require('express');
3 | const cookieParser = require('cookie-parser');
4 | const cors = require('cors');
5 | const { verify } = require('jsonwebtoken');
6 | const { hash, compare } = require('bcryptjs');
7 | const {
8 | createAccessToken,
9 | createRefreshToken,
10 | sendRefreshToken,
11 | sendAccessToken,
12 | } = require('./tokens.js');
13 | const { fakeDB } = require('./fakeDB.js');
14 | const { isAuth } = require('./isAuth.js');
15 |
16 | // 1. Register a user
17 | // 2. Login a user
18 | // 3. Logout a user
19 | // 4. Setup a protected route
20 | // 5. Get a new accesstoken with a refresh token
21 |
22 | const server = express();
23 |
24 | // Use express middleware for easier cookie handling
25 | server.use(cookieParser());
26 |
27 | server.use(
28 | cors({
29 | origin: 'http://localhost:3000',
30 | credentials: true,
31 | }),
32 | );
33 |
34 | // Needed to be able to read body data
35 | server.use(express.json()); // to support JSON-encoded bodies
36 | server.use(express.urlencoded({ extended: true })); // to support URL-encoded bodies
37 |
38 | // 1. Register a user
39 | server.post('/register', async (req, res) => {
40 | const { email, password } = req.body;
41 |
42 | try {
43 | // 1. Check if the user exist
44 | const user = fakeDB.find(user => user.email === email);
45 | if (user) throw new Error('User already exist');
46 | // 2. If not user exist already, hash the password
47 | const hashedPassword = await hash(password, 10);
48 | // 3. Insert the user in "database"
49 | fakeDB.push({
50 | id: fakeDB.length,
51 | email,
52 | password: hashedPassword,
53 | });
54 | res.send({ message: 'User Created' });
55 | console.log(fakeDB);
56 | } catch (err) {
57 | res.send({
58 | error: `${err.message}`,
59 | });
60 | }
61 | });
62 |
63 | // 2. Login a user
64 | server.post('/login', async (req, res) => {
65 | const { email, password } = req.body;
66 |
67 | try {
68 | // 1. Find user in array. If not exist send error
69 | const user = fakeDB.find(user => user.email === email);
70 | if (!user) throw new Error('User does not exist');
71 | // 2. Compare crypted password and see if it checks out. Send error if not
72 | const valid = await compare(password, user.password);
73 | if (!valid) throw new Error('Password not correct');
74 | // 3. Create Refresh- and Accesstoken
75 | const accesstoken = createAccessToken(user.id);
76 | const refreshtoken = createRefreshToken(user.id);
77 | // 4. Store Refreshtoken with user in "db"
78 | // Could also use different version numbers instead.
79 | // Then just increase the version number on the revoke endpoint
80 | user.refreshtoken = refreshtoken;
81 | // 5. Send token. Refreshtoken as a cookie and accesstoken as a regular response
82 | sendRefreshToken(res, refreshtoken);
83 | sendAccessToken(res, req, accesstoken);
84 | } catch (err) {
85 | res.send({
86 | error: `${err.message}`,
87 | });
88 | }
89 | });
90 |
91 | // 3. Logout a user
92 | server.post('/logout', (_req, res) => {
93 | res.clearCookie('refreshtoken', { path: '/refresh_token' });
94 | // Logic here for also remove refreshtoken from db
95 | return res.send({
96 | message: 'Logged out',
97 | });
98 | });
99 |
100 | // 4. Protected route
101 | server.post('/protected', async (req, res) => {
102 | try {
103 | const userId = isAuth(req);
104 | if (userId !== null) {
105 | res.send({
106 | data: 'This is protected data.',
107 | });
108 | }
109 | } catch (err) {
110 | res.send({
111 | error: `${err.message}`,
112 | });
113 | }
114 | });
115 |
116 | // 5. Get a new access token with a refresh token
117 | server.post('/refresh_token', (req, res) => {
118 | const token = req.cookies.refreshtoken;
119 | // If we don't have a token in our request
120 | if (!token) return res.send({ accesstoken: '' });
121 | // We have a token, let's verify it!
122 | let payload = null;
123 | try {
124 | payload = verify(token, process.env.REFRESH_TOKEN_SECRET);
125 | } catch (err) {
126 | return res.send({ accesstoken: '' });
127 | }
128 | // token is valid, check if user exist
129 | const user = fakeDB.find(user => user.id === payload.userId);
130 | if (!user) return res.send({ accesstoken: '' });
131 | // user exist, check if refreshtoken exist on user
132 | if (user.refreshtoken !== token)
133 | return res.send({ accesstoken: '' });
134 | // token exist, create new Refresh- and accesstoken
135 | const accesstoken = createAccessToken(user.id);
136 | const refreshtoken = createRefreshToken(user.id);
137 | // update refreshtoken on user in db
138 | // Could have different versions instead!
139 | user.refreshtoken = refreshtoken;
140 | // All good to go, send new refreshtoken and accesstoken
141 | sendRefreshToken(res, refreshtoken);
142 | return res.send({ accesstoken });
143 | });
144 |
145 | server.listen(process.env.PORT, () =>
146 | console.log(`Server listening on port ${process.env.PORT}!`),
147 | );
148 |
--------------------------------------------------------------------------------
/server/src/isAuth.js:
--------------------------------------------------------------------------------
1 | const { verify } = require('jsonwebtoken');
2 |
3 | const isAuth = req => {
4 | const authorization = req.headers['authorization'];
5 | if (!authorization) throw new Error('You need to login.');
6 | // Based on 'Bearer ksfljrewori384328289398432'
7 | const token = authorization.split(' ')[1];
8 | const { userId } = verify(token, process.env.ACCESS_TOKEN_SECRET);
9 | return userId;
10 | };
11 |
12 | module.exports = {
13 | isAuth,
14 | };
15 |
--------------------------------------------------------------------------------
/server/src/tokens.js:
--------------------------------------------------------------------------------
1 | const { sign } = require('jsonwebtoken');
2 |
3 | // Create tokens
4 | // ----------------------------------
5 | const createAccessToken = userId => {
6 | return sign({ userId }, process.env.ACCESS_TOKEN_SECRET, {
7 | expiresIn: '15m',
8 | });
9 | };
10 |
11 | const createRefreshToken = userId => {
12 | return sign({ userId }, process.env.REFRESH_TOKEN_SECRET, {
13 | expiresIn: '7d',
14 | });
15 | };
16 |
17 | // Send tokens
18 | // ----------------------------------
19 | const sendAccessToken = (res, req, accesstoken) => {
20 | res.send({
21 | accesstoken,
22 | email: req.body.email,
23 | });
24 | };
25 |
26 | const sendRefreshToken = (res, token) => {
27 | res.cookie('refreshtoken', token, {
28 | httpOnly: true,
29 | path: '/refresh_token',
30 | });
31 | };
32 |
33 | module.exports = {
34 | createAccessToken,
35 | createRefreshToken,
36 | sendAccessToken,
37 | sendRefreshToken
38 | };
--------------------------------------------------------------------------------