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