├── .gitignore ├── APIGateway ├── .env ├── .eslintrc.js ├── README.md ├── index.js ├── package-lock.json ├── package.json ├── routes.js └── server.js ├── OrderService ├── .env ├── .eslintrc.js ├── README.md ├── config │ ├── app-config.js │ ├── constants.js │ ├── db.js │ └── express-config.js ├── handlers │ ├── api-handler.js │ ├── query-handler.js │ └── route-handler.js ├── index.js ├── package-lock.json ├── package.json ├── routes.js ├── server.js └── utils │ ├── jwt-route.js │ ├── jwt.js │ └── password-hash.js ├── ProductService ├── .env ├── .eslintrc.js ├── README.md ├── config │ ├── app-config.js │ ├── constants.js │ ├── db.js │ └── express-config.js ├── handlers │ ├── query-handler.js │ └── route-handler.js ├── index.js ├── package-lock.json ├── package.json ├── routes.js ├── server.js └── utils │ ├── jwt-route.js │ ├── jwt.js │ └── password-hash.js ├── README.md └── UserService ├── .env ├── .eslintrc.js ├── README.md ├── config ├── app-config.js ├── constants.js ├── db.js └── express-config.js ├── handlers ├── query-handler.js └── route-handler.js ├── index.js ├── package-lock.json ├── package.json ├── routes.js ├── server.js └── utils ├── jwt-route.js ├── jwt.js └── password-hash.js /.gitignore: -------------------------------------------------------------------------------- 1 | # See http://help.github.com/ignore-files/ for more about ignoring files. 2 | 3 | # dependencies 4 | node_modules/ 5 | 6 | # IDEs and editors 7 | /.idea 8 | .project 9 | .classpath 10 | .c9/ 11 | *.launch 12 | .settings/ 13 | *.sublime-workspace 14 | 15 | # IDE - VSCode 16 | .vscode/* 17 | !.vscode/settings.json 18 | !.vscode/tasks.json 19 | !.vscode/launch.json 20 | !.vscode/extensions.json 21 | 22 | # misc 23 | /.sass-cache 24 | /connect.lock 25 | /coverage 26 | /libpeerconnection.log 27 | npm-debug.log 28 | testem.log 29 | /typings 30 | 31 | # System Files 32 | .DS_Store 33 | Thumbs.db 34 | -------------------------------------------------------------------------------- /APIGateway/.env: -------------------------------------------------------------------------------- 1 | NODE_SERVER_POST=8000 2 | NODE_SERVER_HOST=localhost 3 | USER_SERVICE_URL:http://localhost:4000 4 | PRODUCT_SERVICE_URL:http://localhost:3000 5 | ORDER_SERVICE_URL:http://localhost:2000 -------------------------------------------------------------------------------- /APIGateway/.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | browser: true, 4 | commonjs: true, 5 | es6: true, 6 | }, 7 | extends: 'airbnb-base', 8 | globals: { 9 | Atomics: 'readonly', 10 | SharedArrayBuffer: 'readonly', 11 | }, 12 | parserOptions: { 13 | ecmaVersion: 2018, 14 | }, 15 | rules: { 16 | }, 17 | }; 18 | -------------------------------------------------------------------------------- /APIGateway/README.md: -------------------------------------------------------------------------------- 1 | # API gateway for the application 2 | This Project is a basic demo of an API Gateway implemented in Nodejs. 3 | 4 | ## Installation 5 | 1. `Run install` 6 | 2. `node server.js` 7 | -------------------------------------------------------------------------------- /APIGateway/index.js: -------------------------------------------------------------------------------- 1 | const DotEnv = require('dotenv'); 2 | 3 | DotEnv.config(); 4 | 5 | const Server = require('./server'); 6 | 7 | Server.startTheServer(); 8 | -------------------------------------------------------------------------------- /APIGateway/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "apigateway", 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 | }, 27 | "accepts": { 28 | "version": "1.3.5", 29 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz", 30 | "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=", 31 | "requires": { 32 | "mime-types": "~2.1.18", 33 | "negotiator": "0.6.1" 34 | } 35 | }, 36 | "acorn": { 37 | "version": "6.1.1", 38 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.1.1.tgz", 39 | "integrity": "sha512-jPTiwtOxaHNaAPg/dmrJ/beuzLRnXtB0kQPQ8JpotKJgTB6rX6c8mlf315941pyjBSaPg8NHXS9fhP4u17DpGA==", 40 | "dev": true 41 | }, 42 | "acorn-jsx": { 43 | "version": "5.0.1", 44 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", 45 | "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==", 46 | "dev": true 47 | }, 48 | "ajv": { 49 | "version": "6.10.0", 50 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.0.tgz", 51 | "integrity": "sha512-nffhOpkymDECQyR0mnsUtoCE8RlX38G0rYP+wgLWFyZuUyuuojSSvi/+euOiQBIn63whYwYVIIH1TvE3tu4OEg==", 52 | "dev": true, 53 | "requires": { 54 | "fast-deep-equal": "^2.0.1", 55 | "fast-json-stable-stringify": "^2.0.0", 56 | "json-schema-traverse": "^0.4.1", 57 | "uri-js": "^4.2.2" 58 | } 59 | }, 60 | "ansi-escapes": { 61 | "version": "3.2.0", 62 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", 63 | "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==", 64 | "dev": true 65 | }, 66 | "ansi-regex": { 67 | "version": "3.0.0", 68 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 69 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 70 | "dev": true 71 | }, 72 | "ansi-styles": { 73 | "version": "3.2.1", 74 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 75 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 76 | "dev": true, 77 | "requires": { 78 | "color-convert": "^1.9.0" 79 | } 80 | }, 81 | "argparse": { 82 | "version": "1.0.10", 83 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 84 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 85 | "dev": true, 86 | "requires": { 87 | "sprintf-js": "~1.0.2" 88 | } 89 | }, 90 | "array-flatten": { 91 | "version": "1.1.1", 92 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 93 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 94 | }, 95 | "array-includes": { 96 | "version": "3.0.3", 97 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.0.3.tgz", 98 | "integrity": "sha1-GEtI9i2S10UrsxsyMWXH+L0CJm0=", 99 | "dev": true, 100 | "requires": { 101 | "define-properties": "^1.1.2", 102 | "es-abstract": "^1.7.0" 103 | } 104 | }, 105 | "astral-regex": { 106 | "version": "1.0.0", 107 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 108 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 109 | "dev": true 110 | }, 111 | "balanced-match": { 112 | "version": "1.0.0", 113 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 114 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 115 | "dev": true 116 | }, 117 | "body-parser": { 118 | "version": "1.18.2", 119 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.2.tgz", 120 | "integrity": "sha1-h2eKGdhLR9hZuDGZvVm84iKxBFQ=", 121 | "requires": { 122 | "bytes": "3.0.0", 123 | "content-type": "~1.0.4", 124 | "debug": "2.6.9", 125 | "depd": "~1.1.1", 126 | "http-errors": "~1.6.2", 127 | "iconv-lite": "0.4.19", 128 | "on-finished": "~2.3.0", 129 | "qs": "6.5.1", 130 | "raw-body": "2.3.2", 131 | "type-is": "~1.6.15" 132 | } 133 | }, 134 | "brace-expansion": { 135 | "version": "1.1.11", 136 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 137 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 138 | "dev": true, 139 | "requires": { 140 | "balanced-match": "^1.0.0", 141 | "concat-map": "0.0.1" 142 | } 143 | }, 144 | "bytes": { 145 | "version": "3.0.0", 146 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", 147 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" 148 | }, 149 | "callsites": { 150 | "version": "3.1.0", 151 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 152 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 153 | "dev": true 154 | }, 155 | "chalk": { 156 | "version": "2.4.2", 157 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 158 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 159 | "dev": true, 160 | "requires": { 161 | "ansi-styles": "^3.2.1", 162 | "escape-string-regexp": "^1.0.5", 163 | "supports-color": "^5.3.0" 164 | } 165 | }, 166 | "chardet": { 167 | "version": "0.7.0", 168 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 169 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 170 | "dev": true 171 | }, 172 | "cli-cursor": { 173 | "version": "2.1.0", 174 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 175 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 176 | "dev": true, 177 | "requires": { 178 | "restore-cursor": "^2.0.0" 179 | } 180 | }, 181 | "cli-width": { 182 | "version": "2.2.0", 183 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 184 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 185 | "dev": true 186 | }, 187 | "color-convert": { 188 | "version": "1.9.3", 189 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 190 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 191 | "dev": true, 192 | "requires": { 193 | "color-name": "1.1.3" 194 | } 195 | }, 196 | "color-name": { 197 | "version": "1.1.3", 198 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 199 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 200 | "dev": true 201 | }, 202 | "concat-map": { 203 | "version": "0.0.1", 204 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 205 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 206 | "dev": true 207 | }, 208 | "contains-path": { 209 | "version": "0.1.0", 210 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 211 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 212 | "dev": true 213 | }, 214 | "content-disposition": { 215 | "version": "0.5.2", 216 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", 217 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=" 218 | }, 219 | "content-type": { 220 | "version": "1.0.4", 221 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 222 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 223 | }, 224 | "cookie": { 225 | "version": "0.3.1", 226 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 227 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=" 228 | }, 229 | "cookie-signature": { 230 | "version": "1.0.6", 231 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 232 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 233 | }, 234 | "cross-spawn": { 235 | "version": "6.0.5", 236 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 237 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 238 | "dev": true, 239 | "requires": { 240 | "nice-try": "^1.0.4", 241 | "path-key": "^2.0.1", 242 | "semver": "^5.5.0", 243 | "shebang-command": "^1.2.0", 244 | "which": "^1.2.9" 245 | } 246 | }, 247 | "debug": { 248 | "version": "2.6.9", 249 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 250 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 251 | "requires": { 252 | "ms": "2.0.0" 253 | } 254 | }, 255 | "deep-is": { 256 | "version": "0.1.3", 257 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 258 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 259 | "dev": true 260 | }, 261 | "define-properties": { 262 | "version": "1.1.3", 263 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 264 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 265 | "dev": true, 266 | "requires": { 267 | "object-keys": "^1.0.12" 268 | } 269 | }, 270 | "depd": { 271 | "version": "1.1.2", 272 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 273 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 274 | }, 275 | "destroy": { 276 | "version": "1.0.4", 277 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 278 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 279 | }, 280 | "doctrine": { 281 | "version": "3.0.0", 282 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 283 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 284 | "dev": true, 285 | "requires": { 286 | "esutils": "^2.0.2" 287 | } 288 | }, 289 | "dotenv": { 290 | "version": "7.0.0", 291 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-7.0.0.tgz", 292 | "integrity": "sha512-M3NhsLbV1i6HuGzBUH8vXrtxOk+tWmzWKDMbAVSUp3Zsjm7ywFeuwrUXhmhQyRK1q5B5GGy7hcXPbj3bnfZg2g==" 293 | }, 294 | "ee-first": { 295 | "version": "1.1.1", 296 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 297 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 298 | }, 299 | "emoji-regex": { 300 | "version": "7.0.3", 301 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 302 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 303 | "dev": true 304 | }, 305 | "encodeurl": { 306 | "version": "1.0.2", 307 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 308 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 309 | }, 310 | "error-ex": { 311 | "version": "1.3.2", 312 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 313 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 314 | "dev": true, 315 | "requires": { 316 | "is-arrayish": "^0.2.1" 317 | } 318 | }, 319 | "es-abstract": { 320 | "version": "1.13.0", 321 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", 322 | "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", 323 | "dev": true, 324 | "requires": { 325 | "es-to-primitive": "^1.2.0", 326 | "function-bind": "^1.1.1", 327 | "has": "^1.0.3", 328 | "is-callable": "^1.1.4", 329 | "is-regex": "^1.0.4", 330 | "object-keys": "^1.0.12" 331 | } 332 | }, 333 | "es-to-primitive": { 334 | "version": "1.2.0", 335 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 336 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 337 | "dev": true, 338 | "requires": { 339 | "is-callable": "^1.1.4", 340 | "is-date-object": "^1.0.1", 341 | "is-symbol": "^1.0.2" 342 | } 343 | }, 344 | "es6-promise": { 345 | "version": "4.2.4", 346 | "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.4.tgz", 347 | "integrity": "sha512-/NdNZVJg+uZgtm9eS3O6lrOLYmQag2DjdEXuPaHlZ6RuVqgqaVZfgYCepEIKsLqwdQArOPtC3XzRLqGGfT8KQQ==" 348 | }, 349 | "escape-html": { 350 | "version": "1.0.3", 351 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 352 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 353 | }, 354 | "escape-string-regexp": { 355 | "version": "1.0.5", 356 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 357 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 358 | "dev": true 359 | }, 360 | "eslint": { 361 | "version": "5.16.0", 362 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.16.0.tgz", 363 | "integrity": "sha512-S3Rz11i7c8AA5JPv7xAH+dOyq/Cu/VXHiHXBPOU1k/JAM5dXqQPt3qcrhpHSorXmrpu2g0gkIBVXAqCpzfoZIg==", 364 | "dev": true, 365 | "requires": { 366 | "@babel/code-frame": "^7.0.0", 367 | "ajv": "^6.9.1", 368 | "chalk": "^2.1.0", 369 | "cross-spawn": "^6.0.5", 370 | "debug": "^4.0.1", 371 | "doctrine": "^3.0.0", 372 | "eslint-scope": "^4.0.3", 373 | "eslint-utils": "^1.3.1", 374 | "eslint-visitor-keys": "^1.0.0", 375 | "espree": "^5.0.1", 376 | "esquery": "^1.0.1", 377 | "esutils": "^2.0.2", 378 | "file-entry-cache": "^5.0.1", 379 | "functional-red-black-tree": "^1.0.1", 380 | "glob": "^7.1.2", 381 | "globals": "^11.7.0", 382 | "ignore": "^4.0.6", 383 | "import-fresh": "^3.0.0", 384 | "imurmurhash": "^0.1.4", 385 | "inquirer": "^6.2.2", 386 | "js-yaml": "^3.13.0", 387 | "json-stable-stringify-without-jsonify": "^1.0.1", 388 | "levn": "^0.3.0", 389 | "lodash": "^4.17.11", 390 | "minimatch": "^3.0.4", 391 | "mkdirp": "^0.5.1", 392 | "natural-compare": "^1.4.0", 393 | "optionator": "^0.8.2", 394 | "path-is-inside": "^1.0.2", 395 | "progress": "^2.0.0", 396 | "regexpp": "^2.0.1", 397 | "semver": "^5.5.1", 398 | "strip-ansi": "^4.0.0", 399 | "strip-json-comments": "^2.0.1", 400 | "table": "^5.2.3", 401 | "text-table": "^0.2.0" 402 | }, 403 | "dependencies": { 404 | "debug": { 405 | "version": "4.1.1", 406 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 407 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 408 | "dev": true, 409 | "requires": { 410 | "ms": "^2.1.1" 411 | } 412 | }, 413 | "ms": { 414 | "version": "2.1.1", 415 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 416 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 417 | "dev": true 418 | } 419 | } 420 | }, 421 | "eslint-config-airbnb-base": { 422 | "version": "13.1.0", 423 | "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-13.1.0.tgz", 424 | "integrity": "sha512-XWwQtf3U3zIoKO1BbHh6aUhJZQweOwSt4c2JrPDg9FP3Ltv3+YfEv7jIDB8275tVnO/qOHbfuYg3kzw6Je7uWw==", 425 | "dev": true, 426 | "requires": { 427 | "eslint-restricted-globals": "^0.1.1", 428 | "object.assign": "^4.1.0", 429 | "object.entries": "^1.0.4" 430 | } 431 | }, 432 | "eslint-import-resolver-node": { 433 | "version": "0.3.2", 434 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz", 435 | "integrity": "sha512-sfmTqJfPSizWu4aymbPr4Iidp5yKm8yDkHp+Ir3YiTHiiDfxh69mOUsmiqW6RZ9zRXFaF64GtYmN7e+8GHBv6Q==", 436 | "dev": true, 437 | "requires": { 438 | "debug": "^2.6.9", 439 | "resolve": "^1.5.0" 440 | } 441 | }, 442 | "eslint-module-utils": { 443 | "version": "2.4.0", 444 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.4.0.tgz", 445 | "integrity": "sha512-14tltLm38Eu3zS+mt0KvILC3q8jyIAH518MlG+HO0p+yK885Lb1UHTY/UgR91eOyGdmxAPb+OLoW4znqIT6Ndw==", 446 | "dev": true, 447 | "requires": { 448 | "debug": "^2.6.8", 449 | "pkg-dir": "^2.0.0" 450 | } 451 | }, 452 | "eslint-plugin-import": { 453 | "version": "2.17.1", 454 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.17.1.tgz", 455 | "integrity": "sha512-lzD9uvRvW4MsHzIOMJEDSb5MOV9LzgxRPBaovvOhJqzgxRHYfGy9QOrMuwHIh5ehKFJ7Z3DcrcGKDQ0IbP0EdQ==", 456 | "dev": true, 457 | "requires": { 458 | "array-includes": "^3.0.3", 459 | "contains-path": "^0.1.0", 460 | "debug": "^2.6.9", 461 | "doctrine": "1.5.0", 462 | "eslint-import-resolver-node": "^0.3.2", 463 | "eslint-module-utils": "^2.4.0", 464 | "has": "^1.0.3", 465 | "lodash": "^4.17.11", 466 | "minimatch": "^3.0.4", 467 | "read-pkg-up": "^2.0.0", 468 | "resolve": "^1.10.0" 469 | }, 470 | "dependencies": { 471 | "doctrine": { 472 | "version": "1.5.0", 473 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 474 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 475 | "dev": true, 476 | "requires": { 477 | "esutils": "^2.0.2", 478 | "isarray": "^1.0.0" 479 | } 480 | } 481 | } 482 | }, 483 | "eslint-restricted-globals": { 484 | "version": "0.1.1", 485 | "resolved": "https://registry.npmjs.org/eslint-restricted-globals/-/eslint-restricted-globals-0.1.1.tgz", 486 | "integrity": "sha1-NfDVy8ZMLj7WLpO0saevBbp+1Nc=", 487 | "dev": true 488 | }, 489 | "eslint-scope": { 490 | "version": "4.0.3", 491 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", 492 | "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", 493 | "dev": true, 494 | "requires": { 495 | "esrecurse": "^4.1.0", 496 | "estraverse": "^4.1.1" 497 | } 498 | }, 499 | "eslint-utils": { 500 | "version": "1.3.1", 501 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.3.1.tgz", 502 | "integrity": "sha512-Z7YjnIldX+2XMcjr7ZkgEsOj/bREONV60qYeB/bjMAqqqZ4zxKyWX+BOUkdmRmA9riiIPVvo5x86m5elviOk0Q==", 503 | "dev": true 504 | }, 505 | "eslint-visitor-keys": { 506 | "version": "1.0.0", 507 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 508 | "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", 509 | "dev": true 510 | }, 511 | "espree": { 512 | "version": "5.0.1", 513 | "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.1.tgz", 514 | "integrity": "sha512-qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A==", 515 | "dev": true, 516 | "requires": { 517 | "acorn": "^6.0.7", 518 | "acorn-jsx": "^5.0.0", 519 | "eslint-visitor-keys": "^1.0.0" 520 | } 521 | }, 522 | "esprima": { 523 | "version": "4.0.1", 524 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 525 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 526 | "dev": true 527 | }, 528 | "esquery": { 529 | "version": "1.0.1", 530 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 531 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 532 | "dev": true, 533 | "requires": { 534 | "estraverse": "^4.0.0" 535 | } 536 | }, 537 | "esrecurse": { 538 | "version": "4.2.1", 539 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 540 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 541 | "dev": true, 542 | "requires": { 543 | "estraverse": "^4.1.0" 544 | } 545 | }, 546 | "estraverse": { 547 | "version": "4.2.0", 548 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 549 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", 550 | "dev": true 551 | }, 552 | "esutils": { 553 | "version": "2.0.2", 554 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 555 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 556 | "dev": true 557 | }, 558 | "etag": { 559 | "version": "1.8.1", 560 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 561 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 562 | }, 563 | "express": { 564 | "version": "4.16.3", 565 | "resolved": "https://registry.npmjs.org/express/-/express-4.16.3.tgz", 566 | "integrity": "sha1-avilAjUNsyRuzEvs9rWjTSL37VM=", 567 | "requires": { 568 | "accepts": "~1.3.5", 569 | "array-flatten": "1.1.1", 570 | "body-parser": "1.18.2", 571 | "content-disposition": "0.5.2", 572 | "content-type": "~1.0.4", 573 | "cookie": "0.3.1", 574 | "cookie-signature": "1.0.6", 575 | "debug": "2.6.9", 576 | "depd": "~1.1.2", 577 | "encodeurl": "~1.0.2", 578 | "escape-html": "~1.0.3", 579 | "etag": "~1.8.1", 580 | "finalhandler": "1.1.1", 581 | "fresh": "0.5.2", 582 | "merge-descriptors": "1.0.1", 583 | "methods": "~1.1.2", 584 | "on-finished": "~2.3.0", 585 | "parseurl": "~1.3.2", 586 | "path-to-regexp": "0.1.7", 587 | "proxy-addr": "~2.0.3", 588 | "qs": "6.5.1", 589 | "range-parser": "~1.2.0", 590 | "safe-buffer": "5.1.1", 591 | "send": "0.16.2", 592 | "serve-static": "1.13.2", 593 | "setprototypeof": "1.1.0", 594 | "statuses": "~1.4.0", 595 | "type-is": "~1.6.16", 596 | "utils-merge": "1.0.1", 597 | "vary": "~1.1.2" 598 | } 599 | }, 600 | "express-http-proxy": { 601 | "version": "1.2.0", 602 | "resolved": "https://registry.npmjs.org/express-http-proxy/-/express-http-proxy-1.2.0.tgz", 603 | "integrity": "sha512-HefDxJyPLTtVqQXYhniN0JCS3ibyDwxvIjrwTGqXUeChdeTz9+Lo9LgKHJRTqTIp8wQeknM+W52v/+/NCm4IIw==", 604 | "requires": { 605 | "debug": "^3.0.1", 606 | "es6-promise": "^4.1.1", 607 | "raw-body": "^2.3.0" 608 | }, 609 | "dependencies": { 610 | "debug": { 611 | "version": "3.1.0", 612 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 613 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 614 | "requires": { 615 | "ms": "2.0.0" 616 | } 617 | } 618 | } 619 | }, 620 | "external-editor": { 621 | "version": "3.0.3", 622 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.0.3.tgz", 623 | "integrity": "sha512-bn71H9+qWoOQKyZDo25mOMVpSmXROAsTJVVVYzrrtol3d4y+AsKjf4Iwl2Q+IuT0kFSQ1qo166UuIwqYq7mGnA==", 624 | "dev": true, 625 | "requires": { 626 | "chardet": "^0.7.0", 627 | "iconv-lite": "^0.4.24", 628 | "tmp": "^0.0.33" 629 | }, 630 | "dependencies": { 631 | "iconv-lite": { 632 | "version": "0.4.24", 633 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 634 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 635 | "dev": true, 636 | "requires": { 637 | "safer-buffer": ">= 2.1.2 < 3" 638 | } 639 | } 640 | } 641 | }, 642 | "fast-deep-equal": { 643 | "version": "2.0.1", 644 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 645 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 646 | "dev": true 647 | }, 648 | "fast-json-stable-stringify": { 649 | "version": "2.0.0", 650 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 651 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 652 | "dev": true 653 | }, 654 | "fast-levenshtein": { 655 | "version": "2.0.6", 656 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 657 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 658 | "dev": true 659 | }, 660 | "figures": { 661 | "version": "2.0.0", 662 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 663 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 664 | "dev": true, 665 | "requires": { 666 | "escape-string-regexp": "^1.0.5" 667 | } 668 | }, 669 | "file-entry-cache": { 670 | "version": "5.0.1", 671 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 672 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 673 | "dev": true, 674 | "requires": { 675 | "flat-cache": "^2.0.1" 676 | } 677 | }, 678 | "finalhandler": { 679 | "version": "1.1.1", 680 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.1.tgz", 681 | "integrity": "sha512-Y1GUDo39ez4aHAw7MysnUD5JzYX+WaIj8I57kO3aEPT1fFRL4sr7mjei97FgnwhAyyzRYmQZaTHb2+9uZ1dPtg==", 682 | "requires": { 683 | "debug": "2.6.9", 684 | "encodeurl": "~1.0.2", 685 | "escape-html": "~1.0.3", 686 | "on-finished": "~2.3.0", 687 | "parseurl": "~1.3.2", 688 | "statuses": "~1.4.0", 689 | "unpipe": "~1.0.0" 690 | } 691 | }, 692 | "find-up": { 693 | "version": "2.1.0", 694 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 695 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 696 | "dev": true, 697 | "requires": { 698 | "locate-path": "^2.0.0" 699 | } 700 | }, 701 | "flat-cache": { 702 | "version": "2.0.1", 703 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 704 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 705 | "dev": true, 706 | "requires": { 707 | "flatted": "^2.0.0", 708 | "rimraf": "2.6.3", 709 | "write": "1.0.3" 710 | } 711 | }, 712 | "flatted": { 713 | "version": "2.0.0", 714 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.0.tgz", 715 | "integrity": "sha512-R+H8IZclI8AAkSBRQJLVOsxwAoHd6WC40b4QTNWIjzAa6BXOBfQcM587MXDTVPeYaopFNWHUFLx7eNmHDSxMWg==", 716 | "dev": true 717 | }, 718 | "forwarded": { 719 | "version": "0.1.2", 720 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 721 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 722 | }, 723 | "fresh": { 724 | "version": "0.5.2", 725 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 726 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 727 | }, 728 | "fs.realpath": { 729 | "version": "1.0.0", 730 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 731 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 732 | "dev": true 733 | }, 734 | "function-bind": { 735 | "version": "1.1.1", 736 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 737 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 738 | "dev": true 739 | }, 740 | "functional-red-black-tree": { 741 | "version": "1.0.1", 742 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 743 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 744 | "dev": true 745 | }, 746 | "glob": { 747 | "version": "7.1.3", 748 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 749 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 750 | "dev": true, 751 | "requires": { 752 | "fs.realpath": "^1.0.0", 753 | "inflight": "^1.0.4", 754 | "inherits": "2", 755 | "minimatch": "^3.0.4", 756 | "once": "^1.3.0", 757 | "path-is-absolute": "^1.0.0" 758 | } 759 | }, 760 | "globals": { 761 | "version": "11.11.0", 762 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.11.0.tgz", 763 | "integrity": "sha512-WHq43gS+6ufNOEqlrDBxVEbb8ntfXrfAUU2ZOpCxrBdGKW3gyv8mCxAfIBD0DroPKGrJ2eSsXsLtY9MPntsyTw==", 764 | "dev": true 765 | }, 766 | "graceful-fs": { 767 | "version": "4.1.15", 768 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", 769 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==", 770 | "dev": true 771 | }, 772 | "has": { 773 | "version": "1.0.3", 774 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 775 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 776 | "dev": true, 777 | "requires": { 778 | "function-bind": "^1.1.1" 779 | } 780 | }, 781 | "has-flag": { 782 | "version": "3.0.0", 783 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 784 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 785 | "dev": true 786 | }, 787 | "has-symbols": { 788 | "version": "1.0.0", 789 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 790 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 791 | "dev": true 792 | }, 793 | "hosted-git-info": { 794 | "version": "2.7.1", 795 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz", 796 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==", 797 | "dev": true 798 | }, 799 | "http-errors": { 800 | "version": "1.6.3", 801 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", 802 | "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", 803 | "requires": { 804 | "depd": "~1.1.2", 805 | "inherits": "2.0.3", 806 | "setprototypeof": "1.1.0", 807 | "statuses": ">= 1.4.0 < 2" 808 | } 809 | }, 810 | "iconv-lite": { 811 | "version": "0.4.19", 812 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.19.tgz", 813 | "integrity": "sha512-oTZqweIP51xaGPI4uPa56/Pri/480R+mo7SeU+YETByQNhDG55ycFyNLIgta9vXhILrxXDmF7ZGhqZIcuN0gJQ==" 814 | }, 815 | "ignore": { 816 | "version": "4.0.6", 817 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 818 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 819 | "dev": true 820 | }, 821 | "import-fresh": { 822 | "version": "3.0.0", 823 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.0.0.tgz", 824 | "integrity": "sha512-pOnA9tfM3Uwics+SaBLCNyZZZbK+4PTu0OPZtLlMIrv17EdBoC15S9Kn8ckJ9TZTyKb3ywNE5y1yeDxxGA7nTQ==", 825 | "dev": true, 826 | "requires": { 827 | "parent-module": "^1.0.0", 828 | "resolve-from": "^4.0.0" 829 | } 830 | }, 831 | "imurmurhash": { 832 | "version": "0.1.4", 833 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 834 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 835 | "dev": true 836 | }, 837 | "inflight": { 838 | "version": "1.0.6", 839 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 840 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 841 | "dev": true, 842 | "requires": { 843 | "once": "^1.3.0", 844 | "wrappy": "1" 845 | } 846 | }, 847 | "inherits": { 848 | "version": "2.0.3", 849 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 850 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 851 | }, 852 | "inquirer": { 853 | "version": "6.3.1", 854 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.3.1.tgz", 855 | "integrity": "sha512-MmL624rfkFt4TG9y/Jvmt8vdmOo836U7Y0Hxr2aFk3RelZEGX4Igk0KabWrcaaZaTv9uzglOqWh1Vly+FAWAXA==", 856 | "dev": true, 857 | "requires": { 858 | "ansi-escapes": "^3.2.0", 859 | "chalk": "^2.4.2", 860 | "cli-cursor": "^2.1.0", 861 | "cli-width": "^2.0.0", 862 | "external-editor": "^3.0.3", 863 | "figures": "^2.0.0", 864 | "lodash": "^4.17.11", 865 | "mute-stream": "0.0.7", 866 | "run-async": "^2.2.0", 867 | "rxjs": "^6.4.0", 868 | "string-width": "^2.1.0", 869 | "strip-ansi": "^5.1.0", 870 | "through": "^2.3.6" 871 | }, 872 | "dependencies": { 873 | "ansi-regex": { 874 | "version": "4.1.0", 875 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 876 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 877 | "dev": true 878 | }, 879 | "strip-ansi": { 880 | "version": "5.2.0", 881 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 882 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 883 | "dev": true, 884 | "requires": { 885 | "ansi-regex": "^4.1.0" 886 | } 887 | } 888 | } 889 | }, 890 | "ipaddr.js": { 891 | "version": "1.8.0", 892 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.8.0.tgz", 893 | "integrity": "sha1-6qM9bd16zo9/b+DJygRA5wZzix4=" 894 | }, 895 | "is-arrayish": { 896 | "version": "0.2.1", 897 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 898 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 899 | "dev": true 900 | }, 901 | "is-callable": { 902 | "version": "1.1.4", 903 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 904 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 905 | "dev": true 906 | }, 907 | "is-date-object": { 908 | "version": "1.0.1", 909 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 910 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 911 | "dev": true 912 | }, 913 | "is-fullwidth-code-point": { 914 | "version": "2.0.0", 915 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 916 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 917 | "dev": true 918 | }, 919 | "is-promise": { 920 | "version": "2.1.0", 921 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 922 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 923 | "dev": true 924 | }, 925 | "is-regex": { 926 | "version": "1.0.4", 927 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 928 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 929 | "dev": true, 930 | "requires": { 931 | "has": "^1.0.1" 932 | } 933 | }, 934 | "is-symbol": { 935 | "version": "1.0.2", 936 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 937 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 938 | "dev": true, 939 | "requires": { 940 | "has-symbols": "^1.0.0" 941 | } 942 | }, 943 | "isarray": { 944 | "version": "1.0.0", 945 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 946 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 947 | "dev": true 948 | }, 949 | "isexe": { 950 | "version": "2.0.0", 951 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 952 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 953 | "dev": true 954 | }, 955 | "js-tokens": { 956 | "version": "4.0.0", 957 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 958 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 959 | "dev": true 960 | }, 961 | "js-yaml": { 962 | "version": "3.13.1", 963 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 964 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 965 | "dev": true, 966 | "requires": { 967 | "argparse": "^1.0.7", 968 | "esprima": "^4.0.0" 969 | } 970 | }, 971 | "json-schema-traverse": { 972 | "version": "0.4.1", 973 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 974 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 975 | "dev": true 976 | }, 977 | "json-stable-stringify-without-jsonify": { 978 | "version": "1.0.1", 979 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 980 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 981 | "dev": true 982 | }, 983 | "levn": { 984 | "version": "0.3.0", 985 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 986 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 987 | "dev": true, 988 | "requires": { 989 | "prelude-ls": "~1.1.2", 990 | "type-check": "~0.3.2" 991 | } 992 | }, 993 | "load-json-file": { 994 | "version": "2.0.0", 995 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 996 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 997 | "dev": true, 998 | "requires": { 999 | "graceful-fs": "^4.1.2", 1000 | "parse-json": "^2.2.0", 1001 | "pify": "^2.0.0", 1002 | "strip-bom": "^3.0.0" 1003 | } 1004 | }, 1005 | "locate-path": { 1006 | "version": "2.0.0", 1007 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1008 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1009 | "dev": true, 1010 | "requires": { 1011 | "p-locate": "^2.0.0", 1012 | "path-exists": "^3.0.0" 1013 | } 1014 | }, 1015 | "lodash": { 1016 | "version": "4.17.11", 1017 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 1018 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", 1019 | "dev": true 1020 | }, 1021 | "media-typer": { 1022 | "version": "0.3.0", 1023 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1024 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1025 | }, 1026 | "merge-descriptors": { 1027 | "version": "1.0.1", 1028 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1029 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1030 | }, 1031 | "methods": { 1032 | "version": "1.1.2", 1033 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1034 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1035 | }, 1036 | "mime": { 1037 | "version": "1.4.1", 1038 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz", 1039 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==" 1040 | }, 1041 | "mime-db": { 1042 | "version": "1.35.0", 1043 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.35.0.tgz", 1044 | "integrity": "sha512-JWT/IcCTsB0Io3AhWUMjRqucrHSPsSf2xKLaRldJVULioggvkJvggZ3VXNNSRkCddE6D+BUI4HEIZIA2OjwIvg==" 1045 | }, 1046 | "mime-types": { 1047 | "version": "2.1.19", 1048 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.19.tgz", 1049 | "integrity": "sha512-P1tKYHVSZ6uFo26mtnve4HQFE3koh1UWVkp8YUC+ESBHe945xWSoXuHHiGarDqcEZ+whpCDnlNw5LON0kLo+sw==", 1050 | "requires": { 1051 | "mime-db": "~1.35.0" 1052 | } 1053 | }, 1054 | "mimic-fn": { 1055 | "version": "1.2.0", 1056 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 1057 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", 1058 | "dev": true 1059 | }, 1060 | "minimatch": { 1061 | "version": "3.0.4", 1062 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1063 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1064 | "dev": true, 1065 | "requires": { 1066 | "brace-expansion": "^1.1.7" 1067 | } 1068 | }, 1069 | "minimist": { 1070 | "version": "0.0.8", 1071 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1072 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1073 | "dev": true 1074 | }, 1075 | "mkdirp": { 1076 | "version": "0.5.1", 1077 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1078 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1079 | "dev": true, 1080 | "requires": { 1081 | "minimist": "0.0.8" 1082 | } 1083 | }, 1084 | "ms": { 1085 | "version": "2.0.0", 1086 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1087 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1088 | }, 1089 | "mute-stream": { 1090 | "version": "0.0.7", 1091 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 1092 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", 1093 | "dev": true 1094 | }, 1095 | "natural-compare": { 1096 | "version": "1.4.0", 1097 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1098 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1099 | "dev": true 1100 | }, 1101 | "negotiator": { 1102 | "version": "0.6.1", 1103 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", 1104 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=" 1105 | }, 1106 | "nice-try": { 1107 | "version": "1.0.5", 1108 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1109 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1110 | "dev": true 1111 | }, 1112 | "normalize-package-data": { 1113 | "version": "2.5.0", 1114 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1115 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1116 | "dev": true, 1117 | "requires": { 1118 | "hosted-git-info": "^2.1.4", 1119 | "resolve": "^1.10.0", 1120 | "semver": "2 || 3 || 4 || 5", 1121 | "validate-npm-package-license": "^3.0.1" 1122 | } 1123 | }, 1124 | "object-keys": { 1125 | "version": "1.1.1", 1126 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1127 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1128 | "dev": true 1129 | }, 1130 | "object.assign": { 1131 | "version": "4.1.0", 1132 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1133 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1134 | "dev": true, 1135 | "requires": { 1136 | "define-properties": "^1.1.2", 1137 | "function-bind": "^1.1.1", 1138 | "has-symbols": "^1.0.0", 1139 | "object-keys": "^1.0.11" 1140 | } 1141 | }, 1142 | "object.entries": { 1143 | "version": "1.1.0", 1144 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.0.tgz", 1145 | "integrity": "sha512-l+H6EQ8qzGRxbkHOd5I/aHRhHDKoQXQ8g0BYt4uSweQU1/J6dZUOyWh9a2Vky35YCKjzmgxOzta2hH6kf9HuXA==", 1146 | "dev": true, 1147 | "requires": { 1148 | "define-properties": "^1.1.3", 1149 | "es-abstract": "^1.12.0", 1150 | "function-bind": "^1.1.1", 1151 | "has": "^1.0.3" 1152 | } 1153 | }, 1154 | "on-finished": { 1155 | "version": "2.3.0", 1156 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1157 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1158 | "requires": { 1159 | "ee-first": "1.1.1" 1160 | } 1161 | }, 1162 | "once": { 1163 | "version": "1.4.0", 1164 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1165 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1166 | "dev": true, 1167 | "requires": { 1168 | "wrappy": "1" 1169 | } 1170 | }, 1171 | "onetime": { 1172 | "version": "2.0.1", 1173 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 1174 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 1175 | "dev": true, 1176 | "requires": { 1177 | "mimic-fn": "^1.0.0" 1178 | } 1179 | }, 1180 | "optionator": { 1181 | "version": "0.8.2", 1182 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 1183 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 1184 | "dev": true, 1185 | "requires": { 1186 | "deep-is": "~0.1.3", 1187 | "fast-levenshtein": "~2.0.4", 1188 | "levn": "~0.3.0", 1189 | "prelude-ls": "~1.1.2", 1190 | "type-check": "~0.3.2", 1191 | "wordwrap": "~1.0.0" 1192 | } 1193 | }, 1194 | "os-tmpdir": { 1195 | "version": "1.0.2", 1196 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1197 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1198 | "dev": true 1199 | }, 1200 | "p-limit": { 1201 | "version": "1.3.0", 1202 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1203 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1204 | "dev": true, 1205 | "requires": { 1206 | "p-try": "^1.0.0" 1207 | } 1208 | }, 1209 | "p-locate": { 1210 | "version": "2.0.0", 1211 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1212 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1213 | "dev": true, 1214 | "requires": { 1215 | "p-limit": "^1.1.0" 1216 | } 1217 | }, 1218 | "p-try": { 1219 | "version": "1.0.0", 1220 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1221 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 1222 | "dev": true 1223 | }, 1224 | "parent-module": { 1225 | "version": "1.0.1", 1226 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1227 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1228 | "dev": true, 1229 | "requires": { 1230 | "callsites": "^3.0.0" 1231 | } 1232 | }, 1233 | "parse-json": { 1234 | "version": "2.2.0", 1235 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 1236 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 1237 | "dev": true, 1238 | "requires": { 1239 | "error-ex": "^1.2.0" 1240 | } 1241 | }, 1242 | "parseurl": { 1243 | "version": "1.3.2", 1244 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz", 1245 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=" 1246 | }, 1247 | "path-exists": { 1248 | "version": "3.0.0", 1249 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1250 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1251 | "dev": true 1252 | }, 1253 | "path-is-absolute": { 1254 | "version": "1.0.1", 1255 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1256 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1257 | "dev": true 1258 | }, 1259 | "path-is-inside": { 1260 | "version": "1.0.2", 1261 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 1262 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 1263 | "dev": true 1264 | }, 1265 | "path-key": { 1266 | "version": "2.0.1", 1267 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1268 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1269 | "dev": true 1270 | }, 1271 | "path-parse": { 1272 | "version": "1.0.6", 1273 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1274 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 1275 | "dev": true 1276 | }, 1277 | "path-to-regexp": { 1278 | "version": "0.1.7", 1279 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1280 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1281 | }, 1282 | "path-type": { 1283 | "version": "2.0.0", 1284 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 1285 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 1286 | "dev": true, 1287 | "requires": { 1288 | "pify": "^2.0.0" 1289 | } 1290 | }, 1291 | "pify": { 1292 | "version": "2.3.0", 1293 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1294 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1295 | "dev": true 1296 | }, 1297 | "pkg-dir": { 1298 | "version": "2.0.0", 1299 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", 1300 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", 1301 | "dev": true, 1302 | "requires": { 1303 | "find-up": "^2.1.0" 1304 | } 1305 | }, 1306 | "prelude-ls": { 1307 | "version": "1.1.2", 1308 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1309 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1310 | "dev": true 1311 | }, 1312 | "progress": { 1313 | "version": "2.0.3", 1314 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1315 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1316 | "dev": true 1317 | }, 1318 | "proxy-addr": { 1319 | "version": "2.0.4", 1320 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.4.tgz", 1321 | "integrity": "sha512-5erio2h9jp5CHGwcybmxmVqHmnCBZeewlfJ0pex+UW7Qny7OOZXTtH56TGNyBizkgiOwhJtMKrVzDTeKcySZwA==", 1322 | "requires": { 1323 | "forwarded": "~0.1.2", 1324 | "ipaddr.js": "1.8.0" 1325 | } 1326 | }, 1327 | "punycode": { 1328 | "version": "2.1.1", 1329 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1330 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1331 | "dev": true 1332 | }, 1333 | "qs": { 1334 | "version": "6.5.1", 1335 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.1.tgz", 1336 | "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==" 1337 | }, 1338 | "range-parser": { 1339 | "version": "1.2.0", 1340 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 1341 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=" 1342 | }, 1343 | "raw-body": { 1344 | "version": "2.3.2", 1345 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.2.tgz", 1346 | "integrity": "sha1-vNYMd9Prk83gBQKVw/N5OJvIj4k=", 1347 | "requires": { 1348 | "bytes": "3.0.0", 1349 | "http-errors": "1.6.2", 1350 | "iconv-lite": "0.4.19", 1351 | "unpipe": "1.0.0" 1352 | }, 1353 | "dependencies": { 1354 | "depd": { 1355 | "version": "1.1.1", 1356 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.1.tgz", 1357 | "integrity": "sha1-V4O04cRZ8G+lyif5kfPQbnoxA1k=" 1358 | }, 1359 | "http-errors": { 1360 | "version": "1.6.2", 1361 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.2.tgz", 1362 | "integrity": "sha1-CgAsyFcHGSp+eUbO7cERVfYOxzY=", 1363 | "requires": { 1364 | "depd": "1.1.1", 1365 | "inherits": "2.0.3", 1366 | "setprototypeof": "1.0.3", 1367 | "statuses": ">= 1.3.1 < 2" 1368 | } 1369 | }, 1370 | "setprototypeof": { 1371 | "version": "1.0.3", 1372 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz", 1373 | "integrity": "sha1-ZlZ+NwQ+608E2RvWWMDL77VbjgQ=" 1374 | } 1375 | } 1376 | }, 1377 | "read-pkg": { 1378 | "version": "2.0.0", 1379 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 1380 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 1381 | "dev": true, 1382 | "requires": { 1383 | "load-json-file": "^2.0.0", 1384 | "normalize-package-data": "^2.3.2", 1385 | "path-type": "^2.0.0" 1386 | } 1387 | }, 1388 | "read-pkg-up": { 1389 | "version": "2.0.0", 1390 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 1391 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 1392 | "dev": true, 1393 | "requires": { 1394 | "find-up": "^2.0.0", 1395 | "read-pkg": "^2.0.0" 1396 | } 1397 | }, 1398 | "regexpp": { 1399 | "version": "2.0.1", 1400 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 1401 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 1402 | "dev": true 1403 | }, 1404 | "resolve": { 1405 | "version": "1.10.0", 1406 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.0.tgz", 1407 | "integrity": "sha512-3sUr9aq5OfSg2S9pNtPA9hL1FVEAjvfOC4leW0SNf/mpnaakz2a9femSd6LqAww2RaFctwyf1lCqnTHuF1rxDg==", 1408 | "dev": true, 1409 | "requires": { 1410 | "path-parse": "^1.0.6" 1411 | } 1412 | }, 1413 | "resolve-from": { 1414 | "version": "4.0.0", 1415 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1416 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1417 | "dev": true 1418 | }, 1419 | "restore-cursor": { 1420 | "version": "2.0.0", 1421 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 1422 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 1423 | "dev": true, 1424 | "requires": { 1425 | "onetime": "^2.0.0", 1426 | "signal-exit": "^3.0.2" 1427 | } 1428 | }, 1429 | "rimraf": { 1430 | "version": "2.6.3", 1431 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1432 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1433 | "dev": true, 1434 | "requires": { 1435 | "glob": "^7.1.3" 1436 | } 1437 | }, 1438 | "run-async": { 1439 | "version": "2.3.0", 1440 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 1441 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 1442 | "dev": true, 1443 | "requires": { 1444 | "is-promise": "^2.1.0" 1445 | } 1446 | }, 1447 | "rxjs": { 1448 | "version": "6.4.0", 1449 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.4.0.tgz", 1450 | "integrity": "sha512-Z9Yfa11F6B9Sg/BK9MnqnQ+aQYicPLtilXBp2yUtDt2JRCE0h26d33EnfO3ZxoNxG0T92OUucP3Ct7cpfkdFfw==", 1451 | "dev": true, 1452 | "requires": { 1453 | "tslib": "^1.9.0" 1454 | } 1455 | }, 1456 | "safe-buffer": { 1457 | "version": "5.1.1", 1458 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 1459 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" 1460 | }, 1461 | "safer-buffer": { 1462 | "version": "2.1.2", 1463 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1464 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1465 | "dev": true 1466 | }, 1467 | "semver": { 1468 | "version": "5.7.0", 1469 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz", 1470 | "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==", 1471 | "dev": true 1472 | }, 1473 | "send": { 1474 | "version": "0.16.2", 1475 | "resolved": "https://registry.npmjs.org/send/-/send-0.16.2.tgz", 1476 | "integrity": "sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw==", 1477 | "requires": { 1478 | "debug": "2.6.9", 1479 | "depd": "~1.1.2", 1480 | "destroy": "~1.0.4", 1481 | "encodeurl": "~1.0.2", 1482 | "escape-html": "~1.0.3", 1483 | "etag": "~1.8.1", 1484 | "fresh": "0.5.2", 1485 | "http-errors": "~1.6.2", 1486 | "mime": "1.4.1", 1487 | "ms": "2.0.0", 1488 | "on-finished": "~2.3.0", 1489 | "range-parser": "~1.2.0", 1490 | "statuses": "~1.4.0" 1491 | } 1492 | }, 1493 | "serve-static": { 1494 | "version": "1.13.2", 1495 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.13.2.tgz", 1496 | "integrity": "sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw==", 1497 | "requires": { 1498 | "encodeurl": "~1.0.2", 1499 | "escape-html": "~1.0.3", 1500 | "parseurl": "~1.3.2", 1501 | "send": "0.16.2" 1502 | } 1503 | }, 1504 | "setprototypeof": { 1505 | "version": "1.1.0", 1506 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", 1507 | "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==" 1508 | }, 1509 | "shebang-command": { 1510 | "version": "1.2.0", 1511 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1512 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1513 | "dev": true, 1514 | "requires": { 1515 | "shebang-regex": "^1.0.0" 1516 | } 1517 | }, 1518 | "shebang-regex": { 1519 | "version": "1.0.0", 1520 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1521 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1522 | "dev": true 1523 | }, 1524 | "signal-exit": { 1525 | "version": "3.0.2", 1526 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1527 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 1528 | "dev": true 1529 | }, 1530 | "slice-ansi": { 1531 | "version": "2.1.0", 1532 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 1533 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 1534 | "dev": true, 1535 | "requires": { 1536 | "ansi-styles": "^3.2.0", 1537 | "astral-regex": "^1.0.0", 1538 | "is-fullwidth-code-point": "^2.0.0" 1539 | } 1540 | }, 1541 | "spdx-correct": { 1542 | "version": "3.1.0", 1543 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", 1544 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", 1545 | "dev": true, 1546 | "requires": { 1547 | "spdx-expression-parse": "^3.0.0", 1548 | "spdx-license-ids": "^3.0.0" 1549 | } 1550 | }, 1551 | "spdx-exceptions": { 1552 | "version": "2.2.0", 1553 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", 1554 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", 1555 | "dev": true 1556 | }, 1557 | "spdx-expression-parse": { 1558 | "version": "3.0.0", 1559 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 1560 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 1561 | "dev": true, 1562 | "requires": { 1563 | "spdx-exceptions": "^2.1.0", 1564 | "spdx-license-ids": "^3.0.0" 1565 | } 1566 | }, 1567 | "spdx-license-ids": { 1568 | "version": "3.0.4", 1569 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.4.tgz", 1570 | "integrity": "sha512-7j8LYJLeY/Yb6ACbQ7F76qy5jHkp0U6jgBfJsk97bwWlVUnUWsAgpyaCvo17h0/RQGnQ036tVDomiwoI4pDkQA==", 1571 | "dev": true 1572 | }, 1573 | "sprintf-js": { 1574 | "version": "1.0.3", 1575 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1576 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1577 | "dev": true 1578 | }, 1579 | "statuses": { 1580 | "version": "1.4.0", 1581 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 1582 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==" 1583 | }, 1584 | "string-width": { 1585 | "version": "2.1.1", 1586 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1587 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1588 | "dev": true, 1589 | "requires": { 1590 | "is-fullwidth-code-point": "^2.0.0", 1591 | "strip-ansi": "^4.0.0" 1592 | } 1593 | }, 1594 | "strip-ansi": { 1595 | "version": "4.0.0", 1596 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1597 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1598 | "dev": true, 1599 | "requires": { 1600 | "ansi-regex": "^3.0.0" 1601 | } 1602 | }, 1603 | "strip-bom": { 1604 | "version": "3.0.0", 1605 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1606 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1607 | "dev": true 1608 | }, 1609 | "strip-json-comments": { 1610 | "version": "2.0.1", 1611 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1612 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1613 | "dev": true 1614 | }, 1615 | "supports-color": { 1616 | "version": "5.5.0", 1617 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1618 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1619 | "dev": true, 1620 | "requires": { 1621 | "has-flag": "^3.0.0" 1622 | } 1623 | }, 1624 | "table": { 1625 | "version": "5.2.3", 1626 | "resolved": "https://registry.npmjs.org/table/-/table-5.2.3.tgz", 1627 | "integrity": "sha512-N2RsDAMvDLvYwFcwbPyF3VmVSSkuF+G1e+8inhBLtHpvwXGw4QRPEZhihQNeEN0i1up6/f6ObCJXNdlRG3YVyQ==", 1628 | "dev": true, 1629 | "requires": { 1630 | "ajv": "^6.9.1", 1631 | "lodash": "^4.17.11", 1632 | "slice-ansi": "^2.1.0", 1633 | "string-width": "^3.0.0" 1634 | }, 1635 | "dependencies": { 1636 | "ansi-regex": { 1637 | "version": "4.1.0", 1638 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1639 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1640 | "dev": true 1641 | }, 1642 | "string-width": { 1643 | "version": "3.1.0", 1644 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1645 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1646 | "dev": true, 1647 | "requires": { 1648 | "emoji-regex": "^7.0.1", 1649 | "is-fullwidth-code-point": "^2.0.0", 1650 | "strip-ansi": "^5.1.0" 1651 | } 1652 | }, 1653 | "strip-ansi": { 1654 | "version": "5.2.0", 1655 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1656 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1657 | "dev": true, 1658 | "requires": { 1659 | "ansi-regex": "^4.1.0" 1660 | } 1661 | } 1662 | } 1663 | }, 1664 | "text-table": { 1665 | "version": "0.2.0", 1666 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1667 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1668 | "dev": true 1669 | }, 1670 | "through": { 1671 | "version": "2.3.8", 1672 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1673 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1674 | "dev": true 1675 | }, 1676 | "tmp": { 1677 | "version": "0.0.33", 1678 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 1679 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 1680 | "dev": true, 1681 | "requires": { 1682 | "os-tmpdir": "~1.0.2" 1683 | } 1684 | }, 1685 | "tslib": { 1686 | "version": "1.9.3", 1687 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz", 1688 | "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==", 1689 | "dev": true 1690 | }, 1691 | "type-check": { 1692 | "version": "0.3.2", 1693 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 1694 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 1695 | "dev": true, 1696 | "requires": { 1697 | "prelude-ls": "~1.1.2" 1698 | } 1699 | }, 1700 | "type-is": { 1701 | "version": "1.6.16", 1702 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.16.tgz", 1703 | "integrity": "sha512-HRkVv/5qY2G6I8iab9cI7v1bOIdhm94dVjQCPFElW9W+3GeDOSHmy2EBYe4VTApuzolPcmgFTN3ftVJRKR2J9Q==", 1704 | "requires": { 1705 | "media-typer": "0.3.0", 1706 | "mime-types": "~2.1.18" 1707 | } 1708 | }, 1709 | "unpipe": { 1710 | "version": "1.0.0", 1711 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1712 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 1713 | }, 1714 | "uri-js": { 1715 | "version": "4.2.2", 1716 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1717 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1718 | "dev": true, 1719 | "requires": { 1720 | "punycode": "^2.1.0" 1721 | } 1722 | }, 1723 | "utils-merge": { 1724 | "version": "1.0.1", 1725 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1726 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 1727 | }, 1728 | "validate-npm-package-license": { 1729 | "version": "3.0.4", 1730 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 1731 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 1732 | "dev": true, 1733 | "requires": { 1734 | "spdx-correct": "^3.0.0", 1735 | "spdx-expression-parse": "^3.0.0" 1736 | } 1737 | }, 1738 | "vary": { 1739 | "version": "1.1.2", 1740 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1741 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 1742 | }, 1743 | "which": { 1744 | "version": "1.3.1", 1745 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1746 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1747 | "dev": true, 1748 | "requires": { 1749 | "isexe": "^2.0.0" 1750 | } 1751 | }, 1752 | "wordwrap": { 1753 | "version": "1.0.0", 1754 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 1755 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 1756 | "dev": true 1757 | }, 1758 | "wrappy": { 1759 | "version": "1.0.2", 1760 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1761 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1762 | "dev": true 1763 | }, 1764 | "write": { 1765 | "version": "1.0.3", 1766 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 1767 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 1768 | "dev": true, 1769 | "requires": { 1770 | "mkdirp": "^0.5.1" 1771 | } 1772 | } 1773 | } 1774 | } 1775 | -------------------------------------------------------------------------------- /APIGateway/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "apigateway", 3 | "version": "1.0.0", 4 | "description": "Demo of API Gate for Micro Services", 5 | "main": "server.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1", 8 | "start": "node server.js", 9 | "lint": "eslint" 10 | }, 11 | "author": "Shashank Tiwari", 12 | "license": "MIT", 13 | "dependencies": { 14 | "dotenv": "^7.0.0", 15 | "express": "^4.16.3", 16 | "express-http-proxy": "^1.2.0" 17 | }, 18 | "devDependencies": { 19 | "eslint": "^5.16.0", 20 | "eslint-config-airbnb-base": "^13.1.0", 21 | "eslint-plugin-import": "^2.17.1" 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /APIGateway/routes.js: -------------------------------------------------------------------------------- 1 | const httpProxy = require('express-http-proxy'); 2 | 3 | const userServiceProxy = httpProxy('http://localhost:4000'); 4 | const productServiceProxy = httpProxy('http://localhost:3000'); 5 | const orderServiceProxy = httpProxy('http://localhost:2000'); 6 | 7 | class Routes { 8 | constructor(app) { 9 | this.app = app; 10 | } 11 | 12 | /* creating app Routes starts */ 13 | appRoutes() { 14 | this.app.get('/getUserDetails/:userId', (req, res) => { 15 | userServiceProxy(req, res); 16 | }); 17 | 18 | this.app.post('/register', (req, res) => { 19 | userServiceProxy(req, res); 20 | }); 21 | 22 | this.app.post('/login', (req, res) => { 23 | userServiceProxy(req, res); 24 | }); 25 | 26 | this.app.get('/product/:productId', (req, res) => { 27 | productServiceProxy(req, res); 28 | }); 29 | 30 | this.app.get('/product', (req, res) => { 31 | productServiceProxy(req, res); 32 | }); 33 | 34 | 35 | this.app.post('/order', (req, res) => { 36 | orderServiceProxy(req, res); 37 | }); 38 | 39 | this.app.get('/order', (req, res) => { 40 | orderServiceProxy(req, res); 41 | }); 42 | } 43 | 44 | routesConfig() { 45 | this.appRoutes(); 46 | } 47 | } 48 | 49 | module.exports = Routes; 50 | -------------------------------------------------------------------------------- /APIGateway/server.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable no-console */ 2 | const express = require('express'); 3 | const http = require('http'); 4 | 5 | const Routes = require('./routes'); 6 | 7 | class Server { 8 | constructor() { 9 | this.app = express(); 10 | this.http = http.Server(this.app); 11 | } 12 | 13 | /* Including app Routes starts */ 14 | includeRoutes() { 15 | new Routes(this.app).routesConfig(); 16 | } 17 | /* Including app Routes ends */ 18 | 19 | startTheServer() { 20 | this.includeRoutes(); 21 | 22 | const port = process.env.NODE_SERVER_POST || 8000; 23 | const host = process.env.NODE_SERVER_HOST || 'localhost'; 24 | 25 | this.http.listen(port, host, () => { 26 | console.log(`Listening on http://${host}:${port}`); 27 | }); 28 | } 29 | } 30 | 31 | module.exports = new Server(); -------------------------------------------------------------------------------- /OrderService/.env: -------------------------------------------------------------------------------- 1 | NODE_SERVER_POST=2000 2 | NODE_SERVER_HOST=localhost 3 | REDIS_DB_PORT=6379 4 | REDIS_DB_URL=127.0.0.1 5 | MONGODB_DB_URL=mongodb://127.0.0.1:27017/users 6 | JWT_SECRET=iosysmarketplace -------------------------------------------------------------------------------- /OrderService/.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | browser: true, 4 | commonjs: true, 5 | es6: true, 6 | }, 7 | extends: 'airbnb-base', 8 | globals: { 9 | Atomics: 'readonly', 10 | SharedArrayBuffer: 'readonly', 11 | }, 12 | parserOptions: { 13 | ecmaVersion: 2018, 14 | }, 15 | rules: { 16 | }, 17 | }; 18 | -------------------------------------------------------------------------------- /OrderService/README.md: -------------------------------------------------------------------------------- 1 | # User Service 2 | As the title suggests, This service will demonstrate the user related APIs. 3 | 4 | 5 | ## Installation 6 | 1. `Run install` 7 | 2. `node server.js` 8 | -------------------------------------------------------------------------------- /OrderService/config/app-config.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable class-methods-use-this */ 2 | /* eslint-disable no-console */ 3 | const bodyParser = require('body-parser'); 4 | const cors = require('cors'); 5 | const ExpressConfigModule = require('./express-config'); 6 | const JWT = require('./../utils/jwt'); 7 | 8 | class AppConfig { 9 | constructor(app) { 10 | process.on('unhandledRejection', (reason, p) => { 11 | console.log('Unhandled Rejection at: Promise', p, 'reason:', reason); 12 | // application specific logging, throwing an error, or other logic here 13 | }); 14 | this.app = app; 15 | } 16 | 17 | includeConfig() { 18 | this.loadAppLevelConfig(); 19 | this.loadExpressConfig(); 20 | } 21 | 22 | loadAppLevelConfig() { 23 | this.app.use( 24 | bodyParser.json(), 25 | ); 26 | this.app.use( 27 | cors(), 28 | ); 29 | } 30 | 31 | loadExpressConfig() { 32 | new ExpressConfigModule(this.app).setAppEngine(); 33 | new JWT(this.app).setJWTConfig(); 34 | } 35 | } 36 | module.exports = AppConfig; 37 | -------------------------------------------------------------------------------- /OrderService/config/constants.js: -------------------------------------------------------------------------------- 1 | /* HTTP status code constant starts */ 2 | module.exports.SERVER_ERROR_HTTP_CODE = 412; 3 | module.exports.SERVER_NOT_ALLOWED_HTTP_CODE = 503; 4 | module.exports.SERVER_OK_HTTP_CODE = 200; 5 | module.exports.SERVER_NOT_FOUND_HTTP_CODE = 404; 6 | module.exports.SERVER_INTERNAL_ERROR_HTTP_CODE = 500; 7 | /* HTTP status codeconstant ends */ 8 | 9 | /* General Errors and Routes messages constants start */ 10 | module.exports.ROUTE_NOT_FOUND = 'You are at wrong place. Shhoooo...'; 11 | module.exports.SERVER_ERROR_MESSAGE = 'Something bad happend. It\'s not you, it\'s me.'; 12 | 13 | /* Rest of constants and messages */ 14 | -------------------------------------------------------------------------------- /OrderService/config/db.js: -------------------------------------------------------------------------------- 1 | const mongodb = require('mongodb'); 2 | const redis = require('redis'); 3 | 4 | class MongoDB { 5 | constructor() { 6 | this.mongoClient = mongodb.MongoClient; 7 | this.ObjectID = mongodb.ObjectID; 8 | } 9 | 10 | onConnect() { 11 | return new Promise((resolve, reject) => { 12 | this.mongoClient.connect( 13 | process.env.MONGODB_DB_URL, { 14 | useNewUrlParser: true, 15 | }, 16 | (err, client) => { 17 | if (err) { 18 | reject(err); 19 | } else { 20 | resolve([client.db('users'), this.ObjectID, client]); 21 | } 22 | }, 23 | ); 24 | }); 25 | } 26 | } 27 | module.exports.MongoDB = new MongoDB(); 28 | module.exports.redisClient = redis.createClient(); 29 | -------------------------------------------------------------------------------- /OrderService/config/express-config.js: -------------------------------------------------------------------------------- 1 | class ExpressConfig { 2 | constructor(app) { 3 | this.app = app; 4 | } 5 | 6 | setAppEngine() { 7 | this.app.set('view engine', 'html'); 8 | } 9 | } 10 | module.exports = ExpressConfig; 11 | -------------------------------------------------------------------------------- /OrderService/handlers/api-handler.js: -------------------------------------------------------------------------------- 1 | /* 2 | * Building Micro Services in Nodejs 3 | * @author Shashank Tiwari 4 | */ 5 | 6 | 'use strict'; 7 | const axios = require('axios'); 8 | const CONSTANTS = require('./../config/constants'); 9 | 10 | class ApiHandler{ 11 | 12 | getUserInformation(userId){ 13 | return axios(`http://localhost:4000/getUserDetails/${userId}`); 14 | } 15 | 16 | async getProductInformation(productId){ 17 | return axios(`http://localhost:3000/product/${productId}`); 18 | } 19 | } 20 | 21 | module.exports = new ApiHandler(); 22 | -------------------------------------------------------------------------------- /OrderService/handlers/query-handler.js: -------------------------------------------------------------------------------- 1 | /* 2 | * Building Micro Services in Nodejs 3 | * @author Shashank Tiwari 4 | */ 5 | 'use strict'; 6 | const axios = require('axios'); 7 | 8 | const apiHandler = require('./api-handler'); 9 | 10 | class QueryHandler{ 11 | 12 | constructor(){ 13 | this.Mongodb = require("./../config/db"); 14 | this.projectedKeys = { 15 | "date": true, 16 | "delivery_date": true, 17 | "product_details": true, 18 | "user_details": true, 19 | '_id': false, 20 | 'orderId': '$_id' 21 | }; 22 | } 23 | 24 | /* 25 | * Name of the Method : createOrder 26 | * Description : Creates a new order in MOngoDB by consuming User Service API and Product Service API 27 | * Parameter : 28 | * 1) userId, productId 29 | * Return : Promise 30 | */ 31 | createOrder(userId, productId) { 32 | return new Promise( async (resolve, reject) => { 33 | try { 34 | const serviceResponse = await axios.all([ 35 | apiHandler.getUserInformation(userId), apiHandler.getProductInformation(productId) 36 | ]); 37 | const userDetail = serviceResponse[0].data; 38 | const productDetail = serviceResponse[1].data; 39 | if( userDetail.error ) { 40 | reject(`User Service is Down or not Working`); 41 | } else if (productDetail.error) { 42 | reject(`Product Service is Down or not Working`); 43 | } else { 44 | const orderObject = { 45 | date: new Date(Date.now()).toISOString(), 46 | delivery_date: new Date(new Date().getTime() + (24 * 60 * 60 * 1000)).toISOString(), 47 | product_details: productDetail.details, 48 | user_details: userDetail.details 49 | } 50 | const [DB, ObjectID, DBClient] = await this.Mongodb.onConnect(); 51 | DB.collection('order').insertOne( orderObject , (err, result) => { 52 | DBClient.close(); 53 | if (err) { 54 | reject(err); 55 | } 56 | resolve(result.insertedId); 57 | }); 58 | } 59 | } catch (error) { 60 | console.log('Error', error); 61 | reject(error) 62 | } 63 | }); 64 | } 65 | 66 | /* 67 | * Name of the Method : getOrders 68 | * Description : Fetchs the list of Orders 69 | * Parameter : None 70 | * Return : Promise 71 | */ 72 | getOrders() { 73 | return new Promise(async (resolve, reject) => { 74 | try { 75 | const [DB, ObjectID, DBClient] = await this.Mongodb.onConnect(); 76 | DB.collection('order').aggregate([{ 77 | $project: this.projectedKeys 78 | } 79 | ]).toArray((err, result) => { 80 | DBClient.close(); 81 | if (err) { 82 | reject(err); 83 | } else { 84 | resolve(result); 85 | } 86 | }); 87 | } catch (error) { 88 | reject(error) 89 | } 90 | }); 91 | } 92 | } 93 | 94 | module.exports = new QueryHandler(); 95 | -------------------------------------------------------------------------------- /OrderService/handlers/route-handler.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable class-methods-use-this */ 2 | const helper = require('./../handlers/query-handler'); 3 | const CONSTANTS = require('./../config/constants'); 4 | 5 | class RouteHandler { 6 | async createOrderRouteHandler(request, response) { 7 | const { productId } = request.body; 8 | const { userId } = request.body; 9 | if (productId === '') { 10 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 11 | error: true, 12 | message: CONSTANTS.PRODUCTID_NOT_FOUND, 13 | }); 14 | } else if (userId === '') { 15 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 16 | error: true, 17 | message: CONSTANTS.USERID_NOT_FOUND, 18 | }); 19 | } else { 20 | try { 21 | const orderId = await helper.createOrder(userId.trim(), productId.trim()); 22 | if (orderId === undefined || orderId === null) { 23 | response.status(CONSTANTS.SERVER_INTERNAL_ERROR_HTTP_CODE).json({ 24 | error: true, 25 | details: CONSTANTS.SERVER_ERROR_MESSAGE, 26 | }); 27 | } else { 28 | response.status(CONSTANTS.SERVER_OK_HTTP_CODE).json({ 29 | error: false, 30 | orderId, 31 | }); 32 | } 33 | } catch (error) { 34 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 35 | error: true, 36 | message: CONSTANTS.SERVER_ERROR_MESSAGE, 37 | }); 38 | } 39 | } 40 | } 41 | 42 | async getOrdersRouteHandler(request, response) { 43 | try { 44 | const orders = await helper.getOrders(); 45 | if (orders === undefined) { 46 | response.status(CONSTANTS.SERVER_NOT_FOUND_HTTP_CODE).json({ 47 | error: true, 48 | details: CONSTANTS.ORDER_DETAIL_FAILED, 49 | }); 50 | } else { 51 | response.status(CONSTANTS.SERVER_OK_HTTP_CODE).json({ 52 | error: false, 53 | details: orders, 54 | }); 55 | } 56 | } catch (error) { 57 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 58 | error: true, 59 | message: CONSTANTS.SERVER_ERROR_MESSAGE, 60 | }); 61 | } 62 | } 63 | 64 | routeNotFoundHandler(request, response) { 65 | response.status(CONSTANTS.SERVER_NOT_FOUND_HTTP_CODE).json({ 66 | error: true, 67 | message: CONSTANTS.ROUTE_NOT_FOUND, 68 | }); 69 | } 70 | } 71 | 72 | module.exports = new RouteHandler(); 73 | -------------------------------------------------------------------------------- /OrderService/index.js: -------------------------------------------------------------------------------- 1 | const DotEnv = require('dotenv'); 2 | 3 | DotEnv.config(); 4 | 5 | const Server = require('./server'); 6 | 7 | Server.startTheServer(); 8 | -------------------------------------------------------------------------------- /OrderService/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "userservice", 3 | "version": "1.0.0", 4 | "description": "This is a service to manage Order API", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1", 8 | "start": "node index.js", 9 | "lint": "eslint" 10 | }, 11 | "author": "Iosys Pvt Ltd", 12 | "license": "MIT", 13 | "dependencies": { 14 | "axios": "^0.18.0", 15 | "bcrypt": "^3.0.6", 16 | "body-parser": "^1.18.3", 17 | "cors": "^2.8.4", 18 | "dotenv": "^7.0.0", 19 | "express": "^4.16.3", 20 | "express-jwt": "^5.3.1", 21 | "mongodb": "^3.1.3", 22 | "redis": "^2.8.0" 23 | }, 24 | "devDependencies": { 25 | "eslint": "^5.16.0", 26 | "eslint-config-airbnb-base": "^13.1.0", 27 | "eslint-plugin-import": "^2.17.1" 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /OrderService/routes.js: -------------------------------------------------------------------------------- 1 | const routeHandler = require('./handlers/route-handler'); 2 | 3 | class Routes { 4 | constructor(app) { 5 | this.app = app; 6 | } 7 | 8 | /* creating app Routes starts */ 9 | appRoutes() { 10 | this.app.post('/order', routeHandler.createOrderRouteHandler); 11 | 12 | this.app.get('/order', routeHandler.getOrdersRouteHandler); 13 | 14 | this.app.get('*', routeHandler.routeNotFoundHandler); 15 | } 16 | 17 | routesConfig() { 18 | this.appRoutes(); 19 | } 20 | } 21 | module.exports = Routes; 22 | -------------------------------------------------------------------------------- /OrderService/server.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable no-console */ 2 | const express = require('express'); 3 | const http = require('http'); 4 | 5 | const AppConfig = require('./config/app-config'); 6 | const Routes = require('./routes'); 7 | 8 | class Server { 9 | constructor() { 10 | this.app = express(); 11 | this.http = http.Server(this.app); 12 | } 13 | 14 | appConfig() { 15 | new AppConfig(this.app).includeConfig(); 16 | } 17 | 18 | /* Including app Routes starts */ 19 | includeRoutes() { 20 | new Routes(this.app).routesConfig(); 21 | } 22 | /* Including app Routes ends */ 23 | 24 | startTheServer() { 25 | this.appConfig(); 26 | this.includeRoutes(); 27 | 28 | const port = process.env.NODE_SERVER_POST || 4000; 29 | const host = process.env.NODE_SERVER_HOST || 'localhost'; 30 | 31 | this.http.listen(port, host, () => { 32 | console.log(`Listening on http://${host}:${port}`); 33 | }); 34 | } 35 | } 36 | 37 | module.exports = new Server(); 38 | -------------------------------------------------------------------------------- /OrderService/utils/jwt-route.js: -------------------------------------------------------------------------------- 1 | module.exports = [ 2 | '/', 3 | '/order', 4 | ]; 5 | -------------------------------------------------------------------------------- /OrderService/utils/jwt.js: -------------------------------------------------------------------------------- 1 | const expressJwt = require('express-jwt'); 2 | const publicRoutes = require('./jwt-route'); 3 | 4 | class JWT { 5 | constructor(app) { 6 | this.app = app; 7 | } 8 | 9 | setJWTConfig() { 10 | this.app.use( 11 | expressJwt({ 12 | secret: process.env.JWT_SECRET, 13 | }).unless({ 14 | path: publicRoutes, 15 | }), 16 | ); 17 | } 18 | } 19 | 20 | 21 | module.exports = JWT; 22 | -------------------------------------------------------------------------------- /OrderService/utils/password-hash.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable class-methods-use-this */ 2 | const bcrypt = require('bcrypt'); 3 | 4 | class PasswordHash { 5 | createHash(password) { 6 | return bcrypt.hashSync(password, 10); 7 | } 8 | 9 | compareHash(password, hash) { 10 | return bcrypt.compareSync(password, hash); 11 | } 12 | } 13 | 14 | module.exports = new PasswordHash(); 15 | -------------------------------------------------------------------------------- /ProductService/.env: -------------------------------------------------------------------------------- 1 | NODE_SERVER_POST=3000 2 | NODE_SERVER_HOST=localhost 3 | REDIS_DB_PORT=6379 4 | REDIS_DB_URL=127.0.0.1 5 | MONGODB_DB_URL=mongodb://127.0.0.1:27017/users 6 | JWT_SECRET=iosysmarketplace -------------------------------------------------------------------------------- /ProductService/.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | browser: true, 4 | commonjs: true, 5 | es6: true, 6 | }, 7 | extends: 'airbnb-base', 8 | globals: { 9 | Atomics: 'readonly', 10 | SharedArrayBuffer: 'readonly', 11 | }, 12 | parserOptions: { 13 | ecmaVersion: 2018, 14 | }, 15 | rules: { 16 | }, 17 | }; 18 | -------------------------------------------------------------------------------- /ProductService/README.md: -------------------------------------------------------------------------------- 1 | # User Service 2 | As the title suggests, This service will demonstrate the user related APIs. 3 | 4 | 5 | ## Installation 6 | 1. `Run install` 7 | 2. `node server.js` 8 | -------------------------------------------------------------------------------- /ProductService/config/app-config.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable class-methods-use-this */ 2 | /* eslint-disable no-console */ 3 | const bodyParser = require('body-parser'); 4 | const cors = require('cors'); 5 | const ExpressConfigModule = require('./express-config'); 6 | const JWT = require('./../utils/jwt'); 7 | 8 | class AppConfig { 9 | constructor(app) { 10 | process.on('unhandledRejection', (reason, p) => { 11 | console.log('Unhandled Rejection at: Promise', p, 'reason:', reason); 12 | // application specific logging, throwing an error, or other logic here 13 | }); 14 | this.app = app; 15 | } 16 | 17 | includeConfig() { 18 | this.loadAppLevelConfig(); 19 | this.loadExpressConfig(); 20 | } 21 | 22 | loadAppLevelConfig() { 23 | this.app.use( 24 | bodyParser.json(), 25 | ); 26 | this.app.use( 27 | cors(), 28 | ); 29 | } 30 | 31 | loadExpressConfig() { 32 | new ExpressConfigModule(this.app).setAppEngine(); 33 | new JWT(this.app).setJWTConfig(); 34 | } 35 | } 36 | module.exports = AppConfig; 37 | -------------------------------------------------------------------------------- /ProductService/config/constants.js: -------------------------------------------------------------------------------- 1 | /* HTTP status code constant starts */ 2 | module.exports.SERVER_ERROR_HTTP_CODE = 412; 3 | module.exports.SERVER_NOT_ALLOWED_HTTP_CODE = 503; 4 | module.exports.SERVER_OK_HTTP_CODE = 200; 5 | module.exports.SERVER_NOT_FOUND_HTTP_CODE = 404; 6 | module.exports.SERVER_INTERNAL_ERROR_HTTP_CODE = 500; 7 | /* HTTP status codeconstant ends */ 8 | 9 | /* General Errors and Routes messages constants start */ 10 | module.exports.ROUTE_NOT_FOUND = 'You are at wrong place. Shhoooo...'; 11 | module.exports.SERVER_ERROR_MESSAGE = 'Something bad happend. It\'s not you, it\'s me.'; 12 | 13 | /* Rest of constants and messages */ 14 | -------------------------------------------------------------------------------- /ProductService/config/db.js: -------------------------------------------------------------------------------- 1 | const mongodb = require('mongodb'); 2 | const redis = require('redis'); 3 | 4 | class MongoDB { 5 | constructor() { 6 | this.mongoClient = mongodb.MongoClient; 7 | this.ObjectID = mongodb.ObjectID; 8 | } 9 | 10 | onConnect() { 11 | return new Promise((resolve, reject) => { 12 | this.mongoClient.connect( 13 | process.env.MONGODB_DB_URL, { 14 | useNewUrlParser: true, 15 | }, 16 | (err, client) => { 17 | if (err) { 18 | reject(err); 19 | } else { 20 | resolve([client.db('users'), this.ObjectID, client]); 21 | } 22 | }, 23 | ); 24 | }); 25 | } 26 | } 27 | module.exports.MongoDB = new MongoDB(); 28 | module.exports.redisClient = redis.createClient(); 29 | -------------------------------------------------------------------------------- /ProductService/config/express-config.js: -------------------------------------------------------------------------------- 1 | class ExpressConfig { 2 | constructor(app) { 3 | this.app = app; 4 | } 5 | 6 | setAppEngine() { 7 | this.app.set('view engine', 'html'); 8 | } 9 | } 10 | module.exports = ExpressConfig; 11 | -------------------------------------------------------------------------------- /ProductService/handlers/query-handler.js: -------------------------------------------------------------------------------- 1 | /* 2 | * Building Micro Services in Nodejs 3 | * @author Shashank Tiwari 4 | */ 5 | 'use strict'; 6 | 7 | class QueryHandler{ 8 | 9 | constructor(){ 10 | this.Mongodb = require("./../config/db"); 11 | this.projectedKeys = { 12 | "name": true, 13 | "price": true, 14 | "description": true, 15 | "image": true, 16 | "sku": true, 17 | '_id': false, 18 | 'id': '$_id' 19 | }; 20 | } 21 | 22 | /* 23 | * Name of the Method : getProductDetail 24 | * Description : Fetchs the product details using product id 25 | * Parameter : 26 | * 1) product Id 27 | * Return : Promise 28 | */ 29 | getProductDetail(productId) { 30 | return new Promise( async (resolve, reject) => { 31 | try { 32 | const [DB, ObjectID, DBClient] = await this.Mongodb.onConnect(); 33 | DB.collection('product').aggregate([ 34 | { 35 | $match: { '_id': ObjectID(productId) } 36 | }, 37 | { 38 | $project: this.projectedKeys 39 | } 40 | ]).toArray( (error, result) => { 41 | DBClient.close(); 42 | if( error ){ 43 | reject(error); 44 | } 45 | let userDetails = null; 46 | if (result.length > 0) { 47 | userDetails = result[0]; 48 | } 49 | resolve(userDetails); 50 | }); 51 | } catch (error) { 52 | reject(error) 53 | } 54 | }); 55 | } 56 | 57 | /* 58 | * Name of the Method : getProductDetail 59 | * Description : Fetchs the lis of products 60 | * Parameter : None 61 | * Return : Promise 62 | */ 63 | getProducts() { 64 | return new Promise(async (resolve, reject) => { 65 | try { 66 | const [DB, ObjectID, DBClient] = await this.Mongodb.onConnect(); 67 | DB.collection('product').aggregate([{ 68 | $project: this.projectedKeys 69 | } 70 | ]).toArray((err, result) => { 71 | DBClient.close(); 72 | if (err) { 73 | reject(err); 74 | } else { 75 | resolve(result); 76 | } 77 | }); 78 | } catch (error) { 79 | reject(error) 80 | } 81 | }); 82 | } 83 | } 84 | 85 | module.exports = new QueryHandler(); 86 | -------------------------------------------------------------------------------- /ProductService/handlers/route-handler.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable class-methods-use-this */ 2 | const helper = require('./../handlers/query-handler'); 3 | const CONSTANTS = require('./../config/constants'); 4 | 5 | class RouteHandler { 6 | async getProductDetailHandler(request, response) { 7 | const { productId } = request.params; 8 | if (productId === '') { 9 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 10 | error: true, 11 | message: CONSTANTS.PRODUCTID_NOT_FOUND, 12 | }); 13 | } else { 14 | try { 15 | const productDetails = await helper.getProductDetail(productId.trim()); 16 | if (productDetails === undefined) { 17 | response.status(CONSTANTS.SERVER_NOT_FOUND_HTTP_CODE).json({ 18 | error: true, 19 | details: CONSTANTS.PRODUCT_DETAIL_FAILED, 20 | }); 21 | } else { 22 | response.status(CONSTANTS.SERVER_OK_HTTP_CODE).json({ 23 | error: false, 24 | details: productDetails, 25 | }); 26 | } 27 | } catch (error) { 28 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 29 | error: true, 30 | message: CONSTANTS.SERVER_ERROR_MESSAGE, 31 | }); 32 | } 33 | } 34 | } 35 | 36 | async getProductsRouteHandler(request, response) { 37 | try { 38 | const productDetails = await helper.getProducts(); 39 | if (productDetails === undefined) { 40 | response.status(CONSTANTS.SERVER_NOT_FOUND_HTTP_CODE).json({ 41 | error: true, 42 | details: CONSTANTS.PRODUCT_DETAIL_FAILED, 43 | }); 44 | } else { 45 | response.status(CONSTANTS.SERVER_OK_HTTP_CODE).json({ 46 | error: false, 47 | details: productDetails, 48 | }); 49 | } 50 | } catch (error) { 51 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 52 | error: true, 53 | message: CONSTANTS.SERVER_ERROR_MESSAGE, 54 | }); 55 | } 56 | } 57 | 58 | routeNotFoundHandler(request, response) { 59 | response.status(CONSTANTS.SERVER_NOT_FOUND_HTTP_CODE).json({ 60 | error: true, 61 | message: CONSTANTS.ROUTE_NOT_FOUND, 62 | }); 63 | } 64 | } 65 | 66 | module.exports = new RouteHandler(); 67 | -------------------------------------------------------------------------------- /ProductService/index.js: -------------------------------------------------------------------------------- 1 | const DotEnv = require('dotenv'); 2 | 3 | DotEnv.config(); 4 | 5 | const Server = require('./server'); 6 | 7 | Server.startTheServer(); 8 | -------------------------------------------------------------------------------- /ProductService/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "userservice", 3 | "version": "1.0.0", 4 | "description": "This is a service to manage Products API", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1", 8 | "start": "node index.js", 9 | "lint": "eslint" 10 | }, 11 | "author": "Iosys Pvt Ltd", 12 | "license": "MIT", 13 | "dependencies": { 14 | "bcrypt": "^3.0.6", 15 | "body-parser": "^1.18.3", 16 | "cors": "^2.8.4", 17 | "dotenv": "^7.0.0", 18 | "express": "^4.16.3", 19 | "express-jwt": "^5.3.1", 20 | "mongodb": "^3.1.3", 21 | "redis": "^2.8.0" 22 | }, 23 | "devDependencies": { 24 | "eslint": "^5.16.0", 25 | "eslint-config-airbnb-base": "^13.1.0", 26 | "eslint-plugin-import": "^2.17.1" 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /ProductService/routes.js: -------------------------------------------------------------------------------- 1 | const routeHandler = require('./handlers/route-handler'); 2 | 3 | class Routes { 4 | constructor(app) { 5 | this.app = app; 6 | } 7 | 8 | /* creating app Routes starts */ 9 | appRoutes() { 10 | this.app.get('/product/:productId', routeHandler.getProductDetailHandler); 11 | 12 | this.app.get('/product', routeHandler.getProductsRouteHandler); 13 | 14 | this.app.get('*', routeHandler.routeNotFoundHandler); 15 | } 16 | 17 | routesConfig() { 18 | this.appRoutes(); 19 | } 20 | } 21 | module.exports = Routes; 22 | -------------------------------------------------------------------------------- /ProductService/server.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable no-console */ 2 | const express = require('express'); 3 | const http = require('http'); 4 | 5 | const AppConfig = require('./config/app-config'); 6 | const Routes = require('./routes'); 7 | 8 | class Server { 9 | constructor() { 10 | this.app = express(); 11 | this.http = http.Server(this.app); 12 | } 13 | 14 | appConfig() { 15 | new AppConfig(this.app).includeConfig(); 16 | } 17 | 18 | /* Including app Routes starts */ 19 | includeRoutes() { 20 | new Routes(this.app).routesConfig(); 21 | } 22 | /* Including app Routes ends */ 23 | 24 | startTheServer() { 25 | this.appConfig(); 26 | this.includeRoutes(); 27 | 28 | const port = process.env.NODE_SERVER_POST || 4000; 29 | const host = process.env.NODE_SERVER_HOST || 'localhost'; 30 | 31 | this.http.listen(port, host, () => { 32 | console.log(`Listening on http://${host}:${port}`); 33 | }); 34 | } 35 | } 36 | 37 | module.exports = new Server(); 38 | -------------------------------------------------------------------------------- /ProductService/utils/jwt-route.js: -------------------------------------------------------------------------------- 1 | module.exports = [ 2 | '/', 3 | '/product', 4 | '/product/productId', 5 | ]; 6 | -------------------------------------------------------------------------------- /ProductService/utils/jwt.js: -------------------------------------------------------------------------------- 1 | const expressJwt = require('express-jwt'); 2 | const publicRoutes = require('./jwt-route'); 3 | 4 | class JWT { 5 | constructor(app) { 6 | this.app = app; 7 | } 8 | 9 | setJWTConfig() { 10 | this.app.use( 11 | expressJwt({ 12 | secret: process.env.JWT_SECRET, 13 | }).unless({ 14 | path: publicRoutes, 15 | }), 16 | ); 17 | } 18 | } 19 | 20 | 21 | module.exports = JWT; 22 | -------------------------------------------------------------------------------- /ProductService/utils/password-hash.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable class-methods-use-this */ 2 | const bcrypt = require('bcrypt'); 3 | 4 | class PasswordHash { 5 | createHash(password) { 6 | return bcrypt.hashSync(password, 10); 7 | } 8 | 9 | compareHash(password, hash) { 10 | return bcrypt.compareSync(password, hash); 11 | } 12 | } 13 | 14 | module.exports = new PasswordHash(); 15 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Microservices in Nodejs 2 | This project is basic demo of Microservices in Nodejs, Along with API gatway. In this project we have three Microservices, as slisted below 3 | 1. [User Service](https://github.com/ShankyTiwari/Microservices-in-Nodejs/tree/master/UserService) 4 | 2. [Product Service](https://github.com/ShankyTiwari/Microservices-in-Nodejs/tree/master/ProductService) 5 | 3. [Order Service](https://github.com/ShankyTiwari/Microservices-in-Nodejs/tree/master/OrderService) 6 | 7 | ## User Service 8 | This service will implement the User related APIs. 9 | 10 | ## Product Service 11 | This service will implement the Product related APIs. 12 | 13 | ## Order Service 14 | This service will implement the Order related APIs. 15 | 16 | ## API gateway 17 | An [API Gateway](https://github.com/ShankyTiwari/Microservices-in-Nodejs/tree/master/APIGateway) where you will add Rate Limit and other Authentications. 18 | -------------------------------------------------------------------------------- /UserService/.env: -------------------------------------------------------------------------------- 1 | NODE_SERVER_POST=4000 2 | NODE_SERVER_HOST=localhost 3 | REDIS_DB_PORT=6379 4 | REDIS_DB_URL=127.0.0.1 5 | MONGODB_DB_URL=mongodb://127.0.0.1:27017/users 6 | JWT_SECRET=iosysmarketplace -------------------------------------------------------------------------------- /UserService/.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | browser: true, 4 | commonjs: true, 5 | es6: true, 6 | }, 7 | extends: 'airbnb-base', 8 | globals: { 9 | Atomics: 'readonly', 10 | SharedArrayBuffer: 'readonly', 11 | }, 12 | parserOptions: { 13 | ecmaVersion: 2018, 14 | }, 15 | rules: { 16 | }, 17 | }; 18 | -------------------------------------------------------------------------------- /UserService/README.md: -------------------------------------------------------------------------------- 1 | # User Service Testing Git Merge 2 | As the title suggests, This service will demonstrate the user related APIs. 3 | 4 | 5 | ## Installation 6 | 1. `Run install` 7 | 2. `node server.js` 8 | -------------------------------------------------------------------------------- /UserService/config/app-config.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable class-methods-use-this */ 2 | /* eslint-disable no-console */ 3 | const bodyParser = require('body-parser'); 4 | const cors = require('cors'); 5 | const ExpressConfigModule = require('./express-config'); 6 | const JWT = require('./../utils/jwt'); 7 | 8 | class AppConfig { 9 | constructor(app) { 10 | process.on('unhandledRejection', (reason, p) => { 11 | console.log('Unhandled Rejection at: Promise', p, 'reason:', reason); 12 | // application specific logging, throwing an error, or other logic here 13 | }); 14 | this.app = app; 15 | } 16 | 17 | includeConfig() { 18 | this.loadAppLevelConfig(); 19 | this.loadExpressConfig(); 20 | } 21 | 22 | loadAppLevelConfig() { 23 | this.app.use( 24 | bodyParser.json(), 25 | ); 26 | this.app.use( 27 | cors(), 28 | ); 29 | } 30 | 31 | loadExpressConfig() { 32 | new ExpressConfigModule(this.app).setAppEngine(); 33 | new JWT(this.app).setJWTConfig(); 34 | } 35 | } 36 | module.exports = AppConfig; 37 | -------------------------------------------------------------------------------- /UserService/config/constants.js: -------------------------------------------------------------------------------- 1 | /* Validation related constants starts */ 2 | module.exports.PASSWORD_NOT_FOUND = 'password can\'t be empty.'; 3 | module.exports.USERNAME_NOT_FOUND = 'User name can\'t be empty.'; 4 | module.exports.USERLASTNAME_NOT_FOUND = 'User last name can\'t be empty.'; 5 | module.exports.USERID_NOT_FOUND = 'User Id can\'t be empty.'; 6 | module.exports.EMAIL_NOT_FOUND = 'Email can\'t be empty.'; 7 | module.exports.GENDER_NOT_FOUND = 'Gender can\'t be empty.'; 8 | module.exports.PASSWORD_NOT_FOUND = 'Password can\'t be empty.'; 9 | module.exports.USER_NOT_FOUND = 'User does not exits.'; 10 | /* Validation related constants ends */ 11 | 12 | /* General Errors constants start */ 13 | module.exports.ROUTE_NOT_FOUND = 'You are at wrong place. Shhoooo...'; 14 | module.exports.SERVER_ERROR_MESSAGE = 'Something bad happend. It\'s not you, it\'s me.'; 15 | 16 | /* HTTP status code constant starts */ 17 | module.exports.SERVER_ERROR_HTTP_CODE = 412; 18 | module.exports.SERVER_NOT_ALLOWED_HTTP_CODE = 503; 19 | module.exports.SERVER_OK_HTTP_CODE = 200; 20 | module.exports.SERVER_NOT_FOUND_HTTP_CODE = 404; 21 | module.exports.SERVER_INTERNAL_ERROR_HTTP_CODE = 500; 22 | /* HTTP status codeconstant ends */ 23 | 24 | /* Route related constants starts */ 25 | module.exports.USER_REGISTRATION_OK = 'User registration successful.'; 26 | module.exports.USER_REGISTRATION_FAILED = 'User registration unsuccessful.'; 27 | module.exports.USER_LOGIN_OK = 'User logged in.'; 28 | module.exports.USER_LOGIN_FAILED = 'User not found.'; 29 | /* Route related constants ends */ 30 | -------------------------------------------------------------------------------- /UserService/config/db.js: -------------------------------------------------------------------------------- 1 | const mongodb = require('mongodb'); 2 | const redis = require('redis'); 3 | 4 | class MongoDB { 5 | constructor() { 6 | this.mongoClient = mongodb.MongoClient; 7 | this.ObjectID = mongodb.ObjectID; 8 | } 9 | 10 | onConnect() { 11 | return new Promise((resolve, reject) => { 12 | this.mongoClient.connect( 13 | process.env.MONGODB_DB_URL, { 14 | useNewUrlParser: true, 15 | }, 16 | (err, client) => { 17 | if (err) { 18 | reject(err); 19 | } else { 20 | resolve([client.db('users'), this.ObjectID, client]); 21 | } 22 | }, 23 | ); 24 | }); 25 | } 26 | } 27 | module.exports.MongoDB = new MongoDB(); 28 | module.exports.redisClient = redis.createClient(); 29 | -------------------------------------------------------------------------------- /UserService/config/express-config.js: -------------------------------------------------------------------------------- 1 | class ExpressConfig { 2 | constructor(app) { 3 | this.app = app; 4 | } 5 | 6 | setAppEngine() { 7 | this.app.set('view engine', 'html'); 8 | } 9 | } 10 | module.exports = ExpressConfig; 11 | -------------------------------------------------------------------------------- /UserService/handlers/query-handler.js: -------------------------------------------------------------------------------- 1 | const Mongodb = require('./../config/db'); 2 | 3 | class QueryHandler { 4 | constructor() { 5 | this.Mongodb = Mongodb; 6 | } 7 | 8 | login(data) { 9 | return new Promise(async (resolve, reject) => { 10 | try { 11 | const [DB, ObjectID, DBClient] = await this.Mongodb.onConnect(); 12 | DB.collection('user').findOneAndUpdate( 13 | data, 14 | { 15 | $set: { 16 | online: 'Y', 17 | }, 18 | }, 19 | (error, result) => { 20 | DBClient.close(); 21 | if (error) { 22 | reject(error); 23 | } 24 | result.lastErrorObject.updatedExisting ? resolve(result.value._id) : resolve(null); 25 | }, 26 | ); 27 | } catch (error) { 28 | reject(error); 29 | } 30 | }); 31 | } 32 | 33 | 34 | getUserDetails(userId) { 35 | return new Promise(async (resolve, reject) => { 36 | try { 37 | const [DB, ObjectID, DBClient] = await this.Mongodb.onConnect(); 38 | DB.collection('user').aggregate([ 39 | { 40 | $match: { _id: ObjectID(userId) }, 41 | }, 42 | { 43 | $project: { 44 | name: true, 45 | email: true, 46 | lastname: true, 47 | online: true, 48 | _id: false, 49 | id: '$_id', 50 | }, 51 | }, 52 | ]).toArray((error, result) => { 53 | DBClient.close(); 54 | if (error) { 55 | reject(error); 56 | } 57 | let userDetails = null; 58 | if (result.length > 0) { 59 | userDetails = result[0]; 60 | } 61 | resolve(userDetails); 62 | }); 63 | } catch (error) { 64 | reject(error); 65 | } 66 | }); 67 | } 68 | 69 | registerUser(data) { 70 | return new Promise(async (resolve, reject) => { 71 | try { 72 | const [DB, ObjectID, DBClient] = await this.Mongodb.onConnect(); 73 | DB.collection('user').insertOne(data, (err, result) => { 74 | DBClient.close(); 75 | if (err) { 76 | reject(err); 77 | } 78 | resolve(result); 79 | }); 80 | } catch (error) { 81 | reject(error); 82 | } 83 | }); 84 | } 85 | } 86 | 87 | module.exports = new QueryHandler(); 88 | -------------------------------------------------------------------------------- /UserService/handlers/route-handler.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable class-methods-use-this */ 2 | const helper = require('./../handlers/query-handler'); 3 | const CONSTANTS = require('./../config/constants'); 4 | 5 | class RouteHandler { 6 | async getUserDetailsHandler(request, response) { 7 | const userid = request.params.userId; 8 | if (userid === '') { 9 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 10 | error: true, 11 | message: CONSTANTS.USERID_NOT_FOUND, 12 | }); 13 | } else { 14 | try { 15 | const userDetails = await helper.getUserDetails(userid.trim()); 16 | if (userDetails === undefined) { 17 | response.status(CONSTANTS.SERVER_NOT_FOUND_HTTP_CODE).json({ 18 | error: true, 19 | details: CONSTANTS.USERNAME_DETAIL_FAILED, 20 | }); 21 | } else { 22 | response.status(CONSTANTS.SERVER_OK_HTTP_CODE).json({ 23 | error: false, 24 | details: userDetails, 25 | }); 26 | } 27 | } catch (error) { 28 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 29 | error: true, 30 | message: CONSTANTS.SERVER_ERROR_MESSAGE, 31 | }); 32 | } 33 | } 34 | } 35 | 36 | async loginRouteHandler(request, response) { 37 | const data = { 38 | name: request.body.name === '' || request.body.name === undefined ? null : (request.body.name).trim(), 39 | password: request.body.password === '' || request.body.password === undefined ? null : request.body.password.trim(), 40 | }; 41 | if (data.name === '' || data.name === null) { 42 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 43 | error: true, 44 | message: CONSTANTS.USERNAME_NOT_FOUND, 45 | }); 46 | } else if (data.password === '' || data.password === null) { 47 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 48 | error: true, 49 | message: CONSTANTS.PASSWORD_NOT_FOUND, 50 | }); 51 | } else { 52 | try { 53 | const result = await helper.login(data); 54 | if (result === null || result === undefined) { 55 | response.status(CONSTANTS.SERVER_NOT_FOUND_HTTP_CODE).json({ 56 | error: true, 57 | message: CONSTANTS.USER_LOGIN_FAILED, 58 | }); 59 | } else { 60 | response.status(CONSTANTS.SERVER_NOT_FOUND_HTTP_CODE).json({ 61 | error: false, 62 | userId: result, 63 | message: CONSTANTS.USER_LOGIN_OK, 64 | }); 65 | } 66 | } catch (error) { 67 | response.status(CONSTANTS.SERVER_NOT_FOUND_HTTP_CODE).json({ 68 | error: true, 69 | message: CONSTANTS.USER_LOGIN_FAILED, 70 | }); 71 | } 72 | } 73 | } 74 | 75 | async registerRouteHandler(request, response) { 76 | const data = { 77 | name: request.body.name === '' || request.body.name === undefined ? null : (request.body.name).trim(), 78 | lastname: request.body.lastname === '' || request.body.lastname === undefined ? null : request.body.lastname.trim(), 79 | email: request.body.email === '' || request.body.email === undefined ? null : request.body.email.trim(), 80 | gender: request.body.gender === '' || request.body.gender === undefined ? null : request.body.gender.trim(), 81 | password: request.body.password === '' || request.body.password === undefined ? null : request.body.password.trim(), 82 | }; 83 | if (data.name === '' || data.name === null) { 84 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 85 | error: true, 86 | message: CONSTANTS.USERNAME_NOT_FOUND, 87 | }); 88 | } else if (data.lastname === '' || data.lastname === null) { 89 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 90 | error: true, 91 | message: CONSTANTS.USERLASTNAME_NOT_FOUND, 92 | }); 93 | } else if (data.email === '' || data.email === null) { 94 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 95 | error: true, 96 | message: CONSTANTS.EMAIL_NOT_FOUND, 97 | }); 98 | } else if (data.gender === '' || data.gender === null) { 99 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 100 | error: true, 101 | message: CONSTANTS.PASSWORD_NOT_FOUND, 102 | }); 103 | } else if (data.password === '' || data.password === null) { 104 | response.status(CONSTANTS.SERVER_ERROR_HTTP_CODE).json({ 105 | error: true, 106 | message: CONSTANTS.PASSWORD_NOT_FOUND, 107 | }); 108 | } else { 109 | try { 110 | data.online = 'Y'; 111 | const result = await helper.registerUser(data); 112 | if (result === null || result === undefined) { 113 | response.status(CONSTANTS.SERVER_INTERNAL_ERROR_HTTP_CODE).json({ 114 | error: false, 115 | message: CONSTANTS.USER_REGISTRATION_FAILED, 116 | }); 117 | } else { 118 | response.status(CONSTANTS.SERVER_OK_HTTP_CODE).json({ 119 | error: false, 120 | userId: result.insertedId, 121 | message: CONSTANTS.USER_REGISTRATION_OK, 122 | }); 123 | } 124 | } catch (error) { 125 | response.status(CONSTANTS.SERVER_NOT_FOUND_HTTP_CODE).json({ 126 | error: true, 127 | message: CONSTANTS.SERVER_ERROR_MESSAGE, 128 | }); 129 | } 130 | } 131 | } 132 | 133 | routeNotFoundHandler(request, response) { 134 | response.status(CONSTANTS.SERVER_NOT_FOUND_HTTP_CODE).json({ 135 | error: true, 136 | message: CONSTANTS.ROUTE_NOT_FOUND, 137 | }); 138 | } 139 | } 140 | 141 | module.exports = new RouteHandler(); 142 | -------------------------------------------------------------------------------- /UserService/index.js: -------------------------------------------------------------------------------- 1 | const DotEnv = require('dotenv'); 2 | 3 | DotEnv.config(); 4 | 5 | const Server = require('./server'); 6 | 7 | Server.startTheServer(); 8 | -------------------------------------------------------------------------------- /UserService/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "userservice", 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 | }, 27 | "abbrev": { 28 | "version": "1.1.1", 29 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 30 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 31 | }, 32 | "accepts": { 33 | "version": "1.3.5", 34 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz", 35 | "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=", 36 | "requires": { 37 | "mime-types": "~2.1.18", 38 | "negotiator": "0.6.1" 39 | } 40 | }, 41 | "acorn": { 42 | "version": "6.1.1", 43 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.1.1.tgz", 44 | "integrity": "sha512-jPTiwtOxaHNaAPg/dmrJ/beuzLRnXtB0kQPQ8JpotKJgTB6rX6c8mlf315941pyjBSaPg8NHXS9fhP4u17DpGA==", 45 | "dev": true 46 | }, 47 | "acorn-jsx": { 48 | "version": "5.0.1", 49 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", 50 | "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==", 51 | "dev": true 52 | }, 53 | "ajv": { 54 | "version": "6.10.0", 55 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.0.tgz", 56 | "integrity": "sha512-nffhOpkymDECQyR0mnsUtoCE8RlX38G0rYP+wgLWFyZuUyuuojSSvi/+euOiQBIn63whYwYVIIH1TvE3tu4OEg==", 57 | "dev": true, 58 | "requires": { 59 | "fast-deep-equal": "^2.0.1", 60 | "fast-json-stable-stringify": "^2.0.0", 61 | "json-schema-traverse": "^0.4.1", 62 | "uri-js": "^4.2.2" 63 | } 64 | }, 65 | "ansi-escapes": { 66 | "version": "3.2.0", 67 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", 68 | "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==", 69 | "dev": true 70 | }, 71 | "ansi-regex": { 72 | "version": "3.0.0", 73 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 74 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 75 | }, 76 | "ansi-styles": { 77 | "version": "3.2.1", 78 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 79 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 80 | "dev": true, 81 | "requires": { 82 | "color-convert": "^1.9.0" 83 | } 84 | }, 85 | "aproba": { 86 | "version": "1.2.0", 87 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 88 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" 89 | }, 90 | "are-we-there-yet": { 91 | "version": "1.1.5", 92 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", 93 | "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", 94 | "requires": { 95 | "delegates": "^1.0.0", 96 | "readable-stream": "^2.0.6" 97 | } 98 | }, 99 | "argparse": { 100 | "version": "1.0.10", 101 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 102 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 103 | "dev": true, 104 | "requires": { 105 | "sprintf-js": "~1.0.2" 106 | } 107 | }, 108 | "array-flatten": { 109 | "version": "1.1.1", 110 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 111 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 112 | }, 113 | "array-includes": { 114 | "version": "3.0.3", 115 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.0.3.tgz", 116 | "integrity": "sha1-GEtI9i2S10UrsxsyMWXH+L0CJm0=", 117 | "dev": true, 118 | "requires": { 119 | "define-properties": "^1.1.2", 120 | "es-abstract": "^1.7.0" 121 | } 122 | }, 123 | "astral-regex": { 124 | "version": "1.0.0", 125 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 126 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 127 | "dev": true 128 | }, 129 | "async": { 130 | "version": "1.5.2", 131 | "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz", 132 | "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo=" 133 | }, 134 | "balanced-match": { 135 | "version": "1.0.0", 136 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 137 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 138 | }, 139 | "bcrypt": { 140 | "version": "3.0.6", 141 | "resolved": "https://registry.npmjs.org/bcrypt/-/bcrypt-3.0.6.tgz", 142 | "integrity": "sha512-taA5bCTfXe7FUjKroKky9EXpdhkVvhE5owfxfLYodbrAR1Ul3juLmIQmIQBK4L9a5BuUcE6cqmwT+Da20lF9tg==", 143 | "requires": { 144 | "nan": "2.13.2", 145 | "node-pre-gyp": "0.12.0" 146 | } 147 | }, 148 | "body-parser": { 149 | "version": "1.18.3", 150 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.3.tgz", 151 | "integrity": "sha1-WykhmP/dVTs6DyDe0FkrlWlVyLQ=", 152 | "requires": { 153 | "bytes": "3.0.0", 154 | "content-type": "~1.0.4", 155 | "debug": "2.6.9", 156 | "depd": "~1.1.2", 157 | "http-errors": "~1.6.3", 158 | "iconv-lite": "0.4.23", 159 | "on-finished": "~2.3.0", 160 | "qs": "6.5.2", 161 | "raw-body": "2.3.3", 162 | "type-is": "~1.6.16" 163 | } 164 | }, 165 | "brace-expansion": { 166 | "version": "1.1.11", 167 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 168 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 169 | "requires": { 170 | "balanced-match": "^1.0.0", 171 | "concat-map": "0.0.1" 172 | } 173 | }, 174 | "bson": { 175 | "version": "1.1.0", 176 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.0.tgz", 177 | "integrity": "sha512-9Aeai9TacfNtWXOYarkFJRW2CWo+dRon+fuLZYJmvLV3+MiUp0bEI6IAZfXEIg7/Pl/7IWlLaDnhzTsD81etQA==" 178 | }, 179 | "buffer-equal-constant-time": { 180 | "version": "1.0.1", 181 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 182 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 183 | }, 184 | "bytes": { 185 | "version": "3.0.0", 186 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", 187 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" 188 | }, 189 | "callsites": { 190 | "version": "3.1.0", 191 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 192 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 193 | "dev": true 194 | }, 195 | "chalk": { 196 | "version": "2.4.2", 197 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 198 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 199 | "dev": true, 200 | "requires": { 201 | "ansi-styles": "^3.2.1", 202 | "escape-string-regexp": "^1.0.5", 203 | "supports-color": "^5.3.0" 204 | } 205 | }, 206 | "chardet": { 207 | "version": "0.7.0", 208 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 209 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 210 | "dev": true 211 | }, 212 | "chownr": { 213 | "version": "1.1.1", 214 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.1.tgz", 215 | "integrity": "sha512-j38EvO5+LHX84jlo6h4UzmOwi0UgW61WRyPtJz4qaadK5eY3BTS5TY/S1Stc3Uk2lIM6TPevAlULiEJwie860g==" 216 | }, 217 | "cli-cursor": { 218 | "version": "2.1.0", 219 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 220 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 221 | "dev": true, 222 | "requires": { 223 | "restore-cursor": "^2.0.0" 224 | } 225 | }, 226 | "cli-width": { 227 | "version": "2.2.0", 228 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 229 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 230 | "dev": true 231 | }, 232 | "code-point-at": { 233 | "version": "1.1.0", 234 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 235 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 236 | }, 237 | "color-convert": { 238 | "version": "1.9.3", 239 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 240 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 241 | "dev": true, 242 | "requires": { 243 | "color-name": "1.1.3" 244 | } 245 | }, 246 | "color-name": { 247 | "version": "1.1.3", 248 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 249 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 250 | "dev": true 251 | }, 252 | "concat-map": { 253 | "version": "0.0.1", 254 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 255 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 256 | }, 257 | "console-control-strings": { 258 | "version": "1.1.0", 259 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 260 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" 261 | }, 262 | "contains-path": { 263 | "version": "0.1.0", 264 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 265 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 266 | "dev": true 267 | }, 268 | "content-disposition": { 269 | "version": "0.5.2", 270 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", 271 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=" 272 | }, 273 | "content-type": { 274 | "version": "1.0.4", 275 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 276 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 277 | }, 278 | "cookie": { 279 | "version": "0.3.1", 280 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 281 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=" 282 | }, 283 | "cookie-signature": { 284 | "version": "1.0.6", 285 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 286 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 287 | }, 288 | "core-util-is": { 289 | "version": "1.0.2", 290 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 291 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 292 | }, 293 | "cors": { 294 | "version": "2.8.4", 295 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.4.tgz", 296 | "integrity": "sha1-K9OB8usgECAQXNUOpZ2mMJBpRoY=", 297 | "requires": { 298 | "object-assign": "^4", 299 | "vary": "^1" 300 | } 301 | }, 302 | "cross-spawn": { 303 | "version": "6.0.5", 304 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 305 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 306 | "dev": true, 307 | "requires": { 308 | "nice-try": "^1.0.4", 309 | "path-key": "^2.0.1", 310 | "semver": "^5.5.0", 311 | "shebang-command": "^1.2.0", 312 | "which": "^1.2.9" 313 | } 314 | }, 315 | "debug": { 316 | "version": "2.6.9", 317 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 318 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 319 | "requires": { 320 | "ms": "2.0.0" 321 | } 322 | }, 323 | "deep-extend": { 324 | "version": "0.6.0", 325 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 326 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==" 327 | }, 328 | "deep-is": { 329 | "version": "0.1.3", 330 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 331 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 332 | "dev": true 333 | }, 334 | "define-properties": { 335 | "version": "1.1.3", 336 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 337 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 338 | "dev": true, 339 | "requires": { 340 | "object-keys": "^1.0.12" 341 | } 342 | }, 343 | "delegates": { 344 | "version": "1.0.0", 345 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 346 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" 347 | }, 348 | "depd": { 349 | "version": "1.1.2", 350 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 351 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 352 | }, 353 | "destroy": { 354 | "version": "1.0.4", 355 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 356 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 357 | }, 358 | "detect-libc": { 359 | "version": "1.0.3", 360 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz", 361 | "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=" 362 | }, 363 | "doctrine": { 364 | "version": "3.0.0", 365 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 366 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 367 | "dev": true, 368 | "requires": { 369 | "esutils": "^2.0.2" 370 | } 371 | }, 372 | "dotenv": { 373 | "version": "7.0.0", 374 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-7.0.0.tgz", 375 | "integrity": "sha512-M3NhsLbV1i6HuGzBUH8vXrtxOk+tWmzWKDMbAVSUp3Zsjm7ywFeuwrUXhmhQyRK1q5B5GGy7hcXPbj3bnfZg2g==" 376 | }, 377 | "double-ended-queue": { 378 | "version": "2.1.0-0", 379 | "resolved": "https://registry.npmjs.org/double-ended-queue/-/double-ended-queue-2.1.0-0.tgz", 380 | "integrity": "sha1-ED01J/0xUo9AGIEwyEHv3XgmTlw=" 381 | }, 382 | "ecdsa-sig-formatter": { 383 | "version": "1.0.11", 384 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 385 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 386 | "requires": { 387 | "safe-buffer": "^5.0.1" 388 | } 389 | }, 390 | "ee-first": { 391 | "version": "1.1.1", 392 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 393 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 394 | }, 395 | "emoji-regex": { 396 | "version": "7.0.3", 397 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 398 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 399 | "dev": true 400 | }, 401 | "encodeurl": { 402 | "version": "1.0.2", 403 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 404 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 405 | }, 406 | "error-ex": { 407 | "version": "1.3.2", 408 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 409 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 410 | "dev": true, 411 | "requires": { 412 | "is-arrayish": "^0.2.1" 413 | } 414 | }, 415 | "es-abstract": { 416 | "version": "1.13.0", 417 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", 418 | "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", 419 | "dev": true, 420 | "requires": { 421 | "es-to-primitive": "^1.2.0", 422 | "function-bind": "^1.1.1", 423 | "has": "^1.0.3", 424 | "is-callable": "^1.1.4", 425 | "is-regex": "^1.0.4", 426 | "object-keys": "^1.0.12" 427 | } 428 | }, 429 | "es-to-primitive": { 430 | "version": "1.2.0", 431 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 432 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 433 | "dev": true, 434 | "requires": { 435 | "is-callable": "^1.1.4", 436 | "is-date-object": "^1.0.1", 437 | "is-symbol": "^1.0.2" 438 | } 439 | }, 440 | "escape-html": { 441 | "version": "1.0.3", 442 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 443 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 444 | }, 445 | "escape-string-regexp": { 446 | "version": "1.0.5", 447 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 448 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 449 | "dev": true 450 | }, 451 | "eslint": { 452 | "version": "5.16.0", 453 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.16.0.tgz", 454 | "integrity": "sha512-S3Rz11i7c8AA5JPv7xAH+dOyq/Cu/VXHiHXBPOU1k/JAM5dXqQPt3qcrhpHSorXmrpu2g0gkIBVXAqCpzfoZIg==", 455 | "dev": true, 456 | "requires": { 457 | "@babel/code-frame": "^7.0.0", 458 | "ajv": "^6.9.1", 459 | "chalk": "^2.1.0", 460 | "cross-spawn": "^6.0.5", 461 | "debug": "^4.0.1", 462 | "doctrine": "^3.0.0", 463 | "eslint-scope": "^4.0.3", 464 | "eslint-utils": "^1.3.1", 465 | "eslint-visitor-keys": "^1.0.0", 466 | "espree": "^5.0.1", 467 | "esquery": "^1.0.1", 468 | "esutils": "^2.0.2", 469 | "file-entry-cache": "^5.0.1", 470 | "functional-red-black-tree": "^1.0.1", 471 | "glob": "^7.1.2", 472 | "globals": "^11.7.0", 473 | "ignore": "^4.0.6", 474 | "import-fresh": "^3.0.0", 475 | "imurmurhash": "^0.1.4", 476 | "inquirer": "^6.2.2", 477 | "js-yaml": "^3.13.0", 478 | "json-stable-stringify-without-jsonify": "^1.0.1", 479 | "levn": "^0.3.0", 480 | "lodash": "^4.17.11", 481 | "minimatch": "^3.0.4", 482 | "mkdirp": "^0.5.1", 483 | "natural-compare": "^1.4.0", 484 | "optionator": "^0.8.2", 485 | "path-is-inside": "^1.0.2", 486 | "progress": "^2.0.0", 487 | "regexpp": "^2.0.1", 488 | "semver": "^5.5.1", 489 | "strip-ansi": "^4.0.0", 490 | "strip-json-comments": "^2.0.1", 491 | "table": "^5.2.3", 492 | "text-table": "^0.2.0" 493 | }, 494 | "dependencies": { 495 | "debug": { 496 | "version": "4.1.1", 497 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 498 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 499 | "dev": true, 500 | "requires": { 501 | "ms": "^2.1.1" 502 | } 503 | }, 504 | "ms": { 505 | "version": "2.1.1", 506 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 507 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 508 | "dev": true 509 | }, 510 | "semver": { 511 | "version": "5.7.0", 512 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz", 513 | "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==", 514 | "dev": true 515 | } 516 | } 517 | }, 518 | "eslint-config-airbnb-base": { 519 | "version": "13.1.0", 520 | "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-13.1.0.tgz", 521 | "integrity": "sha512-XWwQtf3U3zIoKO1BbHh6aUhJZQweOwSt4c2JrPDg9FP3Ltv3+YfEv7jIDB8275tVnO/qOHbfuYg3kzw6Je7uWw==", 522 | "dev": true, 523 | "requires": { 524 | "eslint-restricted-globals": "^0.1.1", 525 | "object.assign": "^4.1.0", 526 | "object.entries": "^1.0.4" 527 | } 528 | }, 529 | "eslint-import-resolver-node": { 530 | "version": "0.3.2", 531 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz", 532 | "integrity": "sha512-sfmTqJfPSizWu4aymbPr4Iidp5yKm8yDkHp+Ir3YiTHiiDfxh69mOUsmiqW6RZ9zRXFaF64GtYmN7e+8GHBv6Q==", 533 | "dev": true, 534 | "requires": { 535 | "debug": "^2.6.9", 536 | "resolve": "^1.5.0" 537 | } 538 | }, 539 | "eslint-module-utils": { 540 | "version": "2.4.0", 541 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.4.0.tgz", 542 | "integrity": "sha512-14tltLm38Eu3zS+mt0KvILC3q8jyIAH518MlG+HO0p+yK885Lb1UHTY/UgR91eOyGdmxAPb+OLoW4znqIT6Ndw==", 543 | "dev": true, 544 | "requires": { 545 | "debug": "^2.6.8", 546 | "pkg-dir": "^2.0.0" 547 | } 548 | }, 549 | "eslint-plugin-import": { 550 | "version": "2.17.1", 551 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.17.1.tgz", 552 | "integrity": "sha512-lzD9uvRvW4MsHzIOMJEDSb5MOV9LzgxRPBaovvOhJqzgxRHYfGy9QOrMuwHIh5ehKFJ7Z3DcrcGKDQ0IbP0EdQ==", 553 | "dev": true, 554 | "requires": { 555 | "array-includes": "^3.0.3", 556 | "contains-path": "^0.1.0", 557 | "debug": "^2.6.9", 558 | "doctrine": "1.5.0", 559 | "eslint-import-resolver-node": "^0.3.2", 560 | "eslint-module-utils": "^2.4.0", 561 | "has": "^1.0.3", 562 | "lodash": "^4.17.11", 563 | "minimatch": "^3.0.4", 564 | "read-pkg-up": "^2.0.0", 565 | "resolve": "^1.10.0" 566 | }, 567 | "dependencies": { 568 | "doctrine": { 569 | "version": "1.5.0", 570 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 571 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 572 | "dev": true, 573 | "requires": { 574 | "esutils": "^2.0.2", 575 | "isarray": "^1.0.0" 576 | } 577 | } 578 | } 579 | }, 580 | "eslint-restricted-globals": { 581 | "version": "0.1.1", 582 | "resolved": "https://registry.npmjs.org/eslint-restricted-globals/-/eslint-restricted-globals-0.1.1.tgz", 583 | "integrity": "sha1-NfDVy8ZMLj7WLpO0saevBbp+1Nc=", 584 | "dev": true 585 | }, 586 | "eslint-scope": { 587 | "version": "4.0.3", 588 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", 589 | "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", 590 | "dev": true, 591 | "requires": { 592 | "esrecurse": "^4.1.0", 593 | "estraverse": "^4.1.1" 594 | } 595 | }, 596 | "eslint-utils": { 597 | "version": "1.3.1", 598 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.3.1.tgz", 599 | "integrity": "sha512-Z7YjnIldX+2XMcjr7ZkgEsOj/bREONV60qYeB/bjMAqqqZ4zxKyWX+BOUkdmRmA9riiIPVvo5x86m5elviOk0Q==", 600 | "dev": true 601 | }, 602 | "eslint-visitor-keys": { 603 | "version": "1.0.0", 604 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 605 | "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", 606 | "dev": true 607 | }, 608 | "espree": { 609 | "version": "5.0.1", 610 | "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.1.tgz", 611 | "integrity": "sha512-qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A==", 612 | "dev": true, 613 | "requires": { 614 | "acorn": "^6.0.7", 615 | "acorn-jsx": "^5.0.0", 616 | "eslint-visitor-keys": "^1.0.0" 617 | } 618 | }, 619 | "esprima": { 620 | "version": "4.0.1", 621 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 622 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 623 | "dev": true 624 | }, 625 | "esquery": { 626 | "version": "1.0.1", 627 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 628 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 629 | "dev": true, 630 | "requires": { 631 | "estraverse": "^4.0.0" 632 | } 633 | }, 634 | "esrecurse": { 635 | "version": "4.2.1", 636 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 637 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 638 | "dev": true, 639 | "requires": { 640 | "estraverse": "^4.1.0" 641 | } 642 | }, 643 | "estraverse": { 644 | "version": "4.2.0", 645 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 646 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", 647 | "dev": true 648 | }, 649 | "esutils": { 650 | "version": "2.0.2", 651 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 652 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 653 | "dev": true 654 | }, 655 | "etag": { 656 | "version": "1.8.1", 657 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 658 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 659 | }, 660 | "express": { 661 | "version": "4.16.3", 662 | "resolved": "https://registry.npmjs.org/express/-/express-4.16.3.tgz", 663 | "integrity": "sha1-avilAjUNsyRuzEvs9rWjTSL37VM=", 664 | "requires": { 665 | "accepts": "~1.3.5", 666 | "array-flatten": "1.1.1", 667 | "body-parser": "1.18.2", 668 | "content-disposition": "0.5.2", 669 | "content-type": "~1.0.4", 670 | "cookie": "0.3.1", 671 | "cookie-signature": "1.0.6", 672 | "debug": "2.6.9", 673 | "depd": "~1.1.2", 674 | "encodeurl": "~1.0.2", 675 | "escape-html": "~1.0.3", 676 | "etag": "~1.8.1", 677 | "finalhandler": "1.1.1", 678 | "fresh": "0.5.2", 679 | "merge-descriptors": "1.0.1", 680 | "methods": "~1.1.2", 681 | "on-finished": "~2.3.0", 682 | "parseurl": "~1.3.2", 683 | "path-to-regexp": "0.1.7", 684 | "proxy-addr": "~2.0.3", 685 | "qs": "6.5.1", 686 | "range-parser": "~1.2.0", 687 | "safe-buffer": "5.1.1", 688 | "send": "0.16.2", 689 | "serve-static": "1.13.2", 690 | "setprototypeof": "1.1.0", 691 | "statuses": "~1.4.0", 692 | "type-is": "~1.6.16", 693 | "utils-merge": "1.0.1", 694 | "vary": "~1.1.2" 695 | }, 696 | "dependencies": { 697 | "body-parser": { 698 | "version": "1.18.2", 699 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.2.tgz", 700 | "integrity": "sha1-h2eKGdhLR9hZuDGZvVm84iKxBFQ=", 701 | "requires": { 702 | "bytes": "3.0.0", 703 | "content-type": "~1.0.4", 704 | "debug": "2.6.9", 705 | "depd": "~1.1.1", 706 | "http-errors": "~1.6.2", 707 | "iconv-lite": "0.4.19", 708 | "on-finished": "~2.3.0", 709 | "qs": "6.5.1", 710 | "raw-body": "2.3.2", 711 | "type-is": "~1.6.15" 712 | } 713 | }, 714 | "iconv-lite": { 715 | "version": "0.4.19", 716 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.19.tgz", 717 | "integrity": "sha512-oTZqweIP51xaGPI4uPa56/Pri/480R+mo7SeU+YETByQNhDG55ycFyNLIgta9vXhILrxXDmF7ZGhqZIcuN0gJQ==" 718 | }, 719 | "qs": { 720 | "version": "6.5.1", 721 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.1.tgz", 722 | "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==" 723 | }, 724 | "raw-body": { 725 | "version": "2.3.2", 726 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.2.tgz", 727 | "integrity": "sha1-vNYMd9Prk83gBQKVw/N5OJvIj4k=", 728 | "requires": { 729 | "bytes": "3.0.0", 730 | "http-errors": "1.6.2", 731 | "iconv-lite": "0.4.19", 732 | "unpipe": "1.0.0" 733 | }, 734 | "dependencies": { 735 | "depd": { 736 | "version": "1.1.1", 737 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.1.tgz", 738 | "integrity": "sha1-V4O04cRZ8G+lyif5kfPQbnoxA1k=" 739 | }, 740 | "http-errors": { 741 | "version": "1.6.2", 742 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.2.tgz", 743 | "integrity": "sha1-CgAsyFcHGSp+eUbO7cERVfYOxzY=", 744 | "requires": { 745 | "depd": "1.1.1", 746 | "inherits": "2.0.3", 747 | "setprototypeof": "1.0.3", 748 | "statuses": ">= 1.3.1 < 2" 749 | } 750 | }, 751 | "setprototypeof": { 752 | "version": "1.0.3", 753 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz", 754 | "integrity": "sha1-ZlZ+NwQ+608E2RvWWMDL77VbjgQ=" 755 | } 756 | } 757 | }, 758 | "statuses": { 759 | "version": "1.4.0", 760 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 761 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==" 762 | } 763 | } 764 | }, 765 | "express-jwt": { 766 | "version": "5.3.1", 767 | "resolved": "https://registry.npmjs.org/express-jwt/-/express-jwt-5.3.1.tgz", 768 | "integrity": "sha512-1C9RNq0wMp/JvsH/qZMlg3SIPvKu14YkZ4YYv7gJQ1Vq+Dv8LH9tLKenS5vMNth45gTlEUGx+ycp9IHIlaHP/g==", 769 | "requires": { 770 | "async": "^1.5.0", 771 | "express-unless": "^0.3.0", 772 | "jsonwebtoken": "^8.1.0", 773 | "lodash.set": "^4.0.0" 774 | } 775 | }, 776 | "express-unless": { 777 | "version": "0.3.1", 778 | "resolved": "https://registry.npmjs.org/express-unless/-/express-unless-0.3.1.tgz", 779 | "integrity": "sha1-JVfBRudb65A+LSR/m1ugFFJpbiA=" 780 | }, 781 | "external-editor": { 782 | "version": "3.0.3", 783 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.0.3.tgz", 784 | "integrity": "sha512-bn71H9+qWoOQKyZDo25mOMVpSmXROAsTJVVVYzrrtol3d4y+AsKjf4Iwl2Q+IuT0kFSQ1qo166UuIwqYq7mGnA==", 785 | "dev": true, 786 | "requires": { 787 | "chardet": "^0.7.0", 788 | "iconv-lite": "^0.4.24", 789 | "tmp": "^0.0.33" 790 | }, 791 | "dependencies": { 792 | "iconv-lite": { 793 | "version": "0.4.24", 794 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 795 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 796 | "dev": true, 797 | "requires": { 798 | "safer-buffer": ">= 2.1.2 < 3" 799 | } 800 | } 801 | } 802 | }, 803 | "fast-deep-equal": { 804 | "version": "2.0.1", 805 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 806 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 807 | "dev": true 808 | }, 809 | "fast-json-stable-stringify": { 810 | "version": "2.0.0", 811 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 812 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 813 | "dev": true 814 | }, 815 | "fast-levenshtein": { 816 | "version": "2.0.6", 817 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 818 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 819 | "dev": true 820 | }, 821 | "figures": { 822 | "version": "2.0.0", 823 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 824 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 825 | "dev": true, 826 | "requires": { 827 | "escape-string-regexp": "^1.0.5" 828 | } 829 | }, 830 | "file-entry-cache": { 831 | "version": "5.0.1", 832 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 833 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 834 | "dev": true, 835 | "requires": { 836 | "flat-cache": "^2.0.1" 837 | } 838 | }, 839 | "finalhandler": { 840 | "version": "1.1.1", 841 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.1.tgz", 842 | "integrity": "sha512-Y1GUDo39ez4aHAw7MysnUD5JzYX+WaIj8I57kO3aEPT1fFRL4sr7mjei97FgnwhAyyzRYmQZaTHb2+9uZ1dPtg==", 843 | "requires": { 844 | "debug": "2.6.9", 845 | "encodeurl": "~1.0.2", 846 | "escape-html": "~1.0.3", 847 | "on-finished": "~2.3.0", 848 | "parseurl": "~1.3.2", 849 | "statuses": "~1.4.0", 850 | "unpipe": "~1.0.0" 851 | }, 852 | "dependencies": { 853 | "statuses": { 854 | "version": "1.4.0", 855 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 856 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==" 857 | } 858 | } 859 | }, 860 | "find-up": { 861 | "version": "2.1.0", 862 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 863 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 864 | "dev": true, 865 | "requires": { 866 | "locate-path": "^2.0.0" 867 | } 868 | }, 869 | "flat-cache": { 870 | "version": "2.0.1", 871 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 872 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 873 | "dev": true, 874 | "requires": { 875 | "flatted": "^2.0.0", 876 | "rimraf": "2.6.3", 877 | "write": "1.0.3" 878 | } 879 | }, 880 | "flatted": { 881 | "version": "2.0.0", 882 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.0.tgz", 883 | "integrity": "sha512-R+H8IZclI8AAkSBRQJLVOsxwAoHd6WC40b4QTNWIjzAa6BXOBfQcM587MXDTVPeYaopFNWHUFLx7eNmHDSxMWg==", 884 | "dev": true 885 | }, 886 | "forwarded": { 887 | "version": "0.1.2", 888 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 889 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 890 | }, 891 | "fresh": { 892 | "version": "0.5.2", 893 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 894 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 895 | }, 896 | "fs-minipass": { 897 | "version": "1.2.5", 898 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.5.tgz", 899 | "integrity": "sha512-JhBl0skXjUPCFH7x6x61gQxrKyXsxB5gcgePLZCwfyCGGsTISMoIeObbrvVeP6Xmyaudw4TT43qV2Gz+iyd2oQ==", 900 | "requires": { 901 | "minipass": "^2.2.1" 902 | } 903 | }, 904 | "fs.realpath": { 905 | "version": "1.0.0", 906 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 907 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 908 | }, 909 | "function-bind": { 910 | "version": "1.1.1", 911 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 912 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 913 | "dev": true 914 | }, 915 | "functional-red-black-tree": { 916 | "version": "1.0.1", 917 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 918 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 919 | "dev": true 920 | }, 921 | "gauge": { 922 | "version": "2.7.4", 923 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 924 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 925 | "requires": { 926 | "aproba": "^1.0.3", 927 | "console-control-strings": "^1.0.0", 928 | "has-unicode": "^2.0.0", 929 | "object-assign": "^4.1.0", 930 | "signal-exit": "^3.0.0", 931 | "string-width": "^1.0.1", 932 | "strip-ansi": "^3.0.1", 933 | "wide-align": "^1.1.0" 934 | }, 935 | "dependencies": { 936 | "ansi-regex": { 937 | "version": "2.1.1", 938 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 939 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 940 | }, 941 | "is-fullwidth-code-point": { 942 | "version": "1.0.0", 943 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 944 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 945 | "requires": { 946 | "number-is-nan": "^1.0.0" 947 | } 948 | }, 949 | "string-width": { 950 | "version": "1.0.2", 951 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 952 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 953 | "requires": { 954 | "code-point-at": "^1.0.0", 955 | "is-fullwidth-code-point": "^1.0.0", 956 | "strip-ansi": "^3.0.0" 957 | } 958 | }, 959 | "strip-ansi": { 960 | "version": "3.0.1", 961 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 962 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 963 | "requires": { 964 | "ansi-regex": "^2.0.0" 965 | } 966 | } 967 | } 968 | }, 969 | "glob": { 970 | "version": "7.1.3", 971 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 972 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 973 | "requires": { 974 | "fs.realpath": "^1.0.0", 975 | "inflight": "^1.0.4", 976 | "inherits": "2", 977 | "minimatch": "^3.0.4", 978 | "once": "^1.3.0", 979 | "path-is-absolute": "^1.0.0" 980 | } 981 | }, 982 | "globals": { 983 | "version": "11.11.0", 984 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.11.0.tgz", 985 | "integrity": "sha512-WHq43gS+6ufNOEqlrDBxVEbb8ntfXrfAUU2ZOpCxrBdGKW3gyv8mCxAfIBD0DroPKGrJ2eSsXsLtY9MPntsyTw==", 986 | "dev": true 987 | }, 988 | "graceful-fs": { 989 | "version": "4.1.15", 990 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", 991 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==", 992 | "dev": true 993 | }, 994 | "has": { 995 | "version": "1.0.3", 996 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 997 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 998 | "dev": true, 999 | "requires": { 1000 | "function-bind": "^1.1.1" 1001 | } 1002 | }, 1003 | "has-flag": { 1004 | "version": "3.0.0", 1005 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1006 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1007 | "dev": true 1008 | }, 1009 | "has-symbols": { 1010 | "version": "1.0.0", 1011 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 1012 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 1013 | "dev": true 1014 | }, 1015 | "has-unicode": { 1016 | "version": "2.0.1", 1017 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 1018 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" 1019 | }, 1020 | "hosted-git-info": { 1021 | "version": "2.7.1", 1022 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz", 1023 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==", 1024 | "dev": true 1025 | }, 1026 | "http-errors": { 1027 | "version": "1.6.3", 1028 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", 1029 | "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", 1030 | "requires": { 1031 | "depd": "~1.1.2", 1032 | "inherits": "2.0.3", 1033 | "setprototypeof": "1.1.0", 1034 | "statuses": ">= 1.4.0 < 2" 1035 | } 1036 | }, 1037 | "iconv-lite": { 1038 | "version": "0.4.23", 1039 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz", 1040 | "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==", 1041 | "requires": { 1042 | "safer-buffer": ">= 2.1.2 < 3" 1043 | } 1044 | }, 1045 | "ignore": { 1046 | "version": "4.0.6", 1047 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1048 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1049 | "dev": true 1050 | }, 1051 | "ignore-walk": { 1052 | "version": "3.0.1", 1053 | "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.1.tgz", 1054 | "integrity": "sha512-DTVlMx3IYPe0/JJcYP7Gxg7ttZZu3IInhuEhbchuqneY9wWe5Ojy2mXLBaQFUQmo0AW2r3qG7m1mg86js+gnlQ==", 1055 | "requires": { 1056 | "minimatch": "^3.0.4" 1057 | } 1058 | }, 1059 | "import-fresh": { 1060 | "version": "3.0.0", 1061 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.0.0.tgz", 1062 | "integrity": "sha512-pOnA9tfM3Uwics+SaBLCNyZZZbK+4PTu0OPZtLlMIrv17EdBoC15S9Kn8ckJ9TZTyKb3ywNE5y1yeDxxGA7nTQ==", 1063 | "dev": true, 1064 | "requires": { 1065 | "parent-module": "^1.0.0", 1066 | "resolve-from": "^4.0.0" 1067 | }, 1068 | "dependencies": { 1069 | "resolve-from": { 1070 | "version": "4.0.0", 1071 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1072 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1073 | "dev": true 1074 | } 1075 | } 1076 | }, 1077 | "imurmurhash": { 1078 | "version": "0.1.4", 1079 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1080 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1081 | "dev": true 1082 | }, 1083 | "inflight": { 1084 | "version": "1.0.6", 1085 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1086 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1087 | "requires": { 1088 | "once": "^1.3.0", 1089 | "wrappy": "1" 1090 | } 1091 | }, 1092 | "inherits": { 1093 | "version": "2.0.3", 1094 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1095 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1096 | }, 1097 | "ini": { 1098 | "version": "1.3.5", 1099 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 1100 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==" 1101 | }, 1102 | "inquirer": { 1103 | "version": "6.3.1", 1104 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.3.1.tgz", 1105 | "integrity": "sha512-MmL624rfkFt4TG9y/Jvmt8vdmOo836U7Y0Hxr2aFk3RelZEGX4Igk0KabWrcaaZaTv9uzglOqWh1Vly+FAWAXA==", 1106 | "dev": true, 1107 | "requires": { 1108 | "ansi-escapes": "^3.2.0", 1109 | "chalk": "^2.4.2", 1110 | "cli-cursor": "^2.1.0", 1111 | "cli-width": "^2.0.0", 1112 | "external-editor": "^3.0.3", 1113 | "figures": "^2.0.0", 1114 | "lodash": "^4.17.11", 1115 | "mute-stream": "0.0.7", 1116 | "run-async": "^2.2.0", 1117 | "rxjs": "^6.4.0", 1118 | "string-width": "^2.1.0", 1119 | "strip-ansi": "^5.1.0", 1120 | "through": "^2.3.6" 1121 | }, 1122 | "dependencies": { 1123 | "ansi-regex": { 1124 | "version": "4.1.0", 1125 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1126 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1127 | "dev": true 1128 | }, 1129 | "strip-ansi": { 1130 | "version": "5.2.0", 1131 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1132 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1133 | "dev": true, 1134 | "requires": { 1135 | "ansi-regex": "^4.1.0" 1136 | } 1137 | } 1138 | } 1139 | }, 1140 | "ipaddr.js": { 1141 | "version": "1.8.0", 1142 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.8.0.tgz", 1143 | "integrity": "sha1-6qM9bd16zo9/b+DJygRA5wZzix4=" 1144 | }, 1145 | "is-arrayish": { 1146 | "version": "0.2.1", 1147 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1148 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 1149 | "dev": true 1150 | }, 1151 | "is-callable": { 1152 | "version": "1.1.4", 1153 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 1154 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 1155 | "dev": true 1156 | }, 1157 | "is-date-object": { 1158 | "version": "1.0.1", 1159 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 1160 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 1161 | "dev": true 1162 | }, 1163 | "is-fullwidth-code-point": { 1164 | "version": "2.0.0", 1165 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1166 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 1167 | }, 1168 | "is-promise": { 1169 | "version": "2.1.0", 1170 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1171 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 1172 | "dev": true 1173 | }, 1174 | "is-regex": { 1175 | "version": "1.0.4", 1176 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 1177 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 1178 | "dev": true, 1179 | "requires": { 1180 | "has": "^1.0.1" 1181 | } 1182 | }, 1183 | "is-symbol": { 1184 | "version": "1.0.2", 1185 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 1186 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 1187 | "dev": true, 1188 | "requires": { 1189 | "has-symbols": "^1.0.0" 1190 | } 1191 | }, 1192 | "isarray": { 1193 | "version": "1.0.0", 1194 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1195 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 1196 | }, 1197 | "isexe": { 1198 | "version": "2.0.0", 1199 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1200 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1201 | "dev": true 1202 | }, 1203 | "js-tokens": { 1204 | "version": "4.0.0", 1205 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1206 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1207 | "dev": true 1208 | }, 1209 | "js-yaml": { 1210 | "version": "3.13.1", 1211 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1212 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1213 | "dev": true, 1214 | "requires": { 1215 | "argparse": "^1.0.7", 1216 | "esprima": "^4.0.0" 1217 | } 1218 | }, 1219 | "json-schema-traverse": { 1220 | "version": "0.4.1", 1221 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1222 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1223 | "dev": true 1224 | }, 1225 | "json-stable-stringify-without-jsonify": { 1226 | "version": "1.0.1", 1227 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1228 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1229 | "dev": true 1230 | }, 1231 | "jsonwebtoken": { 1232 | "version": "8.5.1", 1233 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", 1234 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", 1235 | "requires": { 1236 | "jws": "^3.2.2", 1237 | "lodash.includes": "^4.3.0", 1238 | "lodash.isboolean": "^3.0.3", 1239 | "lodash.isinteger": "^4.0.4", 1240 | "lodash.isnumber": "^3.0.3", 1241 | "lodash.isplainobject": "^4.0.6", 1242 | "lodash.isstring": "^4.0.1", 1243 | "lodash.once": "^4.0.0", 1244 | "ms": "^2.1.1", 1245 | "semver": "^5.6.0" 1246 | }, 1247 | "dependencies": { 1248 | "ms": { 1249 | "version": "2.1.1", 1250 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1251 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1252 | }, 1253 | "semver": { 1254 | "version": "5.7.0", 1255 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz", 1256 | "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==" 1257 | } 1258 | } 1259 | }, 1260 | "jwa": { 1261 | "version": "1.4.1", 1262 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 1263 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 1264 | "requires": { 1265 | "buffer-equal-constant-time": "1.0.1", 1266 | "ecdsa-sig-formatter": "1.0.11", 1267 | "safe-buffer": "^5.0.1" 1268 | } 1269 | }, 1270 | "jws": { 1271 | "version": "3.2.2", 1272 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 1273 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 1274 | "requires": { 1275 | "jwa": "^1.4.1", 1276 | "safe-buffer": "^5.0.1" 1277 | } 1278 | }, 1279 | "levn": { 1280 | "version": "0.3.0", 1281 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1282 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1283 | "dev": true, 1284 | "requires": { 1285 | "prelude-ls": "~1.1.2", 1286 | "type-check": "~0.3.2" 1287 | } 1288 | }, 1289 | "load-json-file": { 1290 | "version": "2.0.0", 1291 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 1292 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 1293 | "dev": true, 1294 | "requires": { 1295 | "graceful-fs": "^4.1.2", 1296 | "parse-json": "^2.2.0", 1297 | "pify": "^2.0.0", 1298 | "strip-bom": "^3.0.0" 1299 | } 1300 | }, 1301 | "locate-path": { 1302 | "version": "2.0.0", 1303 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1304 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1305 | "dev": true, 1306 | "requires": { 1307 | "p-locate": "^2.0.0", 1308 | "path-exists": "^3.0.0" 1309 | } 1310 | }, 1311 | "lodash": { 1312 | "version": "4.17.11", 1313 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 1314 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", 1315 | "dev": true 1316 | }, 1317 | "lodash.includes": { 1318 | "version": "4.3.0", 1319 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 1320 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 1321 | }, 1322 | "lodash.isboolean": { 1323 | "version": "3.0.3", 1324 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 1325 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 1326 | }, 1327 | "lodash.isinteger": { 1328 | "version": "4.0.4", 1329 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 1330 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 1331 | }, 1332 | "lodash.isnumber": { 1333 | "version": "3.0.3", 1334 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 1335 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 1336 | }, 1337 | "lodash.isplainobject": { 1338 | "version": "4.0.6", 1339 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 1340 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 1341 | }, 1342 | "lodash.isstring": { 1343 | "version": "4.0.1", 1344 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 1345 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 1346 | }, 1347 | "lodash.once": { 1348 | "version": "4.1.1", 1349 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1350 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 1351 | }, 1352 | "lodash.set": { 1353 | "version": "4.3.2", 1354 | "resolved": "https://registry.npmjs.org/lodash.set/-/lodash.set-4.3.2.tgz", 1355 | "integrity": "sha1-2HV7HagH3eJIFrDWqEvqGnYjCyM=" 1356 | }, 1357 | "media-typer": { 1358 | "version": "0.3.0", 1359 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1360 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1361 | }, 1362 | "merge-descriptors": { 1363 | "version": "1.0.1", 1364 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1365 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1366 | }, 1367 | "methods": { 1368 | "version": "1.1.2", 1369 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1370 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1371 | }, 1372 | "mime": { 1373 | "version": "1.4.1", 1374 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz", 1375 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==" 1376 | }, 1377 | "mime-db": { 1378 | "version": "1.35.0", 1379 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.35.0.tgz", 1380 | "integrity": "sha512-JWT/IcCTsB0Io3AhWUMjRqucrHSPsSf2xKLaRldJVULioggvkJvggZ3VXNNSRkCddE6D+BUI4HEIZIA2OjwIvg==" 1381 | }, 1382 | "mime-types": { 1383 | "version": "2.1.19", 1384 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.19.tgz", 1385 | "integrity": "sha512-P1tKYHVSZ6uFo26mtnve4HQFE3koh1UWVkp8YUC+ESBHe945xWSoXuHHiGarDqcEZ+whpCDnlNw5LON0kLo+sw==", 1386 | "requires": { 1387 | "mime-db": "~1.35.0" 1388 | } 1389 | }, 1390 | "mimic-fn": { 1391 | "version": "1.2.0", 1392 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 1393 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", 1394 | "dev": true 1395 | }, 1396 | "minimatch": { 1397 | "version": "3.0.4", 1398 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1399 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1400 | "requires": { 1401 | "brace-expansion": "^1.1.7" 1402 | } 1403 | }, 1404 | "minimist": { 1405 | "version": "0.0.8", 1406 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1407 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" 1408 | }, 1409 | "minipass": { 1410 | "version": "2.3.5", 1411 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.3.5.tgz", 1412 | "integrity": "sha512-Gi1W4k059gyRbyVUZQ4mEqLm0YIUiGYfvxhF6SIlk3ui1WVxMTGfGdQ2SInh3PDrRTVvPKgULkpJtT4RH10+VA==", 1413 | "requires": { 1414 | "safe-buffer": "^5.1.2", 1415 | "yallist": "^3.0.0" 1416 | }, 1417 | "dependencies": { 1418 | "safe-buffer": { 1419 | "version": "5.1.2", 1420 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1421 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1422 | } 1423 | } 1424 | }, 1425 | "minizlib": { 1426 | "version": "1.2.1", 1427 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.2.1.tgz", 1428 | "integrity": "sha512-7+4oTUOWKg7AuL3vloEWekXY2/D20cevzsrNT2kGWm+39J9hGTCBv8VI5Pm5lXZ/o3/mdR4f8rflAPhnQb8mPA==", 1429 | "requires": { 1430 | "minipass": "^2.2.1" 1431 | } 1432 | }, 1433 | "mkdirp": { 1434 | "version": "0.5.1", 1435 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1436 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1437 | "requires": { 1438 | "minimist": "0.0.8" 1439 | } 1440 | }, 1441 | "mongodb": { 1442 | "version": "3.1.3", 1443 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.1.3.tgz", 1444 | "integrity": "sha512-hfzI54/fe+604w5gP+i9aJ5GGVxnquxZ09ZN1cyLTbpnBfDRpj78lN59SBdDRkF1VNTzmM2KcgDWhHHDHcsJxw==", 1445 | "requires": { 1446 | "mongodb-core": "3.1.2" 1447 | } 1448 | }, 1449 | "mongodb-core": { 1450 | "version": "3.1.2", 1451 | "resolved": "https://registry.npmjs.org/mongodb-core/-/mongodb-core-3.1.2.tgz", 1452 | "integrity": "sha512-R2XxGzsmhlUeOK2jKATj1TWn3q3qNcJpKrSh0rhaBSHxJmV7WZ+ikjocdY8VdJxUkKqOxM8rxMqOAEzeJ3p1ww==", 1453 | "requires": { 1454 | "bson": "^1.1.0", 1455 | "require_optional": "^1.0.1", 1456 | "saslprep": "^1.0.0" 1457 | } 1458 | }, 1459 | "ms": { 1460 | "version": "2.0.0", 1461 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1462 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1463 | }, 1464 | "mute-stream": { 1465 | "version": "0.0.7", 1466 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 1467 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", 1468 | "dev": true 1469 | }, 1470 | "nan": { 1471 | "version": "2.13.2", 1472 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.13.2.tgz", 1473 | "integrity": "sha512-TghvYc72wlMGMVMluVo9WRJc0mB8KxxF/gZ4YYFy7V2ZQX9l7rgbPg7vjS9mt6U5HXODVFVI2bOduCzwOMv/lw==" 1474 | }, 1475 | "natural-compare": { 1476 | "version": "1.4.0", 1477 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1478 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1479 | "dev": true 1480 | }, 1481 | "needle": { 1482 | "version": "2.3.0", 1483 | "resolved": "https://registry.npmjs.org/needle/-/needle-2.3.0.tgz", 1484 | "integrity": "sha512-QBZu7aAFR0522EyaXZM0FZ9GLpq6lvQ3uq8gteiDUp7wKdy0lSd2hPlgFwVuW1CBkfEs9PfDQsQzZghLs/psdg==", 1485 | "requires": { 1486 | "debug": "^4.1.0", 1487 | "iconv-lite": "^0.4.4", 1488 | "sax": "^1.2.4" 1489 | }, 1490 | "dependencies": { 1491 | "debug": { 1492 | "version": "4.1.1", 1493 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 1494 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 1495 | "requires": { 1496 | "ms": "^2.1.1" 1497 | } 1498 | }, 1499 | "ms": { 1500 | "version": "2.1.1", 1501 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1502 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1503 | } 1504 | } 1505 | }, 1506 | "negotiator": { 1507 | "version": "0.6.1", 1508 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", 1509 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=" 1510 | }, 1511 | "nice-try": { 1512 | "version": "1.0.5", 1513 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1514 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1515 | "dev": true 1516 | }, 1517 | "node-pre-gyp": { 1518 | "version": "0.12.0", 1519 | "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.12.0.tgz", 1520 | "integrity": "sha512-4KghwV8vH5k+g2ylT+sLTjy5wmUOb9vPhnM8NHvRf9dHmnW/CndrFXy2aRPaPST6dugXSdHXfeaHQm77PIz/1A==", 1521 | "requires": { 1522 | "detect-libc": "^1.0.2", 1523 | "mkdirp": "^0.5.1", 1524 | "needle": "^2.2.1", 1525 | "nopt": "^4.0.1", 1526 | "npm-packlist": "^1.1.6", 1527 | "npmlog": "^4.0.2", 1528 | "rc": "^1.2.7", 1529 | "rimraf": "^2.6.1", 1530 | "semver": "^5.3.0", 1531 | "tar": "^4" 1532 | } 1533 | }, 1534 | "nopt": { 1535 | "version": "4.0.1", 1536 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.1.tgz", 1537 | "integrity": "sha1-0NRoWv1UFRk8jHUFYC0NF81kR00=", 1538 | "requires": { 1539 | "abbrev": "1", 1540 | "osenv": "^0.1.4" 1541 | } 1542 | }, 1543 | "normalize-package-data": { 1544 | "version": "2.5.0", 1545 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1546 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1547 | "dev": true, 1548 | "requires": { 1549 | "hosted-git-info": "^2.1.4", 1550 | "resolve": "^1.10.0", 1551 | "semver": "2 || 3 || 4 || 5", 1552 | "validate-npm-package-license": "^3.0.1" 1553 | } 1554 | }, 1555 | "npm-bundled": { 1556 | "version": "1.0.6", 1557 | "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.0.6.tgz", 1558 | "integrity": "sha512-8/JCaftHwbd//k6y2rEWp6k1wxVfpFzB6t1p825+cUb7Ym2XQfhwIC5KwhrvzZRJu+LtDE585zVaS32+CGtf0g==" 1559 | }, 1560 | "npm-packlist": { 1561 | "version": "1.4.1", 1562 | "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.4.1.tgz", 1563 | "integrity": "sha512-+TcdO7HJJ8peiiYhvPxsEDhF3PJFGUGRcFsGve3vxvxdcpO2Z4Z7rkosRM0kWj6LfbK/P0gu3dzk5RU1ffvFcw==", 1564 | "requires": { 1565 | "ignore-walk": "^3.0.1", 1566 | "npm-bundled": "^1.0.1" 1567 | } 1568 | }, 1569 | "npmlog": { 1570 | "version": "4.1.2", 1571 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 1572 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 1573 | "requires": { 1574 | "are-we-there-yet": "~1.1.2", 1575 | "console-control-strings": "~1.1.0", 1576 | "gauge": "~2.7.3", 1577 | "set-blocking": "~2.0.0" 1578 | } 1579 | }, 1580 | "number-is-nan": { 1581 | "version": "1.0.1", 1582 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1583 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 1584 | }, 1585 | "object-assign": { 1586 | "version": "4.1.1", 1587 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1588 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1589 | }, 1590 | "object-keys": { 1591 | "version": "1.1.1", 1592 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1593 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1594 | "dev": true 1595 | }, 1596 | "object.assign": { 1597 | "version": "4.1.0", 1598 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1599 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1600 | "dev": true, 1601 | "requires": { 1602 | "define-properties": "^1.1.2", 1603 | "function-bind": "^1.1.1", 1604 | "has-symbols": "^1.0.0", 1605 | "object-keys": "^1.0.11" 1606 | } 1607 | }, 1608 | "object.entries": { 1609 | "version": "1.1.0", 1610 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.0.tgz", 1611 | "integrity": "sha512-l+H6EQ8qzGRxbkHOd5I/aHRhHDKoQXQ8g0BYt4uSweQU1/J6dZUOyWh9a2Vky35YCKjzmgxOzta2hH6kf9HuXA==", 1612 | "dev": true, 1613 | "requires": { 1614 | "define-properties": "^1.1.3", 1615 | "es-abstract": "^1.12.0", 1616 | "function-bind": "^1.1.1", 1617 | "has": "^1.0.3" 1618 | } 1619 | }, 1620 | "on-finished": { 1621 | "version": "2.3.0", 1622 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1623 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1624 | "requires": { 1625 | "ee-first": "1.1.1" 1626 | } 1627 | }, 1628 | "once": { 1629 | "version": "1.4.0", 1630 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1631 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1632 | "requires": { 1633 | "wrappy": "1" 1634 | } 1635 | }, 1636 | "onetime": { 1637 | "version": "2.0.1", 1638 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 1639 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 1640 | "dev": true, 1641 | "requires": { 1642 | "mimic-fn": "^1.0.0" 1643 | } 1644 | }, 1645 | "optionator": { 1646 | "version": "0.8.2", 1647 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 1648 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 1649 | "dev": true, 1650 | "requires": { 1651 | "deep-is": "~0.1.3", 1652 | "fast-levenshtein": "~2.0.4", 1653 | "levn": "~0.3.0", 1654 | "prelude-ls": "~1.1.2", 1655 | "type-check": "~0.3.2", 1656 | "wordwrap": "~1.0.0" 1657 | } 1658 | }, 1659 | "os-homedir": { 1660 | "version": "1.0.2", 1661 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1662 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" 1663 | }, 1664 | "os-tmpdir": { 1665 | "version": "1.0.2", 1666 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1667 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 1668 | }, 1669 | "osenv": { 1670 | "version": "0.1.5", 1671 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", 1672 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", 1673 | "requires": { 1674 | "os-homedir": "^1.0.0", 1675 | "os-tmpdir": "^1.0.0" 1676 | } 1677 | }, 1678 | "p-limit": { 1679 | "version": "1.3.0", 1680 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1681 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1682 | "dev": true, 1683 | "requires": { 1684 | "p-try": "^1.0.0" 1685 | } 1686 | }, 1687 | "p-locate": { 1688 | "version": "2.0.0", 1689 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1690 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1691 | "dev": true, 1692 | "requires": { 1693 | "p-limit": "^1.1.0" 1694 | } 1695 | }, 1696 | "p-try": { 1697 | "version": "1.0.0", 1698 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1699 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 1700 | "dev": true 1701 | }, 1702 | "parent-module": { 1703 | "version": "1.0.1", 1704 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1705 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1706 | "dev": true, 1707 | "requires": { 1708 | "callsites": "^3.0.0" 1709 | } 1710 | }, 1711 | "parse-json": { 1712 | "version": "2.2.0", 1713 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 1714 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 1715 | "dev": true, 1716 | "requires": { 1717 | "error-ex": "^1.2.0" 1718 | } 1719 | }, 1720 | "parseurl": { 1721 | "version": "1.3.2", 1722 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz", 1723 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=" 1724 | }, 1725 | "path-exists": { 1726 | "version": "3.0.0", 1727 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1728 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1729 | "dev": true 1730 | }, 1731 | "path-is-absolute": { 1732 | "version": "1.0.1", 1733 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1734 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1735 | }, 1736 | "path-is-inside": { 1737 | "version": "1.0.2", 1738 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 1739 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 1740 | "dev": true 1741 | }, 1742 | "path-key": { 1743 | "version": "2.0.1", 1744 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1745 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1746 | "dev": true 1747 | }, 1748 | "path-parse": { 1749 | "version": "1.0.6", 1750 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1751 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 1752 | "dev": true 1753 | }, 1754 | "path-to-regexp": { 1755 | "version": "0.1.7", 1756 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1757 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1758 | }, 1759 | "path-type": { 1760 | "version": "2.0.0", 1761 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 1762 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 1763 | "dev": true, 1764 | "requires": { 1765 | "pify": "^2.0.0" 1766 | } 1767 | }, 1768 | "pify": { 1769 | "version": "2.3.0", 1770 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1771 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1772 | "dev": true 1773 | }, 1774 | "pkg-dir": { 1775 | "version": "2.0.0", 1776 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", 1777 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", 1778 | "dev": true, 1779 | "requires": { 1780 | "find-up": "^2.1.0" 1781 | } 1782 | }, 1783 | "prelude-ls": { 1784 | "version": "1.1.2", 1785 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1786 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1787 | "dev": true 1788 | }, 1789 | "process-nextick-args": { 1790 | "version": "2.0.0", 1791 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 1792 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==" 1793 | }, 1794 | "progress": { 1795 | "version": "2.0.3", 1796 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1797 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1798 | "dev": true 1799 | }, 1800 | "proxy-addr": { 1801 | "version": "2.0.4", 1802 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.4.tgz", 1803 | "integrity": "sha512-5erio2h9jp5CHGwcybmxmVqHmnCBZeewlfJ0pex+UW7Qny7OOZXTtH56TGNyBizkgiOwhJtMKrVzDTeKcySZwA==", 1804 | "requires": { 1805 | "forwarded": "~0.1.2", 1806 | "ipaddr.js": "1.8.0" 1807 | } 1808 | }, 1809 | "punycode": { 1810 | "version": "2.1.1", 1811 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1812 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1813 | "dev": true 1814 | }, 1815 | "qs": { 1816 | "version": "6.5.2", 1817 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 1818 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==" 1819 | }, 1820 | "range-parser": { 1821 | "version": "1.2.0", 1822 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 1823 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=" 1824 | }, 1825 | "raw-body": { 1826 | "version": "2.3.3", 1827 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.3.tgz", 1828 | "integrity": "sha512-9esiElv1BrZoI3rCDuOuKCBRbuApGGaDPQfjSflGxdy4oyzqghxu6klEkkVIvBje+FF0BX9coEv8KqW6X/7njw==", 1829 | "requires": { 1830 | "bytes": "3.0.0", 1831 | "http-errors": "1.6.3", 1832 | "iconv-lite": "0.4.23", 1833 | "unpipe": "1.0.0" 1834 | } 1835 | }, 1836 | "rc": { 1837 | "version": "1.2.8", 1838 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1839 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1840 | "requires": { 1841 | "deep-extend": "^0.6.0", 1842 | "ini": "~1.3.0", 1843 | "minimist": "^1.2.0", 1844 | "strip-json-comments": "~2.0.1" 1845 | }, 1846 | "dependencies": { 1847 | "minimist": { 1848 | "version": "1.2.0", 1849 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1850 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" 1851 | } 1852 | } 1853 | }, 1854 | "read-pkg": { 1855 | "version": "2.0.0", 1856 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 1857 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 1858 | "dev": true, 1859 | "requires": { 1860 | "load-json-file": "^2.0.0", 1861 | "normalize-package-data": "^2.3.2", 1862 | "path-type": "^2.0.0" 1863 | } 1864 | }, 1865 | "read-pkg-up": { 1866 | "version": "2.0.0", 1867 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 1868 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 1869 | "dev": true, 1870 | "requires": { 1871 | "find-up": "^2.0.0", 1872 | "read-pkg": "^2.0.0" 1873 | } 1874 | }, 1875 | "readable-stream": { 1876 | "version": "2.3.6", 1877 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 1878 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 1879 | "requires": { 1880 | "core-util-is": "~1.0.0", 1881 | "inherits": "~2.0.3", 1882 | "isarray": "~1.0.0", 1883 | "process-nextick-args": "~2.0.0", 1884 | "safe-buffer": "~5.1.1", 1885 | "string_decoder": "~1.1.1", 1886 | "util-deprecate": "~1.0.1" 1887 | } 1888 | }, 1889 | "redis": { 1890 | "version": "2.8.0", 1891 | "resolved": "https://registry.npmjs.org/redis/-/redis-2.8.0.tgz", 1892 | "integrity": "sha512-M1OkonEQwtRmZv4tEWF2VgpG0JWJ8Fv1PhlgT5+B+uNq2cA3Rt1Yt/ryoR+vQNOQcIEgdCdfH0jr3bDpihAw1A==", 1893 | "requires": { 1894 | "double-ended-queue": "^2.1.0-0", 1895 | "redis-commands": "^1.2.0", 1896 | "redis-parser": "^2.6.0" 1897 | } 1898 | }, 1899 | "redis-commands": { 1900 | "version": "1.4.0", 1901 | "resolved": "https://registry.npmjs.org/redis-commands/-/redis-commands-1.4.0.tgz", 1902 | "integrity": "sha512-cu8EF+MtkwI4DLIT0x9P8qNTLFhQD4jLfxLR0cCNkeGzs87FN6879JOJwNQR/1zD7aSYNbU0hgsV9zGY71Itvw==" 1903 | }, 1904 | "redis-parser": { 1905 | "version": "2.6.0", 1906 | "resolved": "https://registry.npmjs.org/redis-parser/-/redis-parser-2.6.0.tgz", 1907 | "integrity": "sha1-Uu0J2srBCPGmMcB+m2mUHnoZUEs=" 1908 | }, 1909 | "regexpp": { 1910 | "version": "2.0.1", 1911 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 1912 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 1913 | "dev": true 1914 | }, 1915 | "require_optional": { 1916 | "version": "1.0.1", 1917 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 1918 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 1919 | "requires": { 1920 | "resolve-from": "^2.0.0", 1921 | "semver": "^5.1.0" 1922 | } 1923 | }, 1924 | "resolve": { 1925 | "version": "1.10.0", 1926 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.0.tgz", 1927 | "integrity": "sha512-3sUr9aq5OfSg2S9pNtPA9hL1FVEAjvfOC4leW0SNf/mpnaakz2a9femSd6LqAww2RaFctwyf1lCqnTHuF1rxDg==", 1928 | "dev": true, 1929 | "requires": { 1930 | "path-parse": "^1.0.6" 1931 | } 1932 | }, 1933 | "resolve-from": { 1934 | "version": "2.0.0", 1935 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 1936 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=" 1937 | }, 1938 | "restore-cursor": { 1939 | "version": "2.0.0", 1940 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 1941 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 1942 | "dev": true, 1943 | "requires": { 1944 | "onetime": "^2.0.0", 1945 | "signal-exit": "^3.0.2" 1946 | } 1947 | }, 1948 | "rimraf": { 1949 | "version": "2.6.3", 1950 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1951 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1952 | "requires": { 1953 | "glob": "^7.1.3" 1954 | } 1955 | }, 1956 | "run-async": { 1957 | "version": "2.3.0", 1958 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 1959 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 1960 | "dev": true, 1961 | "requires": { 1962 | "is-promise": "^2.1.0" 1963 | } 1964 | }, 1965 | "rxjs": { 1966 | "version": "6.4.0", 1967 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.4.0.tgz", 1968 | "integrity": "sha512-Z9Yfa11F6B9Sg/BK9MnqnQ+aQYicPLtilXBp2yUtDt2JRCE0h26d33EnfO3ZxoNxG0T92OUucP3Ct7cpfkdFfw==", 1969 | "dev": true, 1970 | "requires": { 1971 | "tslib": "^1.9.0" 1972 | } 1973 | }, 1974 | "safe-buffer": { 1975 | "version": "5.1.1", 1976 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 1977 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" 1978 | }, 1979 | "safer-buffer": { 1980 | "version": "2.1.2", 1981 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1982 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1983 | }, 1984 | "saslprep": { 1985 | "version": "1.0.1", 1986 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.1.tgz", 1987 | "integrity": "sha512-ntN6SbE3hRqd45PKKadRPgA+xHPWg5lPSj2JWJdJvjTwXDDfkPVtXWvP8jJojvnm+rAsZ2b299C5NwZqq818EA==", 1988 | "optional": true 1989 | }, 1990 | "sax": { 1991 | "version": "1.2.4", 1992 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 1993 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" 1994 | }, 1995 | "semver": { 1996 | "version": "5.5.0", 1997 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.0.tgz", 1998 | "integrity": "sha512-4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA==" 1999 | }, 2000 | "send": { 2001 | "version": "0.16.2", 2002 | "resolved": "https://registry.npmjs.org/send/-/send-0.16.2.tgz", 2003 | "integrity": "sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw==", 2004 | "requires": { 2005 | "debug": "2.6.9", 2006 | "depd": "~1.1.2", 2007 | "destroy": "~1.0.4", 2008 | "encodeurl": "~1.0.2", 2009 | "escape-html": "~1.0.3", 2010 | "etag": "~1.8.1", 2011 | "fresh": "0.5.2", 2012 | "http-errors": "~1.6.2", 2013 | "mime": "1.4.1", 2014 | "ms": "2.0.0", 2015 | "on-finished": "~2.3.0", 2016 | "range-parser": "~1.2.0", 2017 | "statuses": "~1.4.0" 2018 | }, 2019 | "dependencies": { 2020 | "statuses": { 2021 | "version": "1.4.0", 2022 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 2023 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==" 2024 | } 2025 | } 2026 | }, 2027 | "serve-static": { 2028 | "version": "1.13.2", 2029 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.13.2.tgz", 2030 | "integrity": "sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw==", 2031 | "requires": { 2032 | "encodeurl": "~1.0.2", 2033 | "escape-html": "~1.0.3", 2034 | "parseurl": "~1.3.2", 2035 | "send": "0.16.2" 2036 | } 2037 | }, 2038 | "set-blocking": { 2039 | "version": "2.0.0", 2040 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 2041 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 2042 | }, 2043 | "setprototypeof": { 2044 | "version": "1.1.0", 2045 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", 2046 | "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==" 2047 | }, 2048 | "shebang-command": { 2049 | "version": "1.2.0", 2050 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2051 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2052 | "dev": true, 2053 | "requires": { 2054 | "shebang-regex": "^1.0.0" 2055 | } 2056 | }, 2057 | "shebang-regex": { 2058 | "version": "1.0.0", 2059 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2060 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2061 | "dev": true 2062 | }, 2063 | "signal-exit": { 2064 | "version": "3.0.2", 2065 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2066 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" 2067 | }, 2068 | "slice-ansi": { 2069 | "version": "2.1.0", 2070 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 2071 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 2072 | "dev": true, 2073 | "requires": { 2074 | "ansi-styles": "^3.2.0", 2075 | "astral-regex": "^1.0.0", 2076 | "is-fullwidth-code-point": "^2.0.0" 2077 | } 2078 | }, 2079 | "spdx-correct": { 2080 | "version": "3.1.0", 2081 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", 2082 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", 2083 | "dev": true, 2084 | "requires": { 2085 | "spdx-expression-parse": "^3.0.0", 2086 | "spdx-license-ids": "^3.0.0" 2087 | } 2088 | }, 2089 | "spdx-exceptions": { 2090 | "version": "2.2.0", 2091 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", 2092 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", 2093 | "dev": true 2094 | }, 2095 | "spdx-expression-parse": { 2096 | "version": "3.0.0", 2097 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 2098 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 2099 | "dev": true, 2100 | "requires": { 2101 | "spdx-exceptions": "^2.1.0", 2102 | "spdx-license-ids": "^3.0.0" 2103 | } 2104 | }, 2105 | "spdx-license-ids": { 2106 | "version": "3.0.4", 2107 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.4.tgz", 2108 | "integrity": "sha512-7j8LYJLeY/Yb6ACbQ7F76qy5jHkp0U6jgBfJsk97bwWlVUnUWsAgpyaCvo17h0/RQGnQ036tVDomiwoI4pDkQA==", 2109 | "dev": true 2110 | }, 2111 | "sprintf-js": { 2112 | "version": "1.0.3", 2113 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2114 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2115 | "dev": true 2116 | }, 2117 | "statuses": { 2118 | "version": "1.5.0", 2119 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 2120 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 2121 | }, 2122 | "string-width": { 2123 | "version": "2.1.1", 2124 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2125 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2126 | "requires": { 2127 | "is-fullwidth-code-point": "^2.0.0", 2128 | "strip-ansi": "^4.0.0" 2129 | } 2130 | }, 2131 | "string_decoder": { 2132 | "version": "1.1.1", 2133 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2134 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2135 | "requires": { 2136 | "safe-buffer": "~5.1.0" 2137 | } 2138 | }, 2139 | "strip-ansi": { 2140 | "version": "4.0.0", 2141 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2142 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2143 | "requires": { 2144 | "ansi-regex": "^3.0.0" 2145 | } 2146 | }, 2147 | "strip-bom": { 2148 | "version": "3.0.0", 2149 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2150 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2151 | "dev": true 2152 | }, 2153 | "strip-json-comments": { 2154 | "version": "2.0.1", 2155 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2156 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 2157 | }, 2158 | "supports-color": { 2159 | "version": "5.5.0", 2160 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2161 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2162 | "dev": true, 2163 | "requires": { 2164 | "has-flag": "^3.0.0" 2165 | } 2166 | }, 2167 | "table": { 2168 | "version": "5.2.3", 2169 | "resolved": "https://registry.npmjs.org/table/-/table-5.2.3.tgz", 2170 | "integrity": "sha512-N2RsDAMvDLvYwFcwbPyF3VmVSSkuF+G1e+8inhBLtHpvwXGw4QRPEZhihQNeEN0i1up6/f6ObCJXNdlRG3YVyQ==", 2171 | "dev": true, 2172 | "requires": { 2173 | "ajv": "^6.9.1", 2174 | "lodash": "^4.17.11", 2175 | "slice-ansi": "^2.1.0", 2176 | "string-width": "^3.0.0" 2177 | }, 2178 | "dependencies": { 2179 | "ansi-regex": { 2180 | "version": "4.1.0", 2181 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2182 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2183 | "dev": true 2184 | }, 2185 | "string-width": { 2186 | "version": "3.1.0", 2187 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2188 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2189 | "dev": true, 2190 | "requires": { 2191 | "emoji-regex": "^7.0.1", 2192 | "is-fullwidth-code-point": "^2.0.0", 2193 | "strip-ansi": "^5.1.0" 2194 | } 2195 | }, 2196 | "strip-ansi": { 2197 | "version": "5.2.0", 2198 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2199 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2200 | "dev": true, 2201 | "requires": { 2202 | "ansi-regex": "^4.1.0" 2203 | } 2204 | } 2205 | } 2206 | }, 2207 | "tar": { 2208 | "version": "4.4.8", 2209 | "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.8.tgz", 2210 | "integrity": "sha512-LzHF64s5chPQQS0IYBn9IN5h3i98c12bo4NCO7e0sGM2llXQ3p2FGC5sdENN4cTW48O915Sh+x+EXx7XW96xYQ==", 2211 | "requires": { 2212 | "chownr": "^1.1.1", 2213 | "fs-minipass": "^1.2.5", 2214 | "minipass": "^2.3.4", 2215 | "minizlib": "^1.1.1", 2216 | "mkdirp": "^0.5.0", 2217 | "safe-buffer": "^5.1.2", 2218 | "yallist": "^3.0.2" 2219 | }, 2220 | "dependencies": { 2221 | "safe-buffer": { 2222 | "version": "5.1.2", 2223 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2224 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2225 | } 2226 | } 2227 | }, 2228 | "text-table": { 2229 | "version": "0.2.0", 2230 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2231 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2232 | "dev": true 2233 | }, 2234 | "through": { 2235 | "version": "2.3.8", 2236 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2237 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2238 | "dev": true 2239 | }, 2240 | "tmp": { 2241 | "version": "0.0.33", 2242 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 2243 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 2244 | "dev": true, 2245 | "requires": { 2246 | "os-tmpdir": "~1.0.2" 2247 | } 2248 | }, 2249 | "tslib": { 2250 | "version": "1.9.3", 2251 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz", 2252 | "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==", 2253 | "dev": true 2254 | }, 2255 | "type-check": { 2256 | "version": "0.3.2", 2257 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 2258 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 2259 | "dev": true, 2260 | "requires": { 2261 | "prelude-ls": "~1.1.2" 2262 | } 2263 | }, 2264 | "type-is": { 2265 | "version": "1.6.16", 2266 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.16.tgz", 2267 | "integrity": "sha512-HRkVv/5qY2G6I8iab9cI7v1bOIdhm94dVjQCPFElW9W+3GeDOSHmy2EBYe4VTApuzolPcmgFTN3ftVJRKR2J9Q==", 2268 | "requires": { 2269 | "media-typer": "0.3.0", 2270 | "mime-types": "~2.1.18" 2271 | } 2272 | }, 2273 | "unpipe": { 2274 | "version": "1.0.0", 2275 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2276 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 2277 | }, 2278 | "uri-js": { 2279 | "version": "4.2.2", 2280 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2281 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2282 | "dev": true, 2283 | "requires": { 2284 | "punycode": "^2.1.0" 2285 | } 2286 | }, 2287 | "util-deprecate": { 2288 | "version": "1.0.2", 2289 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2290 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 2291 | }, 2292 | "utils-merge": { 2293 | "version": "1.0.1", 2294 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2295 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 2296 | }, 2297 | "validate-npm-package-license": { 2298 | "version": "3.0.4", 2299 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 2300 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 2301 | "dev": true, 2302 | "requires": { 2303 | "spdx-correct": "^3.0.0", 2304 | "spdx-expression-parse": "^3.0.0" 2305 | } 2306 | }, 2307 | "vary": { 2308 | "version": "1.1.2", 2309 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2310 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 2311 | }, 2312 | "which": { 2313 | "version": "1.3.1", 2314 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2315 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2316 | "dev": true, 2317 | "requires": { 2318 | "isexe": "^2.0.0" 2319 | } 2320 | }, 2321 | "wide-align": { 2322 | "version": "1.1.3", 2323 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 2324 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 2325 | "requires": { 2326 | "string-width": "^1.0.2 || 2" 2327 | } 2328 | }, 2329 | "wordwrap": { 2330 | "version": "1.0.0", 2331 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 2332 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 2333 | "dev": true 2334 | }, 2335 | "wrappy": { 2336 | "version": "1.0.2", 2337 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2338 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 2339 | }, 2340 | "write": { 2341 | "version": "1.0.3", 2342 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 2343 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 2344 | "dev": true, 2345 | "requires": { 2346 | "mkdirp": "^0.5.1" 2347 | } 2348 | }, 2349 | "yallist": { 2350 | "version": "3.0.3", 2351 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.0.3.tgz", 2352 | "integrity": "sha512-S+Zk8DEWE6oKpV+vI3qWkaK+jSbIK86pCwe2IF/xwIpQ8jEuxpw9NyaGjmp9+BoJv5FV2piqCDcoCtStppiq2A==" 2353 | } 2354 | } 2355 | } 2356 | -------------------------------------------------------------------------------- /UserService/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "userservice", 3 | "version": "1.0.0", 4 | "description": "This is a service to manage Users API", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1", 8 | "start": "node index.js", 9 | "lint": "eslint" 10 | }, 11 | "author": "Iosys Pvt Ltd", 12 | "license": "MIT", 13 | "dependencies": { 14 | "bcrypt": "^3.0.6", 15 | "body-parser": "^1.18.3", 16 | "cors": "^2.8.4", 17 | "dotenv": "^7.0.0", 18 | "express": "^4.16.3", 19 | "express-jwt": "^5.3.1", 20 | "mongodb": "^3.1.3", 21 | "redis": "^2.8.0" 22 | }, 23 | "devDependencies": { 24 | "eslint": "^5.16.0", 25 | "eslint-config-airbnb-base": "^13.1.0", 26 | "eslint-plugin-import": "^2.17.1" 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /UserService/routes.js: -------------------------------------------------------------------------------- 1 | const routeHandler = require('./handlers/route-handler'); 2 | 3 | class Routes { 4 | constructor(app) { 5 | this.app = app; 6 | } 7 | 8 | /* creating app Routes starts */ 9 | appRoutes() { 10 | this.app.post('/register', routeHandler.registerRouteHandler); 11 | this.app.post('/login', routeHandler.loginRouteHandler); 12 | this.app.get('/user/:userId', routeHandler.getUserDetailsHandler); 13 | this.app.get('*', routeHandler.routeNotFoundHandler); 14 | } 15 | 16 | routesConfig() { 17 | this.appRoutes(); 18 | } 19 | } 20 | module.exports = Routes; 21 | -------------------------------------------------------------------------------- /UserService/server.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable no-console */ 2 | const express = require('express'); 3 | const http = require('http'); 4 | 5 | const AppConfig = require('./config/app-config'); 6 | const Routes = require('./routes'); 7 | 8 | class Server { 9 | constructor() { 10 | this.app = express(); 11 | this.http = http.Server(this.app); 12 | } 13 | 14 | appConfig() { 15 | new AppConfig(this.app).includeConfig(); 16 | } 17 | 18 | /* Including app Routes starts */ 19 | includeRoutes() { 20 | new Routes(this.app).routesConfig(); 21 | } 22 | /* Including app Routes ends */ 23 | 24 | startTheServer() { 25 | this.appConfig(); 26 | this.includeRoutes(); 27 | 28 | const port = process.env.NODE_SERVER_POST || 4000; 29 | const host = process.env.NODE_SERVER_HOST || 'localhost'; 30 | 31 | this.http.listen(port, host, () => { 32 | console.log(`Listening on http://${host}:${port}`); 33 | }); 34 | } 35 | } 36 | 37 | module.exports = new Server(); 38 | -------------------------------------------------------------------------------- /UserService/utils/jwt-route.js: -------------------------------------------------------------------------------- 1 | module.exports = [ 2 | '/', 3 | '/user/userId', 4 | ]; 5 | -------------------------------------------------------------------------------- /UserService/utils/jwt.js: -------------------------------------------------------------------------------- 1 | const expressJwt = require('express-jwt'); 2 | const publicRoutes = require('./jwt-route'); 3 | 4 | class JWT { 5 | constructor(app) { 6 | this.app = app; 7 | } 8 | 9 | setJWTConfig() { 10 | this.app.use( 11 | expressJwt({ 12 | secret: process.env.JWT_SECRET, 13 | }).unless({ 14 | path: publicRoutes, 15 | }), 16 | ); 17 | } 18 | } 19 | 20 | 21 | module.exports = JWT; 22 | -------------------------------------------------------------------------------- /UserService/utils/password-hash.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable class-methods-use-this */ 2 | const bcrypt = require('bcrypt'); 3 | 4 | class PasswordHash { 5 | createHash(password) { 6 | return bcrypt.hashSync(password, 10); 7 | } 8 | 9 | compareHash(password, hash) { 10 | return bcrypt.compareSync(password, hash); 11 | } 12 | } 13 | 14 | module.exports = new PasswordHash(); 15 | --------------------------------------------------------------------------------