├── .gitignore
├── .vscode
└── launch.json
├── authenticate.js
├── client
├── .gitignore
├── README.md
├── package.json
├── public
│ ├── favicon.ico
│ ├── index.html
│ └── manifest.json
├── src
│ ├── components
│ │ ├── App.css
│ │ ├── App.js
│ │ ├── App.test.js
│ │ ├── Test.js
│ │ ├── navigation
│ │ │ └── Navigation.js
│ │ └── transaction
│ │ │ ├── CrerateTransaction.js
│ │ │ └── UpdateTransaction.js
│ ├── index.css
│ ├── index.js
│ ├── pages
│ │ ├── Dashboard.js
│ │ ├── Home.js
│ │ ├── Login.js
│ │ └── Register.js
│ ├── serviceWorker.js
│ ├── store
│ │ ├── actions
│ │ │ ├── authActions.js
│ │ │ ├── transactionActions.js
│ │ │ └── types.js
│ │ ├── index.js
│ │ └── reducers
│ │ │ ├── authReducer.js
│ │ │ ├── rootReducer.js
│ │ │ └── transactionReducer.js
│ └── utils
│ │ └── setAuthToken.js
└── yarn.lock
├── controllers
├── transactionController.js
└── userController.js
├── model
├── Transaction.js
└── User.js
├── package-lock.json
├── package.json
├── passport.js
├── routers
├── transactionRoute.js
└── userRoute.js
├── server.js
├── util
└── error.js
└── validator
├── loginValidator.js
└── registerValidator.js
/.gitignore:
--------------------------------------------------------------------------------
1 | /node_modules
--------------------------------------------------------------------------------
/.vscode/launch.json:
--------------------------------------------------------------------------------
1 | {
2 | // Use IntelliSense to learn about possible attributes.
3 | // Hover to view descriptions of existing attributes.
4 | // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
5 | "version": "0.2.0",
6 | "configurations": [
7 | {
8 | "type": "node",
9 | "request": "launch",
10 | "name": "Launch Program",
11 | "program": "${workspaceFolder}/server.js"
12 | }
13 | ]
14 | }
--------------------------------------------------------------------------------
/authenticate.js:
--------------------------------------------------------------------------------
1 | const passport = require('passport')
2 |
3 | module.exports = (req, res, next) => {
4 | passport.authenticate('jwt', (err, user, info) => {
5 | if (err) {
6 | console.log(info)
7 | console.log(err)
8 | return next(err)
9 | }
10 |
11 | if (!user) {
12 | return res.status(400).json({
13 | message: 'Authentication Failed'
14 | })
15 | }
16 |
17 | req.user = user
18 | return next()
19 | })(req, res, next)
20 | }
--------------------------------------------------------------------------------
/client/.gitignore:
--------------------------------------------------------------------------------
1 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
2 |
3 | # dependencies
4 | /node_modules
5 | /.pnp
6 | .pnp.js
7 |
8 | # testing
9 | /coverage
10 |
11 | # production
12 | /build
13 |
14 | # misc
15 | .DS_Store
16 | .env.local
17 | .env.development.local
18 | .env.test.local
19 | .env.production.local
20 |
21 | npm-debug.log*
22 | yarn-debug.log*
23 | yarn-error.log*
24 |
--------------------------------------------------------------------------------
/client/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 | ### `npm start`
8 |
9 | Runs the app in the development mode.
10 | Open [http://localhost:3000](http://localhost:3000) to view it in the browser.
11 |
12 | The page will reload if you make edits.
13 | You will also see any lint errors in the console.
14 |
15 | ### `npm test`
16 |
17 | Launches the test runner in the interactive watch mode.
18 | See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information.
19 |
20 | ### `npm run build`
21 |
22 | Builds the app for production to the `build` folder.
23 | It correctly bundles React in production mode and optimizes the build for the best performance.
24 |
25 | The build is minified and the filenames include the hashes.
26 | Your app is ready to be deployed!
27 |
28 | See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information.
29 |
30 | ### `npm run eject`
31 |
32 | **Note: this is a one-way operation. Once you `eject`, you can’t go back!**
33 |
34 | If you aren’t satisfied with the build tool and configuration choices, you can `eject` at any time. This command will remove the single build dependency from your project.
35 |
36 | Instead, it will copy all the configuration files and the transitive dependencies (Webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except `eject` will still work, but they will point to the copied scripts so you can tweak them. At this point you’re on your own.
37 |
38 | You don’t have to ever use `eject`. The curated feature set is suitable for small and middle deployments, and you shouldn’t feel obligated to use this feature. However we understand that this tool wouldn’t be useful if you couldn’t customize it when you are ready for it.
39 |
40 | ## Learn More
41 |
42 | You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started).
43 |
44 | To learn React, check out the [React documentation](https://reactjs.org/).
45 |
--------------------------------------------------------------------------------
/client/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "client",
3 | "version": "0.1.0",
4 | "private": true,
5 | "dependencies": {
6 | "axios": "^0.18.0",
7 | "react": "^16.6.3",
8 | "react-dom": "^16.6.3",
9 | "react-modal": "^3.8.1",
10 | "react-redux": "^6.0.0",
11 | "react-router-dom": "^4.3.1",
12 | "react-scripts": "2.1.1",
13 | "redux": "^4.0.1",
14 | "redux-thunk": "^2.3.0"
15 | },
16 | "scripts": {
17 | "start": "react-scripts start",
18 | "build": "react-scripts build",
19 | "test": "react-scripts test",
20 | "eject": "react-scripts eject"
21 | },
22 | "eslintConfig": {
23 | "extends": "react-app"
24 | },
25 | "browserslist": [
26 | ">0.2%",
27 | "not dead",
28 | "not ie <= 11",
29 | "not op_mini all"
30 | ],
31 | "proxy": "http://localhost:4000"
32 | }
33 |
--------------------------------------------------------------------------------
/client/public/favicon.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/mrhm-dev/money-management-app-tutorial/0e9aafdd2986bbd8b5746458c6f6d8cf0736ec44/client/public/favicon.ico
--------------------------------------------------------------------------------
/client/public/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
12 |
13 |
22 | Money Management App - Fullstack
23 |
24 |
25 |
26 |
27 |
30 |
31 |
41 |
42 |
43 |
--------------------------------------------------------------------------------
/client/public/manifest.json:
--------------------------------------------------------------------------------
1 | {
2 | "short_name": "React App",
3 | "name": "Create React App Sample",
4 | "icons": [
5 | {
6 | "src": "favicon.ico",
7 | "sizes": "64x64 32x32 24x24 16x16",
8 | "type": "image/x-icon"
9 | }
10 | ],
11 | "start_url": ".",
12 | "display": "standalone",
13 | "theme_color": "#000000",
14 | "background_color": "#ffffff"
15 | }
16 |
--------------------------------------------------------------------------------
/client/src/components/App.css:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/mrhm-dev/money-management-app-tutorial/0e9aafdd2986bbd8b5746458c6f6d8cf0736ec44/client/src/components/App.css
--------------------------------------------------------------------------------
/client/src/components/App.js:
--------------------------------------------------------------------------------
1 | import React, { Component } from 'react';
2 | import './App.css';
3 | import { BrowserRouter, Route, Switch } from 'react-router-dom'
4 |
5 | import Home from '../pages/Home'
6 | import Login from '../pages/Login'
7 | import Register from '../pages/Register'
8 | import Dashboard from '../pages/Dashboard'
9 | import Navigation from './navigation/Navigation'
10 |
11 | class App extends Component {
12 | render() {
13 | return (
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 | );
26 | }
27 | }
28 |
29 | export default App;
30 |
--------------------------------------------------------------------------------
/client/src/components/App.test.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import ReactDOM from 'react-dom';
3 | import App from './App';
4 |
5 | it('renders without crashing', () => {
6 | const div = document.createElement('div');
7 | ReactDOM.render(, div);
8 | ReactDOM.unmountComponentAtNode(div);
9 | });
10 |
--------------------------------------------------------------------------------
/client/src/components/Test.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 |
3 | class Test extends React.Component {
4 |
5 | render() {
6 | return (
7 |
8 |
Amount : {this.props.amount}
9 |
Note: {this.props.note}
10 |
11 | )
12 | }
13 | }
14 |
15 | export default Test
--------------------------------------------------------------------------------
/client/src/components/navigation/Navigation.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import { Link, NavLink, withRouter } from 'react-router-dom'
3 | import { connect } from 'react-redux'
4 | import {logout} from '../../store/actions/authActions'
5 |
6 | class Navigation extends React.Component {
7 |
8 | render() {
9 | return (
10 |
71 | )
72 | }
73 | }
74 |
75 | const mapStateToProps = state => ({
76 | auth: state.auth
77 | })
78 |
79 | export default connect(mapStateToProps, {logout})(withRouter(Navigation))
--------------------------------------------------------------------------------
/client/src/components/transaction/CrerateTransaction.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import Modal from 'react-modal'
3 | import { connect } from 'react-redux'
4 | import { addNewTransaction } from '../../store/actions/transactionActions'
5 |
6 |
7 | const customStyles = {
8 | content : {
9 | top : '50%',
10 | left : '50%',
11 | right : 'auto',
12 | bottom : 'auto',
13 | marginRight : '-50%',
14 | transform: 'translate(-50%, -50%)',
15 | width: '500px'
16 | }
17 | };
18 |
19 |
20 | class CreateTransaction extends React.Component {
21 |
22 | state = {
23 | amount: 0,
24 | type: '',
25 | note: ''
26 | }
27 |
28 | changeHandler = event => {
29 | this.setState({
30 | [event.target.name]: event.target.value
31 | })
32 | }
33 |
34 | submitHandler = event => {
35 | event.preventDefault()
36 | this.props.addNewTransaction(this.state)
37 | this.setState({
38 | amount: 0,
39 | type: '',
40 | note: ''
41 | })
42 | }
43 |
44 | render() {
45 | let { amount, note } = this.state
46 | return (
47 |
53 | Create A New Transaction
54 |
93 |
94 | )
95 | }
96 | }
97 |
98 | export default connect(null, { addNewTransaction })(CreateTransaction)
99 |
100 | // amount
101 | // Type
102 | // Note
--------------------------------------------------------------------------------
/client/src/components/transaction/UpdateTransaction.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import Modal from 'react-modal'
3 | import { connect } from 'react-redux'
4 | import { updateTransaction } from '../../store/actions/transactionActions'
5 |
6 |
7 | const customStyles = {
8 | content : {
9 | top : '50%',
10 | left : '50%',
11 | right : 'auto',
12 | bottom : 'auto',
13 | marginRight : '-50%',
14 | transform: 'translate(-50%, -50%)',
15 | width: '500px'
16 | }
17 | };
18 |
19 |
20 | class UpdateTransaction extends React.Component {
21 |
22 | state = {
23 | amount: 0,
24 | note: ''
25 | }
26 |
27 | componentDidMount() {
28 | this.setState({
29 | amount: this.props.transaction.amount,
30 | note: this.props.transaction.note
31 | })
32 | }
33 |
34 | changeHandler = event => {
35 | this.setState({
36 | [event.target.name]: event.target.value
37 | })
38 | }
39 |
40 | submitHandler = event => {
41 | event.preventDefault()
42 | this.props.updateTransaction(this.props.transaction._id, this.state)
43 | this.props.close()
44 | }
45 |
46 | render() {
47 | let { amount, note } = this.state
48 | return (
49 |
55 | Create A New Transaction
56 |
82 |
83 | )
84 | }
85 | }
86 |
87 | export default connect(null, { updateTransaction })(UpdateTransaction)
88 |
89 | // amount
90 | // Type
91 | // Note
--------------------------------------------------------------------------------
/client/src/index.css:
--------------------------------------------------------------------------------
1 | body {
2 | margin: 0;
3 | padding: 0;
4 | font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen",
5 | "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue",
6 | sans-serif;
7 | -webkit-font-smoothing: antialiased;
8 | -moz-osx-font-smoothing: grayscale;
9 | }
10 |
11 | code {
12 | font-family: source-code-pro, Menlo, Monaco, Consolas, "Courier New",
13 | monospace;
14 | }
15 |
--------------------------------------------------------------------------------
/client/src/index.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import ReactDOM from 'react-dom';
3 | import jwtDecode from 'jwt-decode'
4 | import './index.css';
5 | import App from './components/App';
6 | import * as serviceWorker from './serviceWorker';
7 | import { Provider } from 'react-redux'
8 | import store from './store'
9 | import * as Types from './store/actions/types'
10 | import setAuthToken from './utils/setAuthToken'
11 |
12 | const token = localStorage.getItem('auth_token')
13 | if (token) {
14 | let decode = jwtDecode(token)
15 | setAuthToken(token)
16 | store.dispatch({
17 | type: Types.SET_USER,
18 | payload: {
19 | user: decode
20 | }
21 | })
22 | }
23 |
24 | ReactDOM.render(
25 |
26 |
27 | , document.getElementById('root'));
28 |
29 | // If you want your app to work offline and load faster, you can change
30 | // unregister() to register() below. Note this comes with some pitfalls.
31 | // Learn more about service workers: http://bit.ly/CRA-PWA
32 | serviceWorker.unregister();
33 |
--------------------------------------------------------------------------------
/client/src/pages/Dashboard.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import { connect } from 'react-redux'
3 | import { loadTransactions, removeTransaction } from '../store/actions/transactionActions'
4 | import CreateTransaction from '../components/transaction/CrerateTransaction'
5 | import UpdateTransaction from '../components/transaction/UpdateTransaction'
6 |
7 |
8 | class Dashboard extends React.Component {
9 |
10 | state = {
11 | createModalOpen: false,
12 | updateModalOpen: false,
13 | id: ''
14 | }
15 |
16 | openCreateModal = () => {
17 | this.setState({
18 | createModalOpen: true
19 | })
20 | }
21 |
22 | closeCreateModal = () => {
23 | this.setState({
24 | createModalOpen: false
25 | })
26 | }
27 |
28 | openUpdateModal = (id) => {
29 | this.setState({
30 | updateModalOpen: true,
31 | id
32 | })
33 | }
34 |
35 | closeUpdateModal = () => {
36 | this.setState({
37 | updateModalOpen: false,
38 | id: ''
39 | })
40 | }
41 |
42 |
43 | componentDidMount() {
44 | this.props.loadTransactions()
45 | }
46 |
47 | render() {
48 | let {auth, transactions} = this.props
49 | return (
50 |
51 |
52 |
Welcome {auth.user.name}
53 |
You Email is {auth.user.email}
54 |
55 |
61 |
65 |
66 |
Transactions:
67 | {transactions.length > 0 ?
:
There is no transaction
}
79 |
80 |
81 | )
82 | }
83 | }
84 |
85 | const mapStateToProps = state => ({
86 | auth: state.auth,
87 | transactions: state.transactions
88 | })
89 |
90 | export default connect(mapStateToProps, { loadTransactions, removeTransaction })(Dashboard)
--------------------------------------------------------------------------------
/client/src/pages/Home.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import { connect } from 'react-redux'
3 | import { Link } from 'react-router-dom'
4 | import { logout } from '../store/actions/authActions'
5 |
6 | class Home extends React.Component {
7 | render() {
8 | return (
9 |
10 |
I am Home
11 | {
12 | this.props.auth.isAuthenticated ?
13 | :
19 |
20 | }
21 |
22 | )
23 | }
24 | }
25 |
26 | const mapStateToProps = state => ({
27 | auth: state.auth
28 | })
29 |
30 | export default connect(mapStateToProps, {logout})(Home)
--------------------------------------------------------------------------------
/client/src/pages/Login.js:
--------------------------------------------------------------------------------
1 | import React from 'react'
2 | import { Link } from 'react-router-dom'
3 | import {connect} from 'react-redux'
4 | import {login} from '../store/actions/authActions'
5 |
6 | class Login extends React.Component {
7 | state = {
8 | email: '',
9 | password: '',
10 | error: {}
11 | }
12 |
13 | static getDerivedStateFromProps(nextProps, prevState) {
14 | if (
15 | JSON.stringify(nextProps.auth.error) !== JSON.stringify(prevState.error)
16 | ) {
17 | return {
18 | error: nextProps.auth.error
19 | };
20 | }
21 | return null;
22 | }
23 |
24 | changeHandler = event => {
25 | this.setState({
26 | [event.target.name]: event.target.value
27 | })
28 | }
29 |
30 | submitHandler = event => {
31 | event.preventDefault()
32 | this.props.login({
33 | email: this.state.email,
34 | password: this.state.password
35 | }, this.props.history)
36 | }
37 |
38 | render() {
39 | let { email, password, error } = this.state
40 | return (
41 |
42 |
43 |
Login Here
44 |
82 |
83 |
84 | )
85 | }
86 | }
87 |
88 | const mapStateToProps = state => ({
89 | auth: state.auth
90 | })
91 |
92 | export default connect(mapStateToProps, {login})(Login)
--------------------------------------------------------------------------------
/client/src/pages/Register.js:
--------------------------------------------------------------------------------
1 | import React from "react";
2 | import { Link } from "react-router-dom";
3 | import { connect } from "react-redux";
4 | import { register } from "../store/actions/authActions";
5 |
6 | class Register extends React.Component {
7 | state = {
8 | name: "",
9 | email: "",
10 | password: "",
11 | confirmPassword: "",
12 | error: {}
13 | };
14 |
15 | static getDerivedStateFromProps(nextProps, prevState) {
16 | if (
17 | JSON.stringify(nextProps.auth.error) !== JSON.stringify(prevState.error)
18 | ) {
19 | return {
20 | error: nextProps.auth.error
21 | };
22 | }
23 | return null;
24 | }
25 |
26 | changeHandler = event => {
27 | this.setState({
28 | [event.target.name]: event.target.value
29 | });
30 | };
31 |
32 | submitHandler = event => {
33 | event.preventDefault();
34 | let { name, email, password, confirmPassword } = this.state;
35 | this.props.register(
36 | { name, email, password, confirmPassword },
37 | this.props.history
38 | );
39 | };
40 |
41 | render() {
42 | let { name, email, password, confirmPassword, error } = this.state;
43 | return (
44 |
45 |
46 |
Register Here
47 |
121 |
122 |
123 | );
124 | }
125 | }
126 |
127 | const mapStateToProps = state => ({
128 | auth: state.auth
129 | });
130 |
131 | export default connect(
132 | mapStateToProps,
133 | { register }
134 | )(Register);
135 |
--------------------------------------------------------------------------------
/client/src/serviceWorker.js:
--------------------------------------------------------------------------------
1 | // This optional code is used to register a service worker.
2 | // register() is not called by default.
3 |
4 | // This lets the app load faster on subsequent visits in production, and gives
5 | // it offline capabilities. However, it also means that developers (and users)
6 | // will only see deployed updates on subsequent visits to a page, after all the
7 | // existing tabs open on the page have been closed, since previously cached
8 | // resources are updated in the background.
9 |
10 | // To learn more about the benefits of this model and instructions on how to
11 | // opt-in, read http://bit.ly/CRA-PWA
12 |
13 | const isLocalhost = Boolean(
14 | window.location.hostname === 'localhost' ||
15 | // [::1] is the IPv6 localhost address.
16 | window.location.hostname === '[::1]' ||
17 | // 127.0.0.1/8 is considered localhost for IPv4.
18 | window.location.hostname.match(
19 | /^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/
20 | )
21 | );
22 |
23 | export function register(config) {
24 | if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {
25 | // The URL constructor is available in all browsers that support SW.
26 | const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);
27 | if (publicUrl.origin !== window.location.origin) {
28 | // Our service worker won't work if PUBLIC_URL is on a different origin
29 | // from what our page is served on. This might happen if a CDN is used to
30 | // serve assets; see https://github.com/facebook/create-react-app/issues/2374
31 | return;
32 | }
33 |
34 | window.addEventListener('load', () => {
35 | const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;
36 |
37 | if (isLocalhost) {
38 | // This is running on localhost. Let's check if a service worker still exists or not.
39 | checkValidServiceWorker(swUrl, config);
40 |
41 | // Add some additional logging to localhost, pointing developers to the
42 | // service worker/PWA documentation.
43 | navigator.serviceWorker.ready.then(() => {
44 | console.log(
45 | 'This web app is being served cache-first by a service ' +
46 | 'worker. To learn more, visit http://bit.ly/CRA-PWA'
47 | );
48 | });
49 | } else {
50 | // Is not localhost. Just register service worker
51 | registerValidSW(swUrl, config);
52 | }
53 | });
54 | }
55 | }
56 |
57 | function registerValidSW(swUrl, config) {
58 | navigator.serviceWorker
59 | .register(swUrl)
60 | .then(registration => {
61 | registration.onupdatefound = () => {
62 | const installingWorker = registration.installing;
63 | if (installingWorker == null) {
64 | return;
65 | }
66 | installingWorker.onstatechange = () => {
67 | if (installingWorker.state === 'installed') {
68 | if (navigator.serviceWorker.controller) {
69 | // At this point, the updated precached content has been fetched,
70 | // but the previous service worker will still serve the older
71 | // content until all client tabs are closed.
72 | console.log(
73 | 'New content is available and will be used when all ' +
74 | 'tabs for this page are closed. See http://bit.ly/CRA-PWA.'
75 | );
76 |
77 | // Execute callback
78 | if (config && config.onUpdate) {
79 | config.onUpdate(registration);
80 | }
81 | } else {
82 | // At this point, everything has been precached.
83 | // It's the perfect time to display a
84 | // "Content is cached for offline use." message.
85 | console.log('Content is cached for offline use.');
86 |
87 | // Execute callback
88 | if (config && config.onSuccess) {
89 | config.onSuccess(registration);
90 | }
91 | }
92 | }
93 | };
94 | };
95 | })
96 | .catch(error => {
97 | console.error('Error during service worker registration:', error);
98 | });
99 | }
100 |
101 | function checkValidServiceWorker(swUrl, config) {
102 | // Check if the service worker can be found. If it can't reload the page.
103 | fetch(swUrl)
104 | .then(response => {
105 | // Ensure service worker exists, and that we really are getting a JS file.
106 | const contentType = response.headers.get('content-type');
107 | if (
108 | response.status === 404 ||
109 | (contentType != null && contentType.indexOf('javascript') === -1)
110 | ) {
111 | // No service worker found. Probably a different app. Reload the page.
112 | navigator.serviceWorker.ready.then(registration => {
113 | registration.unregister().then(() => {
114 | window.location.reload();
115 | });
116 | });
117 | } else {
118 | // Service worker found. Proceed as normal.
119 | registerValidSW(swUrl, config);
120 | }
121 | })
122 | .catch(() => {
123 | console.log(
124 | 'No internet connection found. App is running in offline mode.'
125 | );
126 | });
127 | }
128 |
129 | export function unregister() {
130 | if ('serviceWorker' in navigator) {
131 | navigator.serviceWorker.ready.then(registration => {
132 | registration.unregister();
133 | });
134 | }
135 | }
136 |
--------------------------------------------------------------------------------
/client/src/store/actions/authActions.js:
--------------------------------------------------------------------------------
1 | import Axios from 'axios'
2 | import jwtDecode from 'jwt-decode'
3 | import * as Types from './types'
4 | import setAuthToken from '../../utils/setAuthToken'
5 |
6 | export const register = (user, history) => dispatch => {
7 | Axios.post('/api/users/register', user)
8 | .then((res) => {
9 | dispatch({
10 | type: Types.USERS_ERROR,
11 | payload: {
12 | error: {}
13 | }
14 | })
15 | console.log(res)
16 | history.push('/login')
17 | })
18 | .catch(error => {
19 | dispatch({
20 | type: Types.USERS_ERROR,
21 | payload: {
22 | error: error.response.data
23 | }
24 | })
25 | })
26 | }
27 |
28 | export const login = (user, history) => dispatch => {
29 | Axios.post('/api/users/login', user)
30 | .then(res => {
31 | let token = res.data.token
32 | localStorage.setItem('auth_token', token)
33 | setAuthToken(token)
34 | let decode = jwtDecode(token)
35 |
36 | dispatch({
37 | type: Types.SET_USER,
38 | payload: {
39 | user: decode
40 | }
41 | })
42 | history.push('/dashboard')
43 | })
44 | .catch(error => {
45 | console.log(error.response.data)
46 | dispatch({
47 | type: Types.USERS_ERROR,
48 | payload: {
49 | error: error.response.data
50 | }
51 | })
52 | })
53 | }
54 |
55 | export const logout = history => {
56 | localStorage.removeItem('auth_token')
57 | history.push('/login')
58 | return {
59 | type: Types.SET_USER,
60 | payload: {
61 | user: {}
62 | }
63 | }
64 | }
--------------------------------------------------------------------------------
/client/src/store/actions/transactionActions.js:
--------------------------------------------------------------------------------
1 | import Axios from 'axios'
2 |
3 | import * as Types from './types'
4 |
5 | export const loadTransactions = () => dispatch => {
6 | Axios.get('/api/transactions/')
7 | .then(response => {
8 | dispatch({
9 | type: Types.LOAD_TRANSACTIONS,
10 | payload: {
11 | transactions: response.data
12 | }
13 | })
14 | })
15 | .catch(error => {
16 | console.log(error)
17 | })
18 | }
19 |
20 | export const addNewTransaction = transaction => dispatch => {
21 | Axios.post('/api/transactions/', transaction)
22 | .then(response => {
23 | console.log(response)
24 | dispatch({type: Types.CREATE_TRANSACTION, payload: { transaction: response.data}})
25 | })
26 | .catch(error => {
27 | console.log(error)
28 | })
29 | }
30 |
31 | export const removeTransaction = id => dispatch => {
32 |
33 | Axios.delete(`/api/transactions/${id}`)
34 | .then(response => {
35 | dispatch({type: Types.REMOVE_TRANSACTION, payload: {id: response.data._id}})
36 | })
37 | .catch(error => {
38 | console.log(error)
39 | })
40 | }
41 |
42 | export const updateTransaction = (id, transaction) => dispatch => {
43 | Axios.put(`/api/transactions/${id}`, transaction)
44 | .then(response => {
45 | dispatch({type: Types.UPDATE_TRANSACTION, payload: {transaction: response.data.transaction}})
46 | })
47 | .catch(error => {
48 | console.log(error)
49 | })
50 | }
--------------------------------------------------------------------------------
/client/src/store/actions/types.js:
--------------------------------------------------------------------------------
1 | export const SET_USER = 'SET_USER'
2 | export const USERS_ERROR = 'USERS_ERROR'
3 | export const LOAD_TRANSACTIONS = 'LOAD_TRANSACTIONS'
4 | export const CREATE_TRANSACTION = 'CREATE_TRANSACTION'
5 | export const REMOVE_TRANSACTION = 'REMOVE_TRANSACTION'
6 | export const UPDATE_TRANSACTION = 'UPDATE_TRANSACTION'
7 |
8 |
--------------------------------------------------------------------------------
/client/src/store/index.js:
--------------------------------------------------------------------------------
1 | import { createStore, compose, applyMiddleware } from 'redux'
2 | import rootReducer from './reducers/rootReducer'
3 | import thunk from 'redux-thunk'
4 |
5 | const middleware = [thunk]
6 |
7 | const store = createStore(rootReducer, compose(
8 | applyMiddleware(...middleware),
9 | window.__REDUX_DEVTOOLS_EXTENSION__ && window.__REDUX_DEVTOOLS_EXTENSION__()
10 | ))
11 |
12 | export default store
13 |
--------------------------------------------------------------------------------
/client/src/store/reducers/authReducer.js:
--------------------------------------------------------------------------------
1 | import * as Types from '../actions/types'
2 |
3 | const init = {
4 | isAuthenticated: false,
5 | user: {},
6 | error: {}
7 | }
8 |
9 | const authReducer = (state=init, action) => {
10 | switch (action.type) {
11 | case Types.SET_USER: {
12 | return {
13 | user: action.payload.user,
14 | isAuthenticated: Object.keys(action.payload.user).length !== 0,
15 | error: {}
16 | }
17 | }
18 | case Types.USERS_ERROR: {
19 | return {
20 | ...state,
21 | error: action.payload.error
22 | }
23 | }
24 | default: return state
25 | }
26 | }
27 |
28 | export default authReducer
--------------------------------------------------------------------------------
/client/src/store/reducers/rootReducer.js:
--------------------------------------------------------------------------------
1 | import { combineReducers } from 'redux'
2 | import authReducer from './authReducer'
3 | import transactionReducer from './transactionReducer'
4 |
5 | const rootReducer = combineReducers({
6 | auth: authReducer,
7 | transactions: transactionReducer
8 | })
9 |
10 | export default rootReducer
--------------------------------------------------------------------------------
/client/src/store/reducers/transactionReducer.js:
--------------------------------------------------------------------------------
1 | import * as Types from '../actions/types'
2 |
3 | const transactionReducer = (state = [], action) => {
4 | switch (action.type) {
5 | case Types.LOAD_TRANSACTIONS: {
6 | return action.payload.transactions
7 | }
8 | case Types.CREATE_TRANSACTION: {
9 | let transactions = [...state]
10 | transactions.unshift(action.payload.transaction)
11 | return transactions
12 | }
13 | case Types.REMOVE_TRANSACTION: {
14 | let transactions = [...state]
15 | return transactions.filter(tran => {
16 | return tran._id !== action.payload.id
17 | })
18 | }
19 | case Types.UPDATE_TRANSACTION: {
20 | let transactions = [...state]
21 | return transactions.map(tran => {
22 | if (tran._id === action.payload.transaction._id) {
23 | return action.payload.transaction
24 | }
25 | return tran
26 | })
27 | }
28 | default: return state
29 | }
30 | }
31 |
32 | export default transactionReducer
--------------------------------------------------------------------------------
/client/src/utils/setAuthToken.js:
--------------------------------------------------------------------------------
1 | import Axios from 'axios'
2 | const setAuthToken = token => {
3 | if (token) {
4 | Axios.defaults.headers.common['Authorization'] = token
5 | } else {
6 | Axios.defaults.headers.common['Authorization'] = ''
7 | }
8 | }
9 |
10 | export default setAuthToken
--------------------------------------------------------------------------------
/controllers/transactionController.js:
--------------------------------------------------------------------------------
1 | const Transaction = require('../model/Transaction')
2 | const User = require('../model/User')
3 | const {serverError} = require('../util/error')
4 |
5 | module.exports = {
6 | create(req, res, next) {
7 | let { amount, note, type } = req.body
8 | let userId = req.user._id
9 |
10 | let transaction = new Transaction({
11 | amount, note, type, author: userId
12 | })
13 |
14 | transaction.save()
15 | .then(trans => {
16 | let updatedUser = { ...req.user._doc }
17 | if (type === 'income') {
18 | updatedUser.balance = updatedUser.balance + amount
19 | updatedUser.income = updatedUser.income + amount
20 | } else if (type === 'expense') {
21 | updatedUser.balance = updatedUser.balance - amount
22 | updatedUser.expense = updatedUser.expense + amount
23 | }
24 | updatedUser.transactions.unshift(trans._id)
25 |
26 | User.findByIdAndUpdate(updatedUser._id, { $set: updatedUser }, { new: true })
27 | .then(result => {
28 | res.status(201).json({
29 | message: 'Transaction Created Successfully',
30 | ...trans._doc,
31 | user: result
32 | })
33 | })
34 | .catch(error => serverError(res, error))
35 |
36 | })
37 | .catch(error => serverError(res, error))
38 | },
39 | getAll(req, res) {
40 | let {_id} = req.user
41 | Transaction.find({author: _id})
42 | .then(transactions => {
43 | if (transactions.length === 0) {
44 | res.status(200).json({
45 | message: 'No Transaction Found'
46 | })
47 | } else {
48 | res.status(200).json(transactions)
49 | }
50 | })
51 | .catch(error => serverError(res, error))
52 | },
53 | getSingleTransaction(req, res) {
54 | let { transactionId } = req.params
55 | Transaction.findById(transactionId)
56 | .then(transaction => {
57 | if (!transaction) {
58 | res.status(200).json({
59 | message: 'No Transaction Found'
60 | })
61 | } else {
62 | res.status(200).json(transaction)
63 | }
64 | })
65 | .catch(error => serverError(res, error))
66 | },
67 | update(req, res) {
68 | let { transactionId } = req.params
69 | Transaction.findOneAndUpdate({ _id: transactionId }, { $set: req.body }, {new: true})
70 | .then(result => {
71 | res.status(200).json({
72 | message: 'Updated Successfully',
73 | transaction: result
74 | })
75 | })
76 | .catch(error => serverError(res, error))
77 | },
78 | remove(req, res) {
79 | let { transactionId } = req.params
80 | Transaction.findOneAndDelete({ _id: transactionId })
81 | .then(result => {
82 | res.status(200).json({
83 | message: 'Deleted Successfully',
84 | ...result._doc
85 | })
86 | })
87 | .catch(error => serverError(res, error))
88 | }
89 | }
--------------------------------------------------------------------------------
/controllers/userController.js:
--------------------------------------------------------------------------------
1 | const bcrypt = require('bcrypt')
2 | const jwt = require('jsonwebtoken')
3 | const registerValidator = require('../validator/registerValidator')
4 | const loginValidator = require('../validator/loginValidator')
5 | const User = require('../model/User')
6 | const {serverError, resourceError} = require('../util/error')
7 |
8 | // login controller
9 | module.exports = {
10 | login(req, res) {
11 | let { email, password } = req.body
12 | let validate = loginValidator({ email, password })
13 |
14 | if (!validate.isValid) {
15 | return res.status(400).json(validate.error)
16 | }
17 |
18 | User.findOne({ email })
19 | // Use Populate for transaction
20 | .then(user => {
21 | if (!user) {
22 | return resourceError(res, 'User Not Found')
23 | }
24 | bcrypt.compare(password, user.password, (err, result) => {
25 | if (err) {
26 | return serverError(res, err)
27 | }
28 | if (!result) {
29 | return resourceError(res, 'Password Doesn\'t Match')
30 | }
31 |
32 | let token = jwt.sign({
33 | _id: user._id,
34 | name: user.name,
35 | email: user.email,
36 | amount: user.amount,
37 | income: user.income,
38 | expense: user.expense,
39 | transactions: user.transactions
40 | }, 'SECRET', {expiresIn: '2h'})
41 |
42 | res.status(200).json({
43 | message: 'Login Successful',
44 | token: `Bearer ${token}`
45 | })
46 |
47 | })
48 | })
49 | .catch(error => serverError(res, error))
50 |
51 | // Generate Token and Response Back
52 | },
53 | register(req, res) {
54 | let { name, email, password, confirmPassword } = req.body
55 | let validate = registerValidator({ name, email, password, confirmPassword })
56 |
57 | if (!validate.isValid) {
58 | return res.status(400).json(validate.error)
59 | } else {
60 | User.findOne({ email })
61 | .then(user => {
62 | if (user) {
63 | return resourceError(res, 'Email Already Exist')
64 | }
65 |
66 | bcrypt.hash(password, 11, (err, hash) => {
67 | if (err) {
68 | return resourceError(res, 'Server Error Occurred')
69 | }
70 |
71 | let user = new User({
72 | name,
73 | email,
74 | password: hash,
75 | balance: 0,
76 | expense: 0,
77 | income: 0,
78 | transactions: []
79 | })
80 |
81 | user.save()
82 | .then(user => {
83 | res.status(201).json({
84 | message: 'User Created Successfully',
85 | user
86 | })
87 | })
88 | .catch(error => serverError(res, error))
89 | })
90 | })
91 | .catch(error => serverError(res, error))
92 | }
93 | },
94 | allUser(req, res) {
95 | User.find()
96 | .then(users => {
97 | res.status(200).json(users)
98 | })
99 | .catch(error => serverError(res, error))
100 | }
101 | }
--------------------------------------------------------------------------------
/model/Transaction.js:
--------------------------------------------------------------------------------
1 | const mongoose = require('mongoose')
2 | const Schema = mongoose.Schema
3 |
4 | const TransactionSchema = new Schema({
5 | amount: {
6 | type: Number,
7 | required: true
8 | },
9 | type: {
10 | type: String,
11 | required: true
12 | },
13 | note: String,
14 | author: {
15 | type: Schema.Types.ObjectId,
16 | ref: 'User'
17 | }
18 | }, { timestamps: true })
19 |
20 | const Transaction = mongoose.model('Transaction', TransactionSchema)
21 | module.exports = Transaction
--------------------------------------------------------------------------------
/model/User.js:
--------------------------------------------------------------------------------
1 | const mongoose = require('mongoose')
2 | const Schema = mongoose.Schema
3 |
4 | const userSchema = new Schema({
5 | name: {
6 | type: String,
7 | required: true,
8 | trim: true
9 | },
10 | email: {
11 | type: String,
12 | required: true
13 | },
14 | password: {
15 | type: String,
16 | required: true
17 | },
18 | balance: Number,
19 | income: Number,
20 | expense: Number,
21 | transactions: {
22 | type: [{
23 | type: Schema.Types.ObjectId,
24 | ref: 'Transaction'
25 | }]
26 | }
27 | })
28 |
29 | const User = mongoose.model('User', userSchema)
30 | module.exports = User
--------------------------------------------------------------------------------
/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "money-management-app",
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.5",
15 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz",
16 | "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=",
17 | "requires": {
18 | "mime-types": "~2.1.18",
19 | "negotiator": "0.6.1"
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 | },
56 | "arr-diff": {
57 | "version": "4.0.0",
58 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz",
59 | "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=",
60 | "dev": true
61 | },
62 | "arr-flatten": {
63 | "version": "1.1.0",
64 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz",
65 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==",
66 | "dev": true
67 | },
68 | "arr-union": {
69 | "version": "3.1.0",
70 | "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz",
71 | "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=",
72 | "dev": true
73 | },
74 | "array-flatten": {
75 | "version": "1.1.1",
76 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
77 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI="
78 | },
79 | "array-unique": {
80 | "version": "0.3.2",
81 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz",
82 | "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=",
83 | "dev": true
84 | },
85 | "assign-symbols": {
86 | "version": "1.0.0",
87 | "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz",
88 | "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=",
89 | "dev": true
90 | },
91 | "async": {
92 | "version": "2.6.1",
93 | "resolved": "https://registry.npmjs.org/async/-/async-2.6.1.tgz",
94 | "integrity": "sha512-fNEiL2+AZt6AlAw/29Cr0UDe4sRAHCpEHh54WMz+Bb7QfNcFw4h3loofyJpLeQs4Yx7yuqu/2dLgM5hKOs6HlQ==",
95 | "requires": {
96 | "lodash": "^4.17.10"
97 | }
98 | },
99 | "async-each": {
100 | "version": "1.0.1",
101 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.1.tgz",
102 | "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=",
103 | "dev": true
104 | },
105 | "atob": {
106 | "version": "2.1.2",
107 | "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz",
108 | "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==",
109 | "dev": true
110 | },
111 | "balanced-match": {
112 | "version": "1.0.0",
113 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz",
114 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=",
115 | "dev": true
116 | },
117 | "base": {
118 | "version": "0.11.2",
119 | "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz",
120 | "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==",
121 | "dev": true,
122 | "requires": {
123 | "cache-base": "^1.0.1",
124 | "class-utils": "^0.3.5",
125 | "component-emitter": "^1.2.1",
126 | "define-property": "^1.0.0",
127 | "isobject": "^3.0.1",
128 | "mixin-deep": "^1.2.0",
129 | "pascalcase": "^0.1.1"
130 | },
131 | "dependencies": {
132 | "define-property": {
133 | "version": "1.0.0",
134 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz",
135 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=",
136 | "dev": true,
137 | "requires": {
138 | "is-descriptor": "^1.0.0"
139 | }
140 | },
141 | "is-accessor-descriptor": {
142 | "version": "1.0.0",
143 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
144 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
145 | "dev": true,
146 | "requires": {
147 | "kind-of": "^6.0.0"
148 | }
149 | },
150 | "is-data-descriptor": {
151 | "version": "1.0.0",
152 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
153 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
154 | "dev": true,
155 | "requires": {
156 | "kind-of": "^6.0.0"
157 | }
158 | },
159 | "is-descriptor": {
160 | "version": "1.0.2",
161 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
162 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
163 | "dev": true,
164 | "requires": {
165 | "is-accessor-descriptor": "^1.0.0",
166 | "is-data-descriptor": "^1.0.0",
167 | "kind-of": "^6.0.2"
168 | }
169 | }
170 | }
171 | },
172 | "basic-auth": {
173 | "version": "2.0.1",
174 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz",
175 | "integrity": "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==",
176 | "requires": {
177 | "safe-buffer": "5.1.2"
178 | }
179 | },
180 | "binary-extensions": {
181 | "version": "1.12.0",
182 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.12.0.tgz",
183 | "integrity": "sha512-DYWGk01lDcxeS/K9IHPGWfT8PsJmbXRtRd2Sx72Tnb8pcYZQFF1oSDb8hJtS1vhp212q1Rzi5dUf9+nq0o9UIg==",
184 | "dev": true
185 | },
186 | "bluebird": {
187 | "version": "3.5.1",
188 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz",
189 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA=="
190 | },
191 | "body-parser": {
192 | "version": "1.18.3",
193 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.3.tgz",
194 | "integrity": "sha1-WykhmP/dVTs6DyDe0FkrlWlVyLQ=",
195 | "requires": {
196 | "bytes": "3.0.0",
197 | "content-type": "~1.0.4",
198 | "debug": "2.6.9",
199 | "depd": "~1.1.2",
200 | "http-errors": "~1.6.3",
201 | "iconv-lite": "0.4.23",
202 | "on-finished": "~2.3.0",
203 | "qs": "6.5.2",
204 | "raw-body": "2.3.3",
205 | "type-is": "~1.6.16"
206 | }
207 | },
208 | "boxen": {
209 | "version": "1.3.0",
210 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-1.3.0.tgz",
211 | "integrity": "sha512-TNPjfTr432qx7yOjQyaXm3dSR0MH9vXp7eT1BFSl/C51g+EFnOR9hTg1IreahGBmDNCehscshe45f+C1TBZbLw==",
212 | "dev": true,
213 | "requires": {
214 | "ansi-align": "^2.0.0",
215 | "camelcase": "^4.0.0",
216 | "chalk": "^2.0.1",
217 | "cli-boxes": "^1.0.0",
218 | "string-width": "^2.0.0",
219 | "term-size": "^1.2.0",
220 | "widest-line": "^2.0.0"
221 | }
222 | },
223 | "brace-expansion": {
224 | "version": "1.1.11",
225 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
226 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
227 | "dev": true,
228 | "requires": {
229 | "balanced-match": "^1.0.0",
230 | "concat-map": "0.0.1"
231 | }
232 | },
233 | "braces": {
234 | "version": "2.3.2",
235 | "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz",
236 | "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==",
237 | "dev": true,
238 | "requires": {
239 | "arr-flatten": "^1.1.0",
240 | "array-unique": "^0.3.2",
241 | "extend-shallow": "^2.0.1",
242 | "fill-range": "^4.0.0",
243 | "isobject": "^3.0.1",
244 | "repeat-element": "^1.1.2",
245 | "snapdragon": "^0.8.1",
246 | "snapdragon-node": "^2.0.1",
247 | "split-string": "^3.0.2",
248 | "to-regex": "^3.0.1"
249 | },
250 | "dependencies": {
251 | "extend-shallow": {
252 | "version": "2.0.1",
253 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
254 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
255 | "dev": true,
256 | "requires": {
257 | "is-extendable": "^0.1.0"
258 | }
259 | }
260 | }
261 | },
262 | "bson": {
263 | "version": "1.1.0",
264 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.0.tgz",
265 | "integrity": "sha512-9Aeai9TacfNtWXOYarkFJRW2CWo+dRon+fuLZYJmvLV3+MiUp0bEI6IAZfXEIg7/Pl/7IWlLaDnhzTsD81etQA=="
266 | },
267 | "buffer-equal-constant-time": {
268 | "version": "1.0.1",
269 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz",
270 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk="
271 | },
272 | "builtin-modules": {
273 | "version": "1.1.1",
274 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz",
275 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=",
276 | "dev": true
277 | },
278 | "bytes": {
279 | "version": "3.0.0",
280 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz",
281 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg="
282 | },
283 | "cache-base": {
284 | "version": "1.0.1",
285 | "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz",
286 | "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==",
287 | "dev": true,
288 | "requires": {
289 | "collection-visit": "^1.0.0",
290 | "component-emitter": "^1.2.1",
291 | "get-value": "^2.0.6",
292 | "has-value": "^1.0.0",
293 | "isobject": "^3.0.1",
294 | "set-value": "^2.0.0",
295 | "to-object-path": "^0.3.0",
296 | "union-value": "^1.0.0",
297 | "unset-value": "^1.0.0"
298 | }
299 | },
300 | "camelcase": {
301 | "version": "4.1.0",
302 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz",
303 | "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=",
304 | "dev": true
305 | },
306 | "capture-stack-trace": {
307 | "version": "1.0.1",
308 | "resolved": "https://registry.npmjs.org/capture-stack-trace/-/capture-stack-trace-1.0.1.tgz",
309 | "integrity": "sha512-mYQLZnx5Qt1JgB1WEiMCf2647plpGeQ2NMR/5L0HNZzGQo4fuSPnK+wjfPnKZV0aiJDgzmWqqkV/g7JD+DW0qw==",
310 | "dev": true
311 | },
312 | "chalk": {
313 | "version": "2.4.1",
314 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz",
315 | "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==",
316 | "dev": true,
317 | "requires": {
318 | "ansi-styles": "^3.2.1",
319 | "escape-string-regexp": "^1.0.5",
320 | "supports-color": "^5.3.0"
321 | }
322 | },
323 | "chokidar": {
324 | "version": "2.0.4",
325 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.0.4.tgz",
326 | "integrity": "sha512-z9n7yt9rOvIJrMhvDtDictKrkFHeihkNl6uWMmZlmL6tJtX9Cs+87oK+teBx+JIgzvbX3yZHT3eF8vpbDxHJXQ==",
327 | "dev": true,
328 | "requires": {
329 | "anymatch": "^2.0.0",
330 | "async-each": "^1.0.0",
331 | "braces": "^2.3.0",
332 | "fsevents": "^1.2.2",
333 | "glob-parent": "^3.1.0",
334 | "inherits": "^2.0.1",
335 | "is-binary-path": "^1.0.0",
336 | "is-glob": "^4.0.0",
337 | "lodash.debounce": "^4.0.8",
338 | "normalize-path": "^2.1.1",
339 | "path-is-absolute": "^1.0.0",
340 | "readdirp": "^2.0.0",
341 | "upath": "^1.0.5"
342 | }
343 | },
344 | "ci-info": {
345 | "version": "1.6.0",
346 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-1.6.0.tgz",
347 | "integrity": "sha512-vsGdkwSCDpWmP80ncATX7iea5DWQemg1UgCW5J8tqjU3lYw4FBYuj89J0CTVomA7BEfvSZd84GmHko+MxFQU2A==",
348 | "dev": true
349 | },
350 | "class-utils": {
351 | "version": "0.3.6",
352 | "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz",
353 | "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==",
354 | "dev": true,
355 | "requires": {
356 | "arr-union": "^3.1.0",
357 | "define-property": "^0.2.5",
358 | "isobject": "^3.0.0",
359 | "static-extend": "^0.1.1"
360 | },
361 | "dependencies": {
362 | "define-property": {
363 | "version": "0.2.5",
364 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
365 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
366 | "dev": true,
367 | "requires": {
368 | "is-descriptor": "^0.1.0"
369 | }
370 | }
371 | }
372 | },
373 | "cli-boxes": {
374 | "version": "1.0.0",
375 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-1.0.0.tgz",
376 | "integrity": "sha1-T6kXw+WclKAEzWH47lCdplFocUM=",
377 | "dev": true
378 | },
379 | "cliui": {
380 | "version": "4.1.0",
381 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz",
382 | "integrity": "sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ==",
383 | "dev": true,
384 | "requires": {
385 | "string-width": "^2.1.1",
386 | "strip-ansi": "^4.0.0",
387 | "wrap-ansi": "^2.0.0"
388 | }
389 | },
390 | "code-point-at": {
391 | "version": "1.1.0",
392 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz",
393 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=",
394 | "dev": true
395 | },
396 | "collection-visit": {
397 | "version": "1.0.0",
398 | "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz",
399 | "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=",
400 | "dev": true,
401 | "requires": {
402 | "map-visit": "^1.0.0",
403 | "object-visit": "^1.0.0"
404 | }
405 | },
406 | "color-convert": {
407 | "version": "1.9.3",
408 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
409 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
410 | "dev": true,
411 | "requires": {
412 | "color-name": "1.1.3"
413 | }
414 | },
415 | "color-name": {
416 | "version": "1.1.3",
417 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
418 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=",
419 | "dev": true
420 | },
421 | "component-emitter": {
422 | "version": "1.2.1",
423 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz",
424 | "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=",
425 | "dev": true
426 | },
427 | "concat-map": {
428 | "version": "0.0.1",
429 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
430 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
431 | "dev": true
432 | },
433 | "concurrently": {
434 | "version": "4.1.0",
435 | "resolved": "https://registry.npmjs.org/concurrently/-/concurrently-4.1.0.tgz",
436 | "integrity": "sha512-pwzXCE7qtOB346LyO9eFWpkFJVO3JQZ/qU/feGeaAHiX1M3Rw3zgXKc5cZ8vSH5DGygkjzLFDzA/pwoQDkRNGg==",
437 | "dev": true,
438 | "requires": {
439 | "chalk": "^2.4.1",
440 | "date-fns": "^1.23.0",
441 | "lodash": "^4.17.10",
442 | "read-pkg": "^4.0.1",
443 | "rxjs": "^6.3.3",
444 | "spawn-command": "^0.0.2-1",
445 | "supports-color": "^4.5.0",
446 | "tree-kill": "^1.1.0",
447 | "yargs": "^12.0.1"
448 | },
449 | "dependencies": {
450 | "has-flag": {
451 | "version": "2.0.0",
452 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz",
453 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=",
454 | "dev": true
455 | },
456 | "supports-color": {
457 | "version": "4.5.0",
458 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.5.0.tgz",
459 | "integrity": "sha1-vnoN5ITexcXN34s9WRJQRJEvY1s=",
460 | "dev": true,
461 | "requires": {
462 | "has-flag": "^2.0.0"
463 | }
464 | }
465 | }
466 | },
467 | "configstore": {
468 | "version": "3.1.2",
469 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-3.1.2.tgz",
470 | "integrity": "sha512-vtv5HtGjcYUgFrXc6Kx747B83MRRVS5R1VTEQoXvuP+kMI+if6uywV0nDGoiydJRy4yk7h9od5Og0kxx4zUXmw==",
471 | "dev": true,
472 | "requires": {
473 | "dot-prop": "^4.1.0",
474 | "graceful-fs": "^4.1.2",
475 | "make-dir": "^1.0.0",
476 | "unique-string": "^1.0.0",
477 | "write-file-atomic": "^2.0.0",
478 | "xdg-basedir": "^3.0.0"
479 | }
480 | },
481 | "content-disposition": {
482 | "version": "0.5.2",
483 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz",
484 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ="
485 | },
486 | "content-type": {
487 | "version": "1.0.4",
488 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz",
489 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA=="
490 | },
491 | "cookie": {
492 | "version": "0.3.1",
493 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz",
494 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s="
495 | },
496 | "cookie-signature": {
497 | "version": "1.0.6",
498 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
499 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw="
500 | },
501 | "copy-descriptor": {
502 | "version": "0.1.1",
503 | "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz",
504 | "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=",
505 | "dev": true
506 | },
507 | "core-util-is": {
508 | "version": "1.0.2",
509 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz",
510 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=",
511 | "dev": true
512 | },
513 | "cors": {
514 | "version": "2.8.5",
515 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz",
516 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==",
517 | "requires": {
518 | "object-assign": "^4",
519 | "vary": "^1"
520 | }
521 | },
522 | "create-error-class": {
523 | "version": "3.0.2",
524 | "resolved": "https://registry.npmjs.org/create-error-class/-/create-error-class-3.0.2.tgz",
525 | "integrity": "sha1-Br56vvlHo/FKMP1hBnHUAbyot7Y=",
526 | "dev": true,
527 | "requires": {
528 | "capture-stack-trace": "^1.0.0"
529 | }
530 | },
531 | "cross-spawn": {
532 | "version": "6.0.5",
533 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz",
534 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==",
535 | "dev": true,
536 | "requires": {
537 | "nice-try": "^1.0.4",
538 | "path-key": "^2.0.1",
539 | "semver": "^5.5.0",
540 | "shebang-command": "^1.2.0",
541 | "which": "^1.2.9"
542 | }
543 | },
544 | "crypto-random-string": {
545 | "version": "1.0.0",
546 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-1.0.0.tgz",
547 | "integrity": "sha1-ojD2T1aDEOFJgAmUB5DsmVRbyn4=",
548 | "dev": true
549 | },
550 | "date-fns": {
551 | "version": "1.30.1",
552 | "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-1.30.1.tgz",
553 | "integrity": "sha512-hBSVCvSmWC+QypYObzwGOd9wqdDpOt+0wl0KbU+R+uuZBS1jN8VsD1ss3irQDknRj5NvxiTF6oj/nDRnN/UQNw==",
554 | "dev": true
555 | },
556 | "debug": {
557 | "version": "2.6.9",
558 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
559 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
560 | "requires": {
561 | "ms": "2.0.0"
562 | }
563 | },
564 | "decamelize": {
565 | "version": "1.2.0",
566 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz",
567 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=",
568 | "dev": true
569 | },
570 | "decode-uri-component": {
571 | "version": "0.2.0",
572 | "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz",
573 | "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=",
574 | "dev": true
575 | },
576 | "deep-extend": {
577 | "version": "0.6.0",
578 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz",
579 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==",
580 | "dev": true
581 | },
582 | "define-property": {
583 | "version": "2.0.2",
584 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz",
585 | "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==",
586 | "dev": true,
587 | "requires": {
588 | "is-descriptor": "^1.0.2",
589 | "isobject": "^3.0.1"
590 | },
591 | "dependencies": {
592 | "is-accessor-descriptor": {
593 | "version": "1.0.0",
594 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
595 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
596 | "dev": true,
597 | "requires": {
598 | "kind-of": "^6.0.0"
599 | }
600 | },
601 | "is-data-descriptor": {
602 | "version": "1.0.0",
603 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
604 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
605 | "dev": true,
606 | "requires": {
607 | "kind-of": "^6.0.0"
608 | }
609 | },
610 | "is-descriptor": {
611 | "version": "1.0.2",
612 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
613 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
614 | "dev": true,
615 | "requires": {
616 | "is-accessor-descriptor": "^1.0.0",
617 | "is-data-descriptor": "^1.0.0",
618 | "kind-of": "^6.0.2"
619 | }
620 | }
621 | }
622 | },
623 | "depd": {
624 | "version": "1.1.2",
625 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz",
626 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak="
627 | },
628 | "destroy": {
629 | "version": "1.0.4",
630 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz",
631 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA="
632 | },
633 | "dot-prop": {
634 | "version": "4.2.0",
635 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-4.2.0.tgz",
636 | "integrity": "sha512-tUMXrxlExSW6U2EXiiKGSBVdYgtV8qlHL+C10TsW4PURY/ic+eaysnSkwB4kA/mBlCyy/IKDJ+Lc3wbWeaXtuQ==",
637 | "dev": true,
638 | "requires": {
639 | "is-obj": "^1.0.0"
640 | }
641 | },
642 | "duplexer3": {
643 | "version": "0.1.4",
644 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz",
645 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=",
646 | "dev": true
647 | },
648 | "ecdsa-sig-formatter": {
649 | "version": "1.0.10",
650 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.10.tgz",
651 | "integrity": "sha1-HFlQAPBKiJffuFAAiSoPTDOvhsM=",
652 | "requires": {
653 | "safe-buffer": "^5.0.1"
654 | }
655 | },
656 | "ee-first": {
657 | "version": "1.1.1",
658 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
659 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0="
660 | },
661 | "encodeurl": {
662 | "version": "1.0.2",
663 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
664 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k="
665 | },
666 | "end-of-stream": {
667 | "version": "1.4.1",
668 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz",
669 | "integrity": "sha512-1MkrZNvWTKCaigbn+W15elq2BB/L22nqrSY5DKlo3X6+vclJm8Bb5djXJBmEX6fS3+zCh/F4VBK5Z2KxJt4s2Q==",
670 | "dev": true,
671 | "requires": {
672 | "once": "^1.4.0"
673 | }
674 | },
675 | "error-ex": {
676 | "version": "1.3.2",
677 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
678 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
679 | "dev": true,
680 | "requires": {
681 | "is-arrayish": "^0.2.1"
682 | }
683 | },
684 | "escape-html": {
685 | "version": "1.0.3",
686 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
687 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg="
688 | },
689 | "escape-string-regexp": {
690 | "version": "1.0.5",
691 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
692 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=",
693 | "dev": true
694 | },
695 | "etag": {
696 | "version": "1.8.1",
697 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
698 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc="
699 | },
700 | "execa": {
701 | "version": "1.0.0",
702 | "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz",
703 | "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==",
704 | "dev": true,
705 | "requires": {
706 | "cross-spawn": "^6.0.0",
707 | "get-stream": "^4.0.0",
708 | "is-stream": "^1.1.0",
709 | "npm-run-path": "^2.0.0",
710 | "p-finally": "^1.0.0",
711 | "signal-exit": "^3.0.0",
712 | "strip-eof": "^1.0.0"
713 | },
714 | "dependencies": {
715 | "get-stream": {
716 | "version": "4.1.0",
717 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz",
718 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==",
719 | "dev": true,
720 | "requires": {
721 | "pump": "^3.0.0"
722 | }
723 | }
724 | }
725 | },
726 | "expand-brackets": {
727 | "version": "2.1.4",
728 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz",
729 | "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=",
730 | "dev": true,
731 | "requires": {
732 | "debug": "^2.3.3",
733 | "define-property": "^0.2.5",
734 | "extend-shallow": "^2.0.1",
735 | "posix-character-classes": "^0.1.0",
736 | "regex-not": "^1.0.0",
737 | "snapdragon": "^0.8.1",
738 | "to-regex": "^3.0.1"
739 | },
740 | "dependencies": {
741 | "define-property": {
742 | "version": "0.2.5",
743 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
744 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
745 | "dev": true,
746 | "requires": {
747 | "is-descriptor": "^0.1.0"
748 | }
749 | },
750 | "extend-shallow": {
751 | "version": "2.0.1",
752 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
753 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
754 | "dev": true,
755 | "requires": {
756 | "is-extendable": "^0.1.0"
757 | }
758 | }
759 | }
760 | },
761 | "express": {
762 | "version": "4.16.4",
763 | "resolved": "https://registry.npmjs.org/express/-/express-4.16.4.tgz",
764 | "integrity": "sha512-j12Uuyb4FMrd/qQAm6uCHAkPtO8FDTRJZBDd5D2KOL2eLaz1yUNdUB/NOIyq0iU4q4cFarsUCrnFDPBcnksuOg==",
765 | "requires": {
766 | "accepts": "~1.3.5",
767 | "array-flatten": "1.1.1",
768 | "body-parser": "1.18.3",
769 | "content-disposition": "0.5.2",
770 | "content-type": "~1.0.4",
771 | "cookie": "0.3.1",
772 | "cookie-signature": "1.0.6",
773 | "debug": "2.6.9",
774 | "depd": "~1.1.2",
775 | "encodeurl": "~1.0.2",
776 | "escape-html": "~1.0.3",
777 | "etag": "~1.8.1",
778 | "finalhandler": "1.1.1",
779 | "fresh": "0.5.2",
780 | "merge-descriptors": "1.0.1",
781 | "methods": "~1.1.2",
782 | "on-finished": "~2.3.0",
783 | "parseurl": "~1.3.2",
784 | "path-to-regexp": "0.1.7",
785 | "proxy-addr": "~2.0.4",
786 | "qs": "6.5.2",
787 | "range-parser": "~1.2.0",
788 | "safe-buffer": "5.1.2",
789 | "send": "0.16.2",
790 | "serve-static": "1.13.2",
791 | "setprototypeof": "1.1.0",
792 | "statuses": "~1.4.0",
793 | "type-is": "~1.6.16",
794 | "utils-merge": "1.0.1",
795 | "vary": "~1.1.2"
796 | },
797 | "dependencies": {
798 | "body-parser": {
799 | "version": "1.18.3",
800 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.3.tgz",
801 | "integrity": "sha1-WykhmP/dVTs6DyDe0FkrlWlVyLQ=",
802 | "requires": {
803 | "bytes": "3.0.0",
804 | "content-type": "~1.0.4",
805 | "debug": "2.6.9",
806 | "depd": "~1.1.2",
807 | "http-errors": "~1.6.3",
808 | "iconv-lite": "0.4.23",
809 | "on-finished": "~2.3.0",
810 | "qs": "6.5.2",
811 | "raw-body": "2.3.3",
812 | "type-is": "~1.6.16"
813 | }
814 | }
815 | }
816 | },
817 | "extend-shallow": {
818 | "version": "3.0.2",
819 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz",
820 | "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=",
821 | "dev": true,
822 | "requires": {
823 | "assign-symbols": "^1.0.0",
824 | "is-extendable": "^1.0.1"
825 | },
826 | "dependencies": {
827 | "is-extendable": {
828 | "version": "1.0.1",
829 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz",
830 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==",
831 | "dev": true,
832 | "requires": {
833 | "is-plain-object": "^2.0.4"
834 | }
835 | }
836 | }
837 | },
838 | "extglob": {
839 | "version": "2.0.4",
840 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz",
841 | "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==",
842 | "dev": true,
843 | "requires": {
844 | "array-unique": "^0.3.2",
845 | "define-property": "^1.0.0",
846 | "expand-brackets": "^2.1.4",
847 | "extend-shallow": "^2.0.1",
848 | "fragment-cache": "^0.2.1",
849 | "regex-not": "^1.0.0",
850 | "snapdragon": "^0.8.1",
851 | "to-regex": "^3.0.1"
852 | },
853 | "dependencies": {
854 | "define-property": {
855 | "version": "1.0.0",
856 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz",
857 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=",
858 | "dev": true,
859 | "requires": {
860 | "is-descriptor": "^1.0.0"
861 | }
862 | },
863 | "extend-shallow": {
864 | "version": "2.0.1",
865 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
866 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
867 | "dev": true,
868 | "requires": {
869 | "is-extendable": "^0.1.0"
870 | }
871 | },
872 | "is-accessor-descriptor": {
873 | "version": "1.0.0",
874 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
875 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
876 | "dev": true,
877 | "requires": {
878 | "kind-of": "^6.0.0"
879 | }
880 | },
881 | "is-data-descriptor": {
882 | "version": "1.0.0",
883 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
884 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
885 | "dev": true,
886 | "requires": {
887 | "kind-of": "^6.0.0"
888 | }
889 | },
890 | "is-descriptor": {
891 | "version": "1.0.2",
892 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
893 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
894 | "dev": true,
895 | "requires": {
896 | "is-accessor-descriptor": "^1.0.0",
897 | "is-data-descriptor": "^1.0.0",
898 | "kind-of": "^6.0.2"
899 | }
900 | }
901 | }
902 | },
903 | "fill-range": {
904 | "version": "4.0.0",
905 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz",
906 | "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=",
907 | "dev": true,
908 | "requires": {
909 | "extend-shallow": "^2.0.1",
910 | "is-number": "^3.0.0",
911 | "repeat-string": "^1.6.1",
912 | "to-regex-range": "^2.1.0"
913 | },
914 | "dependencies": {
915 | "extend-shallow": {
916 | "version": "2.0.1",
917 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
918 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
919 | "dev": true,
920 | "requires": {
921 | "is-extendable": "^0.1.0"
922 | }
923 | }
924 | }
925 | },
926 | "finalhandler": {
927 | "version": "1.1.1",
928 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.1.tgz",
929 | "integrity": "sha512-Y1GUDo39ez4aHAw7MysnUD5JzYX+WaIj8I57kO3aEPT1fFRL4sr7mjei97FgnwhAyyzRYmQZaTHb2+9uZ1dPtg==",
930 | "requires": {
931 | "debug": "2.6.9",
932 | "encodeurl": "~1.0.2",
933 | "escape-html": "~1.0.3",
934 | "on-finished": "~2.3.0",
935 | "parseurl": "~1.3.2",
936 | "statuses": "~1.4.0",
937 | "unpipe": "~1.0.0"
938 | }
939 | },
940 | "find-up": {
941 | "version": "3.0.0",
942 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz",
943 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==",
944 | "dev": true,
945 | "requires": {
946 | "locate-path": "^3.0.0"
947 | }
948 | },
949 | "for-in": {
950 | "version": "1.0.2",
951 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz",
952 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=",
953 | "dev": true
954 | },
955 | "forwarded": {
956 | "version": "0.1.2",
957 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz",
958 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ="
959 | },
960 | "fragment-cache": {
961 | "version": "0.2.1",
962 | "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz",
963 | "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=",
964 | "dev": true,
965 | "requires": {
966 | "map-cache": "^0.2.2"
967 | }
968 | },
969 | "fresh": {
970 | "version": "0.5.2",
971 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
972 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac="
973 | },
974 | "fsevents": {
975 | "version": "1.2.4",
976 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.4.tgz",
977 | "integrity": "sha512-z8H8/diyk76B7q5wg+Ud0+CqzcAF3mBBI/bA5ne5zrRUUIvNkJY//D3BqyH571KuAC4Nr7Rw7CjWX4r0y9DvNg==",
978 | "dev": true,
979 | "optional": true,
980 | "requires": {
981 | "nan": "^2.9.2",
982 | "node-pre-gyp": "^0.10.0"
983 | },
984 | "dependencies": {
985 | "abbrev": {
986 | "version": "1.1.1",
987 | "bundled": true,
988 | "dev": true,
989 | "optional": true
990 | },
991 | "ansi-regex": {
992 | "version": "2.1.1",
993 | "bundled": true,
994 | "dev": true
995 | },
996 | "aproba": {
997 | "version": "1.2.0",
998 | "bundled": true,
999 | "dev": true,
1000 | "optional": true
1001 | },
1002 | "are-we-there-yet": {
1003 | "version": "1.1.4",
1004 | "bundled": true,
1005 | "dev": true,
1006 | "optional": true,
1007 | "requires": {
1008 | "delegates": "^1.0.0",
1009 | "readable-stream": "^2.0.6"
1010 | }
1011 | },
1012 | "balanced-match": {
1013 | "version": "1.0.0",
1014 | "bundled": true,
1015 | "dev": true
1016 | },
1017 | "brace-expansion": {
1018 | "version": "1.1.11",
1019 | "bundled": true,
1020 | "dev": true,
1021 | "requires": {
1022 | "balanced-match": "^1.0.0",
1023 | "concat-map": "0.0.1"
1024 | }
1025 | },
1026 | "chownr": {
1027 | "version": "1.0.1",
1028 | "bundled": true,
1029 | "dev": true,
1030 | "optional": true
1031 | },
1032 | "code-point-at": {
1033 | "version": "1.1.0",
1034 | "bundled": true,
1035 | "dev": true
1036 | },
1037 | "concat-map": {
1038 | "version": "0.0.1",
1039 | "bundled": true,
1040 | "dev": true
1041 | },
1042 | "console-control-strings": {
1043 | "version": "1.1.0",
1044 | "bundled": true,
1045 | "dev": true
1046 | },
1047 | "core-util-is": {
1048 | "version": "1.0.2",
1049 | "bundled": true,
1050 | "dev": true,
1051 | "optional": true
1052 | },
1053 | "debug": {
1054 | "version": "2.6.9",
1055 | "bundled": true,
1056 | "dev": true,
1057 | "optional": true,
1058 | "requires": {
1059 | "ms": "2.0.0"
1060 | }
1061 | },
1062 | "deep-extend": {
1063 | "version": "0.5.1",
1064 | "bundled": true,
1065 | "dev": true,
1066 | "optional": true
1067 | },
1068 | "delegates": {
1069 | "version": "1.0.0",
1070 | "bundled": true,
1071 | "dev": true,
1072 | "optional": true
1073 | },
1074 | "detect-libc": {
1075 | "version": "1.0.3",
1076 | "bundled": true,
1077 | "dev": true,
1078 | "optional": true
1079 | },
1080 | "fs-minipass": {
1081 | "version": "1.2.5",
1082 | "bundled": true,
1083 | "dev": true,
1084 | "optional": true,
1085 | "requires": {
1086 | "minipass": "^2.2.1"
1087 | }
1088 | },
1089 | "fs.realpath": {
1090 | "version": "1.0.0",
1091 | "bundled": true,
1092 | "dev": true,
1093 | "optional": true
1094 | },
1095 | "gauge": {
1096 | "version": "2.7.4",
1097 | "bundled": true,
1098 | "dev": true,
1099 | "optional": true,
1100 | "requires": {
1101 | "aproba": "^1.0.3",
1102 | "console-control-strings": "^1.0.0",
1103 | "has-unicode": "^2.0.0",
1104 | "object-assign": "^4.1.0",
1105 | "signal-exit": "^3.0.0",
1106 | "string-width": "^1.0.1",
1107 | "strip-ansi": "^3.0.1",
1108 | "wide-align": "^1.1.0"
1109 | }
1110 | },
1111 | "glob": {
1112 | "version": "7.1.2",
1113 | "bundled": true,
1114 | "dev": true,
1115 | "optional": true,
1116 | "requires": {
1117 | "fs.realpath": "^1.0.0",
1118 | "inflight": "^1.0.4",
1119 | "inherits": "2",
1120 | "minimatch": "^3.0.4",
1121 | "once": "^1.3.0",
1122 | "path-is-absolute": "^1.0.0"
1123 | }
1124 | },
1125 | "has-unicode": {
1126 | "version": "2.0.1",
1127 | "bundled": true,
1128 | "dev": true,
1129 | "optional": true
1130 | },
1131 | "iconv-lite": {
1132 | "version": "0.4.21",
1133 | "bundled": true,
1134 | "dev": true,
1135 | "optional": true,
1136 | "requires": {
1137 | "safer-buffer": "^2.1.0"
1138 | }
1139 | },
1140 | "ignore-walk": {
1141 | "version": "3.0.1",
1142 | "bundled": true,
1143 | "dev": true,
1144 | "optional": true,
1145 | "requires": {
1146 | "minimatch": "^3.0.4"
1147 | }
1148 | },
1149 | "inflight": {
1150 | "version": "1.0.6",
1151 | "bundled": true,
1152 | "dev": true,
1153 | "optional": true,
1154 | "requires": {
1155 | "once": "^1.3.0",
1156 | "wrappy": "1"
1157 | }
1158 | },
1159 | "inherits": {
1160 | "version": "2.0.3",
1161 | "bundled": true,
1162 | "dev": true
1163 | },
1164 | "ini": {
1165 | "version": "1.3.5",
1166 | "bundled": true,
1167 | "dev": true,
1168 | "optional": true
1169 | },
1170 | "is-fullwidth-code-point": {
1171 | "version": "1.0.0",
1172 | "bundled": true,
1173 | "dev": true,
1174 | "requires": {
1175 | "number-is-nan": "^1.0.0"
1176 | }
1177 | },
1178 | "isarray": {
1179 | "version": "1.0.0",
1180 | "bundled": true,
1181 | "dev": true,
1182 | "optional": true
1183 | },
1184 | "minimatch": {
1185 | "version": "3.0.4",
1186 | "bundled": true,
1187 | "dev": true,
1188 | "requires": {
1189 | "brace-expansion": "^1.1.7"
1190 | }
1191 | },
1192 | "minimist": {
1193 | "version": "0.0.8",
1194 | "bundled": true,
1195 | "dev": true
1196 | },
1197 | "minipass": {
1198 | "version": "2.2.4",
1199 | "bundled": true,
1200 | "dev": true,
1201 | "requires": {
1202 | "safe-buffer": "^5.1.1",
1203 | "yallist": "^3.0.0"
1204 | }
1205 | },
1206 | "minizlib": {
1207 | "version": "1.1.0",
1208 | "bundled": true,
1209 | "dev": true,
1210 | "optional": true,
1211 | "requires": {
1212 | "minipass": "^2.2.1"
1213 | }
1214 | },
1215 | "mkdirp": {
1216 | "version": "0.5.1",
1217 | "bundled": true,
1218 | "dev": true,
1219 | "requires": {
1220 | "minimist": "0.0.8"
1221 | }
1222 | },
1223 | "ms": {
1224 | "version": "2.0.0",
1225 | "bundled": true,
1226 | "dev": true,
1227 | "optional": true
1228 | },
1229 | "needle": {
1230 | "version": "2.2.0",
1231 | "bundled": true,
1232 | "dev": true,
1233 | "optional": true,
1234 | "requires": {
1235 | "debug": "^2.1.2",
1236 | "iconv-lite": "^0.4.4",
1237 | "sax": "^1.2.4"
1238 | }
1239 | },
1240 | "node-pre-gyp": {
1241 | "version": "0.10.0",
1242 | "bundled": true,
1243 | "dev": true,
1244 | "optional": true,
1245 | "requires": {
1246 | "detect-libc": "^1.0.2",
1247 | "mkdirp": "^0.5.1",
1248 | "needle": "^2.2.0",
1249 | "nopt": "^4.0.1",
1250 | "npm-packlist": "^1.1.6",
1251 | "npmlog": "^4.0.2",
1252 | "rc": "^1.1.7",
1253 | "rimraf": "^2.6.1",
1254 | "semver": "^5.3.0",
1255 | "tar": "^4"
1256 | }
1257 | },
1258 | "nopt": {
1259 | "version": "4.0.1",
1260 | "bundled": true,
1261 | "dev": true,
1262 | "optional": true,
1263 | "requires": {
1264 | "abbrev": "1",
1265 | "osenv": "^0.1.4"
1266 | }
1267 | },
1268 | "npm-bundled": {
1269 | "version": "1.0.3",
1270 | "bundled": true,
1271 | "dev": true,
1272 | "optional": true
1273 | },
1274 | "npm-packlist": {
1275 | "version": "1.1.10",
1276 | "bundled": true,
1277 | "dev": true,
1278 | "optional": true,
1279 | "requires": {
1280 | "ignore-walk": "^3.0.1",
1281 | "npm-bundled": "^1.0.1"
1282 | }
1283 | },
1284 | "npmlog": {
1285 | "version": "4.1.2",
1286 | "bundled": true,
1287 | "dev": true,
1288 | "optional": true,
1289 | "requires": {
1290 | "are-we-there-yet": "~1.1.2",
1291 | "console-control-strings": "~1.1.0",
1292 | "gauge": "~2.7.3",
1293 | "set-blocking": "~2.0.0"
1294 | }
1295 | },
1296 | "number-is-nan": {
1297 | "version": "1.0.1",
1298 | "bundled": true,
1299 | "dev": true
1300 | },
1301 | "object-assign": {
1302 | "version": "4.1.1",
1303 | "bundled": true,
1304 | "dev": true,
1305 | "optional": true
1306 | },
1307 | "once": {
1308 | "version": "1.4.0",
1309 | "bundled": true,
1310 | "dev": true,
1311 | "requires": {
1312 | "wrappy": "1"
1313 | }
1314 | },
1315 | "os-homedir": {
1316 | "version": "1.0.2",
1317 | "bundled": true,
1318 | "dev": true,
1319 | "optional": true
1320 | },
1321 | "os-tmpdir": {
1322 | "version": "1.0.2",
1323 | "bundled": true,
1324 | "dev": true,
1325 | "optional": true
1326 | },
1327 | "osenv": {
1328 | "version": "0.1.5",
1329 | "bundled": true,
1330 | "dev": true,
1331 | "optional": true,
1332 | "requires": {
1333 | "os-homedir": "^1.0.0",
1334 | "os-tmpdir": "^1.0.0"
1335 | }
1336 | },
1337 | "path-is-absolute": {
1338 | "version": "1.0.1",
1339 | "bundled": true,
1340 | "dev": true,
1341 | "optional": true
1342 | },
1343 | "process-nextick-args": {
1344 | "version": "2.0.0",
1345 | "bundled": true,
1346 | "dev": true,
1347 | "optional": true
1348 | },
1349 | "rc": {
1350 | "version": "1.2.7",
1351 | "bundled": true,
1352 | "dev": true,
1353 | "optional": true,
1354 | "requires": {
1355 | "deep-extend": "^0.5.1",
1356 | "ini": "~1.3.0",
1357 | "minimist": "^1.2.0",
1358 | "strip-json-comments": "~2.0.1"
1359 | },
1360 | "dependencies": {
1361 | "minimist": {
1362 | "version": "1.2.0",
1363 | "bundled": true,
1364 | "dev": true,
1365 | "optional": true
1366 | }
1367 | }
1368 | },
1369 | "readable-stream": {
1370 | "version": "2.3.6",
1371 | "bundled": true,
1372 | "dev": true,
1373 | "optional": true,
1374 | "requires": {
1375 | "core-util-is": "~1.0.0",
1376 | "inherits": "~2.0.3",
1377 | "isarray": "~1.0.0",
1378 | "process-nextick-args": "~2.0.0",
1379 | "safe-buffer": "~5.1.1",
1380 | "string_decoder": "~1.1.1",
1381 | "util-deprecate": "~1.0.1"
1382 | }
1383 | },
1384 | "rimraf": {
1385 | "version": "2.6.2",
1386 | "bundled": true,
1387 | "dev": true,
1388 | "optional": true,
1389 | "requires": {
1390 | "glob": "^7.0.5"
1391 | }
1392 | },
1393 | "safe-buffer": {
1394 | "version": "5.1.1",
1395 | "bundled": true,
1396 | "dev": true
1397 | },
1398 | "safer-buffer": {
1399 | "version": "2.1.2",
1400 | "bundled": true,
1401 | "dev": true,
1402 | "optional": true
1403 | },
1404 | "sax": {
1405 | "version": "1.2.4",
1406 | "bundled": true,
1407 | "dev": true,
1408 | "optional": true
1409 | },
1410 | "semver": {
1411 | "version": "5.5.0",
1412 | "bundled": true,
1413 | "dev": true,
1414 | "optional": true
1415 | },
1416 | "set-blocking": {
1417 | "version": "2.0.0",
1418 | "bundled": true,
1419 | "dev": true,
1420 | "optional": true
1421 | },
1422 | "signal-exit": {
1423 | "version": "3.0.2",
1424 | "bundled": true,
1425 | "dev": true,
1426 | "optional": true
1427 | },
1428 | "string-width": {
1429 | "version": "1.0.2",
1430 | "bundled": true,
1431 | "dev": true,
1432 | "requires": {
1433 | "code-point-at": "^1.0.0",
1434 | "is-fullwidth-code-point": "^1.0.0",
1435 | "strip-ansi": "^3.0.0"
1436 | }
1437 | },
1438 | "string_decoder": {
1439 | "version": "1.1.1",
1440 | "bundled": true,
1441 | "dev": true,
1442 | "optional": true,
1443 | "requires": {
1444 | "safe-buffer": "~5.1.0"
1445 | }
1446 | },
1447 | "strip-ansi": {
1448 | "version": "3.0.1",
1449 | "bundled": true,
1450 | "dev": true,
1451 | "requires": {
1452 | "ansi-regex": "^2.0.0"
1453 | }
1454 | },
1455 | "strip-json-comments": {
1456 | "version": "2.0.1",
1457 | "bundled": true,
1458 | "dev": true,
1459 | "optional": true
1460 | },
1461 | "tar": {
1462 | "version": "4.4.1",
1463 | "bundled": true,
1464 | "dev": true,
1465 | "optional": true,
1466 | "requires": {
1467 | "chownr": "^1.0.1",
1468 | "fs-minipass": "^1.2.5",
1469 | "minipass": "^2.2.4",
1470 | "minizlib": "^1.1.0",
1471 | "mkdirp": "^0.5.0",
1472 | "safe-buffer": "^5.1.1",
1473 | "yallist": "^3.0.2"
1474 | }
1475 | },
1476 | "util-deprecate": {
1477 | "version": "1.0.2",
1478 | "bundled": true,
1479 | "dev": true,
1480 | "optional": true
1481 | },
1482 | "wide-align": {
1483 | "version": "1.1.2",
1484 | "bundled": true,
1485 | "dev": true,
1486 | "optional": true,
1487 | "requires": {
1488 | "string-width": "^1.0.2"
1489 | }
1490 | },
1491 | "wrappy": {
1492 | "version": "1.0.2",
1493 | "bundled": true,
1494 | "dev": true
1495 | },
1496 | "yallist": {
1497 | "version": "3.0.2",
1498 | "bundled": true,
1499 | "dev": true
1500 | }
1501 | }
1502 | },
1503 | "get-caller-file": {
1504 | "version": "1.0.3",
1505 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz",
1506 | "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==",
1507 | "dev": true
1508 | },
1509 | "get-stream": {
1510 | "version": "3.0.0",
1511 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz",
1512 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=",
1513 | "dev": true
1514 | },
1515 | "get-value": {
1516 | "version": "2.0.6",
1517 | "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz",
1518 | "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=",
1519 | "dev": true
1520 | },
1521 | "glob-parent": {
1522 | "version": "3.1.0",
1523 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz",
1524 | "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=",
1525 | "dev": true,
1526 | "requires": {
1527 | "is-glob": "^3.1.0",
1528 | "path-dirname": "^1.0.0"
1529 | },
1530 | "dependencies": {
1531 | "is-glob": {
1532 | "version": "3.1.0",
1533 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz",
1534 | "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=",
1535 | "dev": true,
1536 | "requires": {
1537 | "is-extglob": "^2.1.0"
1538 | }
1539 | }
1540 | }
1541 | },
1542 | "global-dirs": {
1543 | "version": "0.1.1",
1544 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-0.1.1.tgz",
1545 | "integrity": "sha1-sxnA3UYH81PzvpzKTHL8FIxJ9EU=",
1546 | "dev": true,
1547 | "requires": {
1548 | "ini": "^1.3.4"
1549 | }
1550 | },
1551 | "got": {
1552 | "version": "6.7.1",
1553 | "resolved": "https://registry.npmjs.org/got/-/got-6.7.1.tgz",
1554 | "integrity": "sha1-JAzQV4WpoY5WHcG0S0HHY+8ejbA=",
1555 | "dev": true,
1556 | "requires": {
1557 | "create-error-class": "^3.0.0",
1558 | "duplexer3": "^0.1.4",
1559 | "get-stream": "^3.0.0",
1560 | "is-redirect": "^1.0.0",
1561 | "is-retry-allowed": "^1.0.0",
1562 | "is-stream": "^1.0.0",
1563 | "lowercase-keys": "^1.0.0",
1564 | "safe-buffer": "^5.0.1",
1565 | "timed-out": "^4.0.0",
1566 | "unzip-response": "^2.0.1",
1567 | "url-parse-lax": "^1.0.0"
1568 | }
1569 | },
1570 | "graceful-fs": {
1571 | "version": "4.1.15",
1572 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz",
1573 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==",
1574 | "dev": true
1575 | },
1576 | "has-flag": {
1577 | "version": "3.0.0",
1578 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
1579 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=",
1580 | "dev": true
1581 | },
1582 | "has-value": {
1583 | "version": "1.0.0",
1584 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz",
1585 | "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=",
1586 | "dev": true,
1587 | "requires": {
1588 | "get-value": "^2.0.6",
1589 | "has-values": "^1.0.0",
1590 | "isobject": "^3.0.0"
1591 | }
1592 | },
1593 | "has-values": {
1594 | "version": "1.0.0",
1595 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz",
1596 | "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=",
1597 | "dev": true,
1598 | "requires": {
1599 | "is-number": "^3.0.0",
1600 | "kind-of": "^4.0.0"
1601 | },
1602 | "dependencies": {
1603 | "kind-of": {
1604 | "version": "4.0.0",
1605 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz",
1606 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=",
1607 | "dev": true,
1608 | "requires": {
1609 | "is-buffer": "^1.1.5"
1610 | }
1611 | }
1612 | }
1613 | },
1614 | "hosted-git-info": {
1615 | "version": "2.7.1",
1616 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz",
1617 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==",
1618 | "dev": true
1619 | },
1620 | "http-errors": {
1621 | "version": "1.6.3",
1622 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz",
1623 | "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=",
1624 | "requires": {
1625 | "depd": "~1.1.2",
1626 | "inherits": "2.0.3",
1627 | "setprototypeof": "1.1.0",
1628 | "statuses": ">= 1.4.0 < 2"
1629 | }
1630 | },
1631 | "iconv-lite": {
1632 | "version": "0.4.23",
1633 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz",
1634 | "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==",
1635 | "requires": {
1636 | "safer-buffer": ">= 2.1.2 < 3"
1637 | }
1638 | },
1639 | "ignore-by-default": {
1640 | "version": "1.0.1",
1641 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz",
1642 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=",
1643 | "dev": true
1644 | },
1645 | "import-lazy": {
1646 | "version": "2.1.0",
1647 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz",
1648 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=",
1649 | "dev": true
1650 | },
1651 | "imurmurhash": {
1652 | "version": "0.1.4",
1653 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
1654 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=",
1655 | "dev": true
1656 | },
1657 | "inherits": {
1658 | "version": "2.0.3",
1659 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
1660 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4="
1661 | },
1662 | "ini": {
1663 | "version": "1.3.5",
1664 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz",
1665 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==",
1666 | "dev": true
1667 | },
1668 | "invert-kv": {
1669 | "version": "2.0.0",
1670 | "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-2.0.0.tgz",
1671 | "integrity": "sha512-wPVv/y/QQ/Uiirj/vh3oP+1Ww+AWehmi1g5fFWGPF6IpCBCDVrhgHRMvrLfdYcwDh3QJbGXDW4JAuzxElLSqKA==",
1672 | "dev": true
1673 | },
1674 | "ipaddr.js": {
1675 | "version": "1.8.0",
1676 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.8.0.tgz",
1677 | "integrity": "sha1-6qM9bd16zo9/b+DJygRA5wZzix4="
1678 | },
1679 | "is-accessor-descriptor": {
1680 | "version": "0.1.6",
1681 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz",
1682 | "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=",
1683 | "dev": true,
1684 | "requires": {
1685 | "kind-of": "^3.0.2"
1686 | },
1687 | "dependencies": {
1688 | "kind-of": {
1689 | "version": "3.2.2",
1690 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
1691 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
1692 | "dev": true,
1693 | "requires": {
1694 | "is-buffer": "^1.1.5"
1695 | }
1696 | }
1697 | }
1698 | },
1699 | "is-arrayish": {
1700 | "version": "0.2.1",
1701 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
1702 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=",
1703 | "dev": true
1704 | },
1705 | "is-binary-path": {
1706 | "version": "1.0.1",
1707 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz",
1708 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=",
1709 | "dev": true,
1710 | "requires": {
1711 | "binary-extensions": "^1.0.0"
1712 | }
1713 | },
1714 | "is-buffer": {
1715 | "version": "1.1.6",
1716 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz",
1717 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==",
1718 | "dev": true
1719 | },
1720 | "is-builtin-module": {
1721 | "version": "1.0.0",
1722 | "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz",
1723 | "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=",
1724 | "dev": true,
1725 | "requires": {
1726 | "builtin-modules": "^1.0.0"
1727 | }
1728 | },
1729 | "is-ci": {
1730 | "version": "1.2.1",
1731 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-1.2.1.tgz",
1732 | "integrity": "sha512-s6tfsaQaQi3JNciBH6shVqEDvhGut0SUXr31ag8Pd8BBbVVlcGfWhpPmEOoM6RJ5TFhbypvf5yyRw/VXW1IiWg==",
1733 | "dev": true,
1734 | "requires": {
1735 | "ci-info": "^1.5.0"
1736 | }
1737 | },
1738 | "is-data-descriptor": {
1739 | "version": "0.1.4",
1740 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz",
1741 | "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=",
1742 | "dev": true,
1743 | "requires": {
1744 | "kind-of": "^3.0.2"
1745 | },
1746 | "dependencies": {
1747 | "kind-of": {
1748 | "version": "3.2.2",
1749 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
1750 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
1751 | "dev": true,
1752 | "requires": {
1753 | "is-buffer": "^1.1.5"
1754 | }
1755 | }
1756 | }
1757 | },
1758 | "is-descriptor": {
1759 | "version": "0.1.6",
1760 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz",
1761 | "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==",
1762 | "dev": true,
1763 | "requires": {
1764 | "is-accessor-descriptor": "^0.1.6",
1765 | "is-data-descriptor": "^0.1.4",
1766 | "kind-of": "^5.0.0"
1767 | },
1768 | "dependencies": {
1769 | "kind-of": {
1770 | "version": "5.1.0",
1771 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz",
1772 | "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==",
1773 | "dev": true
1774 | }
1775 | }
1776 | },
1777 | "is-extendable": {
1778 | "version": "0.1.1",
1779 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz",
1780 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=",
1781 | "dev": true
1782 | },
1783 | "is-extglob": {
1784 | "version": "2.1.1",
1785 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
1786 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
1787 | "dev": true
1788 | },
1789 | "is-fullwidth-code-point": {
1790 | "version": "2.0.0",
1791 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz",
1792 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=",
1793 | "dev": true
1794 | },
1795 | "is-glob": {
1796 | "version": "4.0.0",
1797 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.0.tgz",
1798 | "integrity": "sha1-lSHHaEXMJhCoUgPd8ICpWML/q8A=",
1799 | "dev": true,
1800 | "requires": {
1801 | "is-extglob": "^2.1.1"
1802 | }
1803 | },
1804 | "is-installed-globally": {
1805 | "version": "0.1.0",
1806 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.1.0.tgz",
1807 | "integrity": "sha1-Df2Y9akRFxbdU13aZJL2e/PSWoA=",
1808 | "dev": true,
1809 | "requires": {
1810 | "global-dirs": "^0.1.0",
1811 | "is-path-inside": "^1.0.0"
1812 | }
1813 | },
1814 | "is-npm": {
1815 | "version": "1.0.0",
1816 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-1.0.0.tgz",
1817 | "integrity": "sha1-8vtjpl5JBbQGyGBydloaTceTufQ=",
1818 | "dev": true
1819 | },
1820 | "is-number": {
1821 | "version": "3.0.0",
1822 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz",
1823 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=",
1824 | "dev": true,
1825 | "requires": {
1826 | "kind-of": "^3.0.2"
1827 | },
1828 | "dependencies": {
1829 | "kind-of": {
1830 | "version": "3.2.2",
1831 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
1832 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
1833 | "dev": true,
1834 | "requires": {
1835 | "is-buffer": "^1.1.5"
1836 | }
1837 | }
1838 | }
1839 | },
1840 | "is-obj": {
1841 | "version": "1.0.1",
1842 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz",
1843 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=",
1844 | "dev": true
1845 | },
1846 | "is-path-inside": {
1847 | "version": "1.0.1",
1848 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz",
1849 | "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=",
1850 | "dev": true,
1851 | "requires": {
1852 | "path-is-inside": "^1.0.1"
1853 | }
1854 | },
1855 | "is-plain-object": {
1856 | "version": "2.0.4",
1857 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz",
1858 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==",
1859 | "dev": true,
1860 | "requires": {
1861 | "isobject": "^3.0.1"
1862 | }
1863 | },
1864 | "is-redirect": {
1865 | "version": "1.0.0",
1866 | "resolved": "https://registry.npmjs.org/is-redirect/-/is-redirect-1.0.0.tgz",
1867 | "integrity": "sha1-HQPd7VO9jbDzDCbk+V02/HyH3CQ=",
1868 | "dev": true
1869 | },
1870 | "is-retry-allowed": {
1871 | "version": "1.1.0",
1872 | "resolved": "https://registry.npmjs.org/is-retry-allowed/-/is-retry-allowed-1.1.0.tgz",
1873 | "integrity": "sha1-EaBgVotnM5REAz0BJaYaINVk+zQ=",
1874 | "dev": true
1875 | },
1876 | "is-stream": {
1877 | "version": "1.1.0",
1878 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz",
1879 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=",
1880 | "dev": true
1881 | },
1882 | "is-windows": {
1883 | "version": "1.0.2",
1884 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz",
1885 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==",
1886 | "dev": true
1887 | },
1888 | "isarray": {
1889 | "version": "1.0.0",
1890 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
1891 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=",
1892 | "dev": true
1893 | },
1894 | "isexe": {
1895 | "version": "2.0.0",
1896 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
1897 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=",
1898 | "dev": true
1899 | },
1900 | "isobject": {
1901 | "version": "3.0.1",
1902 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz",
1903 | "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=",
1904 | "dev": true
1905 | },
1906 | "json-parse-better-errors": {
1907 | "version": "1.0.2",
1908 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz",
1909 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==",
1910 | "dev": true
1911 | },
1912 | "jsonwebtoken": {
1913 | "version": "8.4.0",
1914 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.4.0.tgz",
1915 | "integrity": "sha512-coyXjRTCy0pw5WYBpMvWOMN+Kjaik2MwTUIq9cna/W7NpO9E+iYbumZONAz3hcr+tXFJECoQVrtmIoC3Oz0gvg==",
1916 | "requires": {
1917 | "jws": "^3.1.5",
1918 | "lodash.includes": "^4.3.0",
1919 | "lodash.isboolean": "^3.0.3",
1920 | "lodash.isinteger": "^4.0.4",
1921 | "lodash.isnumber": "^3.0.3",
1922 | "lodash.isplainobject": "^4.0.6",
1923 | "lodash.isstring": "^4.0.1",
1924 | "lodash.once": "^4.0.0",
1925 | "ms": "^2.1.1"
1926 | },
1927 | "dependencies": {
1928 | "ms": {
1929 | "version": "2.1.1",
1930 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz",
1931 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg=="
1932 | }
1933 | }
1934 | },
1935 | "jwa": {
1936 | "version": "1.1.6",
1937 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.1.6.tgz",
1938 | "integrity": "sha512-tBO/cf++BUsJkYql/kBbJroKOgHWEigTKBAjjBEmrMGYd1QMBC74Hr4Wo2zCZw6ZrVhlJPvoMrkcOnlWR/DJfw==",
1939 | "requires": {
1940 | "buffer-equal-constant-time": "1.0.1",
1941 | "ecdsa-sig-formatter": "1.0.10",
1942 | "safe-buffer": "^5.0.1"
1943 | }
1944 | },
1945 | "jws": {
1946 | "version": "3.1.5",
1947 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.1.5.tgz",
1948 | "integrity": "sha512-GsCSexFADNQUr8T5HPJvayTjvPIfoyJPtLQBwn5a4WZQchcrPMPMAWcC1AzJVRDKyD6ZPROPAxgv6rfHViO4uQ==",
1949 | "requires": {
1950 | "jwa": "^1.1.5",
1951 | "safe-buffer": "^5.0.1"
1952 | }
1953 | },
1954 | "kareem": {
1955 | "version": "2.3.0",
1956 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.0.tgz",
1957 | "integrity": "sha512-6hHxsp9e6zQU8nXsP+02HGWXwTkOEw6IROhF2ZA28cYbUk4eJ6QbtZvdqZOdD9YPKghG3apk5eOCvs+tLl3lRg=="
1958 | },
1959 | "kind-of": {
1960 | "version": "6.0.2",
1961 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz",
1962 | "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==",
1963 | "dev": true
1964 | },
1965 | "latest-version": {
1966 | "version": "3.1.0",
1967 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-3.1.0.tgz",
1968 | "integrity": "sha1-ogU4P+oyKzO1rjsYq+4NwvNW7hU=",
1969 | "dev": true,
1970 | "requires": {
1971 | "package-json": "^4.0.0"
1972 | }
1973 | },
1974 | "lcid": {
1975 | "version": "2.0.0",
1976 | "resolved": "https://registry.npmjs.org/lcid/-/lcid-2.0.0.tgz",
1977 | "integrity": "sha512-avPEb8P8EGnwXKClwsNUgryVjllcRqtMYa49NTsbQagYuT1DcXnl1915oxWjoyGrXR6zH/Y0Zc96xWsPcoDKeA==",
1978 | "dev": true,
1979 | "requires": {
1980 | "invert-kv": "^2.0.0"
1981 | }
1982 | },
1983 | "locate-path": {
1984 | "version": "3.0.0",
1985 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz",
1986 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==",
1987 | "dev": true,
1988 | "requires": {
1989 | "p-locate": "^3.0.0",
1990 | "path-exists": "^3.0.0"
1991 | }
1992 | },
1993 | "lodash": {
1994 | "version": "4.17.11",
1995 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz",
1996 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg=="
1997 | },
1998 | "lodash.debounce": {
1999 | "version": "4.0.8",
2000 | "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz",
2001 | "integrity": "sha1-gteb/zCmfEAF/9XiUVMArZyk168=",
2002 | "dev": true
2003 | },
2004 | "lodash.get": {
2005 | "version": "4.4.2",
2006 | "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz",
2007 | "integrity": "sha1-LRd/ZS+jHpObRDjVNBSZ36OCXpk="
2008 | },
2009 | "lodash.includes": {
2010 | "version": "4.3.0",
2011 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz",
2012 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8="
2013 | },
2014 | "lodash.isboolean": {
2015 | "version": "3.0.3",
2016 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz",
2017 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY="
2018 | },
2019 | "lodash.isinteger": {
2020 | "version": "4.0.4",
2021 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz",
2022 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M="
2023 | },
2024 | "lodash.isnumber": {
2025 | "version": "3.0.3",
2026 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz",
2027 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w="
2028 | },
2029 | "lodash.isplainobject": {
2030 | "version": "4.0.6",
2031 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz",
2032 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs="
2033 | },
2034 | "lodash.isstring": {
2035 | "version": "4.0.1",
2036 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz",
2037 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE="
2038 | },
2039 | "lodash.once": {
2040 | "version": "4.1.1",
2041 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz",
2042 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w="
2043 | },
2044 | "lowercase-keys": {
2045 | "version": "1.0.1",
2046 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz",
2047 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==",
2048 | "dev": true
2049 | },
2050 | "lru-cache": {
2051 | "version": "4.1.5",
2052 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz",
2053 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==",
2054 | "dev": true,
2055 | "requires": {
2056 | "pseudomap": "^1.0.2",
2057 | "yallist": "^2.1.2"
2058 | },
2059 | "dependencies": {
2060 | "yallist": {
2061 | "version": "2.1.2",
2062 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz",
2063 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=",
2064 | "dev": true
2065 | }
2066 | }
2067 | },
2068 | "make-dir": {
2069 | "version": "1.3.0",
2070 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.3.0.tgz",
2071 | "integrity": "sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ==",
2072 | "dev": true,
2073 | "requires": {
2074 | "pify": "^3.0.0"
2075 | }
2076 | },
2077 | "map-age-cleaner": {
2078 | "version": "0.1.3",
2079 | "resolved": "https://registry.npmjs.org/map-age-cleaner/-/map-age-cleaner-0.1.3.tgz",
2080 | "integrity": "sha512-bJzx6nMoP6PDLPBFmg7+xRKeFZvFboMrGlxmNj9ClvX53KrmvM5bXFXEWjbz4cz1AFn+jWJ9z/DJSz7hrs0w3w==",
2081 | "dev": true,
2082 | "requires": {
2083 | "p-defer": "^1.0.0"
2084 | }
2085 | },
2086 | "map-cache": {
2087 | "version": "0.2.2",
2088 | "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz",
2089 | "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=",
2090 | "dev": true
2091 | },
2092 | "map-visit": {
2093 | "version": "1.0.0",
2094 | "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz",
2095 | "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=",
2096 | "dev": true,
2097 | "requires": {
2098 | "object-visit": "^1.0.0"
2099 | }
2100 | },
2101 | "media-typer": {
2102 | "version": "0.3.0",
2103 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
2104 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g="
2105 | },
2106 | "mem": {
2107 | "version": "4.0.0",
2108 | "resolved": "https://registry.npmjs.org/mem/-/mem-4.0.0.tgz",
2109 | "integrity": "sha512-WQxG/5xYc3tMbYLXoXPm81ET2WDULiU5FxbuIoNbJqLOOI8zehXFdZuiUEgfdrU2mVB1pxBZUGlYORSrpuJreA==",
2110 | "dev": true,
2111 | "requires": {
2112 | "map-age-cleaner": "^0.1.1",
2113 | "mimic-fn": "^1.0.0",
2114 | "p-is-promise": "^1.1.0"
2115 | }
2116 | },
2117 | "memory-pager": {
2118 | "version": "1.4.0",
2119 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.4.0.tgz",
2120 | "integrity": "sha512-ycuyV5gKpZln7HB/A11wCpAxEY9VQ2EhYU1F56pUAxvmj6OyOHtB9tkLLjAyFsPdghSP2S3Ujk3aYJCusgiMZg==",
2121 | "optional": true
2122 | },
2123 | "merge-descriptors": {
2124 | "version": "1.0.1",
2125 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
2126 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E="
2127 | },
2128 | "methods": {
2129 | "version": "1.1.2",
2130 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
2131 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4="
2132 | },
2133 | "micromatch": {
2134 | "version": "3.1.10",
2135 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz",
2136 | "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==",
2137 | "dev": true,
2138 | "requires": {
2139 | "arr-diff": "^4.0.0",
2140 | "array-unique": "^0.3.2",
2141 | "braces": "^2.3.1",
2142 | "define-property": "^2.0.2",
2143 | "extend-shallow": "^3.0.2",
2144 | "extglob": "^2.0.4",
2145 | "fragment-cache": "^0.2.1",
2146 | "kind-of": "^6.0.2",
2147 | "nanomatch": "^1.2.9",
2148 | "object.pick": "^1.3.0",
2149 | "regex-not": "^1.0.0",
2150 | "snapdragon": "^0.8.1",
2151 | "to-regex": "^3.0.2"
2152 | }
2153 | },
2154 | "mime": {
2155 | "version": "1.4.1",
2156 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz",
2157 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ=="
2158 | },
2159 | "mime-db": {
2160 | "version": "1.37.0",
2161 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.37.0.tgz",
2162 | "integrity": "sha512-R3C4db6bgQhlIhPU48fUtdVmKnflq+hRdad7IyKhtFj06VPNVdk2RhiYL3UjQIlso8L+YxAtFkobT0VK+S/ybg=="
2163 | },
2164 | "mime-types": {
2165 | "version": "2.1.21",
2166 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.21.tgz",
2167 | "integrity": "sha512-3iL6DbwpyLzjR3xHSFNFeb9Nz/M8WDkX33t1GFQnFOllWk8pOrh/LSrB5OXlnlW5P9LH73X6loW/eogc+F5lJg==",
2168 | "requires": {
2169 | "mime-db": "~1.37.0"
2170 | }
2171 | },
2172 | "mimic-fn": {
2173 | "version": "1.2.0",
2174 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz",
2175 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==",
2176 | "dev": true
2177 | },
2178 | "minimatch": {
2179 | "version": "3.0.4",
2180 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
2181 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
2182 | "dev": true,
2183 | "requires": {
2184 | "brace-expansion": "^1.1.7"
2185 | }
2186 | },
2187 | "mixin-deep": {
2188 | "version": "1.3.1",
2189 | "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.1.tgz",
2190 | "integrity": "sha512-8ZItLHeEgaqEvd5lYBXfm4EZSFCX29Jb9K+lAHhDKzReKBQKj3R+7NOF6tjqYi9t4oI8VUfaWITJQm86wnXGNQ==",
2191 | "dev": true,
2192 | "requires": {
2193 | "for-in": "^1.0.2",
2194 | "is-extendable": "^1.0.1"
2195 | },
2196 | "dependencies": {
2197 | "is-extendable": {
2198 | "version": "1.0.1",
2199 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz",
2200 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==",
2201 | "dev": true,
2202 | "requires": {
2203 | "is-plain-object": "^2.0.4"
2204 | }
2205 | }
2206 | }
2207 | },
2208 | "mongodb": {
2209 | "version": "3.1.10",
2210 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.1.10.tgz",
2211 | "integrity": "sha512-Uml42GeFxhTGQVml1XQ4cD0o/rp7J2ROy0fdYUcVitoE7vFqEhKH4TYVqRDpQr/bXtCJVxJdNQC1ntRxNREkPQ==",
2212 | "requires": {
2213 | "mongodb-core": "3.1.9",
2214 | "safe-buffer": "^5.1.2"
2215 | }
2216 | },
2217 | "mongodb-core": {
2218 | "version": "3.1.9",
2219 | "resolved": "https://registry.npmjs.org/mongodb-core/-/mongodb-core-3.1.9.tgz",
2220 | "integrity": "sha512-MJpciDABXMchrZphh3vMcqu8hkNf/Mi+Gk6btOimVg1XMxLXh87j6FAvRm+KmwD1A9fpu3qRQYcbQe4egj23og==",
2221 | "requires": {
2222 | "bson": "^1.1.0",
2223 | "require_optional": "^1.0.1",
2224 | "safe-buffer": "^5.1.2",
2225 | "saslprep": "^1.0.0"
2226 | }
2227 | },
2228 | "mongoose": {
2229 | "version": "5.4.0",
2230 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.4.0.tgz",
2231 | "integrity": "sha512-pFKa6askJ6xwZT6mWuYBwa2R9ryd1+JrXUhKuAUxEGrUMTi8ADcJC/RgBg4fZ1lL6VPVVChsc9wpVn4X6gcWlg==",
2232 | "requires": {
2233 | "async": "2.6.1",
2234 | "bson": "~1.1.0",
2235 | "kareem": "2.3.0",
2236 | "lodash.get": "4.4.2",
2237 | "mongodb": "3.1.10",
2238 | "mongodb-core": "3.1.9",
2239 | "mongoose-legacy-pluralize": "1.0.2",
2240 | "mpath": "0.5.1",
2241 | "mquery": "3.2.0",
2242 | "ms": "2.0.0",
2243 | "regexp-clone": "0.0.1",
2244 | "safe-buffer": "5.1.2",
2245 | "sliced": "1.0.1"
2246 | }
2247 | },
2248 | "mongoose-legacy-pluralize": {
2249 | "version": "1.0.2",
2250 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz",
2251 | "integrity": "sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ=="
2252 | },
2253 | "morgan": {
2254 | "version": "1.9.1",
2255 | "resolved": "https://registry.npmjs.org/morgan/-/morgan-1.9.1.tgz",
2256 | "integrity": "sha512-HQStPIV4y3afTiCYVxirakhlCfGkI161c76kKFca7Fk1JusM//Qeo1ej2XaMniiNeaZklMVrh3vTtIzpzwbpmA==",
2257 | "requires": {
2258 | "basic-auth": "~2.0.0",
2259 | "debug": "2.6.9",
2260 | "depd": "~1.1.2",
2261 | "on-finished": "~2.3.0",
2262 | "on-headers": "~1.0.1"
2263 | }
2264 | },
2265 | "mpath": {
2266 | "version": "0.5.1",
2267 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.5.1.tgz",
2268 | "integrity": "sha512-H8OVQ+QEz82sch4wbODFOz+3YQ61FYz/z3eJ5pIdbMEaUzDqA268Wd+Vt4Paw9TJfvDgVKaayC0gBzMIw2jhsg=="
2269 | },
2270 | "mquery": {
2271 | "version": "3.2.0",
2272 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.2.0.tgz",
2273 | "integrity": "sha512-qPJcdK/yqcbQiKoemAt62Y0BAc0fTEKo1IThodBD+O5meQRJT/2HSe5QpBNwaa4CjskoGrYWsEyjkqgiE0qjhg==",
2274 | "requires": {
2275 | "bluebird": "3.5.1",
2276 | "debug": "3.1.0",
2277 | "regexp-clone": "0.0.1",
2278 | "safe-buffer": "5.1.2",
2279 | "sliced": "1.0.1"
2280 | },
2281 | "dependencies": {
2282 | "debug": {
2283 | "version": "3.1.0",
2284 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz",
2285 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==",
2286 | "requires": {
2287 | "ms": "2.0.0"
2288 | }
2289 | }
2290 | }
2291 | },
2292 | "ms": {
2293 | "version": "2.0.0",
2294 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
2295 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g="
2296 | },
2297 | "nan": {
2298 | "version": "2.12.1",
2299 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.12.1.tgz",
2300 | "integrity": "sha512-JY7V6lRkStKcKTvHO5NVSQRv+RV+FIL5pvDoLiAtSL9pKlC5x9PKQcZDsq7m4FO4d57mkhC6Z+QhAh3Jdk5JFw==",
2301 | "dev": true,
2302 | "optional": true
2303 | },
2304 | "nanomatch": {
2305 | "version": "1.2.13",
2306 | "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz",
2307 | "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==",
2308 | "dev": true,
2309 | "requires": {
2310 | "arr-diff": "^4.0.0",
2311 | "array-unique": "^0.3.2",
2312 | "define-property": "^2.0.2",
2313 | "extend-shallow": "^3.0.2",
2314 | "fragment-cache": "^0.2.1",
2315 | "is-windows": "^1.0.2",
2316 | "kind-of": "^6.0.2",
2317 | "object.pick": "^1.3.0",
2318 | "regex-not": "^1.0.0",
2319 | "snapdragon": "^0.8.1",
2320 | "to-regex": "^3.0.1"
2321 | }
2322 | },
2323 | "negotiator": {
2324 | "version": "0.6.1",
2325 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz",
2326 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk="
2327 | },
2328 | "nice-try": {
2329 | "version": "1.0.5",
2330 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz",
2331 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==",
2332 | "dev": true
2333 | },
2334 | "nodemon": {
2335 | "version": "1.18.9",
2336 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-1.18.9.tgz",
2337 | "integrity": "sha512-oj/eEVTEI47pzYAjGkpcNw0xYwTl4XSTUQv2NPQI6PpN3b75PhpuYk3Vb3U80xHCyM2Jm+1j68ULHXl4OR3Afw==",
2338 | "dev": true,
2339 | "requires": {
2340 | "chokidar": "^2.0.4",
2341 | "debug": "^3.1.0",
2342 | "ignore-by-default": "^1.0.1",
2343 | "minimatch": "^3.0.4",
2344 | "pstree.remy": "^1.1.6",
2345 | "semver": "^5.5.0",
2346 | "supports-color": "^5.2.0",
2347 | "touch": "^3.1.0",
2348 | "undefsafe": "^2.0.2",
2349 | "update-notifier": "^2.5.0"
2350 | },
2351 | "dependencies": {
2352 | "debug": {
2353 | "version": "3.2.6",
2354 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz",
2355 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==",
2356 | "dev": true,
2357 | "requires": {
2358 | "ms": "^2.1.1"
2359 | }
2360 | },
2361 | "ms": {
2362 | "version": "2.1.1",
2363 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz",
2364 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==",
2365 | "dev": true
2366 | }
2367 | }
2368 | },
2369 | "nopt": {
2370 | "version": "1.0.10",
2371 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz",
2372 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=",
2373 | "dev": true,
2374 | "requires": {
2375 | "abbrev": "1"
2376 | }
2377 | },
2378 | "normalize-package-data": {
2379 | "version": "2.4.0",
2380 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz",
2381 | "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==",
2382 | "dev": true,
2383 | "requires": {
2384 | "hosted-git-info": "^2.1.4",
2385 | "is-builtin-module": "^1.0.0",
2386 | "semver": "2 || 3 || 4 || 5",
2387 | "validate-npm-package-license": "^3.0.1"
2388 | }
2389 | },
2390 | "normalize-path": {
2391 | "version": "2.1.1",
2392 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz",
2393 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=",
2394 | "dev": true,
2395 | "requires": {
2396 | "remove-trailing-separator": "^1.0.1"
2397 | }
2398 | },
2399 | "npm-run-path": {
2400 | "version": "2.0.2",
2401 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz",
2402 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=",
2403 | "dev": true,
2404 | "requires": {
2405 | "path-key": "^2.0.0"
2406 | }
2407 | },
2408 | "number-is-nan": {
2409 | "version": "1.0.1",
2410 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz",
2411 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=",
2412 | "dev": true
2413 | },
2414 | "object-assign": {
2415 | "version": "4.1.1",
2416 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
2417 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM="
2418 | },
2419 | "object-copy": {
2420 | "version": "0.1.0",
2421 | "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz",
2422 | "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=",
2423 | "dev": true,
2424 | "requires": {
2425 | "copy-descriptor": "^0.1.0",
2426 | "define-property": "^0.2.5",
2427 | "kind-of": "^3.0.3"
2428 | },
2429 | "dependencies": {
2430 | "define-property": {
2431 | "version": "0.2.5",
2432 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
2433 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
2434 | "dev": true,
2435 | "requires": {
2436 | "is-descriptor": "^0.1.0"
2437 | }
2438 | },
2439 | "kind-of": {
2440 | "version": "3.2.2",
2441 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
2442 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
2443 | "dev": true,
2444 | "requires": {
2445 | "is-buffer": "^1.1.5"
2446 | }
2447 | }
2448 | }
2449 | },
2450 | "object-visit": {
2451 | "version": "1.0.1",
2452 | "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz",
2453 | "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=",
2454 | "dev": true,
2455 | "requires": {
2456 | "isobject": "^3.0.0"
2457 | }
2458 | },
2459 | "object.pick": {
2460 | "version": "1.3.0",
2461 | "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz",
2462 | "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=",
2463 | "dev": true,
2464 | "requires": {
2465 | "isobject": "^3.0.1"
2466 | }
2467 | },
2468 | "on-finished": {
2469 | "version": "2.3.0",
2470 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz",
2471 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=",
2472 | "requires": {
2473 | "ee-first": "1.1.1"
2474 | }
2475 | },
2476 | "on-headers": {
2477 | "version": "1.0.1",
2478 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.1.tgz",
2479 | "integrity": "sha1-ko9dD0cNSTQmUepnlLCFfBAGk/c="
2480 | },
2481 | "once": {
2482 | "version": "1.4.0",
2483 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
2484 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
2485 | "dev": true,
2486 | "requires": {
2487 | "wrappy": "1"
2488 | }
2489 | },
2490 | "os-locale": {
2491 | "version": "3.1.0",
2492 | "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-3.1.0.tgz",
2493 | "integrity": "sha512-Z8l3R4wYWM40/52Z+S265okfFj8Kt2cC2MKY+xNi3kFs+XGI7WXu/I309QQQYbRW4ijiZ+yxs9pqEhJh0DqW3Q==",
2494 | "dev": true,
2495 | "requires": {
2496 | "execa": "^1.0.0",
2497 | "lcid": "^2.0.0",
2498 | "mem": "^4.0.0"
2499 | }
2500 | },
2501 | "p-defer": {
2502 | "version": "1.0.0",
2503 | "resolved": "https://registry.npmjs.org/p-defer/-/p-defer-1.0.0.tgz",
2504 | "integrity": "sha1-n26xgvbJqozXQwBKfU+WsZaw+ww=",
2505 | "dev": true
2506 | },
2507 | "p-finally": {
2508 | "version": "1.0.0",
2509 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz",
2510 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=",
2511 | "dev": true
2512 | },
2513 | "p-is-promise": {
2514 | "version": "1.1.0",
2515 | "resolved": "https://registry.npmjs.org/p-is-promise/-/p-is-promise-1.1.0.tgz",
2516 | "integrity": "sha1-nJRWmJ6fZYgBewQ01WCXZ1w9oF4=",
2517 | "dev": true
2518 | },
2519 | "p-limit": {
2520 | "version": "2.1.0",
2521 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.1.0.tgz",
2522 | "integrity": "sha512-NhURkNcrVB+8hNfLuysU8enY5xn2KXphsHBaC2YmRNTZRc7RWusw6apSpdEj3jo4CMb6W9nrF6tTnsJsJeyu6g==",
2523 | "dev": true,
2524 | "requires": {
2525 | "p-try": "^2.0.0"
2526 | }
2527 | },
2528 | "p-locate": {
2529 | "version": "3.0.0",
2530 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz",
2531 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==",
2532 | "dev": true,
2533 | "requires": {
2534 | "p-limit": "^2.0.0"
2535 | }
2536 | },
2537 | "p-try": {
2538 | "version": "2.0.0",
2539 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.0.0.tgz",
2540 | "integrity": "sha512-hMp0onDKIajHfIkdRk3P4CdCmErkYAxxDtP3Wx/4nZ3aGlau2VKh3mZpcuFkH27WQkL/3WBCPOktzA9ZOAnMQQ==",
2541 | "dev": true
2542 | },
2543 | "package-json": {
2544 | "version": "4.0.1",
2545 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-4.0.1.tgz",
2546 | "integrity": "sha1-iGmgQBJTZhxMTKPabCEh7VVfXu0=",
2547 | "dev": true,
2548 | "requires": {
2549 | "got": "^6.7.1",
2550 | "registry-auth-token": "^3.0.1",
2551 | "registry-url": "^3.0.3",
2552 | "semver": "^5.1.0"
2553 | }
2554 | },
2555 | "parse-json": {
2556 | "version": "4.0.0",
2557 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz",
2558 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=",
2559 | "dev": true,
2560 | "requires": {
2561 | "error-ex": "^1.3.1",
2562 | "json-parse-better-errors": "^1.0.1"
2563 | }
2564 | },
2565 | "parseurl": {
2566 | "version": "1.3.2",
2567 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz",
2568 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M="
2569 | },
2570 | "pascalcase": {
2571 | "version": "0.1.1",
2572 | "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz",
2573 | "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=",
2574 | "dev": true
2575 | },
2576 | "passport": {
2577 | "version": "0.4.0",
2578 | "resolved": "https://registry.npmjs.org/passport/-/passport-0.4.0.tgz",
2579 | "integrity": "sha1-xQlWkTR71a07XhgCOMORTRbwWBE=",
2580 | "requires": {
2581 | "passport-strategy": "1.x.x",
2582 | "pause": "0.0.1"
2583 | }
2584 | },
2585 | "passport-jwt": {
2586 | "version": "4.0.0",
2587 | "resolved": "https://registry.npmjs.org/passport-jwt/-/passport-jwt-4.0.0.tgz",
2588 | "integrity": "sha512-BwC0n2GP/1hMVjR4QpnvqA61TxenUMlmfNjYNgK0ZAs0HK4SOQkHcSv4L328blNTLtHq7DbmvyNJiH+bn6C5Mg==",
2589 | "requires": {
2590 | "jsonwebtoken": "^8.2.0",
2591 | "passport-strategy": "^1.0.0"
2592 | }
2593 | },
2594 | "passport-strategy": {
2595 | "version": "1.0.0",
2596 | "resolved": "https://registry.npmjs.org/passport-strategy/-/passport-strategy-1.0.0.tgz",
2597 | "integrity": "sha1-tVOaqPwiWj0a0XlHbd8ja0QPUuQ="
2598 | },
2599 | "path-dirname": {
2600 | "version": "1.0.2",
2601 | "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz",
2602 | "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=",
2603 | "dev": true
2604 | },
2605 | "path-exists": {
2606 | "version": "3.0.0",
2607 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz",
2608 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=",
2609 | "dev": true
2610 | },
2611 | "path-is-absolute": {
2612 | "version": "1.0.1",
2613 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
2614 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=",
2615 | "dev": true
2616 | },
2617 | "path-is-inside": {
2618 | "version": "1.0.2",
2619 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz",
2620 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=",
2621 | "dev": true
2622 | },
2623 | "path-key": {
2624 | "version": "2.0.1",
2625 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz",
2626 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=",
2627 | "dev": true
2628 | },
2629 | "path-to-regexp": {
2630 | "version": "0.1.7",
2631 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
2632 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w="
2633 | },
2634 | "pause": {
2635 | "version": "0.0.1",
2636 | "resolved": "https://registry.npmjs.org/pause/-/pause-0.0.1.tgz",
2637 | "integrity": "sha1-HUCLP9t2kjuVQ9lvtMnf1TXZy10="
2638 | },
2639 | "pify": {
2640 | "version": "3.0.0",
2641 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz",
2642 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=",
2643 | "dev": true
2644 | },
2645 | "posix-character-classes": {
2646 | "version": "0.1.1",
2647 | "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz",
2648 | "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=",
2649 | "dev": true
2650 | },
2651 | "prepend-http": {
2652 | "version": "1.0.4",
2653 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz",
2654 | "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=",
2655 | "dev": true
2656 | },
2657 | "process-nextick-args": {
2658 | "version": "2.0.0",
2659 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz",
2660 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==",
2661 | "dev": true
2662 | },
2663 | "proxy-addr": {
2664 | "version": "2.0.4",
2665 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.4.tgz",
2666 | "integrity": "sha512-5erio2h9jp5CHGwcybmxmVqHmnCBZeewlfJ0pex+UW7Qny7OOZXTtH56TGNyBizkgiOwhJtMKrVzDTeKcySZwA==",
2667 | "requires": {
2668 | "forwarded": "~0.1.2",
2669 | "ipaddr.js": "1.8.0"
2670 | }
2671 | },
2672 | "pseudomap": {
2673 | "version": "1.0.2",
2674 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz",
2675 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=",
2676 | "dev": true
2677 | },
2678 | "pstree.remy": {
2679 | "version": "1.1.6",
2680 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.6.tgz",
2681 | "integrity": "sha512-NdF35+QsqD7EgNEI5mkI/X+UwaxVEbQaz9f4IooEmMUv6ZPmlTQYGjBPJGgrlzNdjSvIy4MWMg6Q6vCgBO2K+w==",
2682 | "dev": true
2683 | },
2684 | "pump": {
2685 | "version": "3.0.0",
2686 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz",
2687 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==",
2688 | "dev": true,
2689 | "requires": {
2690 | "end-of-stream": "^1.1.0",
2691 | "once": "^1.3.1"
2692 | }
2693 | },
2694 | "qs": {
2695 | "version": "6.5.2",
2696 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz",
2697 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA=="
2698 | },
2699 | "range-parser": {
2700 | "version": "1.2.0",
2701 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz",
2702 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4="
2703 | },
2704 | "raw-body": {
2705 | "version": "2.3.3",
2706 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.3.tgz",
2707 | "integrity": "sha512-9esiElv1BrZoI3rCDuOuKCBRbuApGGaDPQfjSflGxdy4oyzqghxu6klEkkVIvBje+FF0BX9coEv8KqW6X/7njw==",
2708 | "requires": {
2709 | "bytes": "3.0.0",
2710 | "http-errors": "1.6.3",
2711 | "iconv-lite": "0.4.23",
2712 | "unpipe": "1.0.0"
2713 | }
2714 | },
2715 | "rc": {
2716 | "version": "1.2.8",
2717 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz",
2718 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==",
2719 | "dev": true,
2720 | "requires": {
2721 | "deep-extend": "^0.6.0",
2722 | "ini": "~1.3.0",
2723 | "minimist": "^1.2.0",
2724 | "strip-json-comments": "~2.0.1"
2725 | },
2726 | "dependencies": {
2727 | "minimist": {
2728 | "version": "1.2.0",
2729 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz",
2730 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=",
2731 | "dev": true
2732 | }
2733 | }
2734 | },
2735 | "read-pkg": {
2736 | "version": "4.0.1",
2737 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-4.0.1.tgz",
2738 | "integrity": "sha1-ljYlN48+HE1IyFhytabsfV0JMjc=",
2739 | "dev": true,
2740 | "requires": {
2741 | "normalize-package-data": "^2.3.2",
2742 | "parse-json": "^4.0.0",
2743 | "pify": "^3.0.0"
2744 | }
2745 | },
2746 | "readable-stream": {
2747 | "version": "2.3.6",
2748 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz",
2749 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==",
2750 | "dev": true,
2751 | "requires": {
2752 | "core-util-is": "~1.0.0",
2753 | "inherits": "~2.0.3",
2754 | "isarray": "~1.0.0",
2755 | "process-nextick-args": "~2.0.0",
2756 | "safe-buffer": "~5.1.1",
2757 | "string_decoder": "~1.1.1",
2758 | "util-deprecate": "~1.0.1"
2759 | }
2760 | },
2761 | "readdirp": {
2762 | "version": "2.2.1",
2763 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz",
2764 | "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==",
2765 | "dev": true,
2766 | "requires": {
2767 | "graceful-fs": "^4.1.11",
2768 | "micromatch": "^3.1.10",
2769 | "readable-stream": "^2.0.2"
2770 | }
2771 | },
2772 | "regex-not": {
2773 | "version": "1.0.2",
2774 | "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz",
2775 | "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==",
2776 | "dev": true,
2777 | "requires": {
2778 | "extend-shallow": "^3.0.2",
2779 | "safe-regex": "^1.1.0"
2780 | }
2781 | },
2782 | "regexp-clone": {
2783 | "version": "0.0.1",
2784 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-0.0.1.tgz",
2785 | "integrity": "sha1-p8LgmJH9vzj7sQ03b7cwA+aKxYk="
2786 | },
2787 | "registry-auth-token": {
2788 | "version": "3.3.2",
2789 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-3.3.2.tgz",
2790 | "integrity": "sha512-JL39c60XlzCVgNrO+qq68FoNb56w/m7JYvGR2jT5iR1xBrUA3Mfx5Twk5rqTThPmQKMWydGmq8oFtDlxfrmxnQ==",
2791 | "dev": true,
2792 | "requires": {
2793 | "rc": "^1.1.6",
2794 | "safe-buffer": "^5.0.1"
2795 | }
2796 | },
2797 | "registry-url": {
2798 | "version": "3.1.0",
2799 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-3.1.0.tgz",
2800 | "integrity": "sha1-PU74cPc93h138M+aOBQyRE4XSUI=",
2801 | "dev": true,
2802 | "requires": {
2803 | "rc": "^1.0.1"
2804 | }
2805 | },
2806 | "remove-trailing-separator": {
2807 | "version": "1.1.0",
2808 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz",
2809 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=",
2810 | "dev": true
2811 | },
2812 | "repeat-element": {
2813 | "version": "1.1.3",
2814 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz",
2815 | "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==",
2816 | "dev": true
2817 | },
2818 | "repeat-string": {
2819 | "version": "1.6.1",
2820 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz",
2821 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=",
2822 | "dev": true
2823 | },
2824 | "require-directory": {
2825 | "version": "2.1.1",
2826 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
2827 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=",
2828 | "dev": true
2829 | },
2830 | "require-main-filename": {
2831 | "version": "1.0.1",
2832 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz",
2833 | "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=",
2834 | "dev": true
2835 | },
2836 | "require_optional": {
2837 | "version": "1.0.1",
2838 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz",
2839 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==",
2840 | "requires": {
2841 | "resolve-from": "^2.0.0",
2842 | "semver": "^5.1.0"
2843 | }
2844 | },
2845 | "resolve-from": {
2846 | "version": "2.0.0",
2847 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz",
2848 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c="
2849 | },
2850 | "resolve-url": {
2851 | "version": "0.2.1",
2852 | "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz",
2853 | "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=",
2854 | "dev": true
2855 | },
2856 | "ret": {
2857 | "version": "0.1.15",
2858 | "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz",
2859 | "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==",
2860 | "dev": true
2861 | },
2862 | "rxjs": {
2863 | "version": "6.3.3",
2864 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.3.3.tgz",
2865 | "integrity": "sha512-JTWmoY9tWCs7zvIk/CvRjhjGaOd+OVBM987mxFo+OW66cGpdKjZcpmc74ES1sB//7Kl/PAe8+wEakuhG4pcgOw==",
2866 | "dev": true,
2867 | "requires": {
2868 | "tslib": "^1.9.0"
2869 | }
2870 | },
2871 | "safe-buffer": {
2872 | "version": "5.1.2",
2873 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
2874 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
2875 | },
2876 | "safe-regex": {
2877 | "version": "1.1.0",
2878 | "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz",
2879 | "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=",
2880 | "dev": true,
2881 | "requires": {
2882 | "ret": "~0.1.10"
2883 | }
2884 | },
2885 | "safer-buffer": {
2886 | "version": "2.1.2",
2887 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
2888 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
2889 | },
2890 | "saslprep": {
2891 | "version": "1.0.2",
2892 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.2.tgz",
2893 | "integrity": "sha512-4cDsYuAjXssUSjxHKRe4DTZC0agDwsCqcMqtJAQPzC74nJ7LfAJflAtC1Zed5hMzEQKj82d3tuzqdGNRsLJ4Gw==",
2894 | "optional": true,
2895 | "requires": {
2896 | "sparse-bitfield": "^3.0.3"
2897 | }
2898 | },
2899 | "semver": {
2900 | "version": "5.6.0",
2901 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz",
2902 | "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg=="
2903 | },
2904 | "semver-diff": {
2905 | "version": "2.1.0",
2906 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-2.1.0.tgz",
2907 | "integrity": "sha1-S7uEN8jTfksM8aaP1ybsbWRdbTY=",
2908 | "dev": true,
2909 | "requires": {
2910 | "semver": "^5.0.3"
2911 | }
2912 | },
2913 | "send": {
2914 | "version": "0.16.2",
2915 | "resolved": "https://registry.npmjs.org/send/-/send-0.16.2.tgz",
2916 | "integrity": "sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw==",
2917 | "requires": {
2918 | "debug": "2.6.9",
2919 | "depd": "~1.1.2",
2920 | "destroy": "~1.0.4",
2921 | "encodeurl": "~1.0.2",
2922 | "escape-html": "~1.0.3",
2923 | "etag": "~1.8.1",
2924 | "fresh": "0.5.2",
2925 | "http-errors": "~1.6.2",
2926 | "mime": "1.4.1",
2927 | "ms": "2.0.0",
2928 | "on-finished": "~2.3.0",
2929 | "range-parser": "~1.2.0",
2930 | "statuses": "~1.4.0"
2931 | }
2932 | },
2933 | "serve-static": {
2934 | "version": "1.13.2",
2935 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.13.2.tgz",
2936 | "integrity": "sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw==",
2937 | "requires": {
2938 | "encodeurl": "~1.0.2",
2939 | "escape-html": "~1.0.3",
2940 | "parseurl": "~1.3.2",
2941 | "send": "0.16.2"
2942 | }
2943 | },
2944 | "set-blocking": {
2945 | "version": "2.0.0",
2946 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz",
2947 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=",
2948 | "dev": true
2949 | },
2950 | "set-value": {
2951 | "version": "2.0.0",
2952 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.0.tgz",
2953 | "integrity": "sha512-hw0yxk9GT/Hr5yJEYnHNKYXkIA8mVJgd9ditYZCe16ZczcaELYYcfvaXesNACk2O8O0nTiPQcQhGUQj8JLzeeg==",
2954 | "dev": true,
2955 | "requires": {
2956 | "extend-shallow": "^2.0.1",
2957 | "is-extendable": "^0.1.1",
2958 | "is-plain-object": "^2.0.3",
2959 | "split-string": "^3.0.1"
2960 | },
2961 | "dependencies": {
2962 | "extend-shallow": {
2963 | "version": "2.0.1",
2964 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
2965 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
2966 | "dev": true,
2967 | "requires": {
2968 | "is-extendable": "^0.1.0"
2969 | }
2970 | }
2971 | }
2972 | },
2973 | "setprototypeof": {
2974 | "version": "1.1.0",
2975 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz",
2976 | "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ=="
2977 | },
2978 | "shebang-command": {
2979 | "version": "1.2.0",
2980 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz",
2981 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=",
2982 | "dev": true,
2983 | "requires": {
2984 | "shebang-regex": "^1.0.0"
2985 | }
2986 | },
2987 | "shebang-regex": {
2988 | "version": "1.0.0",
2989 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz",
2990 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=",
2991 | "dev": true
2992 | },
2993 | "signal-exit": {
2994 | "version": "3.0.2",
2995 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz",
2996 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=",
2997 | "dev": true
2998 | },
2999 | "sliced": {
3000 | "version": "1.0.1",
3001 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz",
3002 | "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E="
3003 | },
3004 | "snapdragon": {
3005 | "version": "0.8.2",
3006 | "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz",
3007 | "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==",
3008 | "dev": true,
3009 | "requires": {
3010 | "base": "^0.11.1",
3011 | "debug": "^2.2.0",
3012 | "define-property": "^0.2.5",
3013 | "extend-shallow": "^2.0.1",
3014 | "map-cache": "^0.2.2",
3015 | "source-map": "^0.5.6",
3016 | "source-map-resolve": "^0.5.0",
3017 | "use": "^3.1.0"
3018 | },
3019 | "dependencies": {
3020 | "define-property": {
3021 | "version": "0.2.5",
3022 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
3023 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
3024 | "dev": true,
3025 | "requires": {
3026 | "is-descriptor": "^0.1.0"
3027 | }
3028 | },
3029 | "extend-shallow": {
3030 | "version": "2.0.1",
3031 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
3032 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
3033 | "dev": true,
3034 | "requires": {
3035 | "is-extendable": "^0.1.0"
3036 | }
3037 | }
3038 | }
3039 | },
3040 | "snapdragon-node": {
3041 | "version": "2.1.1",
3042 | "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz",
3043 | "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==",
3044 | "dev": true,
3045 | "requires": {
3046 | "define-property": "^1.0.0",
3047 | "isobject": "^3.0.0",
3048 | "snapdragon-util": "^3.0.1"
3049 | },
3050 | "dependencies": {
3051 | "define-property": {
3052 | "version": "1.0.0",
3053 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz",
3054 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=",
3055 | "dev": true,
3056 | "requires": {
3057 | "is-descriptor": "^1.0.0"
3058 | }
3059 | },
3060 | "is-accessor-descriptor": {
3061 | "version": "1.0.0",
3062 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
3063 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
3064 | "dev": true,
3065 | "requires": {
3066 | "kind-of": "^6.0.0"
3067 | }
3068 | },
3069 | "is-data-descriptor": {
3070 | "version": "1.0.0",
3071 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
3072 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
3073 | "dev": true,
3074 | "requires": {
3075 | "kind-of": "^6.0.0"
3076 | }
3077 | },
3078 | "is-descriptor": {
3079 | "version": "1.0.2",
3080 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
3081 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
3082 | "dev": true,
3083 | "requires": {
3084 | "is-accessor-descriptor": "^1.0.0",
3085 | "is-data-descriptor": "^1.0.0",
3086 | "kind-of": "^6.0.2"
3087 | }
3088 | }
3089 | }
3090 | },
3091 | "snapdragon-util": {
3092 | "version": "3.0.1",
3093 | "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz",
3094 | "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==",
3095 | "dev": true,
3096 | "requires": {
3097 | "kind-of": "^3.2.0"
3098 | },
3099 | "dependencies": {
3100 | "kind-of": {
3101 | "version": "3.2.2",
3102 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
3103 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
3104 | "dev": true,
3105 | "requires": {
3106 | "is-buffer": "^1.1.5"
3107 | }
3108 | }
3109 | }
3110 | },
3111 | "source-map": {
3112 | "version": "0.5.7",
3113 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz",
3114 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=",
3115 | "dev": true
3116 | },
3117 | "source-map-resolve": {
3118 | "version": "0.5.2",
3119 | "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.2.tgz",
3120 | "integrity": "sha512-MjqsvNwyz1s0k81Goz/9vRBe9SZdB09Bdw+/zYyO+3CuPk6fouTaxscHkgtE8jKvf01kVfl8riHzERQ/kefaSA==",
3121 | "dev": true,
3122 | "requires": {
3123 | "atob": "^2.1.1",
3124 | "decode-uri-component": "^0.2.0",
3125 | "resolve-url": "^0.2.1",
3126 | "source-map-url": "^0.4.0",
3127 | "urix": "^0.1.0"
3128 | }
3129 | },
3130 | "source-map-url": {
3131 | "version": "0.4.0",
3132 | "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz",
3133 | "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=",
3134 | "dev": true
3135 | },
3136 | "sparse-bitfield": {
3137 | "version": "3.0.3",
3138 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz",
3139 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=",
3140 | "optional": true,
3141 | "requires": {
3142 | "memory-pager": "^1.0.2"
3143 | }
3144 | },
3145 | "spawn-command": {
3146 | "version": "0.0.2-1",
3147 | "resolved": "https://registry.npmjs.org/spawn-command/-/spawn-command-0.0.2-1.tgz",
3148 | "integrity": "sha1-YvXpRmmBwbeW3Fkpk34RycaSG9A=",
3149 | "dev": true
3150 | },
3151 | "spdx-correct": {
3152 | "version": "3.1.0",
3153 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz",
3154 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==",
3155 | "dev": true,
3156 | "requires": {
3157 | "spdx-expression-parse": "^3.0.0",
3158 | "spdx-license-ids": "^3.0.0"
3159 | }
3160 | },
3161 | "spdx-exceptions": {
3162 | "version": "2.2.0",
3163 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz",
3164 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==",
3165 | "dev": true
3166 | },
3167 | "spdx-expression-parse": {
3168 | "version": "3.0.0",
3169 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz",
3170 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==",
3171 | "dev": true,
3172 | "requires": {
3173 | "spdx-exceptions": "^2.1.0",
3174 | "spdx-license-ids": "^3.0.0"
3175 | }
3176 | },
3177 | "spdx-license-ids": {
3178 | "version": "3.0.3",
3179 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.3.tgz",
3180 | "integrity": "sha512-uBIcIl3Ih6Phe3XHK1NqboJLdGfwr1UN3k6wSD1dZpmPsIkb8AGNbZYJ1fOBk834+Gxy8rpfDxrS6XLEMZMY2g==",
3181 | "dev": true
3182 | },
3183 | "split-string": {
3184 | "version": "3.1.0",
3185 | "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz",
3186 | "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==",
3187 | "dev": true,
3188 | "requires": {
3189 | "extend-shallow": "^3.0.0"
3190 | }
3191 | },
3192 | "static-extend": {
3193 | "version": "0.1.2",
3194 | "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz",
3195 | "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=",
3196 | "dev": true,
3197 | "requires": {
3198 | "define-property": "^0.2.5",
3199 | "object-copy": "^0.1.0"
3200 | },
3201 | "dependencies": {
3202 | "define-property": {
3203 | "version": "0.2.5",
3204 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
3205 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
3206 | "dev": true,
3207 | "requires": {
3208 | "is-descriptor": "^0.1.0"
3209 | }
3210 | }
3211 | }
3212 | },
3213 | "statuses": {
3214 | "version": "1.4.0",
3215 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz",
3216 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew=="
3217 | },
3218 | "string-width": {
3219 | "version": "2.1.1",
3220 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz",
3221 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==",
3222 | "dev": true,
3223 | "requires": {
3224 | "is-fullwidth-code-point": "^2.0.0",
3225 | "strip-ansi": "^4.0.0"
3226 | },
3227 | "dependencies": {
3228 | "ansi-regex": {
3229 | "version": "3.0.0",
3230 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz",
3231 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=",
3232 | "dev": true
3233 | },
3234 | "strip-ansi": {
3235 | "version": "4.0.0",
3236 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz",
3237 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=",
3238 | "dev": true,
3239 | "requires": {
3240 | "ansi-regex": "^3.0.0"
3241 | }
3242 | }
3243 | }
3244 | },
3245 | "string_decoder": {
3246 | "version": "1.1.1",
3247 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
3248 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
3249 | "dev": true,
3250 | "requires": {
3251 | "safe-buffer": "~5.1.0"
3252 | }
3253 | },
3254 | "strip-ansi": {
3255 | "version": "4.0.0",
3256 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz",
3257 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=",
3258 | "dev": true,
3259 | "requires": {
3260 | "ansi-regex": "^3.0.0"
3261 | }
3262 | },
3263 | "strip-eof": {
3264 | "version": "1.0.0",
3265 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz",
3266 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=",
3267 | "dev": true
3268 | },
3269 | "strip-json-comments": {
3270 | "version": "2.0.1",
3271 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz",
3272 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=",
3273 | "dev": true
3274 | },
3275 | "supports-color": {
3276 | "version": "5.5.0",
3277 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
3278 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
3279 | "dev": true,
3280 | "requires": {
3281 | "has-flag": "^3.0.0"
3282 | }
3283 | },
3284 | "term-size": {
3285 | "version": "1.2.0",
3286 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-1.2.0.tgz",
3287 | "integrity": "sha1-RYuDiH8oj8Vtb/+/rSYuJmOO+mk=",
3288 | "dev": true,
3289 | "requires": {
3290 | "execa": "^0.7.0"
3291 | },
3292 | "dependencies": {
3293 | "cross-spawn": {
3294 | "version": "5.1.0",
3295 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz",
3296 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=",
3297 | "dev": true,
3298 | "requires": {
3299 | "lru-cache": "^4.0.1",
3300 | "shebang-command": "^1.2.0",
3301 | "which": "^1.2.9"
3302 | }
3303 | },
3304 | "execa": {
3305 | "version": "0.7.0",
3306 | "resolved": "https://registry.npmjs.org/execa/-/execa-0.7.0.tgz",
3307 | "integrity": "sha1-lEvs00zEHuMqY6n68nrVpl/Fl3c=",
3308 | "dev": true,
3309 | "requires": {
3310 | "cross-spawn": "^5.0.1",
3311 | "get-stream": "^3.0.0",
3312 | "is-stream": "^1.1.0",
3313 | "npm-run-path": "^2.0.0",
3314 | "p-finally": "^1.0.0",
3315 | "signal-exit": "^3.0.0",
3316 | "strip-eof": "^1.0.0"
3317 | }
3318 | }
3319 | }
3320 | },
3321 | "timed-out": {
3322 | "version": "4.0.1",
3323 | "resolved": "https://registry.npmjs.org/timed-out/-/timed-out-4.0.1.tgz",
3324 | "integrity": "sha1-8y6srFoXW+ol1/q1Zas+2HQe9W8=",
3325 | "dev": true
3326 | },
3327 | "to-object-path": {
3328 | "version": "0.3.0",
3329 | "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz",
3330 | "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=",
3331 | "dev": true,
3332 | "requires": {
3333 | "kind-of": "^3.0.2"
3334 | },
3335 | "dependencies": {
3336 | "kind-of": {
3337 | "version": "3.2.2",
3338 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
3339 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
3340 | "dev": true,
3341 | "requires": {
3342 | "is-buffer": "^1.1.5"
3343 | }
3344 | }
3345 | }
3346 | },
3347 | "to-regex": {
3348 | "version": "3.0.2",
3349 | "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz",
3350 | "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==",
3351 | "dev": true,
3352 | "requires": {
3353 | "define-property": "^2.0.2",
3354 | "extend-shallow": "^3.0.2",
3355 | "regex-not": "^1.0.2",
3356 | "safe-regex": "^1.1.0"
3357 | }
3358 | },
3359 | "to-regex-range": {
3360 | "version": "2.1.1",
3361 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz",
3362 | "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=",
3363 | "dev": true,
3364 | "requires": {
3365 | "is-number": "^3.0.0",
3366 | "repeat-string": "^1.6.1"
3367 | }
3368 | },
3369 | "touch": {
3370 | "version": "3.1.0",
3371 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz",
3372 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==",
3373 | "dev": true,
3374 | "requires": {
3375 | "nopt": "~1.0.10"
3376 | }
3377 | },
3378 | "tree-kill": {
3379 | "version": "1.2.1",
3380 | "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.1.tgz",
3381 | "integrity": "sha512-4hjqbObwlh2dLyW4tcz0Ymw0ggoaVDMveUB9w8kFSQScdRLo0gxO9J7WFcUBo+W3C1TLdFIEwNOWebgZZ0RH9Q==",
3382 | "dev": true
3383 | },
3384 | "tslib": {
3385 | "version": "1.9.3",
3386 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz",
3387 | "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==",
3388 | "dev": true
3389 | },
3390 | "type-is": {
3391 | "version": "1.6.16",
3392 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.16.tgz",
3393 | "integrity": "sha512-HRkVv/5qY2G6I8iab9cI7v1bOIdhm94dVjQCPFElW9W+3GeDOSHmy2EBYe4VTApuzolPcmgFTN3ftVJRKR2J9Q==",
3394 | "requires": {
3395 | "media-typer": "0.3.0",
3396 | "mime-types": "~2.1.18"
3397 | }
3398 | },
3399 | "undefsafe": {
3400 | "version": "2.0.2",
3401 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.2.tgz",
3402 | "integrity": "sha1-Il9rngM3Zj4Njnz9aG/Cg2zKznY=",
3403 | "dev": true,
3404 | "requires": {
3405 | "debug": "^2.2.0"
3406 | }
3407 | },
3408 | "union-value": {
3409 | "version": "1.0.0",
3410 | "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.0.tgz",
3411 | "integrity": "sha1-XHHDTLW61dzr4+oM0IIHulqhrqQ=",
3412 | "dev": true,
3413 | "requires": {
3414 | "arr-union": "^3.1.0",
3415 | "get-value": "^2.0.6",
3416 | "is-extendable": "^0.1.1",
3417 | "set-value": "^0.4.3"
3418 | },
3419 | "dependencies": {
3420 | "extend-shallow": {
3421 | "version": "2.0.1",
3422 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
3423 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
3424 | "dev": true,
3425 | "requires": {
3426 | "is-extendable": "^0.1.0"
3427 | }
3428 | },
3429 | "set-value": {
3430 | "version": "0.4.3",
3431 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-0.4.3.tgz",
3432 | "integrity": "sha1-fbCPnT0i3H945Trzw79GZuzfzPE=",
3433 | "dev": true,
3434 | "requires": {
3435 | "extend-shallow": "^2.0.1",
3436 | "is-extendable": "^0.1.1",
3437 | "is-plain-object": "^2.0.1",
3438 | "to-object-path": "^0.3.0"
3439 | }
3440 | }
3441 | }
3442 | },
3443 | "unique-string": {
3444 | "version": "1.0.0",
3445 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-1.0.0.tgz",
3446 | "integrity": "sha1-nhBXzKhRq7kzmPizOuGHuZyuwRo=",
3447 | "dev": true,
3448 | "requires": {
3449 | "crypto-random-string": "^1.0.0"
3450 | }
3451 | },
3452 | "unpipe": {
3453 | "version": "1.0.0",
3454 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
3455 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw="
3456 | },
3457 | "unset-value": {
3458 | "version": "1.0.0",
3459 | "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz",
3460 | "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=",
3461 | "dev": true,
3462 | "requires": {
3463 | "has-value": "^0.3.1",
3464 | "isobject": "^3.0.0"
3465 | },
3466 | "dependencies": {
3467 | "has-value": {
3468 | "version": "0.3.1",
3469 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz",
3470 | "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=",
3471 | "dev": true,
3472 | "requires": {
3473 | "get-value": "^2.0.3",
3474 | "has-values": "^0.1.4",
3475 | "isobject": "^2.0.0"
3476 | },
3477 | "dependencies": {
3478 | "isobject": {
3479 | "version": "2.1.0",
3480 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz",
3481 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=",
3482 | "dev": true,
3483 | "requires": {
3484 | "isarray": "1.0.0"
3485 | }
3486 | }
3487 | }
3488 | },
3489 | "has-values": {
3490 | "version": "0.1.4",
3491 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz",
3492 | "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=",
3493 | "dev": true
3494 | }
3495 | }
3496 | },
3497 | "unzip-response": {
3498 | "version": "2.0.1",
3499 | "resolved": "https://registry.npmjs.org/unzip-response/-/unzip-response-2.0.1.tgz",
3500 | "integrity": "sha1-0vD3N9FrBhXnKmk17QQhRXLVb5c=",
3501 | "dev": true
3502 | },
3503 | "upath": {
3504 | "version": "1.1.0",
3505 | "resolved": "https://registry.npmjs.org/upath/-/upath-1.1.0.tgz",
3506 | "integrity": "sha512-bzpH/oBhoS/QI/YtbkqCg6VEiPYjSZtrHQM6/QnJS6OL9pKUFLqb3aFh4Scvwm45+7iAgiMkLhSbaZxUqmrprw==",
3507 | "dev": true
3508 | },
3509 | "update-notifier": {
3510 | "version": "2.5.0",
3511 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-2.5.0.tgz",
3512 | "integrity": "sha512-gwMdhgJHGuj/+wHJJs9e6PcCszpxR1b236igrOkUofGhqJuG+amlIKwApH1IW1WWl7ovZxsX49lMBWLxSdm5Dw==",
3513 | "dev": true,
3514 | "requires": {
3515 | "boxen": "^1.2.1",
3516 | "chalk": "^2.0.1",
3517 | "configstore": "^3.0.0",
3518 | "import-lazy": "^2.1.0",
3519 | "is-ci": "^1.0.10",
3520 | "is-installed-globally": "^0.1.0",
3521 | "is-npm": "^1.0.0",
3522 | "latest-version": "^3.0.0",
3523 | "semver-diff": "^2.0.0",
3524 | "xdg-basedir": "^3.0.0"
3525 | }
3526 | },
3527 | "urix": {
3528 | "version": "0.1.0",
3529 | "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz",
3530 | "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=",
3531 | "dev": true
3532 | },
3533 | "url-parse-lax": {
3534 | "version": "1.0.0",
3535 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-1.0.0.tgz",
3536 | "integrity": "sha1-evjzA2Rem9eaJy56FKxovAYJ2nM=",
3537 | "dev": true,
3538 | "requires": {
3539 | "prepend-http": "^1.0.1"
3540 | }
3541 | },
3542 | "use": {
3543 | "version": "3.1.1",
3544 | "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz",
3545 | "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==",
3546 | "dev": true
3547 | },
3548 | "util-deprecate": {
3549 | "version": "1.0.2",
3550 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
3551 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=",
3552 | "dev": true
3553 | },
3554 | "utils-merge": {
3555 | "version": "1.0.1",
3556 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
3557 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM="
3558 | },
3559 | "validate-npm-package-license": {
3560 | "version": "3.0.4",
3561 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz",
3562 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==",
3563 | "dev": true,
3564 | "requires": {
3565 | "spdx-correct": "^3.0.0",
3566 | "spdx-expression-parse": "^3.0.0"
3567 | }
3568 | },
3569 | "validator": {
3570 | "version": "10.10.0",
3571 | "resolved": "https://registry.npmjs.org/validator/-/validator-10.10.0.tgz",
3572 | "integrity": "sha512-DyZyLJlMXM3CGdVaVHE/EDzCagMRoPI3mmGdxxNQbqkGqh56+M3d1i0ZAWd69En8U21DHbPTn12aOdhO+hfm5w=="
3573 | },
3574 | "vary": {
3575 | "version": "1.1.2",
3576 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
3577 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw="
3578 | },
3579 | "which": {
3580 | "version": "1.3.1",
3581 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz",
3582 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==",
3583 | "dev": true,
3584 | "requires": {
3585 | "isexe": "^2.0.0"
3586 | }
3587 | },
3588 | "which-module": {
3589 | "version": "2.0.0",
3590 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz",
3591 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=",
3592 | "dev": true
3593 | },
3594 | "widest-line": {
3595 | "version": "2.0.1",
3596 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-2.0.1.tgz",
3597 | "integrity": "sha512-Ba5m9/Fa4Xt9eb2ELXt77JxVDV8w7qQrH0zS/TWSJdLyAwQjWoOzpzj5lwVftDz6n/EOu3tNACS84v509qwnJA==",
3598 | "dev": true,
3599 | "requires": {
3600 | "string-width": "^2.1.1"
3601 | }
3602 | },
3603 | "wrap-ansi": {
3604 | "version": "2.1.0",
3605 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz",
3606 | "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=",
3607 | "dev": true,
3608 | "requires": {
3609 | "string-width": "^1.0.1",
3610 | "strip-ansi": "^3.0.1"
3611 | },
3612 | "dependencies": {
3613 | "ansi-regex": {
3614 | "version": "2.1.1",
3615 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz",
3616 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=",
3617 | "dev": true
3618 | },
3619 | "is-fullwidth-code-point": {
3620 | "version": "1.0.0",
3621 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz",
3622 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=",
3623 | "dev": true,
3624 | "requires": {
3625 | "number-is-nan": "^1.0.0"
3626 | }
3627 | },
3628 | "string-width": {
3629 | "version": "1.0.2",
3630 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz",
3631 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=",
3632 | "dev": true,
3633 | "requires": {
3634 | "code-point-at": "^1.0.0",
3635 | "is-fullwidth-code-point": "^1.0.0",
3636 | "strip-ansi": "^3.0.0"
3637 | }
3638 | },
3639 | "strip-ansi": {
3640 | "version": "3.0.1",
3641 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz",
3642 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=",
3643 | "dev": true,
3644 | "requires": {
3645 | "ansi-regex": "^2.0.0"
3646 | }
3647 | }
3648 | }
3649 | },
3650 | "wrappy": {
3651 | "version": "1.0.2",
3652 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
3653 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=",
3654 | "dev": true
3655 | },
3656 | "write-file-atomic": {
3657 | "version": "2.3.0",
3658 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.3.0.tgz",
3659 | "integrity": "sha512-xuPeK4OdjWqtfi59ylvVL0Yn35SF3zgcAcv7rBPFHVaEapaDr4GdGgm3j7ckTwH9wHL7fGmgfAnb0+THrHb8tA==",
3660 | "dev": true,
3661 | "requires": {
3662 | "graceful-fs": "^4.1.11",
3663 | "imurmurhash": "^0.1.4",
3664 | "signal-exit": "^3.0.2"
3665 | }
3666 | },
3667 | "xdg-basedir": {
3668 | "version": "3.0.0",
3669 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-3.0.0.tgz",
3670 | "integrity": "sha1-SWsswQnsqNus/i3HK2A8F8WHCtQ=",
3671 | "dev": true
3672 | },
3673 | "y18n": {
3674 | "version": "4.0.0",
3675 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz",
3676 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==",
3677 | "dev": true
3678 | },
3679 | "yargs": {
3680 | "version": "12.0.5",
3681 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-12.0.5.tgz",
3682 | "integrity": "sha512-Lhz8TLaYnxq/2ObqHDql8dX8CJi97oHxrjUcYtzKbbykPtVW9WB+poxI+NM2UIzsMgNCZTIf0AQwsjK5yMAqZw==",
3683 | "dev": true,
3684 | "requires": {
3685 | "cliui": "^4.0.0",
3686 | "decamelize": "^1.2.0",
3687 | "find-up": "^3.0.0",
3688 | "get-caller-file": "^1.0.1",
3689 | "os-locale": "^3.0.0",
3690 | "require-directory": "^2.1.1",
3691 | "require-main-filename": "^1.0.1",
3692 | "set-blocking": "^2.0.0",
3693 | "string-width": "^2.0.0",
3694 | "which-module": "^2.0.0",
3695 | "y18n": "^3.2.1 || ^4.0.0",
3696 | "yargs-parser": "^11.1.1"
3697 | }
3698 | },
3699 | "yargs-parser": {
3700 | "version": "11.1.1",
3701 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-11.1.1.tgz",
3702 | "integrity": "sha512-C6kB/WJDiaxONLJQnF8ccx9SEeoTTLek8RVbaOIsrAUS8VrBEXfmeSnCZxygc+XC2sNMBIwOOnfcxiynjHsVSQ==",
3703 | "dev": true,
3704 | "requires": {
3705 | "camelcase": "^5.0.0",
3706 | "decamelize": "^1.2.0"
3707 | },
3708 | "dependencies": {
3709 | "camelcase": {
3710 | "version": "5.0.0",
3711 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.0.0.tgz",
3712 | "integrity": "sha512-faqwZqnWxbxn+F1d399ygeamQNy3lPp/H9H6rNrqYh4FSVCtcY+3cub1MxA8o9mDd55mM8Aghuu/kuyYA6VTsA==",
3713 | "dev": true
3714 | }
3715 | }
3716 | }
3717 | }
3718 | }
3719 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "money-management-app",
3 | "version": "1.0.0",
4 | "description": "",
5 | "main": "server.js",
6 | "scripts": {
7 | "start": "node server.js",
8 | "server": "node server.js",
9 | "client": "npm start --prefix client",
10 | "dev": "concurrently \"npm run server\" \"npm run client\"",
11 | "heroku-postbuild": "NPM_CONFIG_PRODUCTION=false npm install --prefix client && npm run build --prefix client"
12 | },
13 | "keywords": [],
14 | "author": "",
15 | "license": "ISC",
16 | "devDependencies": {
17 | "concurrently": "^4.1.0",
18 | "nodemon": "^1.18.9"
19 | },
20 | "dependencies": {
21 | "bcrypt": "^3.0.3",
22 | "body-parser": "^1.18.3",
23 | "cors": "^2.8.5",
24 | "express": "^4.16.4",
25 | "jsonwebtoken": "^8.4.0",
26 | "jwt-decode": "^2.2.0",
27 | "mongoose": "^5.4.0",
28 | "morgan": "^1.9.1",
29 | "passport": "^0.4.0",
30 | "passport-jwt": "^4.0.0",
31 | "validator": "^10.10.0"
32 | },
33 | "engines": {
34 | "node": "11.3.0"
35 | }
36 | }
37 |
--------------------------------------------------------------------------------
/passport.js:
--------------------------------------------------------------------------------
1 | const JwtStrategy = require('passport-jwt').Strategy
2 | const ExtractJwt = require('passport-jwt').ExtractJwt
3 | const User = require('./model/User')
4 |
5 | const opts = {}
6 | opts.jwtFromRequest = ExtractJwt.fromAuthHeaderAsBearerToken();
7 | opts.secretOrKey = 'SECRET';
8 |
9 | module.exports = passport => {
10 | passport.use(new JwtStrategy(opts, (payload, done) => {
11 | User.findOne({ _id: payload._id })
12 | .then(user => {
13 | if (!user) {
14 | return done(null, false)
15 | } else {
16 | return done(null, user)
17 | }
18 | })
19 | .catch(error => {
20 | console.log(error)
21 | return done(error)
22 | })
23 | }))
24 | }
--------------------------------------------------------------------------------
/routers/transactionRoute.js:
--------------------------------------------------------------------------------
1 | const router = require('express').Router()
2 | const {getAll, create, update, getSingleTransaction, remove} = require('../controllers/transactionController')
3 | const authenticate = require('../authenticate')
4 |
5 | router.get('/', authenticate, getAll)
6 |
7 | router.post('/', authenticate, create)
8 |
9 | router.get('/:transactionId', authenticate, getSingleTransaction)
10 |
11 | router.put('/:transactionId', authenticate, update)
12 |
13 | router.delete('/:transactionId', authenticate, remove)
14 |
15 | module.exports = router
--------------------------------------------------------------------------------
/routers/userRoute.js:
--------------------------------------------------------------------------------
1 | const router = require('express').Router()
2 |
3 | const {login, register, allUser} = require('../controllers/userController')
4 |
5 | // Registration Route
6 | // localhost:4000/api/users/register
7 | router.post('/register', register)
8 |
9 | // Login Route
10 | // localhost:4000/api/users/login
11 | router.post('/login', login)
12 | router.get('/all', allUser)
13 |
14 | module.exports = router
--------------------------------------------------------------------------------
/server.js:
--------------------------------------------------------------------------------
1 | const express = require('express')
2 | const morgan = require('morgan')
3 | const cors = require('cors')
4 | const bodyParser = require('body-parser')
5 | const mongoose = require('mongoose')
6 | const passport = require('passport')
7 | const path = require('path')
8 |
9 | const app = express()
10 | app.use(morgan('dev'))
11 | app.use(cors())
12 |
13 | app.use(bodyParser.urlencoded({ extended: false }))
14 | app.use(bodyParser.json())
15 |
16 | app.use(passport.initialize())
17 | require('./passport')(passport)
18 |
19 | app.use('/api/users', require('./routers/userRoute'))
20 | app.use('/api/transactions', require('./routers/transactionRoute'))
21 |
22 | if (process.env.NODE_ENV === 'production') {
23 | app.use(express.static('client/build'))
24 | app.get('*', (req, res) => {
25 | res.sendFile(path.resolve(__dirname, 'client', 'build', 'index.html'))
26 | })
27 | }
28 |
29 | app.get('/', (req, res) => {
30 |
31 | res.json({
32 | message: 'Welcome To Our Application'
33 | })
34 | })
35 |
36 | const PORT = process.env.PORT || 4000
37 | app.listen(PORT, () => {
38 | console.log(`SERVER is RUNNING ON PORT ${PORT}`)
39 | mongoose.connect(`mongodb://${process.env.dbUsername}:${process.env.dbPassword}@ds261116.mlab.com:61116/money-app`,
40 | { useNewUrlParser: true },
41 | () => {
42 | console.log('Database Connected...')
43 | });
44 | })
45 |
--------------------------------------------------------------------------------
/util/error.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | serverError(res, error) {
3 | console.log(error);
4 | res.status(500).json({
5 | message: "Server Error Occurred"
6 | });
7 | },
8 | resourceError(res, message) {
9 | res.status(400).json({
10 | message
11 | });
12 | }
13 | };
14 |
--------------------------------------------------------------------------------
/validator/loginValidator.js:
--------------------------------------------------------------------------------
1 | const validator = require('validator')
2 |
3 | const validate = user => {
4 | let error = {}
5 |
6 | if (!user.email) {
7 | error.email = 'Please Provide Your Email'
8 | } else if (!validator.isEmail(user.email)) {
9 | error.email = 'Please Provide a Valid Email'
10 | }
11 |
12 | if (!user.password) {
13 | error.password = 'Please Provide a Password'
14 | }
15 |
16 | return {
17 | error,
18 | isValid: Object.keys(error).length === 0
19 | }
20 | }
21 |
22 | module.exports = validate
--------------------------------------------------------------------------------
/validator/registerValidator.js:
--------------------------------------------------------------------------------
1 | const validator = require('validator')
2 |
3 | const validate = user => {
4 | let error = {}
5 |
6 | if (!user.name) {
7 | error.name = 'Please Provide Your Name'
8 | }
9 |
10 | if (!user.email) {
11 | error.email = 'Please Provide Your Email'
12 | } else if (!validator.isEmail(user.email)) {
13 | error.email = 'Please Provide a Valid Email'
14 | }
15 |
16 | if (!user.password) {
17 | error.password = 'Please Provide a Password'
18 | } else if (user.password.length < 6) {
19 | error.password = 'Password Must be Greater or Equal 6 Character'
20 | }
21 |
22 | if (!user.confirmPassword) {
23 | error.confirmPassword = 'Please Provide Confirmation Password'
24 | } else if (user.password !== user.confirmPassword) {
25 | error.confirmPassword = 'Password Doesn\'t Match'
26 | }
27 |
28 | return {
29 | error,
30 | isValid: Object.keys(error).length === 0
31 | }
32 | }
33 |
34 | module.exports = validate
--------------------------------------------------------------------------------