├── .dockerignore
├── .editorconfig
├── .eslintrc
├── .gitignore
├── .prettierrc.json
├── Dockerfile
├── LICENSE.md
├── ReadMe.md
├── config
├── default.js
├── development.js
├── index.js
├── local.js
└── production.js
├── docker-compose.yaml
├── index.js
├── package-lock.json
├── package.json
├── scripts
├── startup.sh
└── wait-for.sh
├── server
├── api
│ ├── index.js
│ └── user
│ │ ├── config.js
│ │ ├── controller.js
│ │ ├── index.js
│ │ ├── route.js
│ │ └── test
│ │ └── controller.test.js
├── core
│ ├── bootstrapper.js
│ ├── commonErrorHandler.js
│ ├── connectors
│ │ ├── index.js
│ │ ├── mongo.js
│ │ ├── mysql.js
│ │ └── redis.js
│ ├── logger.js
│ └── shutdownManager.js
├── index.js
├── testHelpers
│ └── globals.js
└── utils
│ └── error.js
└── tools
├── cli.js
├── lib
├── generator.js
├── logger.js
├── processman.js
├── renderer.js
└── writer.js
└── templates
├── config.tpl
├── controller.tpl
├── index.tpl
├── model.tpl
├── repository.tpl
├── route.tpl
└── service.tpl
/.dockerignore:
--------------------------------------------------------------------------------
1 | # source control
2 | .git
3 | .gitignore
4 |
5 | # IDE
6 | .idea/
7 | .vscode/
8 | .editorconfig
9 | jsconfig.json
10 |
11 | # dependencies
12 | /.pnp
13 | .pnp.js
14 | node_modules/
15 |
16 | # testing
17 | /coverage
18 | .nyc_output
19 | .mocha.setup.js
20 |
21 | # docker
22 | Dockerfile
23 | docker-compose.yml
24 |
25 | # misc
26 | .DS_Store
27 | .env.local
28 | .env.development.local
29 | .env.test.local
30 | .env.production.local
31 |
32 | npm-debug.log*
33 | yarn-debug.log*
34 | yarn-error.log*
35 | app.log
36 |
37 | .eslintrc
38 | .prettierrc
39 |
40 | README.md
41 | /docs
42 |
43 | # gitlab
44 | /builds
45 | /cache
46 | .gitlab-ci.yml
47 |
48 | # kubernetes
49 | /deployment
50 | Makefile
51 |
--------------------------------------------------------------------------------
/.editorconfig:
--------------------------------------------------------------------------------
1 | root = true
2 |
3 | [*]
4 | charset = utf-8
5 | end_of_line = lf
6 | indent_size = 2
7 | indent_style = space
8 | insert_final_newline = true
9 | max_line_length = 80
10 | trim_trailing_whitespace = true
11 |
12 | [*.md]
13 | max_line_length = 0
14 | trim_trailing_whitespace = false
--------------------------------------------------------------------------------
/.eslintrc:
--------------------------------------------------------------------------------
1 | {
2 | "env": {
3 | "es6": true,
4 | "node": true,
5 | "mocha": true
6 | },
7 | "rules": {
8 | "semi": 0,
9 | "space-before-function-paren": 0,
10 | "object-curly-spacing": 0
11 | },
12 | "globals": {
13 | "require": true,
14 | "process": true,
15 | "module": true
16 | },
17 | "extends": "standard"
18 | }
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | .idea/
2 | node_modules/
3 | .env
4 |
--------------------------------------------------------------------------------
/.prettierrc.json:
--------------------------------------------------------------------------------
1 | {
2 | "singleQuote": true,
3 | "endOfLine": "lf",
4 | "tabWidth": 2,
5 | "semi": true
6 | }
--------------------------------------------------------------------------------
/Dockerfile:
--------------------------------------------------------------------------------
1 | FROM node:lts-alpine3.9
2 | EXPOSE 8282
3 |
4 | ENV SERVICE_HOME /service
5 | RUN mkdir -p $SERVICE_HOME
6 | RUN apk add --no-cache bash
7 | WORKDIR $SERVICE_HOME
8 | COPY . .
9 | RUN npm ci --production
10 |
--------------------------------------------------------------------------------
/LICENSE.md:
--------------------------------------------------------------------------------
1 | Copyright 2018 © Munim Dibosh
2 |
3 | Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
4 |
5 | The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
6 |
7 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
--------------------------------------------------------------------------------
/ReadMe.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 🦥 Simple NodeJS Scaffold 🦥
4 |
5 |
6 |
7 |
8 | Simple enough service scaffolding in node and express; to get you started on your project immediately- with right folder structure and architecture practices in place 🤟🏼
9 |
10 |
11 |
12 |
13 | ## Table of Contents
14 |
15 | - [Features](#features)
16 | - [Usage](#usage)
17 | - [Serving Frontend](#serving-frontend)
18 | - [Folder Structure](#folder-structure)
19 | - [Adding new API Resource](#adding-new-api-resource)
20 | - [Others](#others)
21 |
22 |
23 |
24 | ## Features
25 |
26 | - Don't worry about the boilerplate anymore, jump right into writing your API
27 | resources
28 |
29 | - Easily start serving your frontend; great option to create a BFF right away
30 |
31 | - Have error handling and graceful shutdown support out of the box
32 |
33 | - Structure your code in a domain driven approach- with right architectural practices in place
34 |
35 | - Has `mongo` connectivity built-in, simply define schemas and start writing stateful APIs
36 |
37 | - Dockerized
38 | ## Usage
39 |
40 | ### Without Docker
41 |
42 | - `npm install`
43 |
44 | - Create a `.env` file using the following content, feel free to change username and password as you please:
45 |
46 | ```
47 | # COMMON
48 | DB_NAME=sns-db
49 |
50 | # SERVICE
51 | VERSION=1.0.0
52 | SVC_HOST_PORT=8282
53 |
54 | # MONGO_DB
55 | MONGO_USERNAME=sns-user
56 | MONGO_PASSWORD=sns-012345
57 | MONGO_PORT=27017
58 |
59 | # To expose it in host network as well, please specify a port below. Change it to
60 | # any other ports, if the port is already in use in host.
61 | MONGO_HOST_PORT=27018
62 |
63 | # MYSQL
64 | MYSQL_ROOT_USER=root
65 | MYSQL_ROOT_PWORD=root12345 # you can remove this if MYSQL_ALLOW_EMPTY_PASSWORD is set in docker-compose
66 | MYSQL_PORT=3306
67 |
68 | # To expose it in host network as well, please specify a port below. Change it to
69 | # any other ports, if the port is already in use in host.
70 | MYSQL_HOST_PORT=3307
71 | ```
72 |
73 | - Make sure if you have your local `mongo` running. Then, this will start the server in port `8282`: `npm start`
74 |
75 | - To use `mysql`, make sure you have local mysql running with the above setup in `.env` file. Then in `server/core/connectors/index.js` comment out or remove the `mysql` option from ignore list and add `mongo` instead
76 |
77 | ### With Docker
78 |
79 | - Make sure you have created an `.env` file stated above with same content
80 |
81 | - This will run the service at `8282` port with `mongo` connectivity by default:
82 |
83 | `docker-compose build && docker-compose up -d`
84 |
85 | - To check logs: `docker-compose logs`
86 |
87 | - To shutdown: `docker-compose down`
88 |
89 | - To use `mysql` instead, check the `docker-compose` file and follow the instructions given in comments. Finally, do not forget to make the changes in `server/core/connectors/index.js` as described above and run `docker-compose build` once
90 |
91 | ## Serving Frontend
92 |
93 | ### Without Docker
94 |
95 | If your frontend dir has following structure
96 | ```
97 | client/
98 | | - index.html
99 | | - resources/ <-- or may be static/ or dist/
100 | ```
101 |
102 | Then, this can easily be served using-
103 | ```
104 | CLIENT_DIR= npm start
105 | ```
106 |
107 | If your `index.html` file is at one place and folder with static files in another, then the following might be your option-
108 | ```
109 | INDEX= STATIC_DIR= npm start
110 | ```
111 | ### With Docker
112 |
113 | In the `.env` file add following value to serve from a client app:
114 | ```
115 | CLIENT_DIR=
116 | ```
117 |
118 | Or, to serve index and static files separately like stated in `Without Docker` section:
119 | ```
120 | INDEX=
121 | STATIC_DIR=
122 | ```
123 | ## Folder Structure
124 |
125 | At the root of this directory, the `index.js` works as the entrypoint for this service. It hooks up with certain modules under `server` dir and makes the service up and running when you hit- `npm start`.
126 |
127 | This is how the `server` dir is structured at this moment:
128 |
129 | ```
130 | .
131 | ├── api (all the api resources are here)
132 | │ ├── user
133 | │ │ ├── test
134 | │ │ │ └── controller.test.js
135 | │ │ ├── config.js
136 | │ │ ├── controller.js
137 | │ │ ├── index.js
138 | │ │ └── route.js
139 | │ └── index.js
140 | ├── core (all the core functionalities of the service is bundled here)
141 | │ ├── bootstrapper.js
142 | │ ├── commonErrorHandler.js
143 | │ ├── logger.js
144 | │ └── shutdownManager.js
145 | ├── testHelpers (test specific helpers, global vars should be here)
146 | │ └── globals.js
147 | ├── utils (any utils or common helpers should be here)
148 | │ └── error.js
149 | └── index.js
150 | ```
151 | ## Adding new API resource
152 |
153 | ### CLI
154 |
155 | Using the new cli tool bundled in this scaffold, adding a new api resource can be as easy as doing-
156 |
157 | `npm run add-resource `
158 |
159 | Example- `npm run add-resource order-items`
160 |
161 | Please read the comments generated with the files to better understand the architecture and patterns involved.
162 |
163 | ### Manual
164 |
165 | If you still want to do it manually, then follow the instructions below-
166 |
167 | - Create the resource folder under `server/api` (e.g. `users`)
168 |
169 | - Create `route.js`, this will have routing definitions for all the endpoints
170 | under this resource (e.g. `users/`, `users/2/profile`)
171 |
172 | - Create `controller.js`; theoretically this is where you should use different services to cater your api flow
173 |
174 | - Create `service.js`; this is where you should use different db repositories to cater business logic
175 |
176 | - You should separate out your db access logic from services and put them in a separate file called `repository.js`; services will use it to get/manipulate db records
177 |
178 | - You can have a `model.js` if required; which refers to the db schema required for this resource
179 |
180 | - If same resource require multiple models, services etc. they should be grouped under a subfolder like models, services etc.
181 |
182 | Example: for order management api resource, this can be a scenario-
183 |
184 | ```
185 | orders/
186 | models/
187 | - order.js
188 | - order-item.js
189 |
190 | services/
191 | - checkout.js
192 | - payment.js
193 | ```
194 |
195 | - Now, create a `config.js` where you should have your endpoint defined, at least-
196 |
197 | ```
198 | const config = {
199 | ENDPOINT: '/order-items',
200 | };
201 |
202 | module.exports = config;
203 | ```
204 |
205 | - Create an index file(`index.js`) and register the `route` and `config` to expose-
206 |
207 | ```
208 | module.exports = {
209 | route: require('./route'),
210 | config: require('./config'),
211 | };
212 | ```
213 |
214 | - Finally register your resource in api index routing at `server/api/index.js`
215 |
216 | ```
217 | const orderItems = require('./order-items');
218 |
219 | ...
220 | router.use(orderItems.config.ENDPOINT, orderItems.route);
221 |
222 | module.exports = router;
223 | ```
224 |
225 |
226 | > To know more, please take a look at the given sample api resource `user` or try generating a new resource by `npm run add-resource resource-name`
227 |
228 | ## Others
229 |
230 | - To run tests: `npm run test`
231 |
232 | - To check for lint errors: `npm run lint`
233 |
234 |
--------------------------------------------------------------------------------
/config/default.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | SERVER_NAME: 'simpleNodeServer',
3 | DEFAULT_PORT: 8282,
4 | CONNECTION_CLOSING_TIME: 5000,
5 | WAIT_TIME_BEFORE_FORCE_SHUTDOWN: 10000,
6 | };
7 |
--------------------------------------------------------------------------------
/config/development.js:
--------------------------------------------------------------------------------
1 | /**
2 | * This file will be rewritten in dev env by configuration management scripts
3 | */
4 | module.exports = {};
5 |
--------------------------------------------------------------------------------
/config/index.js:
--------------------------------------------------------------------------------
1 | const configMap = {
2 | development: require('./development'),
3 | local: require('./local'),
4 | production: require('./production')
5 | };
6 |
7 | module.exports = Object.assign(require('./default'), configMap[process.env.NODE_ENV || 'local']);
8 |
--------------------------------------------------------------------------------
/config/local.js:
--------------------------------------------------------------------------------
1 | /**
2 | * Should contain same keys and values as in dev and prod config, but for
3 | * running in local
4 | */
5 | module.exports = {};
6 |
--------------------------------------------------------------------------------
/config/production.js:
--------------------------------------------------------------------------------
1 | /**
2 | * This file will be rewritten in prod env by configuration management scripts
3 | */
4 | module.exports = {};
5 |
--------------------------------------------------------------------------------
/docker-compose.yaml:
--------------------------------------------------------------------------------
1 | version: '3.9'
2 |
3 | # If you want to use mysql instead of mongodb, please move the entire mysql
4 | # block from below under `services`. You should then uncomment the
5 | # mysql related env vars in app_svc environment section. Do not forget
6 | # to uncomment mysql-data under volumes.
7 | x-disabled:
8 | mysql:
9 | container_name: mysql
10 | image: mysql:5.7
11 | restart: always
12 | environment:
13 | - MYSQL_DATABASE=$DB_NAME
14 | # Uncomment following line, if root user does not have a
15 | # password. And remove MYSQL_ROOT_PASSWORD
16 | # - MYSQL_ALLOW_EMPTY_PASSWORD=yes
17 | - MYSQL_ROOT_PASSWORD=$MYSQL_ROOT_PWORD
18 | # Uncomment next lines if you have a different user
19 | # than root.
20 | # - MYSQL_USER=$MYSQL_USER
21 | # - MYSQL_PASSWORD=$MYSQL_PWORD
22 | ports:
23 | - $MYSQL_HOST_PORT:$MYSQL_PORT
24 | volumes:
25 | - mysql-data:/var/lib/mysql
26 | networks:
27 | - svc-network
28 |
29 | services:
30 | build_image:
31 | build: .
32 | image: services/sns:${VERSION} # use your own image name e.g. rancher/my-app:{VERSION}
33 |
34 | app_svc:
35 | container_name: sns-service
36 | image: services/sns:${VERSION}
37 | depends_on: [build_image]
38 | restart: on-failure
39 | environment:
40 | - MONGO_USERNAME=$MONGO_USERNAME
41 | - MONGO_PASSWORD=$MONGO_PASSWORD
42 | - MONGO_HOSTNAME=mongo
43 | - MONGO_PORT=$MONGO_PORT
44 | - MONGO_DB=$DB_NAME
45 | # Uncomment if you are using mysql
46 | # - MYSQL_DB=$DB_NAME
47 | # - MYSQL_HOSTNAME=mysql
48 | # - MYSQL_USER=$MYSQL_ROOT_USER # feel free to use a different user
49 | # - MYSQL_PASSWORD=$MYSQL_ROOT_PWORD
50 | # - MYSQL_PORT=$MYSQL_PORT
51 | ports:
52 | - $SVC_HOST_PORT:8282
53 | networks:
54 | - svc-network
55 | command: bash scripts/startup.sh
56 |
57 | mongo:
58 | container_name: mongo
59 | image: mongo:4.1.8-xenial
60 | restart: always
61 | environment:
62 | - MONGO_INITDB_ROOT_USERNAME=$MONGO_USERNAME
63 | - MONGO_INITDB_ROOT_PASSWORD=$MONGO_PASSWORD
64 | - MONGO_INITDB_DATABASE=$DB_NAME
65 | ports:
66 | - $MONGO_HOST_PORT:$MONGO_PORT
67 | volumes:
68 | - mongo-data:/data/db
69 | networks:
70 | - svc-network
71 |
72 | networks:
73 | svc-network:
74 | driver: bridge
75 |
76 | volumes:
77 | mongo-data:
78 | # mysql-data: # uncomment if using mysql
--------------------------------------------------------------------------------
/index.js:
--------------------------------------------------------------------------------
1 | const server = require('./server');
2 |
3 | function options() {
4 | let options = {};
5 | options.port = process.env.PORT;
6 | options.clientDirPath = process.env.CLIENT_DIR || null;
7 | options.indexPath = process.env.INDEX || null;
8 | options.staticDirPath = process.env.STATIC_DIR || null;
9 | return options;
10 | }
11 |
12 | /**
13 | * Initialize the service and start managing it.
14 | */
15 | (async function () {
16 | const service = await server.start(options());
17 | server.autoManageShutdown(service);
18 | })();
19 |
--------------------------------------------------------------------------------
/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "simple-node-server",
3 | "version": "1.0.0",
4 | "lockfileVersion": 1,
5 | "requires": true,
6 | "dependencies": {
7 | "@babel/code-frame": {
8 | "version": "7.0.0",
9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.0.0.tgz",
10 | "integrity": "sha512-OfC2uemaknXr87bdLUkWog7nYuliM9Ij5HUcajsVcMCpQrcLmtxRbVFTIqmcSkSeYRBFBRxs2FiUqFJDLdiebA==",
11 | "dev": true,
12 | "requires": {
13 | "@babel/highlight": "^7.0.0"
14 | }
15 | },
16 | "@babel/highlight": {
17 | "version": "7.0.0",
18 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.0.0.tgz",
19 | "integrity": "sha512-UFMC4ZeFC48Tpvj7C8UgLvtkaUuovQX+5xNWrsIoMG8o2z+XFKjKaN9iVmS84dPwVN00W4wPmqvYoZF3EGAsfw==",
20 | "dev": true,
21 | "requires": {
22 | "chalk": "^2.0.0",
23 | "esutils": "^2.0.2",
24 | "js-tokens": "^4.0.0"
25 | },
26 | "dependencies": {
27 | "chalk": {
28 | "version": "2.4.2",
29 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
30 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
31 | "dev": true,
32 | "requires": {
33 | "ansi-styles": "^3.2.1",
34 | "escape-string-regexp": "^1.0.5",
35 | "supports-color": "^5.3.0"
36 | }
37 | }
38 | }
39 | },
40 | "@types/bson": {
41 | "version": "4.0.3",
42 | "resolved": "https://registry.npmjs.org/@types/bson/-/bson-4.0.3.tgz",
43 | "integrity": "sha512-mVRvYnTOZJz3ccpxhr3wgxVmSeiYinW+zlzQz3SXWaJmD1DuL05Jeq7nKw3SnbKmbleW5qrLG5vdyWe/A9sXhw==",
44 | "requires": {
45 | "@types/node": "*"
46 | }
47 | },
48 | "@types/color-name": {
49 | "version": "1.1.1",
50 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz",
51 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==",
52 | "dev": true
53 | },
54 | "@types/mongodb": {
55 | "version": "3.6.7",
56 | "resolved": "https://registry.npmjs.org/@types/mongodb/-/mongodb-3.6.7.tgz",
57 | "integrity": "sha512-47P64kbkXarlleSMzSrRG04uzY+Dr3xAilOiqRIsqj/sZrmq6cUMx8njydY/iWMqi8IdE9ojFQl/X3ou9EsAlQ==",
58 | "requires": {
59 | "@types/bson": "*",
60 | "@types/node": "*"
61 | }
62 | },
63 | "@types/node": {
64 | "version": "14.14.27",
65 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.14.27.tgz",
66 | "integrity": "sha512-Ecfmo4YDQPwuqTCl1yBxLV5ihKfRlkBmzUEDcfIRvDxOTGQEeikr317Ln7Gcv0tjA8dVgKI3rniqW2G1OyKDng=="
67 | },
68 | "accepts": {
69 | "version": "1.3.5",
70 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz",
71 | "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=",
72 | "requires": {
73 | "mime-types": "~2.1.18",
74 | "negotiator": "0.6.1"
75 | }
76 | },
77 | "acorn": {
78 | "version": "6.4.1",
79 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.1.tgz",
80 | "integrity": "sha512-ZVA9k326Nwrj3Cj9jlh3wGFutC2ZornPNARZwsNYqQYgN0EsV2d53w5RN/co65Ohn4sUAUtb1rSUAOD6XN9idA==",
81 | "dev": true
82 | },
83 | "acorn-jsx": {
84 | "version": "5.0.1",
85 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz",
86 | "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==",
87 | "dev": true
88 | },
89 | "ajv": {
90 | "version": "6.6.1",
91 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.6.1.tgz",
92 | "integrity": "sha512-ZoJjft5B+EJBjUyu9C9Hc0OZyPZSSlOF+plzouTrg6UlA8f+e/n8NIgBFG/9tppJtpPWfthHakK7juJdNDODww==",
93 | "dev": true,
94 | "requires": {
95 | "fast-deep-equal": "^2.0.1",
96 | "fast-json-stable-stringify": "^2.0.0",
97 | "json-schema-traverse": "^0.4.1",
98 | "uri-js": "^4.2.2"
99 | }
100 | },
101 | "ansi-colors": {
102 | "version": "4.1.1",
103 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz",
104 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==",
105 | "dev": true
106 | },
107 | "ansi-escapes": {
108 | "version": "3.1.0",
109 | "resolved": "http://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.1.0.tgz",
110 | "integrity": "sha512-UgAb8H9D41AQnu/PbWlCofQVcnV4Gs2bBJi9eZPxfU/hgglFh3SMDMENRIqdr7H6XFnXdoknctFByVsCOotTVw==",
111 | "dev": true
112 | },
113 | "ansi-regex": {
114 | "version": "3.0.0",
115 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz",
116 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=",
117 | "dev": true
118 | },
119 | "ansi-styles": {
120 | "version": "3.2.1",
121 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
122 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
123 | "dev": true,
124 | "requires": {
125 | "color-convert": "^1.9.0"
126 | }
127 | },
128 | "any-promise": {
129 | "version": "1.3.0",
130 | "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz",
131 | "integrity": "sha1-q8av7tzqUugJzcA3au0845Y10X8="
132 | },
133 | "anymatch": {
134 | "version": "3.1.1",
135 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz",
136 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==",
137 | "dev": true,
138 | "requires": {
139 | "normalize-path": "^3.0.0",
140 | "picomatch": "^2.0.4"
141 | }
142 | },
143 | "argparse": {
144 | "version": "1.0.10",
145 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz",
146 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==",
147 | "dev": true,
148 | "requires": {
149 | "sprintf-js": "~1.0.2"
150 | }
151 | },
152 | "array-flatten": {
153 | "version": "1.1.1",
154 | "resolved": "http://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
155 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI="
156 | },
157 | "array.prototype.map": {
158 | "version": "1.0.2",
159 | "resolved": "https://registry.npmjs.org/array.prototype.map/-/array.prototype.map-1.0.2.tgz",
160 | "integrity": "sha512-Az3OYxgsa1g7xDYp86l0nnN4bcmuEITGe1rbdEBVkrqkzMgDcbdQ2R7r41pNzti+4NMces3H8gMmuioZUilLgw==",
161 | "dev": true,
162 | "requires": {
163 | "define-properties": "^1.1.3",
164 | "es-abstract": "^1.17.0-next.1",
165 | "es-array-method-boxes-properly": "^1.0.0",
166 | "is-string": "^1.0.4"
167 | }
168 | },
169 | "assertion-error": {
170 | "version": "1.1.0",
171 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz",
172 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==",
173 | "dev": true
174 | },
175 | "astral-regex": {
176 | "version": "1.0.0",
177 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz",
178 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==",
179 | "dev": true
180 | },
181 | "balanced-match": {
182 | "version": "1.0.0",
183 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz",
184 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=",
185 | "dev": true
186 | },
187 | "binary-extensions": {
188 | "version": "2.1.0",
189 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.1.0.tgz",
190 | "integrity": "sha512-1Yj8h9Q+QDF5FzhMs/c9+6UntbD5MkRfRwac8DoEm9ZfUBZ7tZ55YcGVAzEe4bXsdQHEk+s9S5wsOKVdZrw0tQ==",
191 | "dev": true
192 | },
193 | "bl": {
194 | "version": "2.2.1",
195 | "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.1.tgz",
196 | "integrity": "sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g==",
197 | "requires": {
198 | "readable-stream": "^2.3.5",
199 | "safe-buffer": "^5.1.1"
200 | }
201 | },
202 | "bluebird": {
203 | "version": "3.5.1",
204 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz",
205 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA=="
206 | },
207 | "body-parser": {
208 | "version": "1.18.3",
209 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.3.tgz",
210 | "integrity": "sha1-WykhmP/dVTs6DyDe0FkrlWlVyLQ=",
211 | "requires": {
212 | "bytes": "3.0.0",
213 | "content-type": "~1.0.4",
214 | "debug": "2.6.9",
215 | "depd": "~1.1.2",
216 | "http-errors": "~1.6.3",
217 | "iconv-lite": "0.4.23",
218 | "on-finished": "~2.3.0",
219 | "qs": "6.5.2",
220 | "raw-body": "2.3.3",
221 | "type-is": "~1.6.16"
222 | },
223 | "dependencies": {
224 | "debug": {
225 | "version": "2.6.9",
226 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
227 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
228 | "requires": {
229 | "ms": "2.0.0"
230 | }
231 | }
232 | }
233 | },
234 | "brace-expansion": {
235 | "version": "1.1.11",
236 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
237 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
238 | "dev": true,
239 | "requires": {
240 | "balanced-match": "^1.0.0",
241 | "concat-map": "0.0.1"
242 | }
243 | },
244 | "braces": {
245 | "version": "3.0.2",
246 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
247 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
248 | "dev": true,
249 | "requires": {
250 | "fill-range": "^7.0.1"
251 | }
252 | },
253 | "browser-stdout": {
254 | "version": "1.3.1",
255 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz",
256 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==",
257 | "dev": true
258 | },
259 | "bson": {
260 | "version": "1.1.5",
261 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.5.tgz",
262 | "integrity": "sha512-kDuEzldR21lHciPQAIulLs1LZlCXdLziXI6Mb/TDkwXhb//UORJNPXgcRs2CuO4H0DcMkpfT3/ySsP3unoZjBg=="
263 | },
264 | "builtin-modules": {
265 | "version": "1.1.1",
266 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz",
267 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=",
268 | "dev": true
269 | },
270 | "bytes": {
271 | "version": "3.0.0",
272 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz",
273 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg="
274 | },
275 | "caller-path": {
276 | "version": "0.1.0",
277 | "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-0.1.0.tgz",
278 | "integrity": "sha1-lAhe9jWB7NPaqSREqP6U6CV3dR8=",
279 | "dev": true,
280 | "requires": {
281 | "callsites": "^0.2.0"
282 | }
283 | },
284 | "callsites": {
285 | "version": "0.2.0",
286 | "resolved": "http://registry.npmjs.org/callsites/-/callsites-0.2.0.tgz",
287 | "integrity": "sha1-r6uWJikQp/M8GaV3WCXGnzTjUMo=",
288 | "dev": true
289 | },
290 | "camelcase": {
291 | "version": "5.3.1",
292 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz",
293 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==",
294 | "dev": true
295 | },
296 | "chai": {
297 | "version": "4.2.0",
298 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.2.0.tgz",
299 | "integrity": "sha512-XQU3bhBukrOsQCuwZndwGcCVQHyZi53fQ6Ys1Fym7E4olpIqqZZhhoFJoaKVvV17lWQoXYwgWN2nF5crA8J2jw==",
300 | "dev": true,
301 | "requires": {
302 | "assertion-error": "^1.1.0",
303 | "check-error": "^1.0.2",
304 | "deep-eql": "^3.0.1",
305 | "get-func-name": "^2.0.0",
306 | "pathval": "^1.1.0",
307 | "type-detect": "^4.0.5"
308 | }
309 | },
310 | "chalk": {
311 | "version": "4.1.0",
312 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
313 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
314 | "dev": true,
315 | "requires": {
316 | "ansi-styles": "^4.1.0",
317 | "supports-color": "^7.1.0"
318 | },
319 | "dependencies": {
320 | "ansi-styles": {
321 | "version": "4.2.1",
322 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz",
323 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==",
324 | "dev": true,
325 | "requires": {
326 | "@types/color-name": "^1.1.1",
327 | "color-convert": "^2.0.1"
328 | }
329 | },
330 | "color-convert": {
331 | "version": "2.0.1",
332 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
333 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
334 | "dev": true,
335 | "requires": {
336 | "color-name": "~1.1.4"
337 | }
338 | },
339 | "color-name": {
340 | "version": "1.1.4",
341 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
342 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
343 | "dev": true
344 | },
345 | "has-flag": {
346 | "version": "4.0.0",
347 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
348 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
349 | "dev": true
350 | },
351 | "supports-color": {
352 | "version": "7.1.0",
353 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz",
354 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==",
355 | "dev": true,
356 | "requires": {
357 | "has-flag": "^4.0.0"
358 | }
359 | }
360 | }
361 | },
362 | "chardet": {
363 | "version": "0.7.0",
364 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz",
365 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==",
366 | "dev": true
367 | },
368 | "check-error": {
369 | "version": "1.0.2",
370 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz",
371 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=",
372 | "dev": true
373 | },
374 | "chokidar": {
375 | "version": "3.3.1",
376 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.3.1.tgz",
377 | "integrity": "sha512-4QYCEWOcK3OJrxwvyyAOxFuhpvOVCYkr33LPfFNBjAD/w3sEzWsp2BUOkI4l9bHvWioAd0rc6NlHUOEaWkTeqg==",
378 | "dev": true,
379 | "requires": {
380 | "anymatch": "~3.1.1",
381 | "braces": "~3.0.2",
382 | "fsevents": "~2.1.2",
383 | "glob-parent": "~5.1.0",
384 | "is-binary-path": "~2.1.0",
385 | "is-glob": "~4.0.1",
386 | "normalize-path": "~3.0.0",
387 | "readdirp": "~3.3.0"
388 | }
389 | },
390 | "circular-json": {
391 | "version": "0.3.3",
392 | "resolved": "https://registry.npmjs.org/circular-json/-/circular-json-0.3.3.tgz",
393 | "integrity": "sha512-UZK3NBx2Mca+b5LsG7bY183pHWt5Y1xts4P3Pz7ENTwGVnJOUWbRb3ocjvX7hx9tq/yTAdclXm9sZ38gNuem4A==",
394 | "dev": true
395 | },
396 | "cli-cursor": {
397 | "version": "2.1.0",
398 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz",
399 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=",
400 | "dev": true,
401 | "requires": {
402 | "restore-cursor": "^2.0.0"
403 | }
404 | },
405 | "cli-width": {
406 | "version": "2.2.0",
407 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz",
408 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=",
409 | "dev": true
410 | },
411 | "cliui": {
412 | "version": "5.0.0",
413 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz",
414 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==",
415 | "dev": true,
416 | "requires": {
417 | "string-width": "^3.1.0",
418 | "strip-ansi": "^5.2.0",
419 | "wrap-ansi": "^5.1.0"
420 | },
421 | "dependencies": {
422 | "ansi-regex": {
423 | "version": "4.1.0",
424 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz",
425 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==",
426 | "dev": true
427 | },
428 | "string-width": {
429 | "version": "3.1.0",
430 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz",
431 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==",
432 | "dev": true,
433 | "requires": {
434 | "emoji-regex": "^7.0.1",
435 | "is-fullwidth-code-point": "^2.0.0",
436 | "strip-ansi": "^5.1.0"
437 | }
438 | },
439 | "strip-ansi": {
440 | "version": "5.2.0",
441 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz",
442 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==",
443 | "dev": true,
444 | "requires": {
445 | "ansi-regex": "^4.1.0"
446 | }
447 | }
448 | }
449 | },
450 | "color-convert": {
451 | "version": "1.9.3",
452 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
453 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
454 | "dev": true,
455 | "requires": {
456 | "color-name": "1.1.3"
457 | }
458 | },
459 | "color-name": {
460 | "version": "1.1.3",
461 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
462 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=",
463 | "dev": true
464 | },
465 | "concat-map": {
466 | "version": "0.0.1",
467 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
468 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
469 | "dev": true
470 | },
471 | "contains-path": {
472 | "version": "0.1.0",
473 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz",
474 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=",
475 | "dev": true
476 | },
477 | "content-disposition": {
478 | "version": "0.5.2",
479 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz",
480 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ="
481 | },
482 | "content-type": {
483 | "version": "1.0.4",
484 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz",
485 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA=="
486 | },
487 | "cookie": {
488 | "version": "0.3.1",
489 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz",
490 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s="
491 | },
492 | "cookie-signature": {
493 | "version": "1.0.6",
494 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
495 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw="
496 | },
497 | "core-util-is": {
498 | "version": "1.0.2",
499 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz",
500 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac="
501 | },
502 | "cors": {
503 | "version": "2.8.5",
504 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz",
505 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==",
506 | "requires": {
507 | "object-assign": "^4",
508 | "vary": "^1"
509 | }
510 | },
511 | "cross-spawn": {
512 | "version": "6.0.5",
513 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz",
514 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==",
515 | "dev": true,
516 | "requires": {
517 | "nice-try": "^1.0.4",
518 | "path-key": "^2.0.1",
519 | "semver": "^5.5.0",
520 | "shebang-command": "^1.2.0",
521 | "which": "^1.2.9"
522 | }
523 | },
524 | "debug": {
525 | "version": "4.1.0",
526 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.0.tgz",
527 | "integrity": "sha512-heNPJUJIqC+xB6ayLAMHaIrmN9HKa7aQO8MGqKpvCA+uJYVcvR6l5kgdrhRuwPFHU7P5/A1w0BjByPHwpfTDKg==",
528 | "requires": {
529 | "ms": "^2.1.1"
530 | },
531 | "dependencies": {
532 | "ms": {
533 | "version": "2.1.1",
534 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz",
535 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg=="
536 | }
537 | }
538 | },
539 | "decamelize": {
540 | "version": "1.2.0",
541 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz",
542 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=",
543 | "dev": true
544 | },
545 | "deep-eql": {
546 | "version": "3.0.1",
547 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz",
548 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==",
549 | "dev": true,
550 | "requires": {
551 | "type-detect": "^4.0.0"
552 | }
553 | },
554 | "deep-is": {
555 | "version": "0.1.3",
556 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz",
557 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=",
558 | "dev": true
559 | },
560 | "define-properties": {
561 | "version": "1.1.3",
562 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz",
563 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==",
564 | "dev": true,
565 | "requires": {
566 | "object-keys": "^1.0.12"
567 | }
568 | },
569 | "denque": {
570 | "version": "1.5.0",
571 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.5.0.tgz",
572 | "integrity": "sha512-CYiCSgIF1p6EUByQPlGkKnP1M9g0ZV3qMIrqMqZqdwazygIA/YP2vrbcyl1h/WppKJTdl1F85cXIle+394iDAQ=="
573 | },
574 | "depd": {
575 | "version": "1.1.2",
576 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz",
577 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak="
578 | },
579 | "destroy": {
580 | "version": "1.0.4",
581 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz",
582 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA="
583 | },
584 | "diff": {
585 | "version": "4.0.2",
586 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz",
587 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==",
588 | "dev": true
589 | },
590 | "doctrine": {
591 | "version": "2.1.0",
592 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz",
593 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==",
594 | "dev": true,
595 | "requires": {
596 | "esutils": "^2.0.2"
597 | }
598 | },
599 | "dottie": {
600 | "version": "2.0.2",
601 | "resolved": "https://registry.npmjs.org/dottie/-/dottie-2.0.2.tgz",
602 | "integrity": "sha512-fmrwR04lsniq/uSr8yikThDTrM7epXHBAAjH9TbeH3rEA8tdCO7mRzB9hdmdGyJCxF8KERo9CITcm3kGuoyMhg=="
603 | },
604 | "ee-first": {
605 | "version": "1.1.1",
606 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
607 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0="
608 | },
609 | "emoji-regex": {
610 | "version": "7.0.3",
611 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz",
612 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==",
613 | "dev": true
614 | },
615 | "encodeurl": {
616 | "version": "1.0.2",
617 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
618 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k="
619 | },
620 | "error-ex": {
621 | "version": "1.3.2",
622 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
623 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
624 | "dev": true,
625 | "requires": {
626 | "is-arrayish": "^0.2.1"
627 | }
628 | },
629 | "es-abstract": {
630 | "version": "1.17.6",
631 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.6.tgz",
632 | "integrity": "sha512-Fr89bON3WFyUi5EvAeI48QTWX0AyekGgLA8H+c+7fbfCkJwRWRMLd8CQedNEyJuoYYhmtEqY92pgte1FAhBlhw==",
633 | "dev": true,
634 | "requires": {
635 | "es-to-primitive": "^1.2.1",
636 | "function-bind": "^1.1.1",
637 | "has": "^1.0.3",
638 | "has-symbols": "^1.0.1",
639 | "is-callable": "^1.2.0",
640 | "is-regex": "^1.1.0",
641 | "object-inspect": "^1.7.0",
642 | "object-keys": "^1.1.1",
643 | "object.assign": "^4.1.0",
644 | "string.prototype.trimend": "^1.0.1",
645 | "string.prototype.trimstart": "^1.0.1"
646 | }
647 | },
648 | "es-array-method-boxes-properly": {
649 | "version": "1.0.0",
650 | "resolved": "https://registry.npmjs.org/es-array-method-boxes-properly/-/es-array-method-boxes-properly-1.0.0.tgz",
651 | "integrity": "sha512-wd6JXUmyHmt8T5a2xreUwKcGPq6f1f+WwIJkijUqiGcJz1qqnZgP6XIK+QyIWU5lT7imeNxUll48bziG+TSYcA==",
652 | "dev": true
653 | },
654 | "es-get-iterator": {
655 | "version": "1.1.0",
656 | "resolved": "https://registry.npmjs.org/es-get-iterator/-/es-get-iterator-1.1.0.tgz",
657 | "integrity": "sha512-UfrmHuWQlNMTs35e1ypnvikg6jCz3SK8v8ImvmDsh36fCVUR1MqoFDiyn0/k52C8NqO3YsO8Oe0azeesNuqSsQ==",
658 | "dev": true,
659 | "requires": {
660 | "es-abstract": "^1.17.4",
661 | "has-symbols": "^1.0.1",
662 | "is-arguments": "^1.0.4",
663 | "is-map": "^2.0.1",
664 | "is-set": "^2.0.1",
665 | "is-string": "^1.0.5",
666 | "isarray": "^2.0.5"
667 | },
668 | "dependencies": {
669 | "isarray": {
670 | "version": "2.0.5",
671 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz",
672 | "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==",
673 | "dev": true
674 | }
675 | }
676 | },
677 | "es-to-primitive": {
678 | "version": "1.2.1",
679 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz",
680 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==",
681 | "dev": true,
682 | "requires": {
683 | "is-callable": "^1.1.4",
684 | "is-date-object": "^1.0.1",
685 | "is-symbol": "^1.0.2"
686 | }
687 | },
688 | "escape-html": {
689 | "version": "1.0.3",
690 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
691 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg="
692 | },
693 | "escape-string-regexp": {
694 | "version": "1.0.5",
695 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
696 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=",
697 | "dev": true
698 | },
699 | "eslint": {
700 | "version": "5.10.0",
701 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.10.0.tgz",
702 | "integrity": "sha512-HpqzC+BHULKlnPwWae9MaVZ5AXJKpkxCVXQHrFaRw3hbDj26V/9ArYM4Rr/SQ8pi6qUPLXSSXC4RBJlyq2Z2OQ==",
703 | "dev": true,
704 | "requires": {
705 | "@babel/code-frame": "^7.0.0",
706 | "ajv": "^6.5.3",
707 | "chalk": "^2.1.0",
708 | "cross-spawn": "^6.0.5",
709 | "debug": "^4.0.1",
710 | "doctrine": "^2.1.0",
711 | "eslint-scope": "^4.0.0",
712 | "eslint-utils": "^1.3.1",
713 | "eslint-visitor-keys": "^1.0.0",
714 | "espree": "^5.0.0",
715 | "esquery": "^1.0.1",
716 | "esutils": "^2.0.2",
717 | "file-entry-cache": "^2.0.0",
718 | "functional-red-black-tree": "^1.0.1",
719 | "glob": "^7.1.2",
720 | "globals": "^11.7.0",
721 | "ignore": "^4.0.6",
722 | "imurmurhash": "^0.1.4",
723 | "inquirer": "^6.1.0",
724 | "js-yaml": "^3.12.0",
725 | "json-stable-stringify-without-jsonify": "^1.0.1",
726 | "levn": "^0.3.0",
727 | "lodash": "^4.17.5",
728 | "minimatch": "^3.0.4",
729 | "mkdirp": "^0.5.1",
730 | "natural-compare": "^1.4.0",
731 | "optionator": "^0.8.2",
732 | "path-is-inside": "^1.0.2",
733 | "pluralize": "^7.0.0",
734 | "progress": "^2.0.0",
735 | "regexpp": "^2.0.1",
736 | "require-uncached": "^1.0.3",
737 | "semver": "^5.5.1",
738 | "strip-ansi": "^4.0.0",
739 | "strip-json-comments": "^2.0.1",
740 | "table": "^5.0.2",
741 | "text-table": "^0.2.0"
742 | },
743 | "dependencies": {
744 | "chalk": {
745 | "version": "2.4.2",
746 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
747 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
748 | "dev": true,
749 | "requires": {
750 | "ansi-styles": "^3.2.1",
751 | "escape-string-regexp": "^1.0.5",
752 | "supports-color": "^5.3.0"
753 | }
754 | }
755 | }
756 | },
757 | "eslint-config-standard": {
758 | "version": "12.0.0",
759 | "resolved": "https://registry.npmjs.org/eslint-config-standard/-/eslint-config-standard-12.0.0.tgz",
760 | "integrity": "sha512-COUz8FnXhqFitYj4DTqHzidjIL/t4mumGZto5c7DrBpvWoie+Sn3P4sLEzUGeYhRElWuFEf8K1S1EfvD1vixCQ==",
761 | "dev": true
762 | },
763 | "eslint-import-resolver-node": {
764 | "version": "0.3.2",
765 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz",
766 | "integrity": "sha512-sfmTqJfPSizWu4aymbPr4Iidp5yKm8yDkHp+Ir3YiTHiiDfxh69mOUsmiqW6RZ9zRXFaF64GtYmN7e+8GHBv6Q==",
767 | "dev": true,
768 | "requires": {
769 | "debug": "^2.6.9",
770 | "resolve": "^1.5.0"
771 | },
772 | "dependencies": {
773 | "debug": {
774 | "version": "2.6.9",
775 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
776 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
777 | "dev": true,
778 | "requires": {
779 | "ms": "2.0.0"
780 | }
781 | }
782 | }
783 | },
784 | "eslint-module-utils": {
785 | "version": "2.2.0",
786 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.2.0.tgz",
787 | "integrity": "sha1-snA2LNiLGkitMIl2zn+lTphBF0Y=",
788 | "dev": true,
789 | "requires": {
790 | "debug": "^2.6.8",
791 | "pkg-dir": "^1.0.0"
792 | },
793 | "dependencies": {
794 | "debug": {
795 | "version": "2.6.9",
796 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
797 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
798 | "dev": true,
799 | "requires": {
800 | "ms": "2.0.0"
801 | }
802 | }
803 | }
804 | },
805 | "eslint-plugin-es": {
806 | "version": "1.4.0",
807 | "resolved": "https://registry.npmjs.org/eslint-plugin-es/-/eslint-plugin-es-1.4.0.tgz",
808 | "integrity": "sha512-XfFmgFdIUDgvaRAlaXUkxrRg5JSADoRC8IkKLc/cISeR3yHVMefFHQZpcyXXEUUPHfy5DwviBcrfqlyqEwlQVw==",
809 | "dev": true,
810 | "requires": {
811 | "eslint-utils": "^1.3.0",
812 | "regexpp": "^2.0.1"
813 | }
814 | },
815 | "eslint-plugin-import": {
816 | "version": "2.14.0",
817 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.14.0.tgz",
818 | "integrity": "sha512-FpuRtniD/AY6sXByma2Wr0TXvXJ4nA/2/04VPlfpmUDPOpOY264x+ILiwnrk/k4RINgDAyFZByxqPUbSQ5YE7g==",
819 | "dev": true,
820 | "requires": {
821 | "contains-path": "^0.1.0",
822 | "debug": "^2.6.8",
823 | "doctrine": "1.5.0",
824 | "eslint-import-resolver-node": "^0.3.1",
825 | "eslint-module-utils": "^2.2.0",
826 | "has": "^1.0.1",
827 | "lodash": "^4.17.4",
828 | "minimatch": "^3.0.3",
829 | "read-pkg-up": "^2.0.0",
830 | "resolve": "^1.6.0"
831 | },
832 | "dependencies": {
833 | "debug": {
834 | "version": "2.6.9",
835 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
836 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
837 | "dev": true,
838 | "requires": {
839 | "ms": "2.0.0"
840 | }
841 | },
842 | "doctrine": {
843 | "version": "1.5.0",
844 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz",
845 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=",
846 | "dev": true,
847 | "requires": {
848 | "esutils": "^2.0.2",
849 | "isarray": "^1.0.0"
850 | }
851 | }
852 | }
853 | },
854 | "eslint-plugin-node": {
855 | "version": "8.0.0",
856 | "resolved": "https://registry.npmjs.org/eslint-plugin-node/-/eslint-plugin-node-8.0.0.tgz",
857 | "integrity": "sha512-Y+ln8iQ52scz9+rSPnSWRaAxeWaoJZ4wIveDR0vLHkuSZGe44Vk1J4HX7WvEP5Cm+iXPE8ixo7OM7gAO3/OKpQ==",
858 | "dev": true,
859 | "requires": {
860 | "eslint-plugin-es": "^1.3.1",
861 | "eslint-utils": "^1.3.1",
862 | "ignore": "^5.0.2",
863 | "minimatch": "^3.0.4",
864 | "resolve": "^1.8.1",
865 | "semver": "^5.5.0"
866 | },
867 | "dependencies": {
868 | "ignore": {
869 | "version": "5.0.4",
870 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.0.4.tgz",
871 | "integrity": "sha512-WLsTMEhsQuXpCiG173+f3aymI43SXa+fB1rSfbzyP4GkPP+ZFVuO0/3sFUGNBtifisPeDcl/uD/Y2NxZ7xFq4g==",
872 | "dev": true
873 | }
874 | }
875 | },
876 | "eslint-plugin-promise": {
877 | "version": "4.0.1",
878 | "resolved": "https://registry.npmjs.org/eslint-plugin-promise/-/eslint-plugin-promise-4.0.1.tgz",
879 | "integrity": "sha512-Si16O0+Hqz1gDHsys6RtFRrW7cCTB6P7p3OJmKp3Y3dxpQE2qwOA7d3xnV+0mBmrPoi0RBnxlCKvqu70te6wjg==",
880 | "dev": true
881 | },
882 | "eslint-plugin-standard": {
883 | "version": "4.0.0",
884 | "resolved": "https://registry.npmjs.org/eslint-plugin-standard/-/eslint-plugin-standard-4.0.0.tgz",
885 | "integrity": "sha512-OwxJkR6TQiYMmt1EsNRMe5qG3GsbjlcOhbGUBY4LtavF9DsLaTcoR+j2Tdjqi23oUwKNUqX7qcn5fPStafMdlA==",
886 | "dev": true
887 | },
888 | "eslint-scope": {
889 | "version": "4.0.0",
890 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.0.tgz",
891 | "integrity": "sha512-1G6UTDi7Jc1ELFwnR58HV4fK9OQK4S6N985f166xqXxpjU6plxFISJa2Ba9KCQuFa8RCnj/lSFJbHo7UFDBnUA==",
892 | "dev": true,
893 | "requires": {
894 | "esrecurse": "^4.1.0",
895 | "estraverse": "^4.1.1"
896 | }
897 | },
898 | "eslint-utils": {
899 | "version": "1.4.2",
900 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.2.tgz",
901 | "integrity": "sha512-eAZS2sEUMlIeCjBeubdj45dmBHQwPHWyBcT1VSYB7o9x9WRRqKxyUoiXlRjyAwzN7YEzHJlYg0NmzDRWx6GP4Q==",
902 | "dev": true,
903 | "requires": {
904 | "eslint-visitor-keys": "^1.0.0"
905 | }
906 | },
907 | "eslint-visitor-keys": {
908 | "version": "1.0.0",
909 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz",
910 | "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==",
911 | "dev": true
912 | },
913 | "espree": {
914 | "version": "5.0.0",
915 | "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.0.tgz",
916 | "integrity": "sha512-1MpUfwsdS9MMoN7ZXqAr9e9UKdVHDcvrJpyx7mm1WuQlx/ygErEQBzgi5Nh5qBHIoYweprhtMkTCb9GhcAIcsA==",
917 | "dev": true,
918 | "requires": {
919 | "acorn": "^6.0.2",
920 | "acorn-jsx": "^5.0.0",
921 | "eslint-visitor-keys": "^1.0.0"
922 | }
923 | },
924 | "esprima": {
925 | "version": "4.0.1",
926 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz",
927 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==",
928 | "dev": true
929 | },
930 | "esquery": {
931 | "version": "1.0.1",
932 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz",
933 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==",
934 | "dev": true,
935 | "requires": {
936 | "estraverse": "^4.0.0"
937 | }
938 | },
939 | "esrecurse": {
940 | "version": "4.2.1",
941 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz",
942 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==",
943 | "dev": true,
944 | "requires": {
945 | "estraverse": "^4.1.0"
946 | }
947 | },
948 | "estraverse": {
949 | "version": "4.2.0",
950 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz",
951 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=",
952 | "dev": true
953 | },
954 | "esutils": {
955 | "version": "2.0.2",
956 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz",
957 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=",
958 | "dev": true
959 | },
960 | "etag": {
961 | "version": "1.8.1",
962 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
963 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc="
964 | },
965 | "express": {
966 | "version": "4.16.4",
967 | "resolved": "https://registry.npmjs.org/express/-/express-4.16.4.tgz",
968 | "integrity": "sha512-j12Uuyb4FMrd/qQAm6uCHAkPtO8FDTRJZBDd5D2KOL2eLaz1yUNdUB/NOIyq0iU4q4cFarsUCrnFDPBcnksuOg==",
969 | "requires": {
970 | "accepts": "~1.3.5",
971 | "array-flatten": "1.1.1",
972 | "body-parser": "1.18.3",
973 | "content-disposition": "0.5.2",
974 | "content-type": "~1.0.4",
975 | "cookie": "0.3.1",
976 | "cookie-signature": "1.0.6",
977 | "debug": "2.6.9",
978 | "depd": "~1.1.2",
979 | "encodeurl": "~1.0.2",
980 | "escape-html": "~1.0.3",
981 | "etag": "~1.8.1",
982 | "finalhandler": "1.1.1",
983 | "fresh": "0.5.2",
984 | "merge-descriptors": "1.0.1",
985 | "methods": "~1.1.2",
986 | "on-finished": "~2.3.0",
987 | "parseurl": "~1.3.2",
988 | "path-to-regexp": "0.1.7",
989 | "proxy-addr": "~2.0.4",
990 | "qs": "6.5.2",
991 | "range-parser": "~1.2.0",
992 | "safe-buffer": "5.1.2",
993 | "send": "0.16.2",
994 | "serve-static": "1.13.2",
995 | "setprototypeof": "1.1.0",
996 | "statuses": "~1.4.0",
997 | "type-is": "~1.6.16",
998 | "utils-merge": "1.0.1",
999 | "vary": "~1.1.2"
1000 | },
1001 | "dependencies": {
1002 | "debug": {
1003 | "version": "2.6.9",
1004 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
1005 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
1006 | "requires": {
1007 | "ms": "2.0.0"
1008 | }
1009 | },
1010 | "statuses": {
1011 | "version": "1.4.0",
1012 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz",
1013 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew=="
1014 | }
1015 | }
1016 | },
1017 | "external-editor": {
1018 | "version": "3.0.3",
1019 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.0.3.tgz",
1020 | "integrity": "sha512-bn71H9+qWoOQKyZDo25mOMVpSmXROAsTJVVVYzrrtol3d4y+AsKjf4Iwl2Q+IuT0kFSQ1qo166UuIwqYq7mGnA==",
1021 | "dev": true,
1022 | "requires": {
1023 | "chardet": "^0.7.0",
1024 | "iconv-lite": "^0.4.24",
1025 | "tmp": "^0.0.33"
1026 | },
1027 | "dependencies": {
1028 | "iconv-lite": {
1029 | "version": "0.4.24",
1030 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
1031 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
1032 | "dev": true,
1033 | "requires": {
1034 | "safer-buffer": ">= 2.1.2 < 3"
1035 | }
1036 | }
1037 | }
1038 | },
1039 | "fast-deep-equal": {
1040 | "version": "2.0.1",
1041 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz",
1042 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=",
1043 | "dev": true
1044 | },
1045 | "fast-json-stable-stringify": {
1046 | "version": "2.0.0",
1047 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz",
1048 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=",
1049 | "dev": true
1050 | },
1051 | "fast-levenshtein": {
1052 | "version": "2.0.6",
1053 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
1054 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=",
1055 | "dev": true
1056 | },
1057 | "figures": {
1058 | "version": "2.0.0",
1059 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz",
1060 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=",
1061 | "dev": true,
1062 | "requires": {
1063 | "escape-string-regexp": "^1.0.5"
1064 | }
1065 | },
1066 | "file-entry-cache": {
1067 | "version": "2.0.0",
1068 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz",
1069 | "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=",
1070 | "dev": true,
1071 | "requires": {
1072 | "flat-cache": "^1.2.1",
1073 | "object-assign": "^4.0.1"
1074 | }
1075 | },
1076 | "fill-range": {
1077 | "version": "7.0.1",
1078 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
1079 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
1080 | "dev": true,
1081 | "requires": {
1082 | "to-regex-range": "^5.0.1"
1083 | }
1084 | },
1085 | "finalhandler": {
1086 | "version": "1.1.1",
1087 | "resolved": "http://registry.npmjs.org/finalhandler/-/finalhandler-1.1.1.tgz",
1088 | "integrity": "sha512-Y1GUDo39ez4aHAw7MysnUD5JzYX+WaIj8I57kO3aEPT1fFRL4sr7mjei97FgnwhAyyzRYmQZaTHb2+9uZ1dPtg==",
1089 | "requires": {
1090 | "debug": "2.6.9",
1091 | "encodeurl": "~1.0.2",
1092 | "escape-html": "~1.0.3",
1093 | "on-finished": "~2.3.0",
1094 | "parseurl": "~1.3.2",
1095 | "statuses": "~1.4.0",
1096 | "unpipe": "~1.0.0"
1097 | },
1098 | "dependencies": {
1099 | "debug": {
1100 | "version": "2.6.9",
1101 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
1102 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
1103 | "requires": {
1104 | "ms": "2.0.0"
1105 | }
1106 | },
1107 | "statuses": {
1108 | "version": "1.4.0",
1109 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz",
1110 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew=="
1111 | }
1112 | }
1113 | },
1114 | "find-up": {
1115 | "version": "1.1.2",
1116 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz",
1117 | "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=",
1118 | "dev": true,
1119 | "requires": {
1120 | "path-exists": "^2.0.0",
1121 | "pinkie-promise": "^2.0.0"
1122 | }
1123 | },
1124 | "flat": {
1125 | "version": "4.1.0",
1126 | "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz",
1127 | "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==",
1128 | "dev": true,
1129 | "requires": {
1130 | "is-buffer": "~2.0.3"
1131 | }
1132 | },
1133 | "flat-cache": {
1134 | "version": "1.3.4",
1135 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.4.tgz",
1136 | "integrity": "sha512-VwyB3Lkgacfik2vhqR4uv2rvebqmDvFu4jlN/C1RzWoJEo8I7z4Q404oiqYCkq41mni8EzQnm95emU9seckwtg==",
1137 | "dev": true,
1138 | "requires": {
1139 | "circular-json": "^0.3.1",
1140 | "graceful-fs": "^4.1.2",
1141 | "rimraf": "~2.6.2",
1142 | "write": "^0.2.1"
1143 | }
1144 | },
1145 | "forwarded": {
1146 | "version": "0.1.2",
1147 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz",
1148 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ="
1149 | },
1150 | "fresh": {
1151 | "version": "0.5.2",
1152 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
1153 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac="
1154 | },
1155 | "fs.realpath": {
1156 | "version": "1.0.0",
1157 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
1158 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=",
1159 | "dev": true
1160 | },
1161 | "fsevents": {
1162 | "version": "2.1.3",
1163 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz",
1164 | "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==",
1165 | "dev": true,
1166 | "optional": true
1167 | },
1168 | "function-bind": {
1169 | "version": "1.1.1",
1170 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
1171 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==",
1172 | "dev": true
1173 | },
1174 | "functional-red-black-tree": {
1175 | "version": "1.0.1",
1176 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz",
1177 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=",
1178 | "dev": true
1179 | },
1180 | "generate-function": {
1181 | "version": "2.3.1",
1182 | "resolved": "https://registry.npmjs.org/generate-function/-/generate-function-2.3.1.tgz",
1183 | "integrity": "sha512-eeB5GfMNeevm/GRYq20ShmsaGcmI81kIX2K9XQx5miC8KdHaC6Jm0qQ8ZNeGOi7wYB8OsdxKs+Y2oVuTFuVwKQ==",
1184 | "requires": {
1185 | "is-property": "^1.0.2"
1186 | }
1187 | },
1188 | "get-caller-file": {
1189 | "version": "2.0.5",
1190 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz",
1191 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==",
1192 | "dev": true
1193 | },
1194 | "get-func-name": {
1195 | "version": "2.0.0",
1196 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz",
1197 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=",
1198 | "dev": true
1199 | },
1200 | "glob": {
1201 | "version": "7.1.2",
1202 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz",
1203 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==",
1204 | "dev": true,
1205 | "requires": {
1206 | "fs.realpath": "^1.0.0",
1207 | "inflight": "^1.0.4",
1208 | "inherits": "2",
1209 | "minimatch": "^3.0.4",
1210 | "once": "^1.3.0",
1211 | "path-is-absolute": "^1.0.0"
1212 | }
1213 | },
1214 | "glob-parent": {
1215 | "version": "5.1.1",
1216 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz",
1217 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==",
1218 | "dev": true,
1219 | "requires": {
1220 | "is-glob": "^4.0.1"
1221 | }
1222 | },
1223 | "globals": {
1224 | "version": "11.9.0",
1225 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.9.0.tgz",
1226 | "integrity": "sha512-5cJVtyXWH8PiJPVLZzzoIizXx944O4OmRro5MWKx5fT4MgcN7OfaMutPeaTdJCCURwbWdhhcCWcKIffPnmTzBg==",
1227 | "dev": true
1228 | },
1229 | "graceful-fs": {
1230 | "version": "4.1.15",
1231 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz",
1232 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==",
1233 | "dev": true
1234 | },
1235 | "growl": {
1236 | "version": "1.10.5",
1237 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz",
1238 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==",
1239 | "dev": true
1240 | },
1241 | "handlebars": {
1242 | "version": "4.7.7",
1243 | "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.7.7.tgz",
1244 | "integrity": "sha512-aAcXm5OAfE/8IXkcZvCepKU3VzW1/39Fb5ZuqMtgI/hT8X2YgoMvBY5dLhq/cpOvw7Lk1nK/UF71aLG/ZnVYRA==",
1245 | "requires": {
1246 | "minimist": "^1.2.5",
1247 | "neo-async": "^2.6.0",
1248 | "source-map": "^0.6.1",
1249 | "uglify-js": "^3.1.4",
1250 | "wordwrap": "^1.0.0"
1251 | }
1252 | },
1253 | "has": {
1254 | "version": "1.0.3",
1255 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
1256 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
1257 | "dev": true,
1258 | "requires": {
1259 | "function-bind": "^1.1.1"
1260 | }
1261 | },
1262 | "has-flag": {
1263 | "version": "3.0.0",
1264 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
1265 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=",
1266 | "dev": true
1267 | },
1268 | "has-symbols": {
1269 | "version": "1.0.1",
1270 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz",
1271 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==",
1272 | "dev": true
1273 | },
1274 | "he": {
1275 | "version": "1.2.0",
1276 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz",
1277 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==",
1278 | "dev": true
1279 | },
1280 | "hosted-git-info": {
1281 | "version": "2.7.1",
1282 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz",
1283 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==",
1284 | "dev": true
1285 | },
1286 | "http-errors": {
1287 | "version": "1.6.3",
1288 | "resolved": "http://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz",
1289 | "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=",
1290 | "requires": {
1291 | "depd": "~1.1.2",
1292 | "inherits": "2.0.3",
1293 | "setprototypeof": "1.1.0",
1294 | "statuses": ">= 1.4.0 < 2"
1295 | }
1296 | },
1297 | "http-status-codes": {
1298 | "version": "1.3.0",
1299 | "resolved": "https://registry.npmjs.org/http-status-codes/-/http-status-codes-1.3.0.tgz",
1300 | "integrity": "sha1-nNDnE5F3PQZxtInUHLxQlKpBY7Y="
1301 | },
1302 | "iconv-lite": {
1303 | "version": "0.4.23",
1304 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz",
1305 | "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==",
1306 | "requires": {
1307 | "safer-buffer": ">= 2.1.2 < 3"
1308 | }
1309 | },
1310 | "ignore": {
1311 | "version": "4.0.6",
1312 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz",
1313 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==",
1314 | "dev": true
1315 | },
1316 | "imurmurhash": {
1317 | "version": "0.1.4",
1318 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
1319 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=",
1320 | "dev": true
1321 | },
1322 | "inflection": {
1323 | "version": "1.12.0",
1324 | "resolved": "https://registry.npmjs.org/inflection/-/inflection-1.12.0.tgz",
1325 | "integrity": "sha1-ogCTVlbW9fa8TcdQLhrstwMihBY="
1326 | },
1327 | "inflight": {
1328 | "version": "1.0.6",
1329 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
1330 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=",
1331 | "dev": true,
1332 | "requires": {
1333 | "once": "^1.3.0",
1334 | "wrappy": "1"
1335 | }
1336 | },
1337 | "inherits": {
1338 | "version": "2.0.3",
1339 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
1340 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4="
1341 | },
1342 | "inquirer": {
1343 | "version": "6.2.1",
1344 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.2.1.tgz",
1345 | "integrity": "sha512-088kl3DRT2dLU5riVMKKr1DlImd6X7smDhpXUCkJDCKvTEJeRiXh0G132HG9u5a+6Ylw9plFRY7RuTnwohYSpg==",
1346 | "dev": true,
1347 | "requires": {
1348 | "ansi-escapes": "^3.0.0",
1349 | "chalk": "^2.0.0",
1350 | "cli-cursor": "^2.1.0",
1351 | "cli-width": "^2.0.0",
1352 | "external-editor": "^3.0.0",
1353 | "figures": "^2.0.0",
1354 | "lodash": "^4.17.10",
1355 | "mute-stream": "0.0.7",
1356 | "run-async": "^2.2.0",
1357 | "rxjs": "^6.1.0",
1358 | "string-width": "^2.1.0",
1359 | "strip-ansi": "^5.0.0",
1360 | "through": "^2.3.6"
1361 | },
1362 | "dependencies": {
1363 | "ansi-regex": {
1364 | "version": "4.0.0",
1365 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.0.0.tgz",
1366 | "integrity": "sha512-iB5Dda8t/UqpPI/IjsejXu5jOGDrzn41wJyljwPH65VCIbk6+1BzFIMJGFwTNrYXT1CrD+B4l19U7awiQ8rk7w==",
1367 | "dev": true
1368 | },
1369 | "chalk": {
1370 | "version": "2.4.2",
1371 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
1372 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
1373 | "dev": true,
1374 | "requires": {
1375 | "ansi-styles": "^3.2.1",
1376 | "escape-string-regexp": "^1.0.5",
1377 | "supports-color": "^5.3.0"
1378 | }
1379 | },
1380 | "strip-ansi": {
1381 | "version": "5.0.0",
1382 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.0.0.tgz",
1383 | "integrity": "sha512-Uu7gQyZI7J7gn5qLn1Np3G9vcYGTVqB+lFTytnDJv83dd8T22aGH451P3jueT2/QemInJDfxHB5Tde5OzgG1Ow==",
1384 | "dev": true,
1385 | "requires": {
1386 | "ansi-regex": "^4.0.0"
1387 | }
1388 | }
1389 | }
1390 | },
1391 | "ipaddr.js": {
1392 | "version": "1.8.0",
1393 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.8.0.tgz",
1394 | "integrity": "sha1-6qM9bd16zo9/b+DJygRA5wZzix4="
1395 | },
1396 | "is-arguments": {
1397 | "version": "1.0.4",
1398 | "resolved": "https://registry.npmjs.org/is-arguments/-/is-arguments-1.0.4.tgz",
1399 | "integrity": "sha512-xPh0Rmt8NE65sNzvyUmWgI1tz3mKq74lGA0mL8LYZcoIzKOzDh6HmrYm3d18k60nHerC8A9Km8kYu87zfSFnLA==",
1400 | "dev": true
1401 | },
1402 | "is-arrayish": {
1403 | "version": "0.2.1",
1404 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
1405 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=",
1406 | "dev": true
1407 | },
1408 | "is-binary-path": {
1409 | "version": "2.1.0",
1410 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
1411 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
1412 | "dev": true,
1413 | "requires": {
1414 | "binary-extensions": "^2.0.0"
1415 | }
1416 | },
1417 | "is-buffer": {
1418 | "version": "2.0.4",
1419 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.4.tgz",
1420 | "integrity": "sha512-Kq1rokWXOPXWuaMAqZiJW4XxsmD9zGx9q4aePabbn3qCRGedtH7Cm+zV8WETitMfu1wdh+Rvd6w5egwSngUX2A==",
1421 | "dev": true
1422 | },
1423 | "is-builtin-module": {
1424 | "version": "1.0.0",
1425 | "resolved": "http://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz",
1426 | "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=",
1427 | "dev": true,
1428 | "requires": {
1429 | "builtin-modules": "^1.0.0"
1430 | }
1431 | },
1432 | "is-callable": {
1433 | "version": "1.2.0",
1434 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.0.tgz",
1435 | "integrity": "sha512-pyVD9AaGLxtg6srb2Ng6ynWJqkHU9bEM087AKck0w8QwDarTfNcpIYoU8x8Hv2Icm8u6kFJM18Dag8lyqGkviw==",
1436 | "dev": true
1437 | },
1438 | "is-date-object": {
1439 | "version": "1.0.2",
1440 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz",
1441 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==",
1442 | "dev": true
1443 | },
1444 | "is-extglob": {
1445 | "version": "2.1.1",
1446 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
1447 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
1448 | "dev": true
1449 | },
1450 | "is-fullwidth-code-point": {
1451 | "version": "2.0.0",
1452 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz",
1453 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=",
1454 | "dev": true
1455 | },
1456 | "is-glob": {
1457 | "version": "4.0.1",
1458 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz",
1459 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==",
1460 | "dev": true,
1461 | "requires": {
1462 | "is-extglob": "^2.1.1"
1463 | }
1464 | },
1465 | "is-map": {
1466 | "version": "2.0.1",
1467 | "resolved": "https://registry.npmjs.org/is-map/-/is-map-2.0.1.tgz",
1468 | "integrity": "sha512-T/S49scO8plUiAOA2DBTBG3JHpn1yiw0kRp6dgiZ0v2/6twi5eiB0rHtHFH9ZIrvlWc6+4O+m4zg5+Z833aXgw==",
1469 | "dev": true
1470 | },
1471 | "is-number": {
1472 | "version": "7.0.0",
1473 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
1474 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
1475 | "dev": true
1476 | },
1477 | "is-plain-obj": {
1478 | "version": "1.1.0",
1479 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz",
1480 | "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=",
1481 | "dev": true
1482 | },
1483 | "is-promise": {
1484 | "version": "2.1.0",
1485 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz",
1486 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=",
1487 | "dev": true
1488 | },
1489 | "is-property": {
1490 | "version": "1.0.2",
1491 | "resolved": "https://registry.npmjs.org/is-property/-/is-property-1.0.2.tgz",
1492 | "integrity": "sha1-V/4cTkhHTt1lsJkR8msc1Ald2oQ="
1493 | },
1494 | "is-regex": {
1495 | "version": "1.1.1",
1496 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.1.tgz",
1497 | "integrity": "sha512-1+QkEcxiLlB7VEyFtyBg94e08OAsvq7FUBgApTq/w2ymCLyKJgDPsybBENVtA7XCQEgEXxKPonG+mvYRxh/LIg==",
1498 | "dev": true,
1499 | "requires": {
1500 | "has-symbols": "^1.0.1"
1501 | }
1502 | },
1503 | "is-set": {
1504 | "version": "2.0.1",
1505 | "resolved": "https://registry.npmjs.org/is-set/-/is-set-2.0.1.tgz",
1506 | "integrity": "sha512-eJEzOtVyenDs1TMzSQ3kU3K+E0GUS9sno+F0OBT97xsgcJsF9nXMBtkT9/kut5JEpM7oL7X/0qxR17K3mcwIAA==",
1507 | "dev": true
1508 | },
1509 | "is-string": {
1510 | "version": "1.0.5",
1511 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.5.tgz",
1512 | "integrity": "sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ==",
1513 | "dev": true
1514 | },
1515 | "is-symbol": {
1516 | "version": "1.0.3",
1517 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz",
1518 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==",
1519 | "dev": true,
1520 | "requires": {
1521 | "has-symbols": "^1.0.1"
1522 | }
1523 | },
1524 | "isarray": {
1525 | "version": "1.0.0",
1526 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
1527 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE="
1528 | },
1529 | "isexe": {
1530 | "version": "2.0.0",
1531 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
1532 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=",
1533 | "dev": true
1534 | },
1535 | "iterate-iterator": {
1536 | "version": "1.0.1",
1537 | "resolved": "https://registry.npmjs.org/iterate-iterator/-/iterate-iterator-1.0.1.tgz",
1538 | "integrity": "sha512-3Q6tudGN05kbkDQDI4CqjaBf4qf85w6W6GnuZDtUVYwKgtC1q8yxYX7CZed7N+tLzQqS6roujWvszf13T+n9aw==",
1539 | "dev": true
1540 | },
1541 | "iterate-value": {
1542 | "version": "1.0.2",
1543 | "resolved": "https://registry.npmjs.org/iterate-value/-/iterate-value-1.0.2.tgz",
1544 | "integrity": "sha512-A6fMAio4D2ot2r/TYzr4yUWrmwNdsN5xL7+HUiyACE4DXm+q8HtPcnFTp+NnW3k4N05tZ7FVYFFb2CR13NxyHQ==",
1545 | "dev": true,
1546 | "requires": {
1547 | "es-get-iterator": "^1.0.2",
1548 | "iterate-iterator": "^1.0.1"
1549 | }
1550 | },
1551 | "js-tokens": {
1552 | "version": "4.0.0",
1553 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
1554 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==",
1555 | "dev": true
1556 | },
1557 | "js-yaml": {
1558 | "version": "3.13.1",
1559 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz",
1560 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==",
1561 | "dev": true,
1562 | "requires": {
1563 | "argparse": "^1.0.7",
1564 | "esprima": "^4.0.0"
1565 | }
1566 | },
1567 | "json-schema-traverse": {
1568 | "version": "0.4.1",
1569 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
1570 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
1571 | "dev": true
1572 | },
1573 | "json-stable-stringify-without-jsonify": {
1574 | "version": "1.0.1",
1575 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
1576 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=",
1577 | "dev": true
1578 | },
1579 | "kareem": {
1580 | "version": "2.3.2",
1581 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.2.tgz",
1582 | "integrity": "sha512-STHz9P7X2L4Kwn72fA4rGyqyXdmrMSdxqHx9IXon/FXluXieaFA6KJ2upcHAHxQPQ0LeM/OjLrhFxifHewOALQ=="
1583 | },
1584 | "levn": {
1585 | "version": "0.3.0",
1586 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz",
1587 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=",
1588 | "dev": true,
1589 | "requires": {
1590 | "prelude-ls": "~1.1.2",
1591 | "type-check": "~0.3.2"
1592 | }
1593 | },
1594 | "load-json-file": {
1595 | "version": "2.0.0",
1596 | "resolved": "http://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz",
1597 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=",
1598 | "dev": true,
1599 | "requires": {
1600 | "graceful-fs": "^4.1.2",
1601 | "parse-json": "^2.2.0",
1602 | "pify": "^2.0.0",
1603 | "strip-bom": "^3.0.0"
1604 | }
1605 | },
1606 | "locate-path": {
1607 | "version": "2.0.0",
1608 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz",
1609 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=",
1610 | "dev": true,
1611 | "requires": {
1612 | "p-locate": "^2.0.0",
1613 | "path-exists": "^3.0.0"
1614 | },
1615 | "dependencies": {
1616 | "path-exists": {
1617 | "version": "3.0.0",
1618 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz",
1619 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=",
1620 | "dev": true
1621 | }
1622 | }
1623 | },
1624 | "lodash": {
1625 | "version": "4.17.19",
1626 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.19.tgz",
1627 | "integrity": "sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ==",
1628 | "dev": true
1629 | },
1630 | "log-symbols": {
1631 | "version": "3.0.0",
1632 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-3.0.0.tgz",
1633 | "integrity": "sha512-dSkNGuI7iG3mfvDzUuYZyvk5dD9ocYCYzNU6CYDE6+Xqd+gwme6Z00NS3dUh8mq/73HaEtT7m6W+yUPtU6BZnQ==",
1634 | "dev": true,
1635 | "requires": {
1636 | "chalk": "^2.4.2"
1637 | },
1638 | "dependencies": {
1639 | "chalk": {
1640 | "version": "2.4.2",
1641 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
1642 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
1643 | "dev": true,
1644 | "requires": {
1645 | "ansi-styles": "^3.2.1",
1646 | "escape-string-regexp": "^1.0.5",
1647 | "supports-color": "^5.3.0"
1648 | }
1649 | }
1650 | }
1651 | },
1652 | "long": {
1653 | "version": "4.0.0",
1654 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz",
1655 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA=="
1656 | },
1657 | "lru-cache": {
1658 | "version": "6.0.0",
1659 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
1660 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
1661 | "requires": {
1662 | "yallist": "^4.0.0"
1663 | }
1664 | },
1665 | "media-typer": {
1666 | "version": "0.3.0",
1667 | "resolved": "http://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
1668 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g="
1669 | },
1670 | "memory-pager": {
1671 | "version": "1.5.0",
1672 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz",
1673 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==",
1674 | "optional": true
1675 | },
1676 | "merge-descriptors": {
1677 | "version": "1.0.1",
1678 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
1679 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E="
1680 | },
1681 | "methods": {
1682 | "version": "1.1.2",
1683 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
1684 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4="
1685 | },
1686 | "mime": {
1687 | "version": "1.4.1",
1688 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz",
1689 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ=="
1690 | },
1691 | "mime-db": {
1692 | "version": "1.37.0",
1693 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.37.0.tgz",
1694 | "integrity": "sha512-R3C4db6bgQhlIhPU48fUtdVmKnflq+hRdad7IyKhtFj06VPNVdk2RhiYL3UjQIlso8L+YxAtFkobT0VK+S/ybg=="
1695 | },
1696 | "mime-types": {
1697 | "version": "2.1.21",
1698 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.21.tgz",
1699 | "integrity": "sha512-3iL6DbwpyLzjR3xHSFNFeb9Nz/M8WDkX33t1GFQnFOllWk8pOrh/LSrB5OXlnlW5P9LH73X6loW/eogc+F5lJg==",
1700 | "requires": {
1701 | "mime-db": "~1.37.0"
1702 | }
1703 | },
1704 | "mimic-fn": {
1705 | "version": "1.2.0",
1706 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz",
1707 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==",
1708 | "dev": true
1709 | },
1710 | "minimatch": {
1711 | "version": "3.0.4",
1712 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
1713 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
1714 | "dev": true,
1715 | "requires": {
1716 | "brace-expansion": "^1.1.7"
1717 | }
1718 | },
1719 | "minimist": {
1720 | "version": "1.2.5",
1721 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
1722 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw=="
1723 | },
1724 | "mkdirp": {
1725 | "version": "0.5.5",
1726 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz",
1727 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==",
1728 | "dev": true,
1729 | "requires": {
1730 | "minimist": "^1.2.5"
1731 | }
1732 | },
1733 | "mocha": {
1734 | "version": "8.1.1",
1735 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-8.1.1.tgz",
1736 | "integrity": "sha512-p7FuGlYH8t7gaiodlFreseLxEmxTgvyG9RgPHODFPySNhwUehu8NIb0vdSt3WFckSneswZ0Un5typYcWElk7HQ==",
1737 | "dev": true,
1738 | "requires": {
1739 | "ansi-colors": "4.1.1",
1740 | "browser-stdout": "1.3.1",
1741 | "chokidar": "3.3.1",
1742 | "debug": "3.2.6",
1743 | "diff": "4.0.2",
1744 | "escape-string-regexp": "1.0.5",
1745 | "find-up": "4.1.0",
1746 | "glob": "7.1.6",
1747 | "growl": "1.10.5",
1748 | "he": "1.2.0",
1749 | "js-yaml": "3.13.1",
1750 | "log-symbols": "3.0.0",
1751 | "minimatch": "3.0.4",
1752 | "ms": "2.1.2",
1753 | "object.assign": "4.1.0",
1754 | "promise.allsettled": "1.0.2",
1755 | "serialize-javascript": "4.0.0",
1756 | "strip-json-comments": "3.0.1",
1757 | "supports-color": "7.1.0",
1758 | "which": "2.0.2",
1759 | "wide-align": "1.1.3",
1760 | "workerpool": "6.0.0",
1761 | "yargs": "13.3.2",
1762 | "yargs-parser": "13.1.2",
1763 | "yargs-unparser": "1.6.1"
1764 | },
1765 | "dependencies": {
1766 | "debug": {
1767 | "version": "3.2.6",
1768 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz",
1769 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==",
1770 | "dev": true,
1771 | "requires": {
1772 | "ms": "^2.1.1"
1773 | }
1774 | },
1775 | "find-up": {
1776 | "version": "4.1.0",
1777 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz",
1778 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==",
1779 | "dev": true,
1780 | "requires": {
1781 | "locate-path": "^5.0.0",
1782 | "path-exists": "^4.0.0"
1783 | }
1784 | },
1785 | "glob": {
1786 | "version": "7.1.6",
1787 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz",
1788 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==",
1789 | "dev": true,
1790 | "requires": {
1791 | "fs.realpath": "^1.0.0",
1792 | "inflight": "^1.0.4",
1793 | "inherits": "2",
1794 | "minimatch": "^3.0.4",
1795 | "once": "^1.3.0",
1796 | "path-is-absolute": "^1.0.0"
1797 | }
1798 | },
1799 | "has-flag": {
1800 | "version": "4.0.0",
1801 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
1802 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
1803 | "dev": true
1804 | },
1805 | "locate-path": {
1806 | "version": "5.0.0",
1807 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz",
1808 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==",
1809 | "dev": true,
1810 | "requires": {
1811 | "p-locate": "^4.1.0"
1812 | }
1813 | },
1814 | "ms": {
1815 | "version": "2.1.2",
1816 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
1817 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
1818 | "dev": true
1819 | },
1820 | "p-limit": {
1821 | "version": "2.3.0",
1822 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz",
1823 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==",
1824 | "dev": true,
1825 | "requires": {
1826 | "p-try": "^2.0.0"
1827 | }
1828 | },
1829 | "p-locate": {
1830 | "version": "4.1.0",
1831 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz",
1832 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==",
1833 | "dev": true,
1834 | "requires": {
1835 | "p-limit": "^2.2.0"
1836 | }
1837 | },
1838 | "p-try": {
1839 | "version": "2.2.0",
1840 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz",
1841 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==",
1842 | "dev": true
1843 | },
1844 | "path-exists": {
1845 | "version": "4.0.0",
1846 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
1847 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
1848 | "dev": true
1849 | },
1850 | "strip-json-comments": {
1851 | "version": "3.0.1",
1852 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.0.1.tgz",
1853 | "integrity": "sha512-VTyMAUfdm047mwKl+u79WIdrZxtFtn+nBxHeb844XBQ9uMNTuTHdx2hc5RiAJYqwTj3wc/xe5HLSdJSkJ+WfZw==",
1854 | "dev": true
1855 | },
1856 | "supports-color": {
1857 | "version": "7.1.0",
1858 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz",
1859 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==",
1860 | "dev": true,
1861 | "requires": {
1862 | "has-flag": "^4.0.0"
1863 | }
1864 | },
1865 | "which": {
1866 | "version": "2.0.2",
1867 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
1868 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
1869 | "dev": true,
1870 | "requires": {
1871 | "isexe": "^2.0.0"
1872 | }
1873 | }
1874 | }
1875 | },
1876 | "module-alias": {
1877 | "version": "2.2.2",
1878 | "resolved": "https://registry.npmjs.org/module-alias/-/module-alias-2.2.2.tgz",
1879 | "integrity": "sha512-A/78XjoX2EmNvppVWEhM2oGk3x4lLxnkEA4jTbaK97QKSDjkIoOsKQlfylt/d3kKKi596Qy3NP5XrXJ6fZIC9Q=="
1880 | },
1881 | "moment": {
1882 | "version": "2.29.1",
1883 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz",
1884 | "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ=="
1885 | },
1886 | "moment-timezone": {
1887 | "version": "0.5.33",
1888 | "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.33.tgz",
1889 | "integrity": "sha512-PTc2vcT8K9J5/9rDEPe5czSIKgLoGsH8UNpA4qZTVw0Vd/Uz19geE9abbIOQKaAQFcnQ3v5YEXrbSc5BpshH+w==",
1890 | "requires": {
1891 | "moment": ">= 2.9.0"
1892 | }
1893 | },
1894 | "mongodb": {
1895 | "version": "3.6.4",
1896 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.6.4.tgz",
1897 | "integrity": "sha512-Y+Ki9iXE9jI+n9bVtbTOOdK0B95d6wVGSucwtBkvQ+HIvVdTCfpVRp01FDC24uhC/Q2WXQ8Lpq3/zwtB5Op9Qw==",
1898 | "requires": {
1899 | "bl": "^2.2.1",
1900 | "bson": "^1.1.4",
1901 | "denque": "^1.4.1",
1902 | "require_optional": "^1.0.1",
1903 | "safe-buffer": "^5.1.2",
1904 | "saslprep": "^1.0.0"
1905 | }
1906 | },
1907 | "mongoose": {
1908 | "version": "5.11.16",
1909 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.11.16.tgz",
1910 | "integrity": "sha512-qmolyGAskPuq0Xr3j2Tjm9jwRccGGnLRWtTuyRvYBZoyItajwIoQdetJH8oVzs3N7aZK/GKZ82xV/t97suF8Pg==",
1911 | "requires": {
1912 | "@types/mongodb": "^3.5.27",
1913 | "bson": "^1.1.4",
1914 | "kareem": "2.3.2",
1915 | "mongodb": "3.6.4",
1916 | "mongoose-legacy-pluralize": "1.0.2",
1917 | "mpath": "0.8.3",
1918 | "mquery": "3.2.4",
1919 | "ms": "2.1.2",
1920 | "regexp-clone": "1.0.0",
1921 | "safe-buffer": "5.2.1",
1922 | "sift": "7.0.1",
1923 | "sliced": "1.0.1"
1924 | },
1925 | "dependencies": {
1926 | "ms": {
1927 | "version": "2.1.2",
1928 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
1929 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
1930 | },
1931 | "safe-buffer": {
1932 | "version": "5.2.1",
1933 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
1934 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ=="
1935 | }
1936 | }
1937 | },
1938 | "mongoose-legacy-pluralize": {
1939 | "version": "1.0.2",
1940 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz",
1941 | "integrity": "sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ=="
1942 | },
1943 | "mpath": {
1944 | "version": "0.8.3",
1945 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.8.3.tgz",
1946 | "integrity": "sha512-eb9rRvhDltXVNL6Fxd2zM9D4vKBxjVVQNLNijlj7uoXUy19zNDsIif5zR+pWmPCWNKwAtqyo4JveQm4nfD5+eA=="
1947 | },
1948 | "mquery": {
1949 | "version": "3.2.4",
1950 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.2.4.tgz",
1951 | "integrity": "sha512-uOLpp7iRX0BV1Uu6YpsqJ5b42LwYnmu0WeF/f8qgD/On3g0XDaQM6pfn0m6UxO6SM8DioZ9Bk6xxbWIGHm2zHg==",
1952 | "requires": {
1953 | "bluebird": "3.5.1",
1954 | "debug": "3.1.0",
1955 | "regexp-clone": "^1.0.0",
1956 | "safe-buffer": "5.1.2",
1957 | "sliced": "1.0.1"
1958 | },
1959 | "dependencies": {
1960 | "debug": {
1961 | "version": "3.1.0",
1962 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz",
1963 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==",
1964 | "requires": {
1965 | "ms": "2.0.0"
1966 | }
1967 | }
1968 | }
1969 | },
1970 | "ms": {
1971 | "version": "2.0.0",
1972 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
1973 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g="
1974 | },
1975 | "mute-stream": {
1976 | "version": "0.0.7",
1977 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz",
1978 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=",
1979 | "dev": true
1980 | },
1981 | "mysql2": {
1982 | "version": "2.2.5",
1983 | "resolved": "https://registry.npmjs.org/mysql2/-/mysql2-2.2.5.tgz",
1984 | "integrity": "sha512-XRqPNxcZTpmFdXbJqb+/CtYVLCx14x1RTeNMD4954L331APu75IC74GDqnZMEt1kwaXy6TySo55rF2F3YJS78g==",
1985 | "requires": {
1986 | "denque": "^1.4.1",
1987 | "generate-function": "^2.3.1",
1988 | "iconv-lite": "^0.6.2",
1989 | "long": "^4.0.0",
1990 | "lru-cache": "^6.0.0",
1991 | "named-placeholders": "^1.1.2",
1992 | "seq-queue": "^0.0.5",
1993 | "sqlstring": "^2.3.2"
1994 | },
1995 | "dependencies": {
1996 | "iconv-lite": {
1997 | "version": "0.6.2",
1998 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.2.tgz",
1999 | "integrity": "sha512-2y91h5OpQlolefMPmUlivelittSWy0rP+oYVpn6A7GwVHNE8AWzoYOBNmlwks3LobaJxgHCYZAnyNo2GgpNRNQ==",
2000 | "requires": {
2001 | "safer-buffer": ">= 2.1.2 < 3.0.0"
2002 | }
2003 | }
2004 | }
2005 | },
2006 | "named-placeholders": {
2007 | "version": "1.1.2",
2008 | "resolved": "https://registry.npmjs.org/named-placeholders/-/named-placeholders-1.1.2.tgz",
2009 | "integrity": "sha512-wiFWqxoLL3PGVReSZpjLVxyJ1bRqe+KKJVbr4hGs1KWfTZTQyezHFBbuKj9hsizHyGV2ne7EMjHdxEGAybD5SA==",
2010 | "requires": {
2011 | "lru-cache": "^4.1.3"
2012 | },
2013 | "dependencies": {
2014 | "lru-cache": {
2015 | "version": "4.1.5",
2016 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz",
2017 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==",
2018 | "requires": {
2019 | "pseudomap": "^1.0.2",
2020 | "yallist": "^2.1.2"
2021 | }
2022 | },
2023 | "yallist": {
2024 | "version": "2.1.2",
2025 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz",
2026 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI="
2027 | }
2028 | }
2029 | },
2030 | "natural-compare": {
2031 | "version": "1.4.0",
2032 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
2033 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=",
2034 | "dev": true
2035 | },
2036 | "negotiator": {
2037 | "version": "0.6.1",
2038 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz",
2039 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk="
2040 | },
2041 | "neo-async": {
2042 | "version": "2.6.2",
2043 | "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz",
2044 | "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw=="
2045 | },
2046 | "nice-try": {
2047 | "version": "1.0.5",
2048 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz",
2049 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==",
2050 | "dev": true
2051 | },
2052 | "normalize-package-data": {
2053 | "version": "2.4.0",
2054 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz",
2055 | "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==",
2056 | "dev": true,
2057 | "requires": {
2058 | "hosted-git-info": "^2.1.4",
2059 | "is-builtin-module": "^1.0.0",
2060 | "semver": "2 || 3 || 4 || 5",
2061 | "validate-npm-package-license": "^3.0.1"
2062 | }
2063 | },
2064 | "normalize-path": {
2065 | "version": "3.0.0",
2066 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
2067 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
2068 | "dev": true
2069 | },
2070 | "object-assign": {
2071 | "version": "4.1.1",
2072 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
2073 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM="
2074 | },
2075 | "object-inspect": {
2076 | "version": "1.8.0",
2077 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.8.0.tgz",
2078 | "integrity": "sha512-jLdtEOB112fORuypAyl/50VRVIBIdVQOSUUGQHzJ4xBSbit81zRarz7GThkEFZy1RceYrWYcPcBFPQwHyAc1gA==",
2079 | "dev": true
2080 | },
2081 | "object-keys": {
2082 | "version": "1.1.1",
2083 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz",
2084 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==",
2085 | "dev": true
2086 | },
2087 | "object.assign": {
2088 | "version": "4.1.0",
2089 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz",
2090 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==",
2091 | "dev": true,
2092 | "requires": {
2093 | "define-properties": "^1.1.2",
2094 | "function-bind": "^1.1.1",
2095 | "has-symbols": "^1.0.0",
2096 | "object-keys": "^1.0.11"
2097 | }
2098 | },
2099 | "on-finished": {
2100 | "version": "2.3.0",
2101 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz",
2102 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=",
2103 | "requires": {
2104 | "ee-first": "1.1.1"
2105 | }
2106 | },
2107 | "once": {
2108 | "version": "1.4.0",
2109 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
2110 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
2111 | "dev": true,
2112 | "requires": {
2113 | "wrappy": "1"
2114 | }
2115 | },
2116 | "onetime": {
2117 | "version": "2.0.1",
2118 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz",
2119 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=",
2120 | "dev": true,
2121 | "requires": {
2122 | "mimic-fn": "^1.0.0"
2123 | }
2124 | },
2125 | "optionator": {
2126 | "version": "0.8.2",
2127 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz",
2128 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=",
2129 | "dev": true,
2130 | "requires": {
2131 | "deep-is": "~0.1.3",
2132 | "fast-levenshtein": "~2.0.4",
2133 | "levn": "~0.3.0",
2134 | "prelude-ls": "~1.1.2",
2135 | "type-check": "~0.3.2",
2136 | "wordwrap": "~1.0.0"
2137 | }
2138 | },
2139 | "os-tmpdir": {
2140 | "version": "1.0.2",
2141 | "resolved": "http://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz",
2142 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=",
2143 | "dev": true
2144 | },
2145 | "p-limit": {
2146 | "version": "1.3.0",
2147 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz",
2148 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==",
2149 | "dev": true,
2150 | "requires": {
2151 | "p-try": "^1.0.0"
2152 | }
2153 | },
2154 | "p-locate": {
2155 | "version": "2.0.0",
2156 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz",
2157 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=",
2158 | "dev": true,
2159 | "requires": {
2160 | "p-limit": "^1.1.0"
2161 | }
2162 | },
2163 | "p-try": {
2164 | "version": "1.0.0",
2165 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz",
2166 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=",
2167 | "dev": true
2168 | },
2169 | "parse-json": {
2170 | "version": "2.2.0",
2171 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz",
2172 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=",
2173 | "dev": true,
2174 | "requires": {
2175 | "error-ex": "^1.2.0"
2176 | }
2177 | },
2178 | "parseurl": {
2179 | "version": "1.3.2",
2180 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz",
2181 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M="
2182 | },
2183 | "path-exists": {
2184 | "version": "2.1.0",
2185 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz",
2186 | "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=",
2187 | "dev": true,
2188 | "requires": {
2189 | "pinkie-promise": "^2.0.0"
2190 | }
2191 | },
2192 | "path-is-absolute": {
2193 | "version": "1.0.1",
2194 | "resolved": "http://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
2195 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=",
2196 | "dev": true
2197 | },
2198 | "path-is-inside": {
2199 | "version": "1.0.2",
2200 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz",
2201 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=",
2202 | "dev": true
2203 | },
2204 | "path-key": {
2205 | "version": "2.0.1",
2206 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz",
2207 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=",
2208 | "dev": true
2209 | },
2210 | "path-parse": {
2211 | "version": "1.0.6",
2212 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz",
2213 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==",
2214 | "dev": true
2215 | },
2216 | "path-to-regexp": {
2217 | "version": "0.1.7",
2218 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
2219 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w="
2220 | },
2221 | "path-type": {
2222 | "version": "2.0.0",
2223 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz",
2224 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=",
2225 | "dev": true,
2226 | "requires": {
2227 | "pify": "^2.0.0"
2228 | }
2229 | },
2230 | "pathval": {
2231 | "version": "1.1.0",
2232 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.0.tgz",
2233 | "integrity": "sha1-uULm1L3mUwBe9rcTYd74cn0GReA=",
2234 | "dev": true
2235 | },
2236 | "picomatch": {
2237 | "version": "2.2.2",
2238 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz",
2239 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==",
2240 | "dev": true
2241 | },
2242 | "pify": {
2243 | "version": "2.3.0",
2244 | "resolved": "http://registry.npmjs.org/pify/-/pify-2.3.0.tgz",
2245 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=",
2246 | "dev": true
2247 | },
2248 | "pinkie": {
2249 | "version": "2.0.4",
2250 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz",
2251 | "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=",
2252 | "dev": true
2253 | },
2254 | "pinkie-promise": {
2255 | "version": "2.0.1",
2256 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz",
2257 | "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=",
2258 | "dev": true,
2259 | "requires": {
2260 | "pinkie": "^2.0.0"
2261 | }
2262 | },
2263 | "pkg-dir": {
2264 | "version": "1.0.0",
2265 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-1.0.0.tgz",
2266 | "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=",
2267 | "dev": true,
2268 | "requires": {
2269 | "find-up": "^1.0.0"
2270 | }
2271 | },
2272 | "pluralize": {
2273 | "version": "7.0.0",
2274 | "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-7.0.0.tgz",
2275 | "integrity": "sha512-ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow==",
2276 | "dev": true
2277 | },
2278 | "prelude-ls": {
2279 | "version": "1.1.2",
2280 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz",
2281 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=",
2282 | "dev": true
2283 | },
2284 | "process-nextick-args": {
2285 | "version": "2.0.1",
2286 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz",
2287 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag=="
2288 | },
2289 | "progress": {
2290 | "version": "2.0.3",
2291 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz",
2292 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==",
2293 | "dev": true
2294 | },
2295 | "promise.allsettled": {
2296 | "version": "1.0.2",
2297 | "resolved": "https://registry.npmjs.org/promise.allsettled/-/promise.allsettled-1.0.2.tgz",
2298 | "integrity": "sha512-UpcYW5S1RaNKT6pd+s9jp9K9rlQge1UXKskec0j6Mmuq7UJCvlS2J2/s/yuPN8ehftf9HXMxWlKiPbGGUzpoRg==",
2299 | "dev": true,
2300 | "requires": {
2301 | "array.prototype.map": "^1.0.1",
2302 | "define-properties": "^1.1.3",
2303 | "es-abstract": "^1.17.0-next.1",
2304 | "function-bind": "^1.1.1",
2305 | "iterate-value": "^1.0.0"
2306 | }
2307 | },
2308 | "proxy-addr": {
2309 | "version": "2.0.4",
2310 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.4.tgz",
2311 | "integrity": "sha512-5erio2h9jp5CHGwcybmxmVqHmnCBZeewlfJ0pex+UW7Qny7OOZXTtH56TGNyBizkgiOwhJtMKrVzDTeKcySZwA==",
2312 | "requires": {
2313 | "forwarded": "~0.1.2",
2314 | "ipaddr.js": "1.8.0"
2315 | }
2316 | },
2317 | "pseudomap": {
2318 | "version": "1.0.2",
2319 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz",
2320 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM="
2321 | },
2322 | "punycode": {
2323 | "version": "2.1.1",
2324 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz",
2325 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==",
2326 | "dev": true
2327 | },
2328 | "qs": {
2329 | "version": "6.5.2",
2330 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz",
2331 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA=="
2332 | },
2333 | "randombytes": {
2334 | "version": "2.1.0",
2335 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz",
2336 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==",
2337 | "dev": true,
2338 | "requires": {
2339 | "safe-buffer": "^5.1.0"
2340 | }
2341 | },
2342 | "range-parser": {
2343 | "version": "1.2.0",
2344 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz",
2345 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4="
2346 | },
2347 | "raw-body": {
2348 | "version": "2.3.3",
2349 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.3.tgz",
2350 | "integrity": "sha512-9esiElv1BrZoI3rCDuOuKCBRbuApGGaDPQfjSflGxdy4oyzqghxu6klEkkVIvBje+FF0BX9coEv8KqW6X/7njw==",
2351 | "requires": {
2352 | "bytes": "3.0.0",
2353 | "http-errors": "1.6.3",
2354 | "iconv-lite": "0.4.23",
2355 | "unpipe": "1.0.0"
2356 | }
2357 | },
2358 | "read-pkg": {
2359 | "version": "2.0.0",
2360 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz",
2361 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=",
2362 | "dev": true,
2363 | "requires": {
2364 | "load-json-file": "^2.0.0",
2365 | "normalize-package-data": "^2.3.2",
2366 | "path-type": "^2.0.0"
2367 | }
2368 | },
2369 | "read-pkg-up": {
2370 | "version": "2.0.0",
2371 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz",
2372 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=",
2373 | "dev": true,
2374 | "requires": {
2375 | "find-up": "^2.0.0",
2376 | "read-pkg": "^2.0.0"
2377 | },
2378 | "dependencies": {
2379 | "find-up": {
2380 | "version": "2.1.0",
2381 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz",
2382 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=",
2383 | "dev": true,
2384 | "requires": {
2385 | "locate-path": "^2.0.0"
2386 | }
2387 | }
2388 | }
2389 | },
2390 | "readable-stream": {
2391 | "version": "2.3.7",
2392 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz",
2393 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==",
2394 | "requires": {
2395 | "core-util-is": "~1.0.0",
2396 | "inherits": "~2.0.3",
2397 | "isarray": "~1.0.0",
2398 | "process-nextick-args": "~2.0.0",
2399 | "safe-buffer": "~5.1.1",
2400 | "string_decoder": "~1.1.1",
2401 | "util-deprecate": "~1.0.1"
2402 | }
2403 | },
2404 | "readdirp": {
2405 | "version": "3.3.0",
2406 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.3.0.tgz",
2407 | "integrity": "sha512-zz0pAkSPOXXm1viEwygWIPSPkcBYjW1xU5j/JBh5t9bGCJwa6f9+BJa6VaB2g+b55yVrmXzqkyLf4xaWYM0IkQ==",
2408 | "dev": true,
2409 | "requires": {
2410 | "picomatch": "^2.0.7"
2411 | }
2412 | },
2413 | "redis": {
2414 | "version": "3.0.2",
2415 | "resolved": "https://registry.npmjs.org/redis/-/redis-3.0.2.tgz",
2416 | "integrity": "sha512-PNhLCrjU6vKVuMOyFu7oSP296mwBkcE6lrAjruBYG5LgdSqtRBoVQIylrMyVZD/lkF24RSNNatzvYag6HRBHjQ==",
2417 | "requires": {
2418 | "denque": "^1.4.1",
2419 | "redis-commands": "^1.5.0",
2420 | "redis-errors": "^1.2.0",
2421 | "redis-parser": "^3.0.0"
2422 | }
2423 | },
2424 | "redis-commands": {
2425 | "version": "1.7.0",
2426 | "resolved": "https://registry.npmjs.org/redis-commands/-/redis-commands-1.7.0.tgz",
2427 | "integrity": "sha512-nJWqw3bTFy21hX/CPKHth6sfhZbdiHP6bTawSgQBlKOVRG7EZkfHbbHwQJnrE4vsQf0CMNE+3gJ4Fmm16vdVlQ=="
2428 | },
2429 | "redis-errors": {
2430 | "version": "1.2.0",
2431 | "resolved": "https://registry.npmjs.org/redis-errors/-/redis-errors-1.2.0.tgz",
2432 | "integrity": "sha1-62LSrbFeTq9GEMBK/hUpOEJQq60="
2433 | },
2434 | "redis-parser": {
2435 | "version": "3.0.0",
2436 | "resolved": "https://registry.npmjs.org/redis-parser/-/redis-parser-3.0.0.tgz",
2437 | "integrity": "sha1-tm2CjNyv5rS4pCin3vTGvKwxyLQ=",
2438 | "requires": {
2439 | "redis-errors": "^1.0.0"
2440 | }
2441 | },
2442 | "regexp-clone": {
2443 | "version": "1.0.0",
2444 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-1.0.0.tgz",
2445 | "integrity": "sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw=="
2446 | },
2447 | "regexpp": {
2448 | "version": "2.0.1",
2449 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz",
2450 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==",
2451 | "dev": true
2452 | },
2453 | "require-directory": {
2454 | "version": "2.1.1",
2455 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
2456 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=",
2457 | "dev": true
2458 | },
2459 | "require-main-filename": {
2460 | "version": "2.0.0",
2461 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz",
2462 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==",
2463 | "dev": true
2464 | },
2465 | "require-uncached": {
2466 | "version": "1.0.3",
2467 | "resolved": "http://registry.npmjs.org/require-uncached/-/require-uncached-1.0.3.tgz",
2468 | "integrity": "sha1-Tg1W1slmL9MeQwEcS5WqSZVUIdM=",
2469 | "dev": true,
2470 | "requires": {
2471 | "caller-path": "^0.1.0",
2472 | "resolve-from": "^1.0.0"
2473 | }
2474 | },
2475 | "require_optional": {
2476 | "version": "1.0.1",
2477 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz",
2478 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==",
2479 | "requires": {
2480 | "resolve-from": "^2.0.0",
2481 | "semver": "^5.1.0"
2482 | },
2483 | "dependencies": {
2484 | "resolve-from": {
2485 | "version": "2.0.0",
2486 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz",
2487 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c="
2488 | }
2489 | }
2490 | },
2491 | "resolve": {
2492 | "version": "1.8.1",
2493 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.8.1.tgz",
2494 | "integrity": "sha512-AicPrAC7Qu1JxPCZ9ZgCZlY35QgFnNqc+0LtbRNxnVw4TXvjQ72wnuL9JQcEBgXkI9JM8MsT9kaQoHcpCRJOYA==",
2495 | "dev": true,
2496 | "requires": {
2497 | "path-parse": "^1.0.5"
2498 | }
2499 | },
2500 | "resolve-from": {
2501 | "version": "1.0.1",
2502 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-1.0.1.tgz",
2503 | "integrity": "sha1-Jsv+k10a7uq7Kbw/5a6wHpPUQiY=",
2504 | "dev": true
2505 | },
2506 | "restore-cursor": {
2507 | "version": "2.0.0",
2508 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz",
2509 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=",
2510 | "dev": true,
2511 | "requires": {
2512 | "onetime": "^2.0.0",
2513 | "signal-exit": "^3.0.2"
2514 | }
2515 | },
2516 | "retry-as-promised": {
2517 | "version": "3.2.0",
2518 | "resolved": "https://registry.npmjs.org/retry-as-promised/-/retry-as-promised-3.2.0.tgz",
2519 | "integrity": "sha512-CybGs60B7oYU/qSQ6kuaFmRd9sTZ6oXSc0toqePvV74Ac6/IFZSI1ReFQmtCN+uvW1Mtqdwpvt/LGOiCBAY2Mg==",
2520 | "requires": {
2521 | "any-promise": "^1.3.0"
2522 | }
2523 | },
2524 | "rimraf": {
2525 | "version": "2.6.2",
2526 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz",
2527 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==",
2528 | "dev": true,
2529 | "requires": {
2530 | "glob": "^7.0.5"
2531 | }
2532 | },
2533 | "run-async": {
2534 | "version": "2.3.0",
2535 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz",
2536 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=",
2537 | "dev": true,
2538 | "requires": {
2539 | "is-promise": "^2.1.0"
2540 | }
2541 | },
2542 | "rxjs": {
2543 | "version": "6.3.3",
2544 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.3.3.tgz",
2545 | "integrity": "sha512-JTWmoY9tWCs7zvIk/CvRjhjGaOd+OVBM987mxFo+OW66cGpdKjZcpmc74ES1sB//7Kl/PAe8+wEakuhG4pcgOw==",
2546 | "dev": true,
2547 | "requires": {
2548 | "tslib": "^1.9.0"
2549 | }
2550 | },
2551 | "safe-buffer": {
2552 | "version": "5.1.2",
2553 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
2554 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
2555 | },
2556 | "safer-buffer": {
2557 | "version": "2.1.2",
2558 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
2559 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
2560 | },
2561 | "saslprep": {
2562 | "version": "1.0.3",
2563 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz",
2564 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==",
2565 | "optional": true,
2566 | "requires": {
2567 | "sparse-bitfield": "^3.0.3"
2568 | }
2569 | },
2570 | "semver": {
2571 | "version": "5.6.0",
2572 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz",
2573 | "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg=="
2574 | },
2575 | "send": {
2576 | "version": "0.16.2",
2577 | "resolved": "https://registry.npmjs.org/send/-/send-0.16.2.tgz",
2578 | "integrity": "sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw==",
2579 | "requires": {
2580 | "debug": "2.6.9",
2581 | "depd": "~1.1.2",
2582 | "destroy": "~1.0.4",
2583 | "encodeurl": "~1.0.2",
2584 | "escape-html": "~1.0.3",
2585 | "etag": "~1.8.1",
2586 | "fresh": "0.5.2",
2587 | "http-errors": "~1.6.2",
2588 | "mime": "1.4.1",
2589 | "ms": "2.0.0",
2590 | "on-finished": "~2.3.0",
2591 | "range-parser": "~1.2.0",
2592 | "statuses": "~1.4.0"
2593 | },
2594 | "dependencies": {
2595 | "debug": {
2596 | "version": "2.6.9",
2597 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
2598 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
2599 | "requires": {
2600 | "ms": "2.0.0"
2601 | }
2602 | },
2603 | "statuses": {
2604 | "version": "1.4.0",
2605 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz",
2606 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew=="
2607 | }
2608 | }
2609 | },
2610 | "seq-queue": {
2611 | "version": "0.0.5",
2612 | "resolved": "https://registry.npmjs.org/seq-queue/-/seq-queue-0.0.5.tgz",
2613 | "integrity": "sha1-1WgS4cAXpuTnw+Ojeh2m143TyT4="
2614 | },
2615 | "sequelize": {
2616 | "version": "6.5.0",
2617 | "resolved": "https://registry.npmjs.org/sequelize/-/sequelize-6.5.0.tgz",
2618 | "integrity": "sha512-owBt8fnzVy8E1OvyCyfCdVk7OOLyPVrBCMEf+CvRReC5oCyo+UqeXCtwaex9L6LM9ifZ1i3TG3sFeM5MgLK0CQ==",
2619 | "requires": {
2620 | "debug": "^4.1.1",
2621 | "dottie": "^2.0.0",
2622 | "inflection": "1.12.0",
2623 | "lodash": "^4.17.20",
2624 | "moment": "^2.26.0",
2625 | "moment-timezone": "^0.5.31",
2626 | "retry-as-promised": "^3.2.0",
2627 | "semver": "^7.3.2",
2628 | "sequelize-pool": "^6.0.0",
2629 | "toposort-class": "^1.0.1",
2630 | "uuid": "^8.1.0",
2631 | "validator": "^10.11.0",
2632 | "wkx": "^0.5.0"
2633 | },
2634 | "dependencies": {
2635 | "debug": {
2636 | "version": "4.3.1",
2637 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz",
2638 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==",
2639 | "requires": {
2640 | "ms": "2.1.2"
2641 | }
2642 | },
2643 | "lodash": {
2644 | "version": "4.17.21",
2645 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz",
2646 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg=="
2647 | },
2648 | "ms": {
2649 | "version": "2.1.2",
2650 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
2651 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
2652 | },
2653 | "semver": {
2654 | "version": "7.3.4",
2655 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz",
2656 | "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==",
2657 | "requires": {
2658 | "lru-cache": "^6.0.0"
2659 | }
2660 | }
2661 | }
2662 | },
2663 | "sequelize-pool": {
2664 | "version": "6.1.0",
2665 | "resolved": "https://registry.npmjs.org/sequelize-pool/-/sequelize-pool-6.1.0.tgz",
2666 | "integrity": "sha512-4YwEw3ZgK/tY/so+GfnSgXkdwIJJ1I32uZJztIEgZeAO6HMgj64OzySbWLgxj+tXhZCJnzRfkY9gINw8Ft8ZMg=="
2667 | },
2668 | "serialize-javascript": {
2669 | "version": "4.0.0",
2670 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-4.0.0.tgz",
2671 | "integrity": "sha512-GaNA54380uFefWghODBWEGisLZFj00nS5ACs6yHa9nLqlLpVLO8ChDGeKRjZnV4Nh4n0Qi7nhYZD/9fCPzEqkw==",
2672 | "dev": true,
2673 | "requires": {
2674 | "randombytes": "^2.1.0"
2675 | }
2676 | },
2677 | "serve-static": {
2678 | "version": "1.13.2",
2679 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.13.2.tgz",
2680 | "integrity": "sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw==",
2681 | "requires": {
2682 | "encodeurl": "~1.0.2",
2683 | "escape-html": "~1.0.3",
2684 | "parseurl": "~1.3.2",
2685 | "send": "0.16.2"
2686 | }
2687 | },
2688 | "set-blocking": {
2689 | "version": "2.0.0",
2690 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz",
2691 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=",
2692 | "dev": true
2693 | },
2694 | "setprototypeof": {
2695 | "version": "1.1.0",
2696 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz",
2697 | "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ=="
2698 | },
2699 | "shebang-command": {
2700 | "version": "1.2.0",
2701 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz",
2702 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=",
2703 | "dev": true,
2704 | "requires": {
2705 | "shebang-regex": "^1.0.0"
2706 | }
2707 | },
2708 | "shebang-regex": {
2709 | "version": "1.0.0",
2710 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz",
2711 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=",
2712 | "dev": true
2713 | },
2714 | "sift": {
2715 | "version": "7.0.1",
2716 | "resolved": "https://registry.npmjs.org/sift/-/sift-7.0.1.tgz",
2717 | "integrity": "sha512-oqD7PMJ+uO6jV9EQCl0LrRw1OwsiPsiFQR5AR30heR+4Dl7jBBbDLnNvWiak20tzZlSE1H7RB30SX/1j/YYT7g=="
2718 | },
2719 | "signal-exit": {
2720 | "version": "3.0.2",
2721 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz",
2722 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=",
2723 | "dev": true
2724 | },
2725 | "slice-ansi": {
2726 | "version": "2.0.0",
2727 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.0.0.tgz",
2728 | "integrity": "sha512-4j2WTWjp3GsZ+AOagyzVbzp4vWGtZ0hEZ/gDY/uTvm6MTxUfTUIsnMIFb1bn8o0RuXiqUw15H1bue8f22Vw2oQ==",
2729 | "dev": true,
2730 | "requires": {
2731 | "ansi-styles": "^3.2.0",
2732 | "astral-regex": "^1.0.0",
2733 | "is-fullwidth-code-point": "^2.0.0"
2734 | }
2735 | },
2736 | "sliced": {
2737 | "version": "1.0.1",
2738 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz",
2739 | "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E="
2740 | },
2741 | "source-map": {
2742 | "version": "0.6.1",
2743 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
2744 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g=="
2745 | },
2746 | "sparse-bitfield": {
2747 | "version": "3.0.3",
2748 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz",
2749 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=",
2750 | "optional": true,
2751 | "requires": {
2752 | "memory-pager": "^1.0.2"
2753 | }
2754 | },
2755 | "spdx-correct": {
2756 | "version": "3.1.0",
2757 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz",
2758 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==",
2759 | "dev": true,
2760 | "requires": {
2761 | "spdx-expression-parse": "^3.0.0",
2762 | "spdx-license-ids": "^3.0.0"
2763 | }
2764 | },
2765 | "spdx-exceptions": {
2766 | "version": "2.2.0",
2767 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz",
2768 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==",
2769 | "dev": true
2770 | },
2771 | "spdx-expression-parse": {
2772 | "version": "3.0.0",
2773 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz",
2774 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==",
2775 | "dev": true,
2776 | "requires": {
2777 | "spdx-exceptions": "^2.1.0",
2778 | "spdx-license-ids": "^3.0.0"
2779 | }
2780 | },
2781 | "spdx-license-ids": {
2782 | "version": "3.0.2",
2783 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.2.tgz",
2784 | "integrity": "sha512-qky9CVt0lVIECkEsYbNILVnPvycuEBkXoMFLRWsREkomQLevYhtRKC+R91a5TOAQ3bCMjikRwhyaRqj1VYatYg==",
2785 | "dev": true
2786 | },
2787 | "sprintf-js": {
2788 | "version": "1.0.3",
2789 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz",
2790 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=",
2791 | "dev": true
2792 | },
2793 | "sqlstring": {
2794 | "version": "2.3.2",
2795 | "resolved": "https://registry.npmjs.org/sqlstring/-/sqlstring-2.3.2.tgz",
2796 | "integrity": "sha512-vF4ZbYdKS8OnoJAWBmMxCQDkiEBkGQYU7UZPtL8flbDRSNkhaXvRJ279ZtI6M+zDaQovVU4tuRgzK5fVhvFAhg=="
2797 | },
2798 | "statuses": {
2799 | "version": "1.5.0",
2800 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz",
2801 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow="
2802 | },
2803 | "string-width": {
2804 | "version": "2.1.1",
2805 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz",
2806 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==",
2807 | "dev": true,
2808 | "requires": {
2809 | "is-fullwidth-code-point": "^2.0.0",
2810 | "strip-ansi": "^4.0.0"
2811 | }
2812 | },
2813 | "string.prototype.trimend": {
2814 | "version": "1.0.1",
2815 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz",
2816 | "integrity": "sha512-LRPxFUaTtpqYsTeNKaFOw3R4bxIzWOnbQ837QfBylo8jIxtcbK/A/sMV7Q+OAV/vWo+7s25pOE10KYSjaSO06g==",
2817 | "dev": true,
2818 | "requires": {
2819 | "define-properties": "^1.1.3",
2820 | "es-abstract": "^1.17.5"
2821 | }
2822 | },
2823 | "string.prototype.trimstart": {
2824 | "version": "1.0.1",
2825 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz",
2826 | "integrity": "sha512-XxZn+QpvrBI1FOcg6dIpxUPgWCPuNXvMD72aaRaUQv1eD4e/Qy8i/hFTe0BUmD60p/QA6bh1avmuPTfNjqVWRw==",
2827 | "dev": true,
2828 | "requires": {
2829 | "define-properties": "^1.1.3",
2830 | "es-abstract": "^1.17.5"
2831 | }
2832 | },
2833 | "string_decoder": {
2834 | "version": "1.1.1",
2835 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
2836 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
2837 | "requires": {
2838 | "safe-buffer": "~5.1.0"
2839 | }
2840 | },
2841 | "strip-ansi": {
2842 | "version": "4.0.0",
2843 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz",
2844 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=",
2845 | "dev": true,
2846 | "requires": {
2847 | "ansi-regex": "^3.0.0"
2848 | }
2849 | },
2850 | "strip-bom": {
2851 | "version": "3.0.0",
2852 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz",
2853 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=",
2854 | "dev": true
2855 | },
2856 | "strip-json-comments": {
2857 | "version": "2.0.1",
2858 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz",
2859 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=",
2860 | "dev": true
2861 | },
2862 | "supports-color": {
2863 | "version": "5.4.0",
2864 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.4.0.tgz",
2865 | "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==",
2866 | "dev": true,
2867 | "requires": {
2868 | "has-flag": "^3.0.0"
2869 | }
2870 | },
2871 | "table": {
2872 | "version": "5.1.1",
2873 | "resolved": "https://registry.npmjs.org/table/-/table-5.1.1.tgz",
2874 | "integrity": "sha512-NUjapYb/qd4PeFW03HnAuOJ7OMcBkJlqeClWxeNlQ0lXGSb52oZXGzkO0/I0ARegQ2eUT1g2VDJH0eUxDRcHmw==",
2875 | "dev": true,
2876 | "requires": {
2877 | "ajv": "^6.6.1",
2878 | "lodash": "^4.17.11",
2879 | "slice-ansi": "2.0.0",
2880 | "string-width": "^2.1.1"
2881 | }
2882 | },
2883 | "text-table": {
2884 | "version": "0.2.0",
2885 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
2886 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=",
2887 | "dev": true
2888 | },
2889 | "through": {
2890 | "version": "2.3.8",
2891 | "resolved": "http://registry.npmjs.org/through/-/through-2.3.8.tgz",
2892 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=",
2893 | "dev": true
2894 | },
2895 | "tmp": {
2896 | "version": "0.0.33",
2897 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz",
2898 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==",
2899 | "dev": true,
2900 | "requires": {
2901 | "os-tmpdir": "~1.0.2"
2902 | }
2903 | },
2904 | "to-regex-range": {
2905 | "version": "5.0.1",
2906 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
2907 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
2908 | "dev": true,
2909 | "requires": {
2910 | "is-number": "^7.0.0"
2911 | }
2912 | },
2913 | "toposort-class": {
2914 | "version": "1.0.1",
2915 | "resolved": "https://registry.npmjs.org/toposort-class/-/toposort-class-1.0.1.tgz",
2916 | "integrity": "sha1-f/0feMi+KMO6Rc1OGj9e4ZO9mYg="
2917 | },
2918 | "tslib": {
2919 | "version": "1.9.3",
2920 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz",
2921 | "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==",
2922 | "dev": true
2923 | },
2924 | "type-check": {
2925 | "version": "0.3.2",
2926 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz",
2927 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=",
2928 | "dev": true,
2929 | "requires": {
2930 | "prelude-ls": "~1.1.2"
2931 | }
2932 | },
2933 | "type-detect": {
2934 | "version": "4.0.8",
2935 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz",
2936 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==",
2937 | "dev": true
2938 | },
2939 | "type-is": {
2940 | "version": "1.6.16",
2941 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.16.tgz",
2942 | "integrity": "sha512-HRkVv/5qY2G6I8iab9cI7v1bOIdhm94dVjQCPFElW9W+3GeDOSHmy2EBYe4VTApuzolPcmgFTN3ftVJRKR2J9Q==",
2943 | "requires": {
2944 | "media-typer": "0.3.0",
2945 | "mime-types": "~2.1.18"
2946 | }
2947 | },
2948 | "uglify-js": {
2949 | "version": "3.12.8",
2950 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.12.8.tgz",
2951 | "integrity": "sha512-fvBeuXOsvqjecUtF/l1dwsrrf5y2BCUk9AOJGzGcm6tE7vegku5u/YvqjyDaAGr422PLoLnrxg3EnRvTqsdC1w==",
2952 | "optional": true
2953 | },
2954 | "unpipe": {
2955 | "version": "1.0.0",
2956 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
2957 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw="
2958 | },
2959 | "uri-js": {
2960 | "version": "4.2.2",
2961 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz",
2962 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==",
2963 | "dev": true,
2964 | "requires": {
2965 | "punycode": "^2.1.0"
2966 | }
2967 | },
2968 | "util-deprecate": {
2969 | "version": "1.0.2",
2970 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
2971 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8="
2972 | },
2973 | "utils-merge": {
2974 | "version": "1.0.1",
2975 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
2976 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM="
2977 | },
2978 | "uuid": {
2979 | "version": "8.3.2",
2980 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz",
2981 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg=="
2982 | },
2983 | "validate-npm-package-license": {
2984 | "version": "3.0.4",
2985 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz",
2986 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==",
2987 | "dev": true,
2988 | "requires": {
2989 | "spdx-correct": "^3.0.0",
2990 | "spdx-expression-parse": "^3.0.0"
2991 | }
2992 | },
2993 | "validator": {
2994 | "version": "10.11.0",
2995 | "resolved": "https://registry.npmjs.org/validator/-/validator-10.11.0.tgz",
2996 | "integrity": "sha512-X/p3UZerAIsbBfN/IwahhYaBbY68EN/UQBWHtsbXGT5bfrH/p4NQzUCG1kF/rtKaNpnJ7jAu6NGTdSNtyNIXMw=="
2997 | },
2998 | "vary": {
2999 | "version": "1.1.2",
3000 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
3001 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw="
3002 | },
3003 | "which": {
3004 | "version": "1.3.1",
3005 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz",
3006 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==",
3007 | "dev": true,
3008 | "requires": {
3009 | "isexe": "^2.0.0"
3010 | }
3011 | },
3012 | "which-module": {
3013 | "version": "2.0.0",
3014 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz",
3015 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=",
3016 | "dev": true
3017 | },
3018 | "wide-align": {
3019 | "version": "1.1.3",
3020 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz",
3021 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==",
3022 | "dev": true,
3023 | "requires": {
3024 | "string-width": "^1.0.2 || 2"
3025 | }
3026 | },
3027 | "wkx": {
3028 | "version": "0.5.0",
3029 | "resolved": "https://registry.npmjs.org/wkx/-/wkx-0.5.0.tgz",
3030 | "integrity": "sha512-Xng/d4Ichh8uN4l0FToV/258EjMGU9MGcA0HV2d9B/ZpZB3lqQm7nkOdZdm5GhKtLLhAE7PiVQwN4eN+2YJJUg==",
3031 | "requires": {
3032 | "@types/node": "*"
3033 | }
3034 | },
3035 | "wordwrap": {
3036 | "version": "1.0.0",
3037 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz",
3038 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus="
3039 | },
3040 | "workerpool": {
3041 | "version": "6.0.0",
3042 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.0.0.tgz",
3043 | "integrity": "sha512-fU2OcNA/GVAJLLyKUoHkAgIhKb0JoCpSjLC/G2vYKxUjVmQwGbRVeoPJ1a8U4pnVofz4AQV5Y/NEw8oKqxEBtA==",
3044 | "dev": true
3045 | },
3046 | "wrap-ansi": {
3047 | "version": "5.1.0",
3048 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz",
3049 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==",
3050 | "dev": true,
3051 | "requires": {
3052 | "ansi-styles": "^3.2.0",
3053 | "string-width": "^3.0.0",
3054 | "strip-ansi": "^5.0.0"
3055 | },
3056 | "dependencies": {
3057 | "ansi-regex": {
3058 | "version": "4.1.0",
3059 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz",
3060 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==",
3061 | "dev": true
3062 | },
3063 | "string-width": {
3064 | "version": "3.1.0",
3065 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz",
3066 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==",
3067 | "dev": true,
3068 | "requires": {
3069 | "emoji-regex": "^7.0.1",
3070 | "is-fullwidth-code-point": "^2.0.0",
3071 | "strip-ansi": "^5.1.0"
3072 | }
3073 | },
3074 | "strip-ansi": {
3075 | "version": "5.2.0",
3076 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz",
3077 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==",
3078 | "dev": true,
3079 | "requires": {
3080 | "ansi-regex": "^4.1.0"
3081 | }
3082 | }
3083 | }
3084 | },
3085 | "wrappy": {
3086 | "version": "1.0.2",
3087 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
3088 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=",
3089 | "dev": true
3090 | },
3091 | "write": {
3092 | "version": "0.2.1",
3093 | "resolved": "https://registry.npmjs.org/write/-/write-0.2.1.tgz",
3094 | "integrity": "sha1-X8A4KOJkzqP+kUVUdvejxWbLB1c=",
3095 | "dev": true,
3096 | "requires": {
3097 | "mkdirp": "^0.5.1"
3098 | }
3099 | },
3100 | "y18n": {
3101 | "version": "4.0.0",
3102 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz",
3103 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==",
3104 | "dev": true
3105 | },
3106 | "yallist": {
3107 | "version": "4.0.0",
3108 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
3109 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A=="
3110 | },
3111 | "yargs": {
3112 | "version": "13.3.2",
3113 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz",
3114 | "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==",
3115 | "dev": true,
3116 | "requires": {
3117 | "cliui": "^5.0.0",
3118 | "find-up": "^3.0.0",
3119 | "get-caller-file": "^2.0.1",
3120 | "require-directory": "^2.1.1",
3121 | "require-main-filename": "^2.0.0",
3122 | "set-blocking": "^2.0.0",
3123 | "string-width": "^3.0.0",
3124 | "which-module": "^2.0.0",
3125 | "y18n": "^4.0.0",
3126 | "yargs-parser": "^13.1.2"
3127 | },
3128 | "dependencies": {
3129 | "ansi-regex": {
3130 | "version": "4.1.0",
3131 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz",
3132 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==",
3133 | "dev": true
3134 | },
3135 | "find-up": {
3136 | "version": "3.0.0",
3137 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz",
3138 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==",
3139 | "dev": true,
3140 | "requires": {
3141 | "locate-path": "^3.0.0"
3142 | }
3143 | },
3144 | "locate-path": {
3145 | "version": "3.0.0",
3146 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz",
3147 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==",
3148 | "dev": true,
3149 | "requires": {
3150 | "p-locate": "^3.0.0",
3151 | "path-exists": "^3.0.0"
3152 | }
3153 | },
3154 | "p-limit": {
3155 | "version": "2.3.0",
3156 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz",
3157 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==",
3158 | "dev": true,
3159 | "requires": {
3160 | "p-try": "^2.0.0"
3161 | }
3162 | },
3163 | "p-locate": {
3164 | "version": "3.0.0",
3165 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz",
3166 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==",
3167 | "dev": true,
3168 | "requires": {
3169 | "p-limit": "^2.0.0"
3170 | }
3171 | },
3172 | "p-try": {
3173 | "version": "2.2.0",
3174 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz",
3175 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==",
3176 | "dev": true
3177 | },
3178 | "path-exists": {
3179 | "version": "3.0.0",
3180 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz",
3181 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=",
3182 | "dev": true
3183 | },
3184 | "string-width": {
3185 | "version": "3.1.0",
3186 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz",
3187 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==",
3188 | "dev": true,
3189 | "requires": {
3190 | "emoji-regex": "^7.0.1",
3191 | "is-fullwidth-code-point": "^2.0.0",
3192 | "strip-ansi": "^5.1.0"
3193 | }
3194 | },
3195 | "strip-ansi": {
3196 | "version": "5.2.0",
3197 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz",
3198 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==",
3199 | "dev": true,
3200 | "requires": {
3201 | "ansi-regex": "^4.1.0"
3202 | }
3203 | }
3204 | }
3205 | },
3206 | "yargs-parser": {
3207 | "version": "13.1.2",
3208 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz",
3209 | "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==",
3210 | "dev": true,
3211 | "requires": {
3212 | "camelcase": "^5.0.0",
3213 | "decamelize": "^1.2.0"
3214 | }
3215 | },
3216 | "yargs-unparser": {
3217 | "version": "1.6.1",
3218 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.6.1.tgz",
3219 | "integrity": "sha512-qZV14lK9MWsGCmcr7u5oXGH0dbGqZAIxTDrWXZDo5zUr6b6iUmelNKO6x6R1dQT24AH3LgRxJpr8meWy2unolA==",
3220 | "dev": true,
3221 | "requires": {
3222 | "camelcase": "^5.3.1",
3223 | "decamelize": "^1.2.0",
3224 | "flat": "^4.1.0",
3225 | "is-plain-obj": "^1.1.0",
3226 | "yargs": "^14.2.3"
3227 | },
3228 | "dependencies": {
3229 | "ansi-regex": {
3230 | "version": "4.1.0",
3231 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz",
3232 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==",
3233 | "dev": true
3234 | },
3235 | "find-up": {
3236 | "version": "3.0.0",
3237 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz",
3238 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==",
3239 | "dev": true,
3240 | "requires": {
3241 | "locate-path": "^3.0.0"
3242 | }
3243 | },
3244 | "locate-path": {
3245 | "version": "3.0.0",
3246 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz",
3247 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==",
3248 | "dev": true,
3249 | "requires": {
3250 | "p-locate": "^3.0.0",
3251 | "path-exists": "^3.0.0"
3252 | }
3253 | },
3254 | "p-limit": {
3255 | "version": "2.3.0",
3256 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz",
3257 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==",
3258 | "dev": true,
3259 | "requires": {
3260 | "p-try": "^2.0.0"
3261 | }
3262 | },
3263 | "p-locate": {
3264 | "version": "3.0.0",
3265 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz",
3266 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==",
3267 | "dev": true,
3268 | "requires": {
3269 | "p-limit": "^2.0.0"
3270 | }
3271 | },
3272 | "p-try": {
3273 | "version": "2.2.0",
3274 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz",
3275 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==",
3276 | "dev": true
3277 | },
3278 | "path-exists": {
3279 | "version": "3.0.0",
3280 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz",
3281 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=",
3282 | "dev": true
3283 | },
3284 | "string-width": {
3285 | "version": "3.1.0",
3286 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz",
3287 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==",
3288 | "dev": true,
3289 | "requires": {
3290 | "emoji-regex": "^7.0.1",
3291 | "is-fullwidth-code-point": "^2.0.0",
3292 | "strip-ansi": "^5.1.0"
3293 | }
3294 | },
3295 | "strip-ansi": {
3296 | "version": "5.2.0",
3297 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz",
3298 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==",
3299 | "dev": true,
3300 | "requires": {
3301 | "ansi-regex": "^4.1.0"
3302 | }
3303 | },
3304 | "yargs": {
3305 | "version": "14.2.3",
3306 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-14.2.3.tgz",
3307 | "integrity": "sha512-ZbotRWhF+lkjijC/VhmOT9wSgyBQ7+zr13+YLkhfsSiTriYsMzkTUFP18pFhWwBeMa5gUc1MzbhrO6/VB7c9Xg==",
3308 | "dev": true,
3309 | "requires": {
3310 | "cliui": "^5.0.0",
3311 | "decamelize": "^1.2.0",
3312 | "find-up": "^3.0.0",
3313 | "get-caller-file": "^2.0.1",
3314 | "require-directory": "^2.1.1",
3315 | "require-main-filename": "^2.0.0",
3316 | "set-blocking": "^2.0.0",
3317 | "string-width": "^3.0.0",
3318 | "which-module": "^2.0.0",
3319 | "y18n": "^4.0.0",
3320 | "yargs-parser": "^15.0.1"
3321 | }
3322 | },
3323 | "yargs-parser": {
3324 | "version": "15.0.1",
3325 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-15.0.1.tgz",
3326 | "integrity": "sha512-0OAMV2mAZQrs3FkNpDQcBk1x5HXb8X4twADss4S0Iuk+2dGnLOE/fRHrsYm542GduMveyA77OF4wrNJuanRCWw==",
3327 | "dev": true,
3328 | "requires": {
3329 | "camelcase": "^5.0.0",
3330 | "decamelize": "^1.2.0"
3331 | }
3332 | }
3333 | }
3334 | }
3335 | }
3336 | }
3337 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "simple-node-server",
3 | "version": "1.0.0",
4 | "description": "A simple enough node server scaffolding to get you started on your project immediately",
5 | "main": "index.js",
6 | "engines": {
7 | "node": ">=10.13.0"
8 | },
9 | "_moduleAliases": {
10 | "@root": "server",
11 | "@core": "server/core",
12 | "@api": "server/api",
13 | "@config": "config/"
14 | },
15 | "scripts": {
16 | "start": "DEBUG=simpleNodeServer node index.js",
17 | "test": "mocha -r server/testHelpers/globals.js server/**/*.test.js",
18 | "lint": "eslint server/",
19 | "add-resource": "node ./tools/cli.js"
20 | },
21 | "keywords": [
22 | "node",
23 | "scaffold",
24 | "expressjs",
25 | "server",
26 | "node",
27 | "project",
28 | "nodejs",
29 | "server",
30 | "simple",
31 | "http",
32 | "boilerplate",
33 | "api-design",
34 | "microservices",
35 | "backend"
36 | ],
37 | "author": "Munim Dibosh",
38 | "license": "ISC",
39 | "dependencies": {
40 | "cors": "^2.8.5",
41 | "debug": "^4.1.0",
42 | "express": "^4.16.4",
43 | "handlebars": "^4.7.7",
44 | "http-status-codes": "^1.3.0",
45 | "module-alias": "^2.2.2",
46 | "mongoose": "^5.11.16",
47 | "mysql2": "^2.2.5",
48 | "redis": "^3.0.2",
49 | "sequelize": "^6.5.0"
50 | },
51 | "devDependencies": {
52 | "chai": "^4.2.0",
53 | "chalk": "^4.1.0",
54 | "eslint": "5.10.0",
55 | "eslint-config-standard": "12.0.0",
56 | "eslint-plugin-import": "^2.14.0",
57 | "eslint-plugin-node": "^8.0.0",
58 | "eslint-plugin-promise": "^4.0.1",
59 | "eslint-plugin-standard": "^4.0.0",
60 | "mocha": "^8.1.1"
61 | }
62 | }
63 |
--------------------------------------------------------------------------------
/scripts/startup.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 | #
3 | # This script supports the following environment vars:
4 | # - WEB_MEMORY: the amount of memory each
5 | # process is expected to consume, in MB.
6 |
7 | if [[ -n "$WEB_MEMORY" ]]; then
8 | # The heap contains two main areas:
9 | #
10 | # New Space: all newly allocated objects are created here first.
11 | # The new space is often small (typically 1-8 MB), and it is
12 | # fast to collect garbage here.
13 | #
14 | # Old Space: any objects which are not garbage collected from
15 | # New Space eventually end up here. The vast majority of your
16 | # heap will be consumed by Old Space. Garbage collection is slower
17 | # here, as the size of Old Space is much larger than New Space,
18 | # and a different mechanism is employed to actually perform the collection.
19 | #
20 | # For this reason, garbage collection is only performed when there is not
21 | # much room left in Old Space. So, it makes sense to concentrate on the
22 | # heap’s Old Space when targeting memory usage.
23 |
24 |
25 | # The WEB_MEMORY environment variable is set. Set the `mem_old_space_size`
26 | # flag to 4/5 of the available memory. 4/5 has been determined via trial
27 | # and error to be the optimum value, to try and ensure that v8 uses the
28 | # available memory.
29 | mem_node_old_space=$((($WEB_MEMORY*4)/5))
30 | echo "Provided memory: $WEB_MEMORY, Memory for Old Space: $mem_node_old_space"
31 | node_args="--max_old_space_size=$mem_node_old_space $node_args"
32 | fi
33 |
34 | export NODE_OPTIONS=${node_args}
35 | export DEBUG=formatWebApp:*
36 |
37 | echo "Starting app:"
38 | echo "> npm start"
39 |
40 | # Start the process using `exec`. This ensures that when node exits, the exit
41 | # code is passed up to the caller of this script.
42 | exec npm start
--------------------------------------------------------------------------------
/scripts/wait-for.sh:
--------------------------------------------------------------------------------
1 | #!/bin/sh
2 |
3 | # original script: https://github.com/eficode/wait-for/blob/master/wait-for
4 |
5 | TIMEOUT=15
6 | QUIET=0
7 |
8 | echoerr() {
9 | if [ "$QUIET" -ne 1 ]; then printf "%s\n" "$*" 1>&2; fi
10 | }
11 |
12 | usage() {
13 | exitcode="$1"
14 | cat << USAGE >&2
15 | Usage:
16 | $cmdname host:port [-t timeout] [-- command args]
17 | -q | --quiet Do not output any status messages
18 | -t TIMEOUT | --timeout=timeout Timeout in seconds, zero for no timeout
19 | -- COMMAND ARGS Execute command with args after the test finishes
20 | USAGE
21 | exit "$exitcode"
22 | }
23 |
24 | wait_for() {
25 | for i in `seq $TIMEOUT` ; do
26 | nc -z "$HOST" "$PORT" > /dev/null 2>&1
27 |
28 | result=$?
29 | if [ $result -eq 0 ] ; then
30 | if [ $# -gt 0 ] ; then
31 | exec "$@"
32 | fi
33 | exit 0
34 | fi
35 | sleep 1
36 | done
37 | echo "Operation timed out" >&2
38 | exit 1
39 | }
40 |
41 | while [ $# -gt 0 ]
42 | do
43 | case "$1" in
44 | *:* )
45 | HOST=$(printf "%s\n" "$1"| cut -d : -f 1)
46 | PORT=$(printf "%s\n" "$1"| cut -d : -f 2)
47 | shift 1
48 | ;;
49 | -q | --quiet)
50 | QUIET=1
51 | shift 1
52 | ;;
53 | -t)
54 | TIMEOUT="$2"
55 | if [ "$TIMEOUT" = "" ]; then break; fi
56 | shift 2
57 | ;;
58 | --timeout=*)
59 | TIMEOUT="${1#*=}"
60 | shift 1
61 | ;;
62 | --)
63 | shift
64 | break
65 | ;;
66 | --help)
67 | usage 0
68 | ;;
69 | *)
70 | echoerr "Unknown argument: $1"
71 | usage 1
72 | ;;
73 | esac
74 | done
75 |
76 | if [ "$HOST" = "" -o "$PORT" = "" ]; then
77 | echoerr "Error: you need to provide a host and port to test."
78 | usage 2
79 | fi
80 |
81 | wait_for "$@"
82 |
--------------------------------------------------------------------------------
/server/api/index.js:
--------------------------------------------------------------------------------
1 | const express = require('express');
2 | const router = express.Router();
3 |
4 | // Any new resource api should imported here and then registered to
5 | // router with proper api endpoint prefix (e.g /user user.route, /items items.route etc.)
6 | //
7 | // Do not remove the /** --route:import-- */ placeholder, if you use the cli to generate
8 | // api resources, this works as placeholder to inject new route file requires.
9 | //
10 | // If you add a require manually, add it above the /** --route:import-- */ line.
11 | const user = require('./user');
12 | /** --route:import-- */
13 |
14 | // Do not remove the /** --route-- */ placeholder, if you use the cli to generate
15 | // api resources, this works as placeholder to inject new routes.
16 | //
17 | // If you add a require manually, add it above the /** --route-- */ line.
18 | router.use(user.config.ENDPOINT, user.route);
19 | /** --route-- */
20 |
21 | module.exports = router;
22 |
--------------------------------------------------------------------------------
/server/api/user/config.js:
--------------------------------------------------------------------------------
1 | const config = {
2 | ENDPOINT: '/user', // change this to your base api url
3 | };
4 |
5 | module.exports = config;
6 |
--------------------------------------------------------------------------------
/server/api/user/controller.js:
--------------------------------------------------------------------------------
1 | class Controller {
2 | static async getUser() {
3 | return {
4 | name: 'John Doe',
5 | role: 'admin',
6 | actions: ['profile', 'settings'],
7 | };
8 | }
9 | }
10 |
11 | module.exports = Controller;
12 |
--------------------------------------------------------------------------------
/server/api/user/index.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | config: require('./config'),
3 | route: require('./route')
4 | };
5 |
--------------------------------------------------------------------------------
/server/api/user/route.js:
--------------------------------------------------------------------------------
1 | const express = require('express');
2 | const statusCodes = require('http-status-codes');
3 |
4 | // we might need to access all the routing params from parent as well,
5 | // so the better practice is to have mergeParams: true
6 | const router = express.Router({mergeParams: true});
7 |
8 | const controller = require('./controller');
9 |
10 | router.get('/one', async function (req, res) {
11 | res.status(statusCodes.OK).send(await controller.getUser());
12 | });
13 |
14 | module.exports = router;
15 |
--------------------------------------------------------------------------------
/server/api/user/test/controller.test.js:
--------------------------------------------------------------------------------
1 | const controller = require('../controller');
2 |
3 | describe('user.controller', function () {
4 | describe('getUser', function () {
5 | it('should return dummy user object', async function () {
6 | let user = await controller.getUser();
7 | user.name.should.equal('John Doe');
8 | user.role.should.equal('admin');
9 | });
10 | });
11 | });
12 |
--------------------------------------------------------------------------------
/server/core/bootstrapper.js:
--------------------------------------------------------------------------------
1 | const cors = require('cors');
2 | const express = require('express');
3 | const fs = require('fs');
4 | const path = require('path');
5 |
6 | const errorUtils = require('@root/utils/error');
7 | const logger = require('@core/logger');
8 |
9 | /**
10 | * Creates a barebone express app with basic setup.
11 | */
12 | function _initialize_() {
13 | let app = express();
14 |
15 | app.use(cors());
16 | app.use(express.json());
17 |
18 | app.get('/health', (req, res) => {
19 | res.status(200).send({ message: 'Up and running' });
20 | });
21 |
22 | return app;
23 | }
24 |
25 | /**
26 | * The main entry point that creates the express app instance which later spins
27 | * up as server.
28 | * @param clientPath The absolute path for client app folder which needs to be
29 | * served by this app, must have an index.html with resources folder named
30 | * as any of these-
31 | * `resources`, `static`, `dist`
32 | *
33 | * So, the file structure inside the client folder must be like below-
34 | * ```
35 | * client
36 | * - index.html
37 | * - dist(or static or resources)/
38 | * - ...
39 | *
40 | * If the `clientPath` is not given, returns a basic express app instance.
41 | * ```
42 | * @returns {Function}
43 | */
44 |
45 | function initiate(clientPath) {
46 | let app = _initialize_();
47 |
48 | if (clientPath) {
49 | if (fs.existsSync(clientPath)) {
50 | let staticPaths = ['dist', 'resources', 'static'];
51 |
52 | staticPaths.forEach((staticPath) => {
53 | app.use(express.static(path.resolve(clientPath, staticPath)));
54 | });
55 |
56 | app.get('/', function (req, res) {
57 | res.sendFile(path.resolve(clientPath, 'index.html'));
58 | });
59 | } else {
60 | logger.log('invalid client folder path; try absolute path or make sure it exists');
61 | }
62 | }
63 |
64 | return app;
65 | }
66 |
67 | /**
68 | * Explicitly define the client index.html absolute path and static directory to serve
69 | * @param indexPath
70 | * @param staticDirPath
71 | */
72 | function initiateWithIndexAndStaticDir(indexPath, staticDirPath) {
73 | let app = _initialize_();
74 |
75 | if (indexPath && staticDirPath && fs.existsSync(indexPath) && fs.existsSync(staticDirPath)) {
76 | app.use(express.static(staticDirPath));
77 | app.get('/', function (req, res) {
78 | res.sendFile(indexPath);
79 | });
80 | } else {
81 | errorUtils.throwError('index path and/or static dir path is invalid or make sure they exist');
82 | return;
83 | }
84 |
85 | return app;
86 | }
87 |
88 | module.exports = {
89 | initiate,
90 | initiateWithIndexAndStaticDir
91 | };
92 |
--------------------------------------------------------------------------------
/server/core/commonErrorHandler.js:
--------------------------------------------------------------------------------
1 | const statusCodes = require('http-status-codes');
2 |
3 | const logger = require('@core/logger');
4 |
5 | /**
6 | * Takes care of any uncaught error that was not handled specifically for
7 | * a specific app instance.
8 | * @param app Express app instance
9 | */
10 | function attachWithApp(app) {
11 | app.use((err, req, res, next) => {
12 | if (!err) {
13 | next();
14 | }
15 |
16 | logger.log('Error: %s %O', err.message, err.stack);
17 | res.status(statusCodes.INTERNAL_SERVER_ERROR).send({
18 | 'message': 'Internal Server Error'
19 | });
20 | });
21 | }
22 |
23 | module.exports = {
24 | attachWithApp
25 | };
26 |
--------------------------------------------------------------------------------
/server/core/connectors/index.js:
--------------------------------------------------------------------------------
1 | const fs = require('fs');
2 | const path = require('path');
3 | const logger = require('@core/logger');
4 |
5 | async function connectAll() {
6 | const ignore = [
7 | 'index',
8 | // list down the connectors that should be ignored
9 | 'mysql',
10 | ];
11 |
12 | const connectors = fs
13 | .readdirSync(path.resolve(__dirname))
14 | .filter((connector) => {
15 | connector = connector.replace('.js', '');
16 | return !ignore.includes(connector);
17 | })
18 | .map((connector) => {
19 | return require(`./${connector}`).connect();
20 | });
21 |
22 | try {
23 | const connectionObjects = await Promise.all(connectors);
24 | return connectionObjects;
25 | } catch (ex) {
26 | logger.log('connectors.connectAll', ex);
27 | process.exit(1);
28 | }
29 | }
30 |
31 | module.exports = {
32 | connectAll,
33 | };
34 |
--------------------------------------------------------------------------------
/server/core/connectors/mongo.js:
--------------------------------------------------------------------------------
1 | const mongoose = require('mongoose');
2 | const logger = require('@core/logger');
3 |
4 | async function connect() {
5 | const {
6 | MONGO_USERNAME,
7 | MONGO_PASSWORD,
8 | MONGO_HOSTNAME,
9 | MONGO_PORT,
10 | MONGO_DB,
11 | } = process.env;
12 |
13 | const url = `mongodb://${MONGO_USERNAME}:${MONGO_PASSWORD}@${MONGO_HOSTNAME}:${MONGO_PORT}/${MONGO_DB}?authSource=admin`;
14 |
15 | const options = {
16 | useNewUrlParser: true,
17 | connectTimeoutMS: 10000,
18 | useUnifiedTopology: true,
19 | };
20 |
21 | try {
22 | await mongoose.connect(url, options);
23 | logger.log('mongo db is connected');
24 | } catch (ex) {
25 | logger.log('mongo db connection failed');
26 | return Promise.reject(ex);
27 | }
28 | }
29 |
30 | module.exports = {
31 | connect,
32 | };
33 |
--------------------------------------------------------------------------------
/server/core/connectors/mysql.js:
--------------------------------------------------------------------------------
1 | const { Sequelize } = require('sequelize');
2 | const logger = require('@core/logger');
3 |
4 | async function connect() {
5 | const {
6 | MYSQL_USER: username,
7 | MYSQL_PASSWORD: password,
8 | MYSQL_DB: database,
9 | MYSQL_PORT: port,
10 | MYSQL_HOSTNAME: host,
11 | } = process.env;
12 |
13 | const sequelize = new Sequelize({
14 | username,
15 | password,
16 | database,
17 | port,
18 | host,
19 | dialect: 'mysql',
20 | });
21 |
22 | try {
23 | await sequelize.authenticate();
24 | logger.log('mysql is connected');
25 | return sequelize;
26 | } catch (ex) {
27 | logger.log('mysql connection failed');
28 | return Promise.reject(ex);
29 | }
30 | }
31 |
32 | module.exports = {
33 | connect,
34 | };
35 |
--------------------------------------------------------------------------------
/server/core/connectors/redis.js:
--------------------------------------------------------------------------------
1 | const redis = require('redis');
2 | const logger = require('@core/logger');
3 |
4 | async function connect() {
5 | const { REDIS_PORT } = process.env;
6 | const client = redis.createClient({
7 | host: 'localhost',
8 | port: REDIS_PORT,
9 | });
10 | return new Promise((resolve, reject) => {
11 | client.on('ready', () => {
12 | logger.log('redis is connected');
13 | resolve(client);
14 | });
15 | client.on('error', (err) => {
16 | logger.log('redis connection failed');
17 | reject(err);
18 | });
19 | });
20 | }
21 |
22 | module.exports = {
23 | connect,
24 | };
25 |
--------------------------------------------------------------------------------
/server/core/logger.js:
--------------------------------------------------------------------------------
1 | const config = require('@config');
2 | const debug = require('debug')(config.SERVER_NAME);
3 |
4 | module.exports = {
5 | log: debug
6 | };
7 |
--------------------------------------------------------------------------------
/server/core/shutdownManager.js:
--------------------------------------------------------------------------------
1 | const logger = require('@core/logger');
2 | const config = require('@config');
3 |
4 | /**
5 | * A basic shutdown manager for the node backend. In case of any emergencies,
6 | * if manual interruption is initiated, it can do graceful shutdown of pending
7 | * connections and rollbacks.
8 | * @param server An already spawn server instance
9 | */
10 | function manage(server) {
11 | let connections = [];
12 |
13 | let shutDown = () => {
14 | logger.log('Received kill signal, shutting down gracefully');
15 |
16 | server.close(() => {
17 | logger.log('Closed out remaining connections');
18 | process.exit(0);
19 | });
20 |
21 | connections.forEach((curr) => {
22 | curr.end();
23 | });
24 |
25 | setTimeout(() => {
26 | connections.forEach((curr) => {
27 | curr.destroy();
28 | });
29 | }, config.CONNECTION_CLOSING_TIME);
30 |
31 | setTimeout(() => {
32 | logger.log(
33 | 'Could not close connections in time, forcefully shutting down'
34 | );
35 | process.exit(1);
36 | }, config.WAIT_TIME_BEFORE_FORCE_SHUTDOWN);
37 | };
38 |
39 | process.on('SIGTERM', shutDown);
40 | process.on('SIGINT', shutDown);
41 |
42 | server.on('connection', (connection) => {
43 | connections.push(connection);
44 | logger.log('%s connections currently open', connections.length);
45 | connection.on('close', function () {
46 | connections = connections.filter((curr) => {
47 | return curr !== connection;
48 | });
49 | });
50 | });
51 | }
52 |
53 | module.exports = {
54 | manage
55 | };
56 |
--------------------------------------------------------------------------------
/server/index.js:
--------------------------------------------------------------------------------
1 | // start - initialize module aliases
2 | require('module-alias/register');
3 | // end - initialize module aliases
4 |
5 | const apiRoute = require('@api');
6 | const bootstrapper = require('@core/bootstrapper');
7 | const commonErrorHandler = require('@core/commonErrorHandler');
8 | const connectors = require('@core/connectors');
9 | const config = require('@config');
10 | const shutDownManager = require('@core/shutdownManager');
11 | const logger = require('@core/logger');
12 |
13 | /**
14 | * Creates a server instance
15 | * @param {*} options Options; can contain either a `clientPath` or `indexPath` together with
16 | * a `resourcesPath`.
17 | */
18 | async function start(options) {
19 | options = options || {};
20 | const port = options.port || config.DEFAULT_PORT;
21 | const app = _createApp(options);
22 | await connectors.connectAll();
23 | return app.listen(port, function () {
24 | logger.log(`server started on port ${port}`);
25 | });
26 | }
27 |
28 | /**
29 | * Manages force shutdown cases by closing all the open connections
30 | * and house keeping.
31 | * @param {*} server An server instance created by invoking `start`
32 | */
33 | function autoManageShutdown(server) {
34 | shutDownManager.manage(server);
35 | }
36 |
37 | /**
38 | * Helper method to create an express app with necessary setup.
39 | * @param {*} options Options; can contain either a `clientPath` or `indexPath` together with
40 | * a `resourcesPath`
41 | */
42 | function _createApp(options) {
43 | let app;
44 | options = options || {};
45 | const { clientDirPath, indexPath, staticDirPath } = options;
46 | /**
47 | * App is bootstrapped only after all the models and routes have
48 | * been loaded using `apiRoute`
49 | */
50 | if (indexPath && staticDirPath) {
51 | app = bootstrapper.initiateWithIndexAndStaticDir(indexPath, staticDirPath);
52 | } else {
53 | app = bootstrapper.initiate(clientDirPath);
54 | }
55 |
56 | // apis are available under /api prefix
57 | app.use('/api', apiRoute);
58 |
59 | // error handler middleware has to be attached at the very end
60 | commonErrorHandler.attachWithApp(app);
61 |
62 | return app;
63 | }
64 |
65 | module.exports = {
66 | autoManageShutdown,
67 | start
68 | };
69 |
--------------------------------------------------------------------------------
/server/testHelpers/globals.js:
--------------------------------------------------------------------------------
1 | require('chai').should();
2 |
--------------------------------------------------------------------------------
/server/utils/error.js:
--------------------------------------------------------------------------------
1 | /* eslint no-caller: 0 */
2 |
3 | function throwError(initiatingMethod, errorMessage) {
4 | throw new Error(`${arguments.callee.caller.name}: ${errorMessage}`);
5 | }
6 |
7 | module.exports = {
8 | throwError
9 | };
10 |
--------------------------------------------------------------------------------
/tools/cli.js:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env node
2 | const generator = require('./lib/generator');
3 |
4 | (function exec() {
5 | const args = process.argv.slice(2);
6 |
7 | if (args && args.length) {
8 | const resourceName = args[0];
9 | generator.generate(resourceName);
10 | }
11 | })();
12 |
--------------------------------------------------------------------------------
/tools/lib/generator.js:
--------------------------------------------------------------------------------
1 | const path = require('path');
2 | const logger = require('./logger');
3 | const pman = require('./processman');
4 | const renderer = require('./renderer');
5 | const writer = require('./writer');
6 |
7 | const outputDir = path.resolve(__dirname, '../../server/api');
8 |
9 | /**
10 | * Generate resource files and add resource route to api index.
11 | *
12 | * @param {*} resourceName
13 | */
14 | async function generate(resourceName) {
15 | resourceName = resourceName.toLowerCase();
16 | if (/[._ ]/.test(resourceName)) {
17 | logger.error(
18 | 'resource names of these formats are allowed: users, parkings, paid-customers, order-items etc.'
19 | );
20 | pman.makeBadExit();
21 | }
22 |
23 | const folderPath = path.join(outputDir, resourceName);
24 |
25 | try {
26 | writer.writeFiles(
27 | folderPath,
28 | renderer.renderBaseFiles({ resource: { name: resourceName } })
29 | );
30 | const indexFileContent = renderer.renderIndexFile(
31 | path.join(outputDir, 'index.js'),
32 | resourceName,
33 | resourceName
34 | );
35 | writer.write(outputDir, 'index.js', indexFileContent);
36 | logger.debug('completed generating the resource files and adding route to api index');
37 | } catch (err) {
38 | logger.error('failed to generate necessary files', err);
39 | pman.makeBadExit();
40 | }
41 | }
42 |
43 | module.exports = {
44 | generate,
45 | };
46 |
--------------------------------------------------------------------------------
/tools/lib/logger.js:
--------------------------------------------------------------------------------
1 | const chalk = require('chalk');
2 |
3 | function debug(message, ...args) {
4 | console.log('\n');
5 | console.log(chalk.green(message), ...args);
6 | console.log('\n');
7 | }
8 |
9 | function error(message, ...args) {
10 | console.log('\n');
11 | console.error(chalk.red(message), ...args);
12 | console.log('\n');
13 | }
14 |
15 | module.exports = {
16 | debug,
17 | error,
18 | };
19 |
--------------------------------------------------------------------------------
/tools/lib/processman.js:
--------------------------------------------------------------------------------
1 | function makeGoodExit() {
2 | process.exit(0);
3 | }
4 |
5 | function makeBadExit() {
6 | process.exit(1);
7 | }
8 |
9 | module.exports = {
10 | makeBadExit,
11 | makeGoodExit,
12 | };
13 |
--------------------------------------------------------------------------------
/tools/lib/renderer.js:
--------------------------------------------------------------------------------
1 | const fs = require('fs');
2 | const path = require('path');
3 | const handlebars = require('handlebars');
4 | const pman = require('./processman');
5 | const logger = require('./logger');
6 |
7 | const baseTplDirPath = path.resolve(__dirname, '../templates');
8 |
9 | /**
10 | * Renders API index file with necessary changes.
11 | *
12 | * @param {*} apiIndexPath
13 | * @param {*} resourceFolderName
14 | * @param {*} resourcePrefix
15 | */
16 | function renderIndexFile(apiIndexPath, resourceFolderName, resourcePrefix) {
17 | const content = fs.readFileSync(apiIndexPath, 'utf8');
18 | const normalisedName = resourceFolderName.replace(
19 | /-([a-zA-Z])/g,
20 | (m) => m[1] && m[1].toUpperCase()
21 | );
22 | const importLine = `const ${normalisedName} = require('./${resourceFolderName}');\n/** --route:import-- */`;
23 | const hookLine = `router.use(${normalisedName}.config.ENDPOINT, ${normalisedName}.route);\n/** --route-- */`;
24 |
25 | return content
26 | .replace('/** --route:import-- */', importLine)
27 | .replace('/** --route-- */', hookLine);
28 | }
29 |
30 | function renderBaseFiles(data, ignoreFiles = []) {
31 | return renderFiles(baseTplDirPath, data, ignoreFiles);
32 | }
33 |
34 | /**
35 | * Render template files in a given dir.
36 | * @param {*} dirPath
37 | * @param {*} data
38 | * @param {array} ignoreFiles Files that should be ignored, e.g. ['ingress', 'hpa']
39 | */
40 | function renderFiles(dirPath, data, ignoreFiles = []) {
41 | if (!dirPath || !data) {
42 | throw new Error('Either dirPath or data is not provided.');
43 | }
44 |
45 | const tplContentMap = {};
46 | fs.readdirSync(dirPath).forEach((f) => {
47 | if (!ignoreFiles.includes(f)) {
48 | const tplPath = path.join(dirPath, f);
49 | tplContentMap[f] = render(tplPath, data);
50 | }
51 | });
52 |
53 | return tplContentMap;
54 | }
55 |
56 | /**
57 | * Render a template file with given data.
58 | *
59 | * @param {*} tplPath
60 | * @param {*} data
61 | */
62 | function render(tplPath, data) {
63 | if (!fs.existsSync(tplPath)) {
64 | logger.error(`template render failed; ${tplPath} was not found.`);
65 | pman.makeBadExit();
66 | }
67 |
68 | try {
69 | const tpl = fs.readFileSync(tplPath, 'utf8');
70 | const compiled = handlebars.compile(tpl);
71 | return compiled(data);
72 | } catch (err) {
73 | logger.error(`template render failed.`, err);
74 | pman.makeBadExit();
75 | }
76 | }
77 |
78 | module.exports = {
79 | renderBaseFiles,
80 | renderIndexFile,
81 | };
82 |
--------------------------------------------------------------------------------
/tools/lib/writer.js:
--------------------------------------------------------------------------------
1 | const fs = require('fs');
2 | const path = require('path');
3 |
4 | /**
5 | * Given a filemap of filename vs file content along with
6 | * a folder path, creates all the .yml files.
7 | * @param {*} rootPath the absolute path of where the output folder exists
8 | * @param {*} fileMap contains file content against it's name as key
9 | * @param {*} folder the output folder
10 | */
11 | function writeFiles(rootPath, fileMap, folder) {
12 | Object.keys(fileMap).forEach((filename) => {
13 | write(
14 | rootPath,
15 | `${filename}.js`.replace('.tpl', ''),
16 | fileMap[filename],
17 | folder,
18 | );
19 | });
20 | }
21 |
22 | function write(rootPath, filename, content, folder = '') {
23 | const embeddedDir = path.dirname(filename);
24 | const dumpDirPath = path.join(rootPath, folder, embeddedDir);
25 | if (!fs.existsSync(dumpDirPath)) {
26 | fs.mkdirSync(dumpDirPath, {recursive: true});
27 | }
28 | const dumpPath = path.join(dumpDirPath, path.basename(filename));
29 | fs.writeFileSync(dumpPath, content);
30 | }
31 |
32 | module.exports = {
33 | writeFiles,
34 | write,
35 | };
36 |
--------------------------------------------------------------------------------
/tools/templates/config.tpl:
--------------------------------------------------------------------------------
1 | const config = {
2 | ENDPOINT: '/{{resource.name}}',
3 | };
4 |
5 | module.exports = config;
6 |
--------------------------------------------------------------------------------
/tools/templates/controller.tpl:
--------------------------------------------------------------------------------
1 | /**
2 | * @module {{resource.name}} controller
3 | *
4 | * @description
5 | * The controller layer. Instead of directly writing any
6 | * business logics here, please use service(s).
7 | *
8 | * The basic controller is written as CRUD controller, but
9 | * you can write it any way to support your api endpoint.
10 | * For example, for a checkout API, the CRUD will not make
11 | * sense but a `checkout` function will.
12 | */
13 |
14 | class Controller {
15 | static async get() {}
16 | static async remove() {}
17 | static async save() {}
18 | }
19 |
20 | module.exports = Controller;
21 |
--------------------------------------------------------------------------------
/tools/templates/index.tpl:
--------------------------------------------------------------------------------
1 | /**
2 | * @module {{resource.name}}
3 | *
4 | * @description
5 | * All the exportable files and functions should be added here.
6 | * This file exposes the portions of this module. Routes and endpoint
7 | * should be exposed by default. Apart from routes, anything else should
8 | * not be exposed unless needed otherwise.
9 | */
10 | module.exports = {
11 | config: require('./config'),
12 | route: require('./route'),
13 | };
14 |
--------------------------------------------------------------------------------
/tools/templates/model.tpl:
--------------------------------------------------------------------------------
1 | /**
2 | * @module {{resource.name}} model
3 | *
4 | * @description
5 | * Depending on which ORM you use(e.g. mongoose, Joi, TypeORM etc.)
6 | * you should define the model for your resource here. If you need
7 | * multiple models for your api, consider defining a `models` folder
8 | * and putting all the model files inside with respective names.
9 | *
10 | * Example-
11 | * For an order management API the models folder might look like below-
12 | *
13 | * models
14 | * - order.item.js
15 | * - order.js
16 | */
17 | module.exports = {};
18 |
--------------------------------------------------------------------------------
/tools/templates/repository.tpl:
--------------------------------------------------------------------------------
1 | /**
2 | * @module {{resource.name}} repository
3 | *
4 | * @description
5 | * This is the layer that works as the gateway to communicate
6 | * to and from db. This layer takes care of retrieving and saving
7 | * persistent objects. Keeping this separate allows you to keep
8 | * db integration tied to one layer, while keeping the upper
9 | * layer(e.g. service) contract intact. Hence, replacing with a
10 | * new persistence option integration is easy and quick. This is
11 | * where you put your ORM codes to access your models.
12 | *
13 | * A single repository can handle db communications for all the
14 | * models. That is absolutely fine. But if you want to have separate
15 | * repositories for each models, that's also possible. But make sure
16 | * to avoid repeting codes, you define a core repository, that is
17 | * used by all others.
18 | */
19 |
20 | class Repository {
21 | }
22 |
23 | module.exports = Repository;
--------------------------------------------------------------------------------
/tools/templates/route.tpl:
--------------------------------------------------------------------------------
1 | /**
2 | * @module {{resource.name}} router
3 | *
4 | * @description
5 | * All routing for this resource/api should be defined here.
6 | * This route then gets added to the base api routing.
7 | */
8 |
9 | const express = require('express');
10 | const statusCodes = require('http-status-codes');
11 |
12 | // we might need to access all the routing params from parent as well,
13 | // so the practice is to have mergeParams: true
14 | const router = express.Router({ mergeParams: true });
15 |
16 | const controller = require('./controller');
17 |
18 | // a sample routing
19 | router.get('/:id', async function (req, res) {
20 | // res.status(statusCodes.OK).send(await controller.get({ id: req.params.id }));
21 | });
22 |
23 | module.exports = router;
24 |
--------------------------------------------------------------------------------
/tools/templates/service.tpl:
--------------------------------------------------------------------------------
1 | /**
2 | * @module {{resource.name}} service
3 | *
4 | * @description
5 | * This is where you should use the repositories for different models
6 | * and add your business logics to support controller demand.
7 | * The data transfer should always be-
8 | *
9 | * controller -> [request/domain object] -> service
10 | * service -> [model/db object] -> repository
11 | * repository -> [model/db object] -> service
12 | * service -> [response/domain object] -> controller
13 | *
14 | * Service should always use repositories to get, save, delete persistence
15 | * objects. It should never directly communicate with database.
16 | *
17 | * If you have multiple services, consider adding them inside a folder called
18 | * `services` and give every file respective names.
19 | *
20 | * Example:
21 | *
22 | * For a checkout API, the services folder may look like-
23 | *
24 | * services/
25 | * - checkout.service.js
26 | * - payment.service.js
27 | * - notification.service.js
28 | */
29 |
30 | class Service {
31 | }
32 |
33 | module.exports = Service;
--------------------------------------------------------------------------------