├── .dockerignore ├── .eslintrc.json ├── .gitignore ├── .husky ├── .gitignore └── pre-commit ├── .prettierignore ├── .prettierrc.json ├── .vscode ├── launch.json └── settings.json ├── README.md ├── docs ├── architecture.jpg └── clean-architecture.jpg ├── package-lock.json ├── package.json ├── src ├── app.ts ├── configs.ts ├── controllers │ ├── activity.controller.ts │ ├── auth.controller.ts │ ├── definations.ts │ ├── task.controller.ts │ └── user.controller.ts ├── entities │ ├── activity.entity.ts │ ├── task.entity.ts │ └── user.entity.ts ├── env.ts ├── events │ ├── activity.event.ts │ └── definations.ts ├── index.ts ├── repositories │ ├── activity.repository.ts │ ├── definations.ts │ ├── task.repository.ts │ └── user.repository.ts └── services │ ├── activity.service.ts │ ├── auth.service.test.ts │ ├── auth.service.ts │ ├── definations.ts │ ├── task.service.ts │ └── user.service.ts └── tsconfig.json /.dockerignore: -------------------------------------------------------------------------------- 1 | .vscode/ 2 | /configs 3 | node_modules/ 4 | .dockerignore 5 | .gitignore 6 | docker_*.sh 7 | Dockerfile 8 | *.md 9 | **/test/ 10 | .env 11 | docker-compose.* 12 | deploy/ 13 | dist/ 14 | logs/ 15 | .eslintrc 16 | resources 17 | -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "root": true, 3 | "parser": "@typescript-eslint/parser", 4 | "plugins": ["@typescript-eslint", "prettier"], 5 | "extends": [ 6 | "eslint:recommended", 7 | "plugin:@typescript-eslint/eslint-recommended", 8 | "plugin:@typescript-eslint/recommended", 9 | "prettier" 10 | ], 11 | "rules": { 12 | "prettier/prettier": 1, 13 | "@typescript-eslint/no-explicit-any": "off", 14 | "@typescript-eslint/no-unused-vars": "off", 15 | "@typescript-eslint/explicit-module-boundary-types": "off", 16 | "@typescript-eslint/no-empty-interface": "off", 17 | "no-case-declarations": "off", 18 | "no-constant-condition": "off", 19 | "no-useless-escape": "off" 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | deploy/deploy.sh 2 | deploy/docker-compose.env 3 | deploy/initdb.js 4 | 5 | public/ 6 | # Logs 7 | logs 8 | *.log 9 | npm-debug.log* 10 | yarn-debug.log* 11 | yarn-error.log* 12 | 13 | # Runtime data 14 | pids 15 | *.pid 16 | *.seed 17 | *.pid.lock 18 | 19 | # Directory for instrumented libs generated by jscoverage/JSCover 20 | lib-cov 21 | 22 | # Coverage directory used by tools like istanbul 23 | coverage 24 | 25 | # nyc test coverage 26 | .nyc_output 27 | 28 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 29 | .grunt 30 | 31 | # Bower dependency directory (https://bower.io/) 32 | bower_components 33 | 34 | # node-waf configuration 35 | .lock-wscript 36 | 37 | # Compiled binary addons (https://nodejs.org/api/addons.html) 38 | build/Release 39 | 40 | # Dependency directories 41 | node_modules/ 42 | jspm_packages/ 43 | 44 | # Typescript v1 declaration files 45 | typings/ 46 | 47 | # Optional npm cache directory 48 | .npm 49 | 50 | # Optional eslint cache 51 | .eslintcache 52 | 53 | # Optional REPL history 54 | .node_repl_history 55 | 56 | # Output of 'npm pack' 57 | *.tgz 58 | 59 | # Yarn Integrity file 60 | .yarn-integrity 61 | 62 | # dotenv environment variables file 63 | .env 64 | 65 | # next.js build output 66 | .next 67 | 68 | # JetBrains IDE 69 | .idea 70 | 71 | # Don't track transpiled files 72 | dist/ 73 | docker-compose.yml -------------------------------------------------------------------------------- /.husky/.gitignore: -------------------------------------------------------------------------------- 1 | _ 2 | -------------------------------------------------------------------------------- /.husky/pre-commit: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | . "$(dirname "$0")/_/husky.sh" 3 | 4 | npx lint-staged 5 | npx lint-staged 6 | -------------------------------------------------------------------------------- /.prettierignore: -------------------------------------------------------------------------------- 1 | dist 2 | node_modules 3 | public 4 | .vscode 5 | 6 | -------------------------------------------------------------------------------- /.prettierrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "semi": true, 3 | "trailingComma": "none", 4 | "singleQuote": true, 5 | "printWidth": 100 6 | } 7 | -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | { 2 | // Use IntelliSense to learn about possible attributes. 3 | // Hover to view descriptions of existing attributes. 4 | // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 5 | "version": "0.2.0", 6 | "configurations": [ 7 | { 8 | "type": "node", 9 | "request": "launch", 10 | "name": "Launch Program", 11 | "skipFiles": ["/**"], 12 | "program": "${workspaceFolder}/src/index.ts", 13 | "preLaunchTask": "tsc: build - tsconfig.json", 14 | "sourceMaps": true, 15 | "smartStep": true, 16 | "outFiles": ["${workspaceFolder}/dist/**/*.js"] 17 | } 18 | ] 19 | } 20 | -------------------------------------------------------------------------------- /.vscode/settings.json: -------------------------------------------------------------------------------- 1 | { 2 | "editor.tabSize": 2, 3 | "editor.defaultFormatter": "dbaeumer.vscode-eslint", 4 | "editor.formatOnSave": true, 5 | "eslint.alwaysShowStatus": true, 6 | "eslint.validate": ["javascript", "typescript"], 7 | } 8 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # NODEJS ARCHITECTURE WITH SOLID PRINCIPLES 2 | 3 | ## Running 4 | ### 1. Install Package 5 | - npm install 6 | - npm install -D @types/express @types/mongoose 7 | 8 | ### 2. Testing 9 | npm run test 10 | 11 | ### 3. Run in development mode 12 | npm run dev 13 | 14 | ### 4. Build 15 | npm run build 16 | 17 | ### 5. Run in production mode 18 | npm run start 19 | 20 | ## Architecture 21 | 22 |

23 | 24 |

25 | 26 |

27 | 28 |

29 | 30 | ## FLOW 31 | 32 | Table 33 | ``` 34 | User 35 | Task: User do task 36 | Activity: Logging user action from event 37 | ``` 38 | 39 | Guide: update soon at https://mysolution.dev -------------------------------------------------------------------------------- /docs/architecture.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/vtuanjs/typescript-solid-principles/ea23275de05159ef65570fa5dcb557ebb78ed427/docs/architecture.jpg -------------------------------------------------------------------------------- /docs/clean-architecture.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/vtuanjs/typescript-solid-principles/ea23275de05159ef65570fa5dcb557ebb78ed427/docs/clean-architecture.jpg -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "ega-mini-crm", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.12.11", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 10 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.10.4" 14 | } 15 | }, 16 | "@babel/helper-validator-identifier": { 17 | "version": "7.14.0", 18 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.0.tgz", 19 | "integrity": "sha512-V3ts7zMSu5lfiwWDVWzRDGIN+lnCEUdaXgtVHJgLb1rGaA6jMrtB9EmE7L18foXJIE8Un/A/h6NJfGQp/e1J4A==", 20 | "dev": true 21 | }, 22 | "@babel/highlight": { 23 | "version": "7.14.0", 24 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.14.0.tgz", 25 | "integrity": "sha512-YSCOwxvTYEIMSGaBQb5kDDsCopDdiUGsqpatp3fOlI4+2HQSkTmEVWnVuySdAC5EWCqSWWTv0ib63RjR7dTBdg==", 26 | "dev": true, 27 | "requires": { 28 | "@babel/helper-validator-identifier": "^7.14.0", 29 | "chalk": "^2.0.0", 30 | "js-tokens": "^4.0.0" 31 | }, 32 | "dependencies": { 33 | "chalk": { 34 | "version": "2.4.2", 35 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 36 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 37 | "dev": true, 38 | "requires": { 39 | "ansi-styles": "^3.2.1", 40 | "escape-string-regexp": "^1.0.5", 41 | "supports-color": "^5.3.0" 42 | } 43 | }, 44 | "escape-string-regexp": { 45 | "version": "1.0.5", 46 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 47 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 48 | "dev": true 49 | } 50 | } 51 | }, 52 | "@dabh/diagnostics": { 53 | "version": "2.0.2", 54 | "resolved": "https://registry.npmjs.org/@dabh/diagnostics/-/diagnostics-2.0.2.tgz", 55 | "integrity": "sha512-+A1YivoVDNNVCdfozHSR8v/jyuuLTMXwjWuxPFlFlUapXoGc+Gj9mDlTDDfrwl7rXCl2tNZ0kE8sIBO6YOn96Q==", 56 | "requires": { 57 | "colorspace": "1.1.x", 58 | "enabled": "2.0.x", 59 | "kuler": "^2.0.0" 60 | } 61 | }, 62 | "@eslint/eslintrc": { 63 | "version": "0.4.1", 64 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.1.tgz", 65 | "integrity": "sha512-5v7TDE9plVhvxQeWLXDTvFvJBdH6pEsdnl2g/dAptmuFEPedQ4Erq5rsDsX+mvAM610IhNaO2W5V1dOOnDKxkQ==", 66 | "dev": true, 67 | "requires": { 68 | "ajv": "^6.12.4", 69 | "debug": "^4.1.1", 70 | "espree": "^7.3.0", 71 | "globals": "^12.1.0", 72 | "ignore": "^4.0.6", 73 | "import-fresh": "^3.2.1", 74 | "js-yaml": "^3.13.1", 75 | "minimatch": "^3.0.4", 76 | "strip-json-comments": "^3.1.1" 77 | }, 78 | "dependencies": { 79 | "globals": { 80 | "version": "12.4.0", 81 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 82 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 83 | "dev": true, 84 | "requires": { 85 | "type-fest": "^0.8.1" 86 | } 87 | }, 88 | "ignore": { 89 | "version": "4.0.6", 90 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 91 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 92 | "dev": true 93 | } 94 | } 95 | }, 96 | "@mapbox/node-pre-gyp": { 97 | "version": "1.0.5", 98 | "resolved": "https://registry.npmjs.org/@mapbox/node-pre-gyp/-/node-pre-gyp-1.0.5.tgz", 99 | "integrity": "sha512-4srsKPXWlIxp5Vbqz5uLfBN+du2fJChBoYn/f2h991WLdk7jUvcSk/McVLSv/X+xQIPI8eGD5GjrnygdyHnhPA==", 100 | "requires": { 101 | "detect-libc": "^1.0.3", 102 | "https-proxy-agent": "^5.0.0", 103 | "make-dir": "^3.1.0", 104 | "node-fetch": "^2.6.1", 105 | "nopt": "^5.0.0", 106 | "npmlog": "^4.1.2", 107 | "rimraf": "^3.0.2", 108 | "semver": "^7.3.4", 109 | "tar": "^6.1.0" 110 | } 111 | }, 112 | "@nodelib/fs.scandir": { 113 | "version": "2.1.4", 114 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.4.tgz", 115 | "integrity": "sha512-33g3pMJk3bg5nXbL/+CY6I2eJDzZAni49PfJnL5fghPTggPvBd/pFNSgJsdAgWptuFu7qq/ERvOYFlhvsLTCKA==", 116 | "dev": true, 117 | "requires": { 118 | "@nodelib/fs.stat": "2.0.4", 119 | "run-parallel": "^1.1.9" 120 | } 121 | }, 122 | "@nodelib/fs.stat": { 123 | "version": "2.0.4", 124 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.4.tgz", 125 | "integrity": "sha512-IYlHJA0clt2+Vg7bccq+TzRdJvv19c2INqBSsoOLp1je7xjtr7J26+WXR72MCdvU9q1qTzIWDfhMf+DRvQJK4Q==", 126 | "dev": true 127 | }, 128 | "@nodelib/fs.walk": { 129 | "version": "1.2.6", 130 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.6.tgz", 131 | "integrity": "sha512-8Broas6vTtW4GIXTAHDoE32hnN2M5ykgCpWGbuXHQ15vEMqr23pB76e/GZcYsZCHALv50ktd24qhEyKr6wBtow==", 132 | "dev": true, 133 | "requires": { 134 | "@nodelib/fs.scandir": "2.1.4", 135 | "fastq": "^1.6.0" 136 | } 137 | }, 138 | "@sinonjs/commons": { 139 | "version": "1.8.3", 140 | "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.3.tgz", 141 | "integrity": "sha512-xkNcLAn/wZaX14RPlwizcKicDk9G3F8m2nU3L7Ukm5zBgTwiT0wsoFAHx9Jq56fJA1z/7uKGtCRu16sOUCLIHQ==", 142 | "dev": true, 143 | "requires": { 144 | "type-detect": "4.0.8" 145 | } 146 | }, 147 | "@sinonjs/fake-timers": { 148 | "version": "6.0.1", 149 | "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-6.0.1.tgz", 150 | "integrity": "sha512-MZPUxrmFubI36XS1DI3qmI0YdN1gks62JtFZvxR67ljjSNCeK6U08Zx4msEWOXuofgqUt6zPHSi1H9fbjR/NRA==", 151 | "dev": true, 152 | "requires": { 153 | "@sinonjs/commons": "^1.7.0" 154 | } 155 | }, 156 | "@sinonjs/samsam": { 157 | "version": "5.3.1", 158 | "resolved": "https://registry.npmjs.org/@sinonjs/samsam/-/samsam-5.3.1.tgz", 159 | "integrity": "sha512-1Hc0b1TtyfBu8ixF/tpfSHTVWKwCBLY4QJbkgnE7HcwyvT2xArDxb4K7dMgqRm3szI+LJbzmW/s4xxEhv6hwDg==", 160 | "dev": true, 161 | "requires": { 162 | "@sinonjs/commons": "^1.6.0", 163 | "lodash.get": "^4.4.2", 164 | "type-detect": "^4.0.8" 165 | } 166 | }, 167 | "@sinonjs/text-encoding": { 168 | "version": "0.7.1", 169 | "resolved": "https://registry.npmjs.org/@sinonjs/text-encoding/-/text-encoding-0.7.1.tgz", 170 | "integrity": "sha512-+iTbntw2IZPb/anVDbypzfQa+ay64MW0Zo8aJ8gZPWMMK6/OubMVb6lUPMagqjOPnmtauXnFCACVl3O7ogjeqQ==", 171 | "dev": true 172 | }, 173 | "@types/bcrypt": { 174 | "version": "5.0.0", 175 | "resolved": "https://registry.npmjs.org/@types/bcrypt/-/bcrypt-5.0.0.tgz", 176 | "integrity": "sha512-agtcFKaruL8TmcvqbndlqHPSJgsolhf/qPWchFlgnW1gECTN/nKbFcoFnvKAQRFfKbh+BO6A3SWdJu9t+xF3Lw==", 177 | "dev": true, 178 | "requires": { 179 | "@types/node": "*" 180 | } 181 | }, 182 | "@types/body-parser": { 183 | "version": "1.19.0", 184 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.0.tgz", 185 | "integrity": "sha512-W98JrE0j2K78swW4ukqMleo8R7h/pFETjM2DQ90MF6XK2i4LO4W3gQ71Lt4w3bfm2EvVSyWHplECvB5sK22yFQ==", 186 | "dev": true, 187 | "requires": { 188 | "@types/connect": "*", 189 | "@types/node": "*" 190 | } 191 | }, 192 | "@types/bson": { 193 | "version": "4.0.3", 194 | "resolved": "https://registry.npmjs.org/@types/bson/-/bson-4.0.3.tgz", 195 | "integrity": "sha512-mVRvYnTOZJz3ccpxhr3wgxVmSeiYinW+zlzQz3SXWaJmD1DuL05Jeq7nKw3SnbKmbleW5qrLG5vdyWe/A9sXhw==", 196 | "dev": true, 197 | "requires": { 198 | "@types/node": "*" 199 | } 200 | }, 201 | "@types/chai": { 202 | "version": "4.2.18", 203 | "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.2.18.tgz", 204 | "integrity": "sha512-rS27+EkB/RE1Iz3u0XtVL5q36MGDWbgYe7zWiodyKNUnthxY0rukK5V36eiUCtCisB7NN8zKYH6DO2M37qxFEQ==", 205 | "dev": true 206 | }, 207 | "@types/connect": { 208 | "version": "3.4.34", 209 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.34.tgz", 210 | "integrity": "sha512-ePPA/JuI+X0vb+gSWlPKOY0NdNAie/rPUqX2GUPpbZwiKTkSPhjXWuee47E4MtE54QVzGCQMQkAL6JhV2E1+cQ==", 211 | "dev": true, 212 | "requires": { 213 | "@types/node": "*" 214 | } 215 | }, 216 | "@types/express": { 217 | "version": "4.17.11", 218 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.11.tgz", 219 | "integrity": "sha512-no+R6rW60JEc59977wIxreQVsIEOAYwgCqldrA/vkpCnbD7MqTefO97lmoBe4WE0F156bC4uLSP1XHDOySnChg==", 220 | "dev": true, 221 | "requires": { 222 | "@types/body-parser": "*", 223 | "@types/express-serve-static-core": "^4.17.18", 224 | "@types/qs": "*", 225 | "@types/serve-static": "*" 226 | } 227 | }, 228 | "@types/express-serve-static-core": { 229 | "version": "4.17.19", 230 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.19.tgz", 231 | "integrity": "sha512-DJOSHzX7pCiSElWaGR8kCprwibCB/3yW6vcT8VG3P0SJjnv19gnWG/AZMfM60Xj/YJIp/YCaDHyvzsFVeniARA==", 232 | "dev": true, 233 | "requires": { 234 | "@types/node": "*", 235 | "@types/qs": "*", 236 | "@types/range-parser": "*" 237 | } 238 | }, 239 | "@types/json-schema": { 240 | "version": "7.0.7", 241 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.7.tgz", 242 | "integrity": "sha512-cxWFQVseBm6O9Gbw1IWb8r6OS4OhSt3hPZLkFApLjM8TEXROBuQGLAH2i2gZpcXdLBIrpXuTDhH7Vbm1iXmNGA==", 243 | "dev": true 244 | }, 245 | "@types/mime": { 246 | "version": "1.3.2", 247 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", 248 | "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==", 249 | "dev": true 250 | }, 251 | "@types/mocha": { 252 | "version": "8.2.2", 253 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-8.2.2.tgz", 254 | "integrity": "sha512-Lwh0lzzqT5Pqh6z61P3c3P5nm6fzQK/MMHl9UKeneAeInVflBSz1O2EkX6gM6xfJd7FBXBY5purtLx7fUiZ7Hw==", 255 | "dev": true 256 | }, 257 | "@types/mongodb": { 258 | "version": "3.6.16", 259 | "resolved": "https://registry.npmjs.org/@types/mongodb/-/mongodb-3.6.16.tgz", 260 | "integrity": "sha512-D3tM0iRUet3TiIMAdvovxAIRG9gYqFd4j7visGwmPNdQj8Fq/uFFfRxyGCgEwVXAs0NnJPMI/QGVTADxDwhmSQ==", 261 | "dev": true, 262 | "requires": { 263 | "@types/bson": "*", 264 | "@types/node": "*" 265 | } 266 | }, 267 | "@types/mongoose": { 268 | "version": "5.10.5", 269 | "resolved": "https://registry.npmjs.org/@types/mongoose/-/mongoose-5.10.5.tgz", 270 | "integrity": "sha512-37QMIA954T3n+HSksSNLlxZsqF8fMJu5S4dyPBod6gRxGtsXlQ9jUtL8BE8Seimv99u79eLXI3bggoCnSQ/fxQ==", 271 | "dev": true, 272 | "requires": { 273 | "@types/mongodb": "*", 274 | "@types/node": "*" 275 | } 276 | }, 277 | "@types/node": { 278 | "version": "15.6.0", 279 | "resolved": "https://registry.npmjs.org/@types/node/-/node-15.6.0.tgz", 280 | "integrity": "sha512-gCYSfQpy+LYhOFTKAeE8BkyGqaxmlFxe+n4DKM6DR0wzw/HISUE/hAmkC/KT8Sw5PCJblqg062b3z9gucv3k0A==", 281 | "dev": true 282 | }, 283 | "@types/parse-json": { 284 | "version": "4.0.0", 285 | "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz", 286 | "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==", 287 | "dev": true 288 | }, 289 | "@types/qs": { 290 | "version": "6.9.6", 291 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.6.tgz", 292 | "integrity": "sha512-0/HnwIfW4ki2D8L8c9GVcG5I72s9jP5GSLVF0VIXDW00kmIpA6O33G7a8n59Tmh7Nz0WUC3rSb7PTY/sdW2JzA==", 293 | "dev": true 294 | }, 295 | "@types/range-parser": { 296 | "version": "1.2.3", 297 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.3.tgz", 298 | "integrity": "sha512-ewFXqrQHlFsgc09MK5jP5iR7vumV/BYayNC6PgJO2LPe8vrnNFyjQjSppfEngITi0qvfKtzFvgKymGheFM9UOA==", 299 | "dev": true 300 | }, 301 | "@types/serve-static": { 302 | "version": "1.13.9", 303 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.9.tgz", 304 | "integrity": "sha512-ZFqF6qa48XsPdjXV5Gsz0Zqmux2PerNd3a/ktL45mHpa19cuMi/cL8tcxdAx497yRh+QtYPuofjT9oWw9P7nkA==", 305 | "dev": true, 306 | "requires": { 307 | "@types/mime": "^1", 308 | "@types/node": "*" 309 | } 310 | }, 311 | "@types/sinon": { 312 | "version": "10.0.0", 313 | "resolved": "https://registry.npmjs.org/@types/sinon/-/sinon-10.0.0.tgz", 314 | "integrity": "sha512-jDZ55oCKxqlDmoTBBbBBEx+N8ZraUVhggMZ9T5t+6/Dh8/4NiOjSUfpLrPiEwxQDlAe3wpAkoXhWvE6LibtsMQ==", 315 | "dev": true, 316 | "requires": { 317 | "@sinonjs/fake-timers": "^7.0.4" 318 | }, 319 | "dependencies": { 320 | "@sinonjs/fake-timers": { 321 | "version": "7.1.0", 322 | "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-7.1.0.tgz", 323 | "integrity": "sha512-hAEzXi6Wbvlb67NnGMGSNOeAflLVnMa4yliPU/ty1qjgW/vAletH15/v/esJwASSIA0YlIyjnloenFbEZc9q9A==", 324 | "dev": true, 325 | "requires": { 326 | "@sinonjs/commons": "^1.7.0" 327 | } 328 | } 329 | } 330 | }, 331 | "@typescript-eslint/eslint-plugin": { 332 | "version": "4.24.0", 333 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-4.24.0.tgz", 334 | "integrity": "sha512-qbCgkPM7DWTsYQGjx9RTuQGswi+bEt0isqDBeo+CKV0953zqI0Tp7CZ7Fi9ipgFA6mcQqF4NOVNwS/f2r6xShw==", 335 | "dev": true, 336 | "requires": { 337 | "@typescript-eslint/experimental-utils": "4.24.0", 338 | "@typescript-eslint/scope-manager": "4.24.0", 339 | "debug": "^4.1.1", 340 | "functional-red-black-tree": "^1.0.1", 341 | "lodash": "^4.17.15", 342 | "regexpp": "^3.0.0", 343 | "semver": "^7.3.2", 344 | "tsutils": "^3.17.1" 345 | } 346 | }, 347 | "@typescript-eslint/experimental-utils": { 348 | "version": "4.24.0", 349 | "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-4.24.0.tgz", 350 | "integrity": "sha512-IwTT2VNDKH1h8RZseMH4CcYBz6lTvRoOLDuuqNZZoThvfHEhOiZPQCow+5El3PtyxJ1iDr6UXZwYtE3yZQjhcw==", 351 | "dev": true, 352 | "requires": { 353 | "@types/json-schema": "^7.0.3", 354 | "@typescript-eslint/scope-manager": "4.24.0", 355 | "@typescript-eslint/types": "4.24.0", 356 | "@typescript-eslint/typescript-estree": "4.24.0", 357 | "eslint-scope": "^5.0.0", 358 | "eslint-utils": "^2.0.0" 359 | } 360 | }, 361 | "@typescript-eslint/parser": { 362 | "version": "4.24.0", 363 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-4.24.0.tgz", 364 | "integrity": "sha512-dj1ZIh/4QKeECLb2f/QjRwMmDArcwc2WorWPRlB8UNTZlY1KpTVsbX7e3ZZdphfRw29aTFUSNuGB8w9X5sS97w==", 365 | "dev": true, 366 | "requires": { 367 | "@typescript-eslint/scope-manager": "4.24.0", 368 | "@typescript-eslint/types": "4.24.0", 369 | "@typescript-eslint/typescript-estree": "4.24.0", 370 | "debug": "^4.1.1" 371 | } 372 | }, 373 | "@typescript-eslint/scope-manager": { 374 | "version": "4.24.0", 375 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-4.24.0.tgz", 376 | "integrity": "sha512-9+WYJGDnuC9VtYLqBhcSuM7du75fyCS/ypC8c5g7Sdw7pGL4NDTbeH38eJPfzIydCHZDoOgjloxSAA3+4l/zsA==", 377 | "dev": true, 378 | "requires": { 379 | "@typescript-eslint/types": "4.24.0", 380 | "@typescript-eslint/visitor-keys": "4.24.0" 381 | } 382 | }, 383 | "@typescript-eslint/types": { 384 | "version": "4.24.0", 385 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-4.24.0.tgz", 386 | "integrity": "sha512-tkZUBgDQKdvfs8L47LaqxojKDE+mIUmOzdz7r+u+U54l3GDkTpEbQ1Jp3cNqqAU9vMUCBA1fitsIhm7yN0vx9Q==", 387 | "dev": true 388 | }, 389 | "@typescript-eslint/typescript-estree": { 390 | "version": "4.24.0", 391 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-4.24.0.tgz", 392 | "integrity": "sha512-kBDitL/by/HK7g8CYLT7aKpAwlR8doshfWz8d71j97n5kUa5caHWvY0RvEUEanL/EqBJoANev8Xc/mQ6LLwXGA==", 393 | "dev": true, 394 | "requires": { 395 | "@typescript-eslint/types": "4.24.0", 396 | "@typescript-eslint/visitor-keys": "4.24.0", 397 | "debug": "^4.1.1", 398 | "globby": "^11.0.1", 399 | "is-glob": "^4.0.1", 400 | "semver": "^7.3.2", 401 | "tsutils": "^3.17.1" 402 | } 403 | }, 404 | "@typescript-eslint/visitor-keys": { 405 | "version": "4.24.0", 406 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-4.24.0.tgz", 407 | "integrity": "sha512-4ox1sjmGHIxjEDBnMCtWFFhErXtKA1Ec0sBpuz0fqf3P+g3JFGyTxxbF06byw0FRsPnnbq44cKivH7Ks1/0s6g==", 408 | "dev": true, 409 | "requires": { 410 | "@typescript-eslint/types": "4.24.0", 411 | "eslint-visitor-keys": "^2.0.0" 412 | } 413 | }, 414 | "@ungap/promise-all-settled": { 415 | "version": "1.1.2", 416 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 417 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 418 | "dev": true 419 | }, 420 | "@vtjs/auth": { 421 | "version": "0.2.0", 422 | "resolved": "https://registry.npmjs.org/@vtjs/auth/-/auth-0.2.0.tgz", 423 | "integrity": "sha512-zMvwYt7EoPwhHC4a/AA91/N9SIHVnnx2Es9rQ4tCngDeWHjw007PJ6+lbNJnXXPn+tgPmRtxG7xPvl2oizum8w==", 424 | "requires": { 425 | "jsonwebtoken": "^8.5.1" 426 | } 427 | }, 428 | "@vtjs/cache": { 429 | "version": "0.1.5", 430 | "resolved": "https://registry.npmjs.org/@vtjs/cache/-/cache-0.1.5.tgz", 431 | "integrity": "sha512-B/UB3SI/ce0x3YDmwkugRWJJvt9+6TXSVrUBxRRV4XRRmfc+KMQ2agY99vKQkKptOcvOC56sR7yecCbLFfjunQ==", 432 | "requires": { 433 | "redis": "^3.1.2" 434 | } 435 | }, 436 | "@vtjs/common": { 437 | "version": "0.1.9", 438 | "resolved": "https://registry.npmjs.org/@vtjs/common/-/common-0.1.9.tgz", 439 | "integrity": "sha512-5aHntUroXrtRrreK0T/KN8ofUbvWu/+toZwSLVlLzqVZTngy/YlQAEMJQ50cxWcypsjOGgA6hQWOVcoLAYoKRA==", 440 | "requires": { 441 | "axios": "^0.21.1", 442 | "winston": "^3.3.3" 443 | } 444 | }, 445 | "@vtjs/core": { 446 | "version": "0.2.6", 447 | "resolved": "https://registry.npmjs.org/@vtjs/core/-/core-0.2.6.tgz", 448 | "integrity": "sha512-LQaGU/lddH5ToGcCWXzv/0rmS0fu02TWdY7RMZrpMMecs6BSnnHCbnvs/pGu0xrqdXEgVsLPk3BFNJjHTkQ9aA==", 449 | "requires": { 450 | "compression": "^1.7.4", 451 | "cors": "^2.8.5", 452 | "express": "^4.17.1" 453 | } 454 | }, 455 | "@vtjs/mongoose": { 456 | "version": "0.1.8", 457 | "resolved": "https://registry.npmjs.org/@vtjs/mongoose/-/mongoose-0.1.8.tgz", 458 | "integrity": "sha512-Th9O+48UArkNnPR2UgXy2jezLd2UYdDF2zcJQj6kCYNDjs+9LqJAOqRCjzJD3EmlksPxuqcFZnhQuO4zAQIaSQ==", 459 | "requires": { 460 | "mongoose": "5.10.5" 461 | } 462 | }, 463 | "@vtjs/rabbitmq": { 464 | "version": "0.1.0", 465 | "resolved": "https://registry.npmjs.org/@vtjs/rabbitmq/-/rabbitmq-0.1.0.tgz", 466 | "integrity": "sha512-KSLqY2VcX6AKQlDeLlkt+LlXHJP7qieeWXZI2M2Ej+ob9Gw8DkR3gMXP5wRLRiHeI2su/qZFa6liUCBT6zHAiQ==", 467 | "requires": { 468 | "amqplib": "^0.7.1" 469 | } 470 | }, 471 | "abbrev": { 472 | "version": "1.1.1", 473 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 474 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 475 | }, 476 | "accepts": { 477 | "version": "1.3.7", 478 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 479 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 480 | "requires": { 481 | "mime-types": "~2.1.24", 482 | "negotiator": "0.6.2" 483 | } 484 | }, 485 | "acorn": { 486 | "version": "7.4.1", 487 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 488 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 489 | "dev": true 490 | }, 491 | "acorn-jsx": { 492 | "version": "5.3.1", 493 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz", 494 | "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==", 495 | "dev": true 496 | }, 497 | "agent-base": { 498 | "version": "6.0.2", 499 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 500 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 501 | "requires": { 502 | "debug": "4" 503 | } 504 | }, 505 | "aggregate-error": { 506 | "version": "3.1.0", 507 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", 508 | "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", 509 | "dev": true, 510 | "requires": { 511 | "clean-stack": "^2.0.0", 512 | "indent-string": "^4.0.0" 513 | } 514 | }, 515 | "ajv": { 516 | "version": "6.12.6", 517 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 518 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 519 | "dev": true, 520 | "requires": { 521 | "fast-deep-equal": "^3.1.1", 522 | "fast-json-stable-stringify": "^2.0.0", 523 | "json-schema-traverse": "^0.4.1", 524 | "uri-js": "^4.2.2" 525 | } 526 | }, 527 | "amqplib": { 528 | "version": "0.7.1", 529 | "resolved": "https://registry.npmjs.org/amqplib/-/amqplib-0.7.1.tgz", 530 | "integrity": "sha512-KePK3tTOLGU4emTo+PwSDMbc123jrxo13FpRpim1LzJoSlQrIBB2/kMeCC40jK/Zb0olHGaABjLqXDsdK46iLA==", 531 | "requires": { 532 | "bitsyntax": "~0.1.0", 533 | "bluebird": "^3.7.2", 534 | "buffer-more-ints": "~1.0.0", 535 | "readable-stream": "1.x >=1.1.9", 536 | "safe-buffer": "~5.2.1", 537 | "url-parse": "~1.5.1" 538 | }, 539 | "dependencies": { 540 | "bluebird": { 541 | "version": "3.7.2", 542 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", 543 | "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==" 544 | }, 545 | "isarray": { 546 | "version": "0.0.1", 547 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 548 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=" 549 | }, 550 | "readable-stream": { 551 | "version": "1.1.14", 552 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", 553 | "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", 554 | "requires": { 555 | "core-util-is": "~1.0.0", 556 | "inherits": "~2.0.1", 557 | "isarray": "0.0.1", 558 | "string_decoder": "~0.10.x" 559 | } 560 | }, 561 | "string_decoder": { 562 | "version": "0.10.31", 563 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 564 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=" 565 | } 566 | } 567 | }, 568 | "ansi-colors": { 569 | "version": "4.1.1", 570 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 571 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 572 | "dev": true 573 | }, 574 | "ansi-escapes": { 575 | "version": "4.3.2", 576 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", 577 | "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", 578 | "dev": true, 579 | "requires": { 580 | "type-fest": "^0.21.3" 581 | }, 582 | "dependencies": { 583 | "type-fest": { 584 | "version": "0.21.3", 585 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", 586 | "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", 587 | "dev": true 588 | } 589 | } 590 | }, 591 | "ansi-regex": { 592 | "version": "5.0.0", 593 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 594 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 595 | "dev": true 596 | }, 597 | "ansi-styles": { 598 | "version": "3.2.1", 599 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 600 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 601 | "dev": true, 602 | "requires": { 603 | "color-convert": "^1.9.0" 604 | } 605 | }, 606 | "anymatch": { 607 | "version": "3.1.2", 608 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 609 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 610 | "dev": true, 611 | "requires": { 612 | "normalize-path": "^3.0.0", 613 | "picomatch": "^2.0.4" 614 | } 615 | }, 616 | "aproba": { 617 | "version": "1.2.0", 618 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 619 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" 620 | }, 621 | "are-we-there-yet": { 622 | "version": "1.1.5", 623 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", 624 | "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", 625 | "requires": { 626 | "delegates": "^1.0.0", 627 | "readable-stream": "^2.0.6" 628 | }, 629 | "dependencies": { 630 | "readable-stream": { 631 | "version": "2.3.7", 632 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 633 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 634 | "requires": { 635 | "core-util-is": "~1.0.0", 636 | "inherits": "~2.0.3", 637 | "isarray": "~1.0.0", 638 | "process-nextick-args": "~2.0.0", 639 | "safe-buffer": "~5.1.1", 640 | "string_decoder": "~1.1.1", 641 | "util-deprecate": "~1.0.1" 642 | } 643 | }, 644 | "safe-buffer": { 645 | "version": "5.1.2", 646 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 647 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 648 | }, 649 | "string_decoder": { 650 | "version": "1.1.1", 651 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 652 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 653 | "requires": { 654 | "safe-buffer": "~5.1.0" 655 | } 656 | } 657 | } 658 | }, 659 | "arg": { 660 | "version": "4.1.3", 661 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 662 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 663 | "dev": true 664 | }, 665 | "argparse": { 666 | "version": "1.0.10", 667 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 668 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 669 | "dev": true, 670 | "requires": { 671 | "sprintf-js": "~1.0.2" 672 | } 673 | }, 674 | "array-flatten": { 675 | "version": "1.1.1", 676 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 677 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 678 | }, 679 | "array-union": { 680 | "version": "2.1.0", 681 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 682 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 683 | "dev": true 684 | }, 685 | "assertion-error": { 686 | "version": "1.1.0", 687 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 688 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 689 | "dev": true 690 | }, 691 | "astral-regex": { 692 | "version": "2.0.0", 693 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 694 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 695 | "dev": true 696 | }, 697 | "async": { 698 | "version": "3.2.0", 699 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.0.tgz", 700 | "integrity": "sha512-TR2mEZFVOj2pLStYxLht7TyfuRzaydfpxr3k9RpHIzMgw7A64dzsdqCxH1WJyQdoe8T10nDXd9wnEigmiuHIZw==" 701 | }, 702 | "axios": { 703 | "version": "0.21.1", 704 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.21.1.tgz", 705 | "integrity": "sha512-dKQiRHxGD9PPRIUNIWvZhPTPpl1rf/OxTYKsqKUDjBwYylTvV7SjSHJb9ratfyzM6wCdLCOYLzs73qpg5c4iGA==", 706 | "requires": { 707 | "follow-redirects": "^1.10.0" 708 | } 709 | }, 710 | "axios-retry": { 711 | "version": "3.1.9", 712 | "resolved": "https://registry.npmjs.org/axios-retry/-/axios-retry-3.1.9.tgz", 713 | "integrity": "sha512-NFCoNIHq8lYkJa6ku4m+V1837TP6lCa7n79Iuf8/AqATAHYB0ISaAS1eyIenDOfHOLtym34W65Sjke2xjg2fsA==", 714 | "requires": { 715 | "is-retry-allowed": "^1.1.0" 716 | } 717 | }, 718 | "balanced-match": { 719 | "version": "1.0.2", 720 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 721 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 722 | }, 723 | "bcrypt": { 724 | "version": "5.0.1", 725 | "resolved": "https://registry.npmjs.org/bcrypt/-/bcrypt-5.0.1.tgz", 726 | "integrity": "sha512-9BTgmrhZM2t1bNuDtrtIMVSmmxZBrJ71n8Wg+YgdjHuIWYF7SjjmCPZFB+/5i/o/PIeRpwVJR3P+NrpIItUjqw==", 727 | "requires": { 728 | "@mapbox/node-pre-gyp": "^1.0.0", 729 | "node-addon-api": "^3.1.0" 730 | } 731 | }, 732 | "binary-extensions": { 733 | "version": "2.2.0", 734 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 735 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 736 | "dev": true 737 | }, 738 | "bitsyntax": { 739 | "version": "0.1.0", 740 | "resolved": "https://registry.npmjs.org/bitsyntax/-/bitsyntax-0.1.0.tgz", 741 | "integrity": "sha512-ikAdCnrloKmFOugAfxWws89/fPc+nw0OOG1IzIE72uSOg/A3cYptKCjSUhDTuj7fhsJtzkzlv7l3b8PzRHLN0Q==", 742 | "requires": { 743 | "buffer-more-ints": "~1.0.0", 744 | "debug": "~2.6.9", 745 | "safe-buffer": "~5.1.2" 746 | }, 747 | "dependencies": { 748 | "debug": { 749 | "version": "2.6.9", 750 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 751 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 752 | "requires": { 753 | "ms": "2.0.0" 754 | } 755 | }, 756 | "ms": { 757 | "version": "2.0.0", 758 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 759 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 760 | }, 761 | "safe-buffer": { 762 | "version": "5.1.2", 763 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 764 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 765 | } 766 | } 767 | }, 768 | "bl": { 769 | "version": "2.2.1", 770 | "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.1.tgz", 771 | "integrity": "sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g==", 772 | "requires": { 773 | "readable-stream": "^2.3.5", 774 | "safe-buffer": "^5.1.1" 775 | }, 776 | "dependencies": { 777 | "readable-stream": { 778 | "version": "2.3.7", 779 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 780 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 781 | "requires": { 782 | "core-util-is": "~1.0.0", 783 | "inherits": "~2.0.3", 784 | "isarray": "~1.0.0", 785 | "process-nextick-args": "~2.0.0", 786 | "safe-buffer": "~5.1.1", 787 | "string_decoder": "~1.1.1", 788 | "util-deprecate": "~1.0.1" 789 | }, 790 | "dependencies": { 791 | "safe-buffer": { 792 | "version": "5.1.2", 793 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 794 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 795 | } 796 | } 797 | }, 798 | "string_decoder": { 799 | "version": "1.1.1", 800 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 801 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 802 | "requires": { 803 | "safe-buffer": "~5.1.0" 804 | }, 805 | "dependencies": { 806 | "safe-buffer": { 807 | "version": "5.1.2", 808 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 809 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 810 | } 811 | } 812 | } 813 | } 814 | }, 815 | "bluebird": { 816 | "version": "3.5.1", 817 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", 818 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" 819 | }, 820 | "body-parser": { 821 | "version": "1.19.0", 822 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 823 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 824 | "requires": { 825 | "bytes": "3.1.0", 826 | "content-type": "~1.0.4", 827 | "debug": "2.6.9", 828 | "depd": "~1.1.2", 829 | "http-errors": "1.7.2", 830 | "iconv-lite": "0.4.24", 831 | "on-finished": "~2.3.0", 832 | "qs": "6.7.0", 833 | "raw-body": "2.4.0", 834 | "type-is": "~1.6.17" 835 | }, 836 | "dependencies": { 837 | "bytes": { 838 | "version": "3.1.0", 839 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 840 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 841 | }, 842 | "debug": { 843 | "version": "2.6.9", 844 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 845 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 846 | "requires": { 847 | "ms": "2.0.0" 848 | } 849 | }, 850 | "ms": { 851 | "version": "2.0.0", 852 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 853 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 854 | } 855 | } 856 | }, 857 | "brace-expansion": { 858 | "version": "1.1.11", 859 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 860 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 861 | "requires": { 862 | "balanced-match": "^1.0.0", 863 | "concat-map": "0.0.1" 864 | } 865 | }, 866 | "braces": { 867 | "version": "3.0.2", 868 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 869 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 870 | "dev": true, 871 | "requires": { 872 | "fill-range": "^7.0.1" 873 | } 874 | }, 875 | "browser-stdout": { 876 | "version": "1.3.1", 877 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 878 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 879 | "dev": true 880 | }, 881 | "bson": { 882 | "version": "1.1.6", 883 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.6.tgz", 884 | "integrity": "sha512-EvVNVeGo4tHxwi8L6bPj3y3itEvStdwvvlojVxxbyYfoaxJ6keLgrTuKdyfEAszFK+H3olzBuafE0yoh0D1gdg==" 885 | }, 886 | "buffer-equal-constant-time": { 887 | "version": "1.0.1", 888 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 889 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 890 | }, 891 | "buffer-from": { 892 | "version": "1.1.1", 893 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 894 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 895 | "dev": true 896 | }, 897 | "buffer-more-ints": { 898 | "version": "1.0.0", 899 | "resolved": "https://registry.npmjs.org/buffer-more-ints/-/buffer-more-ints-1.0.0.tgz", 900 | "integrity": "sha512-EMetuGFz5SLsT0QTnXzINh4Ksr+oo4i+UGTXEshiGCQWnsgSs7ZhJ8fzlwQ+OzEMs0MpDAMr1hxnblp5a4vcHg==" 901 | }, 902 | "bytes": { 903 | "version": "3.0.0", 904 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", 905 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" 906 | }, 907 | "callsites": { 908 | "version": "3.1.0", 909 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 910 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 911 | "dev": true 912 | }, 913 | "camelcase": { 914 | "version": "6.2.0", 915 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.0.tgz", 916 | "integrity": "sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==", 917 | "dev": true 918 | }, 919 | "chai": { 920 | "version": "4.3.4", 921 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.4.tgz", 922 | "integrity": "sha512-yS5H68VYOCtN1cjfwumDSuzn/9c+yza4f3reKXlE5rUg7SFcCEy90gJvydNgOYtblyf4Zi6jIWRnXOgErta0KA==", 923 | "dev": true, 924 | "requires": { 925 | "assertion-error": "^1.1.0", 926 | "check-error": "^1.0.2", 927 | "deep-eql": "^3.0.1", 928 | "get-func-name": "^2.0.0", 929 | "pathval": "^1.1.1", 930 | "type-detect": "^4.0.5" 931 | } 932 | }, 933 | "chalk": { 934 | "version": "4.1.1", 935 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz", 936 | "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==", 937 | "dev": true, 938 | "requires": { 939 | "ansi-styles": "^4.1.0", 940 | "supports-color": "^7.1.0" 941 | }, 942 | "dependencies": { 943 | "ansi-styles": { 944 | "version": "4.3.0", 945 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 946 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 947 | "dev": true, 948 | "requires": { 949 | "color-convert": "^2.0.1" 950 | } 951 | }, 952 | "color-convert": { 953 | "version": "2.0.1", 954 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 955 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 956 | "dev": true, 957 | "requires": { 958 | "color-name": "~1.1.4" 959 | } 960 | }, 961 | "color-name": { 962 | "version": "1.1.4", 963 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 964 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 965 | "dev": true 966 | }, 967 | "has-flag": { 968 | "version": "4.0.0", 969 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 970 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 971 | "dev": true 972 | }, 973 | "supports-color": { 974 | "version": "7.2.0", 975 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 976 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 977 | "dev": true, 978 | "requires": { 979 | "has-flag": "^4.0.0" 980 | } 981 | } 982 | } 983 | }, 984 | "check-error": { 985 | "version": "1.0.2", 986 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 987 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 988 | "dev": true 989 | }, 990 | "chokidar": { 991 | "version": "3.5.1", 992 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.1.tgz", 993 | "integrity": "sha512-9+s+Od+W0VJJzawDma/gvBNQqkTiqYTWLuZoyAsivsI4AaWTCzHG06/TMjsf1cYe9Cb97UCEhjz7HvnPk2p/tw==", 994 | "dev": true, 995 | "requires": { 996 | "anymatch": "~3.1.1", 997 | "braces": "~3.0.2", 998 | "fsevents": "~2.3.1", 999 | "glob-parent": "~5.1.0", 1000 | "is-binary-path": "~2.1.0", 1001 | "is-glob": "~4.0.1", 1002 | "normalize-path": "~3.0.0", 1003 | "readdirp": "~3.5.0" 1004 | } 1005 | }, 1006 | "chownr": { 1007 | "version": "2.0.0", 1008 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", 1009 | "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==" 1010 | }, 1011 | "clean-stack": { 1012 | "version": "2.2.0", 1013 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 1014 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 1015 | "dev": true 1016 | }, 1017 | "cli-cursor": { 1018 | "version": "3.1.0", 1019 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 1020 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 1021 | "dev": true, 1022 | "requires": { 1023 | "restore-cursor": "^3.1.0" 1024 | } 1025 | }, 1026 | "cli-truncate": { 1027 | "version": "2.1.0", 1028 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-2.1.0.tgz", 1029 | "integrity": "sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg==", 1030 | "dev": true, 1031 | "requires": { 1032 | "slice-ansi": "^3.0.0", 1033 | "string-width": "^4.2.0" 1034 | }, 1035 | "dependencies": { 1036 | "ansi-styles": { 1037 | "version": "4.3.0", 1038 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1039 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1040 | "dev": true, 1041 | "requires": { 1042 | "color-convert": "^2.0.1" 1043 | } 1044 | }, 1045 | "color-convert": { 1046 | "version": "2.0.1", 1047 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1048 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1049 | "dev": true, 1050 | "requires": { 1051 | "color-name": "~1.1.4" 1052 | } 1053 | }, 1054 | "color-name": { 1055 | "version": "1.1.4", 1056 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1057 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1058 | "dev": true 1059 | }, 1060 | "slice-ansi": { 1061 | "version": "3.0.0", 1062 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-3.0.0.tgz", 1063 | "integrity": "sha512-pSyv7bSTC7ig9Dcgbw9AuRNUb5k5V6oDudjZoMBSr13qpLBG7tB+zgCkARjq7xIUgdz5P1Qe8u+rSGdouOOIyQ==", 1064 | "dev": true, 1065 | "requires": { 1066 | "ansi-styles": "^4.0.0", 1067 | "astral-regex": "^2.0.0", 1068 | "is-fullwidth-code-point": "^3.0.0" 1069 | } 1070 | } 1071 | } 1072 | }, 1073 | "cliui": { 1074 | "version": "7.0.4", 1075 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 1076 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 1077 | "dev": true, 1078 | "requires": { 1079 | "string-width": "^4.2.0", 1080 | "strip-ansi": "^6.0.0", 1081 | "wrap-ansi": "^7.0.0" 1082 | } 1083 | }, 1084 | "code-point-at": { 1085 | "version": "1.1.0", 1086 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 1087 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 1088 | }, 1089 | "color": { 1090 | "version": "3.0.0", 1091 | "resolved": "https://registry.npmjs.org/color/-/color-3.0.0.tgz", 1092 | "integrity": "sha512-jCpd5+s0s0t7p3pHQKpnJ0TpQKKdleP71LWcA0aqiljpiuAkOSUFN/dyH8ZwF0hRmFlrIuRhufds1QyEP9EB+w==", 1093 | "requires": { 1094 | "color-convert": "^1.9.1", 1095 | "color-string": "^1.5.2" 1096 | } 1097 | }, 1098 | "color-convert": { 1099 | "version": "1.9.3", 1100 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1101 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1102 | "requires": { 1103 | "color-name": "1.1.3" 1104 | } 1105 | }, 1106 | "color-name": { 1107 | "version": "1.1.3", 1108 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1109 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 1110 | }, 1111 | "color-string": { 1112 | "version": "1.5.5", 1113 | "resolved": "https://registry.npmjs.org/color-string/-/color-string-1.5.5.tgz", 1114 | "integrity": "sha512-jgIoum0OfQfq9Whcfc2z/VhCNcmQjWbey6qBX0vqt7YICflUmBCh9E9CiQD5GSJ+Uehixm3NUwHVhqUAWRivZg==", 1115 | "requires": { 1116 | "color-name": "^1.0.0", 1117 | "simple-swizzle": "^0.2.2" 1118 | } 1119 | }, 1120 | "colors": { 1121 | "version": "1.4.0", 1122 | "resolved": "https://registry.npmjs.org/colors/-/colors-1.4.0.tgz", 1123 | "integrity": "sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA==" 1124 | }, 1125 | "colorspace": { 1126 | "version": "1.1.2", 1127 | "resolved": "https://registry.npmjs.org/colorspace/-/colorspace-1.1.2.tgz", 1128 | "integrity": "sha512-vt+OoIP2d76xLhjwbBaucYlNSpPsrJWPlBTtwCpQKIu6/CSMutyzX93O/Do0qzpH3YoHEes8YEFXyZ797rEhzQ==", 1129 | "requires": { 1130 | "color": "3.0.x", 1131 | "text-hex": "1.0.x" 1132 | } 1133 | }, 1134 | "commander": { 1135 | "version": "7.2.0", 1136 | "resolved": "https://registry.npmjs.org/commander/-/commander-7.2.0.tgz", 1137 | "integrity": "sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw==", 1138 | "dev": true 1139 | }, 1140 | "compressible": { 1141 | "version": "2.0.18", 1142 | "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz", 1143 | "integrity": "sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==", 1144 | "requires": { 1145 | "mime-db": ">= 1.43.0 < 2" 1146 | } 1147 | }, 1148 | "compression": { 1149 | "version": "1.7.4", 1150 | "resolved": "https://registry.npmjs.org/compression/-/compression-1.7.4.tgz", 1151 | "integrity": "sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ==", 1152 | "requires": { 1153 | "accepts": "~1.3.5", 1154 | "bytes": "3.0.0", 1155 | "compressible": "~2.0.16", 1156 | "debug": "2.6.9", 1157 | "on-headers": "~1.0.2", 1158 | "safe-buffer": "5.1.2", 1159 | "vary": "~1.1.2" 1160 | }, 1161 | "dependencies": { 1162 | "debug": { 1163 | "version": "2.6.9", 1164 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1165 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1166 | "requires": { 1167 | "ms": "2.0.0" 1168 | } 1169 | }, 1170 | "ms": { 1171 | "version": "2.0.0", 1172 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1173 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1174 | }, 1175 | "safe-buffer": { 1176 | "version": "5.1.2", 1177 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1178 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1179 | } 1180 | } 1181 | }, 1182 | "concat-map": { 1183 | "version": "0.0.1", 1184 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1185 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 1186 | }, 1187 | "console-control-strings": { 1188 | "version": "1.1.0", 1189 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 1190 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" 1191 | }, 1192 | "content-disposition": { 1193 | "version": "0.5.3", 1194 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 1195 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 1196 | "requires": { 1197 | "safe-buffer": "5.1.2" 1198 | }, 1199 | "dependencies": { 1200 | "safe-buffer": { 1201 | "version": "5.1.2", 1202 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1203 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1204 | } 1205 | } 1206 | }, 1207 | "content-type": { 1208 | "version": "1.0.4", 1209 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 1210 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 1211 | }, 1212 | "cookie": { 1213 | "version": "0.4.0", 1214 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 1215 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 1216 | }, 1217 | "cookie-signature": { 1218 | "version": "1.0.6", 1219 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 1220 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 1221 | }, 1222 | "core-util-is": { 1223 | "version": "1.0.2", 1224 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 1225 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 1226 | }, 1227 | "cors": { 1228 | "version": "2.8.5", 1229 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 1230 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 1231 | "requires": { 1232 | "object-assign": "^4", 1233 | "vary": "^1" 1234 | } 1235 | }, 1236 | "cosmiconfig": { 1237 | "version": "7.0.0", 1238 | "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.0.0.tgz", 1239 | "integrity": "sha512-pondGvTuVYDk++upghXJabWzL6Kxu6f26ljFw64Swq9v6sQPUL3EUlVDV56diOjpCayKihL6hVe8exIACU4XcA==", 1240 | "dev": true, 1241 | "requires": { 1242 | "@types/parse-json": "^4.0.0", 1243 | "import-fresh": "^3.2.1", 1244 | "parse-json": "^5.0.0", 1245 | "path-type": "^4.0.0", 1246 | "yaml": "^1.10.0" 1247 | } 1248 | }, 1249 | "create-require": { 1250 | "version": "1.1.1", 1251 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 1252 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 1253 | "dev": true 1254 | }, 1255 | "cross-spawn": { 1256 | "version": "7.0.3", 1257 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1258 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1259 | "dev": true, 1260 | "requires": { 1261 | "path-key": "^3.1.0", 1262 | "shebang-command": "^2.0.0", 1263 | "which": "^2.0.1" 1264 | } 1265 | }, 1266 | "debug": { 1267 | "version": "4.3.1", 1268 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 1269 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 1270 | "requires": { 1271 | "ms": "2.1.2" 1272 | } 1273 | }, 1274 | "decamelize": { 1275 | "version": "4.0.0", 1276 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 1277 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 1278 | "dev": true 1279 | }, 1280 | "dedent": { 1281 | "version": "0.7.0", 1282 | "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", 1283 | "integrity": "sha1-JJXduvbrh0q7Dhvp3yLS5aVEMmw=", 1284 | "dev": true 1285 | }, 1286 | "deep-eql": { 1287 | "version": "3.0.1", 1288 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 1289 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 1290 | "dev": true, 1291 | "requires": { 1292 | "type-detect": "^4.0.0" 1293 | } 1294 | }, 1295 | "deep-is": { 1296 | "version": "0.1.3", 1297 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 1298 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 1299 | "dev": true 1300 | }, 1301 | "delegates": { 1302 | "version": "1.0.0", 1303 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 1304 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" 1305 | }, 1306 | "denque": { 1307 | "version": "1.5.0", 1308 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.5.0.tgz", 1309 | "integrity": "sha512-CYiCSgIF1p6EUByQPlGkKnP1M9g0ZV3qMIrqMqZqdwazygIA/YP2vrbcyl1h/WppKJTdl1F85cXIle+394iDAQ==" 1310 | }, 1311 | "depd": { 1312 | "version": "1.1.2", 1313 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 1314 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 1315 | }, 1316 | "destroy": { 1317 | "version": "1.0.4", 1318 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 1319 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 1320 | }, 1321 | "detect-libc": { 1322 | "version": "1.0.3", 1323 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz", 1324 | "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=" 1325 | }, 1326 | "diff": { 1327 | "version": "4.0.2", 1328 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 1329 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 1330 | "dev": true 1331 | }, 1332 | "dir-glob": { 1333 | "version": "3.0.1", 1334 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 1335 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 1336 | "dev": true, 1337 | "requires": { 1338 | "path-type": "^4.0.0" 1339 | } 1340 | }, 1341 | "doctrine": { 1342 | "version": "3.0.0", 1343 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 1344 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 1345 | "dev": true, 1346 | "requires": { 1347 | "esutils": "^2.0.2" 1348 | } 1349 | }, 1350 | "dotenv": { 1351 | "version": "9.0.2", 1352 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-9.0.2.tgz", 1353 | "integrity": "sha512-I9OvvrHp4pIARv4+x9iuewrWycX6CcZtoAu1XrzPxc5UygMJXJZYmBsynku8IkrJwgypE5DGNjDPmPRhDCptUg==" 1354 | }, 1355 | "ecdsa-sig-formatter": { 1356 | "version": "1.0.11", 1357 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 1358 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 1359 | "requires": { 1360 | "safe-buffer": "^5.0.1" 1361 | } 1362 | }, 1363 | "ee-first": { 1364 | "version": "1.1.1", 1365 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 1366 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 1367 | }, 1368 | "emoji-regex": { 1369 | "version": "8.0.0", 1370 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1371 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1372 | "dev": true 1373 | }, 1374 | "enabled": { 1375 | "version": "2.0.0", 1376 | "resolved": "https://registry.npmjs.org/enabled/-/enabled-2.0.0.tgz", 1377 | "integrity": "sha512-AKrN98kuwOzMIdAizXGI86UFBoo26CL21UM763y1h/GMSJ4/OHU9k2YlsmBpyScFo/wbLzWQJBMCW4+IO3/+OQ==" 1378 | }, 1379 | "encodeurl": { 1380 | "version": "1.0.2", 1381 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 1382 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 1383 | }, 1384 | "enquirer": { 1385 | "version": "2.3.6", 1386 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 1387 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 1388 | "dev": true, 1389 | "requires": { 1390 | "ansi-colors": "^4.1.1" 1391 | } 1392 | }, 1393 | "error-ex": { 1394 | "version": "1.3.2", 1395 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 1396 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 1397 | "dev": true, 1398 | "requires": { 1399 | "is-arrayish": "^0.2.1" 1400 | } 1401 | }, 1402 | "escalade": { 1403 | "version": "3.1.1", 1404 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 1405 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 1406 | "dev": true 1407 | }, 1408 | "escape-html": { 1409 | "version": "1.0.3", 1410 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 1411 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 1412 | }, 1413 | "escape-string-regexp": { 1414 | "version": "4.0.0", 1415 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1416 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1417 | "dev": true 1418 | }, 1419 | "eslint": { 1420 | "version": "7.27.0", 1421 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.27.0.tgz", 1422 | "integrity": "sha512-JZuR6La2ZF0UD384lcbnd0Cgg6QJjiCwhMD6eU4h/VGPcVGwawNNzKU41tgokGXnfjOOyI6QIffthhJTPzzuRA==", 1423 | "dev": true, 1424 | "requires": { 1425 | "@babel/code-frame": "7.12.11", 1426 | "@eslint/eslintrc": "^0.4.1", 1427 | "ajv": "^6.10.0", 1428 | "chalk": "^4.0.0", 1429 | "cross-spawn": "^7.0.2", 1430 | "debug": "^4.0.1", 1431 | "doctrine": "^3.0.0", 1432 | "enquirer": "^2.3.5", 1433 | "escape-string-regexp": "^4.0.0", 1434 | "eslint-scope": "^5.1.1", 1435 | "eslint-utils": "^2.1.0", 1436 | "eslint-visitor-keys": "^2.0.0", 1437 | "espree": "^7.3.1", 1438 | "esquery": "^1.4.0", 1439 | "esutils": "^2.0.2", 1440 | "fast-deep-equal": "^3.1.3", 1441 | "file-entry-cache": "^6.0.1", 1442 | "functional-red-black-tree": "^1.0.1", 1443 | "glob-parent": "^5.0.0", 1444 | "globals": "^13.6.0", 1445 | "ignore": "^4.0.6", 1446 | "import-fresh": "^3.0.0", 1447 | "imurmurhash": "^0.1.4", 1448 | "is-glob": "^4.0.0", 1449 | "js-yaml": "^3.13.1", 1450 | "json-stable-stringify-without-jsonify": "^1.0.1", 1451 | "levn": "^0.4.1", 1452 | "lodash.merge": "^4.6.2", 1453 | "minimatch": "^3.0.4", 1454 | "natural-compare": "^1.4.0", 1455 | "optionator": "^0.9.1", 1456 | "progress": "^2.0.0", 1457 | "regexpp": "^3.1.0", 1458 | "semver": "^7.2.1", 1459 | "strip-ansi": "^6.0.0", 1460 | "strip-json-comments": "^3.1.0", 1461 | "table": "^6.0.9", 1462 | "text-table": "^0.2.0", 1463 | "v8-compile-cache": "^2.0.3" 1464 | }, 1465 | "dependencies": { 1466 | "ignore": { 1467 | "version": "4.0.6", 1468 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1469 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1470 | "dev": true 1471 | } 1472 | } 1473 | }, 1474 | "eslint-config-prettier": { 1475 | "version": "8.3.0", 1476 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.3.0.tgz", 1477 | "integrity": "sha512-BgZuLUSeKzvlL/VUjx/Yb787VQ26RU3gGjA3iiFvdsp/2bMfVIWUVP7tjxtjS0e+HP409cPlPvNkQloz8C91ew==", 1478 | "dev": true 1479 | }, 1480 | "eslint-plugin-prettier": { 1481 | "version": "3.4.0", 1482 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.4.0.tgz", 1483 | "integrity": "sha512-UDK6rJT6INSfcOo545jiaOwB701uAIt2/dR7WnFQoGCVl1/EMqdANBmwUaqqQ45aXprsTGzSa39LI1PyuRBxxw==", 1484 | "dev": true, 1485 | "requires": { 1486 | "prettier-linter-helpers": "^1.0.0" 1487 | } 1488 | }, 1489 | "eslint-scope": { 1490 | "version": "5.1.1", 1491 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 1492 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 1493 | "dev": true, 1494 | "requires": { 1495 | "esrecurse": "^4.3.0", 1496 | "estraverse": "^4.1.1" 1497 | } 1498 | }, 1499 | "eslint-utils": { 1500 | "version": "2.1.0", 1501 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 1502 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 1503 | "dev": true, 1504 | "requires": { 1505 | "eslint-visitor-keys": "^1.1.0" 1506 | }, 1507 | "dependencies": { 1508 | "eslint-visitor-keys": { 1509 | "version": "1.3.0", 1510 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 1511 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 1512 | "dev": true 1513 | } 1514 | } 1515 | }, 1516 | "eslint-visitor-keys": { 1517 | "version": "2.1.0", 1518 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 1519 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 1520 | "dev": true 1521 | }, 1522 | "espree": { 1523 | "version": "7.3.1", 1524 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 1525 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 1526 | "dev": true, 1527 | "requires": { 1528 | "acorn": "^7.4.0", 1529 | "acorn-jsx": "^5.3.1", 1530 | "eslint-visitor-keys": "^1.3.0" 1531 | }, 1532 | "dependencies": { 1533 | "eslint-visitor-keys": { 1534 | "version": "1.3.0", 1535 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 1536 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 1537 | "dev": true 1538 | } 1539 | } 1540 | }, 1541 | "esprima": { 1542 | "version": "4.0.1", 1543 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1544 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1545 | "dev": true 1546 | }, 1547 | "esquery": { 1548 | "version": "1.4.0", 1549 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 1550 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 1551 | "dev": true, 1552 | "requires": { 1553 | "estraverse": "^5.1.0" 1554 | }, 1555 | "dependencies": { 1556 | "estraverse": { 1557 | "version": "5.2.0", 1558 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 1559 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 1560 | "dev": true 1561 | } 1562 | } 1563 | }, 1564 | "esrecurse": { 1565 | "version": "4.3.0", 1566 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 1567 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 1568 | "dev": true, 1569 | "requires": { 1570 | "estraverse": "^5.2.0" 1571 | }, 1572 | "dependencies": { 1573 | "estraverse": { 1574 | "version": "5.2.0", 1575 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 1576 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 1577 | "dev": true 1578 | } 1579 | } 1580 | }, 1581 | "estraverse": { 1582 | "version": "4.3.0", 1583 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 1584 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 1585 | "dev": true 1586 | }, 1587 | "esutils": { 1588 | "version": "2.0.3", 1589 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1590 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1591 | "dev": true 1592 | }, 1593 | "etag": { 1594 | "version": "1.8.1", 1595 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 1596 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 1597 | }, 1598 | "execa": { 1599 | "version": "5.0.0", 1600 | "resolved": "https://registry.npmjs.org/execa/-/execa-5.0.0.tgz", 1601 | "integrity": "sha512-ov6w/2LCiuyO4RLYGdpFGjkcs0wMTgGE8PrkTHikeUy5iJekXyPIKUjifk5CsE0pt7sMCrMZ3YNqoCj6idQOnQ==", 1602 | "dev": true, 1603 | "requires": { 1604 | "cross-spawn": "^7.0.3", 1605 | "get-stream": "^6.0.0", 1606 | "human-signals": "^2.1.0", 1607 | "is-stream": "^2.0.0", 1608 | "merge-stream": "^2.0.0", 1609 | "npm-run-path": "^4.0.1", 1610 | "onetime": "^5.1.2", 1611 | "signal-exit": "^3.0.3", 1612 | "strip-final-newline": "^2.0.0" 1613 | } 1614 | }, 1615 | "express": { 1616 | "version": "4.17.1", 1617 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 1618 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 1619 | "requires": { 1620 | "accepts": "~1.3.7", 1621 | "array-flatten": "1.1.1", 1622 | "body-parser": "1.19.0", 1623 | "content-disposition": "0.5.3", 1624 | "content-type": "~1.0.4", 1625 | "cookie": "0.4.0", 1626 | "cookie-signature": "1.0.6", 1627 | "debug": "2.6.9", 1628 | "depd": "~1.1.2", 1629 | "encodeurl": "~1.0.2", 1630 | "escape-html": "~1.0.3", 1631 | "etag": "~1.8.1", 1632 | "finalhandler": "~1.1.2", 1633 | "fresh": "0.5.2", 1634 | "merge-descriptors": "1.0.1", 1635 | "methods": "~1.1.2", 1636 | "on-finished": "~2.3.0", 1637 | "parseurl": "~1.3.3", 1638 | "path-to-regexp": "0.1.7", 1639 | "proxy-addr": "~2.0.5", 1640 | "qs": "6.7.0", 1641 | "range-parser": "~1.2.1", 1642 | "safe-buffer": "5.1.2", 1643 | "send": "0.17.1", 1644 | "serve-static": "1.14.1", 1645 | "setprototypeof": "1.1.1", 1646 | "statuses": "~1.5.0", 1647 | "type-is": "~1.6.18", 1648 | "utils-merge": "1.0.1", 1649 | "vary": "~1.1.2" 1650 | }, 1651 | "dependencies": { 1652 | "debug": { 1653 | "version": "2.6.9", 1654 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1655 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1656 | "requires": { 1657 | "ms": "2.0.0" 1658 | } 1659 | }, 1660 | "ms": { 1661 | "version": "2.0.0", 1662 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1663 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1664 | }, 1665 | "path-to-regexp": { 1666 | "version": "0.1.7", 1667 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1668 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1669 | }, 1670 | "safe-buffer": { 1671 | "version": "5.1.2", 1672 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1673 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1674 | } 1675 | } 1676 | }, 1677 | "fast-deep-equal": { 1678 | "version": "3.1.3", 1679 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1680 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1681 | "dev": true 1682 | }, 1683 | "fast-diff": { 1684 | "version": "1.2.0", 1685 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 1686 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 1687 | "dev": true 1688 | }, 1689 | "fast-glob": { 1690 | "version": "3.2.5", 1691 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.5.tgz", 1692 | "integrity": "sha512-2DtFcgT68wiTTiwZ2hNdJfcHNke9XOfnwmBRWXhmeKM8rF0TGwmC/Qto3S7RoZKp5cilZbxzO5iTNTQsJ+EeDg==", 1693 | "dev": true, 1694 | "requires": { 1695 | "@nodelib/fs.stat": "^2.0.2", 1696 | "@nodelib/fs.walk": "^1.2.3", 1697 | "glob-parent": "^5.1.0", 1698 | "merge2": "^1.3.0", 1699 | "micromatch": "^4.0.2", 1700 | "picomatch": "^2.2.1" 1701 | } 1702 | }, 1703 | "fast-json-stable-stringify": { 1704 | "version": "2.1.0", 1705 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1706 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1707 | "dev": true 1708 | }, 1709 | "fast-levenshtein": { 1710 | "version": "2.0.6", 1711 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1712 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 1713 | "dev": true 1714 | }, 1715 | "fast-safe-stringify": { 1716 | "version": "2.0.7", 1717 | "resolved": "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.0.7.tgz", 1718 | "integrity": "sha512-Utm6CdzT+6xsDk2m8S6uL8VHxNwI6Jub+e9NYTcAms28T84pTa25GJQV9j0CY0N1rM8hK4x6grpF2BQf+2qwVA==" 1719 | }, 1720 | "fastq": { 1721 | "version": "1.11.0", 1722 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.11.0.tgz", 1723 | "integrity": "sha512-7Eczs8gIPDrVzT+EksYBcupqMyxSHXXrHOLRRxU2/DicV8789MRBRR8+Hc2uWzUupOs4YS4JzBmBxjjCVBxD/g==", 1724 | "dev": true, 1725 | "requires": { 1726 | "reusify": "^1.0.4" 1727 | } 1728 | }, 1729 | "fecha": { 1730 | "version": "4.2.1", 1731 | "resolved": "https://registry.npmjs.org/fecha/-/fecha-4.2.1.tgz", 1732 | "integrity": "sha512-MMMQ0ludy/nBs1/o0zVOiKTpG7qMbonKUzjJgQFEuvq6INZ1OraKPRAWkBq5vlKLOUMpmNYG1JoN3oDPUQ9m3Q==" 1733 | }, 1734 | "figures": { 1735 | "version": "3.2.0", 1736 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", 1737 | "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", 1738 | "dev": true, 1739 | "requires": { 1740 | "escape-string-regexp": "^1.0.5" 1741 | }, 1742 | "dependencies": { 1743 | "escape-string-regexp": { 1744 | "version": "1.0.5", 1745 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1746 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 1747 | "dev": true 1748 | } 1749 | } 1750 | }, 1751 | "file-entry-cache": { 1752 | "version": "6.0.1", 1753 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 1754 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 1755 | "dev": true, 1756 | "requires": { 1757 | "flat-cache": "^3.0.4" 1758 | } 1759 | }, 1760 | "fill-range": { 1761 | "version": "7.0.1", 1762 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1763 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1764 | "dev": true, 1765 | "requires": { 1766 | "to-regex-range": "^5.0.1" 1767 | } 1768 | }, 1769 | "finalhandler": { 1770 | "version": "1.1.2", 1771 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 1772 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 1773 | "requires": { 1774 | "debug": "2.6.9", 1775 | "encodeurl": "~1.0.2", 1776 | "escape-html": "~1.0.3", 1777 | "on-finished": "~2.3.0", 1778 | "parseurl": "~1.3.3", 1779 | "statuses": "~1.5.0", 1780 | "unpipe": "~1.0.0" 1781 | }, 1782 | "dependencies": { 1783 | "debug": { 1784 | "version": "2.6.9", 1785 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1786 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1787 | "requires": { 1788 | "ms": "2.0.0" 1789 | } 1790 | }, 1791 | "ms": { 1792 | "version": "2.0.0", 1793 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1794 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1795 | } 1796 | } 1797 | }, 1798 | "find-up": { 1799 | "version": "5.0.0", 1800 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1801 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1802 | "dev": true, 1803 | "requires": { 1804 | "locate-path": "^6.0.0", 1805 | "path-exists": "^4.0.0" 1806 | } 1807 | }, 1808 | "flat": { 1809 | "version": "5.0.2", 1810 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 1811 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 1812 | "dev": true 1813 | }, 1814 | "flat-cache": { 1815 | "version": "3.0.4", 1816 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 1817 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 1818 | "dev": true, 1819 | "requires": { 1820 | "flatted": "^3.1.0", 1821 | "rimraf": "^3.0.2" 1822 | } 1823 | }, 1824 | "flatted": { 1825 | "version": "3.1.1", 1826 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.1.tgz", 1827 | "integrity": "sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA==", 1828 | "dev": true 1829 | }, 1830 | "fn.name": { 1831 | "version": "1.1.0", 1832 | "resolved": "https://registry.npmjs.org/fn.name/-/fn.name-1.1.0.tgz", 1833 | "integrity": "sha512-GRnmB5gPyJpAhTQdSZTSp9uaPSvl09KoYcMQtsB9rQoOmzs9dH6ffeccH+Z+cv6P68Hu5bC6JjRh4Ah/mHSNRw==" 1834 | }, 1835 | "follow-redirects": { 1836 | "version": "1.14.1", 1837 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.1.tgz", 1838 | "integrity": "sha512-HWqDgT7ZEkqRzBvc2s64vSZ/hfOceEol3ac/7tKwzuvEyWx3/4UegXh5oBOIotkGsObyk3xznnSRVADBgWSQVg==" 1839 | }, 1840 | "forwarded": { 1841 | "version": "0.1.2", 1842 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 1843 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 1844 | }, 1845 | "fresh": { 1846 | "version": "0.5.2", 1847 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 1848 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 1849 | }, 1850 | "fs-minipass": { 1851 | "version": "2.1.0", 1852 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz", 1853 | "integrity": "sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==", 1854 | "requires": { 1855 | "minipass": "^3.0.0" 1856 | } 1857 | }, 1858 | "fs.realpath": { 1859 | "version": "1.0.0", 1860 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1861 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 1862 | }, 1863 | "fsevents": { 1864 | "version": "2.3.2", 1865 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1866 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1867 | "dev": true, 1868 | "optional": true 1869 | }, 1870 | "functional-red-black-tree": { 1871 | "version": "1.0.1", 1872 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1873 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1874 | "dev": true 1875 | }, 1876 | "gauge": { 1877 | "version": "2.7.4", 1878 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 1879 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 1880 | "requires": { 1881 | "aproba": "^1.0.3", 1882 | "console-control-strings": "^1.0.0", 1883 | "has-unicode": "^2.0.0", 1884 | "object-assign": "^4.1.0", 1885 | "signal-exit": "^3.0.0", 1886 | "string-width": "^1.0.1", 1887 | "strip-ansi": "^3.0.1", 1888 | "wide-align": "^1.1.0" 1889 | }, 1890 | "dependencies": { 1891 | "ansi-regex": { 1892 | "version": "2.1.1", 1893 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 1894 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 1895 | }, 1896 | "is-fullwidth-code-point": { 1897 | "version": "1.0.0", 1898 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 1899 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 1900 | "requires": { 1901 | "number-is-nan": "^1.0.0" 1902 | } 1903 | }, 1904 | "string-width": { 1905 | "version": "1.0.2", 1906 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 1907 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 1908 | "requires": { 1909 | "code-point-at": "^1.0.0", 1910 | "is-fullwidth-code-point": "^1.0.0", 1911 | "strip-ansi": "^3.0.0" 1912 | } 1913 | }, 1914 | "strip-ansi": { 1915 | "version": "3.0.1", 1916 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 1917 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 1918 | "requires": { 1919 | "ansi-regex": "^2.0.0" 1920 | } 1921 | } 1922 | } 1923 | }, 1924 | "get-caller-file": { 1925 | "version": "2.0.5", 1926 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1927 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1928 | "dev": true 1929 | }, 1930 | "get-func-name": { 1931 | "version": "2.0.0", 1932 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 1933 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 1934 | "dev": true 1935 | }, 1936 | "get-own-enumerable-property-symbols": { 1937 | "version": "3.0.2", 1938 | "resolved": "https://registry.npmjs.org/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz", 1939 | "integrity": "sha512-I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g==", 1940 | "dev": true 1941 | }, 1942 | "get-stream": { 1943 | "version": "6.0.1", 1944 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 1945 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 1946 | "dev": true 1947 | }, 1948 | "glob": { 1949 | "version": "7.1.7", 1950 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 1951 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 1952 | "requires": { 1953 | "fs.realpath": "^1.0.0", 1954 | "inflight": "^1.0.4", 1955 | "inherits": "2", 1956 | "minimatch": "^3.0.4", 1957 | "once": "^1.3.0", 1958 | "path-is-absolute": "^1.0.0" 1959 | } 1960 | }, 1961 | "glob-parent": { 1962 | "version": "5.1.2", 1963 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1964 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1965 | "dev": true, 1966 | "requires": { 1967 | "is-glob": "^4.0.1" 1968 | } 1969 | }, 1970 | "globals": { 1971 | "version": "13.8.0", 1972 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.8.0.tgz", 1973 | "integrity": "sha512-rHtdA6+PDBIjeEvA91rpqzEvk/k3/i7EeNQiryiWuJH0Hw9cpyJMAt2jtbAwUaRdhD+573X4vWw6IcjKPasi9Q==", 1974 | "dev": true, 1975 | "requires": { 1976 | "type-fest": "^0.20.2" 1977 | }, 1978 | "dependencies": { 1979 | "type-fest": { 1980 | "version": "0.20.2", 1981 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1982 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1983 | "dev": true 1984 | } 1985 | } 1986 | }, 1987 | "globby": { 1988 | "version": "11.0.3", 1989 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.0.3.tgz", 1990 | "integrity": "sha512-ffdmosjA807y7+lA1NM0jELARVmYul/715xiILEjo3hBLPTcirgQNnXECn5g3mtR8TOLCVbkfua1Hpen25/Xcg==", 1991 | "dev": true, 1992 | "requires": { 1993 | "array-union": "^2.1.0", 1994 | "dir-glob": "^3.0.1", 1995 | "fast-glob": "^3.1.1", 1996 | "ignore": "^5.1.4", 1997 | "merge2": "^1.3.0", 1998 | "slash": "^3.0.0" 1999 | } 2000 | }, 2001 | "growl": { 2002 | "version": "1.10.5", 2003 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 2004 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 2005 | "dev": true 2006 | }, 2007 | "has-flag": { 2008 | "version": "3.0.0", 2009 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2010 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 2011 | "dev": true 2012 | }, 2013 | "has-unicode": { 2014 | "version": "2.0.1", 2015 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 2016 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" 2017 | }, 2018 | "he": { 2019 | "version": "1.2.0", 2020 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 2021 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 2022 | "dev": true 2023 | }, 2024 | "http-errors": { 2025 | "version": "1.7.2", 2026 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 2027 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 2028 | "requires": { 2029 | "depd": "~1.1.2", 2030 | "inherits": "2.0.3", 2031 | "setprototypeof": "1.1.1", 2032 | "statuses": ">= 1.5.0 < 2", 2033 | "toidentifier": "1.0.0" 2034 | }, 2035 | "dependencies": { 2036 | "inherits": { 2037 | "version": "2.0.3", 2038 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 2039 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 2040 | } 2041 | } 2042 | }, 2043 | "https-proxy-agent": { 2044 | "version": "5.0.0", 2045 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 2046 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 2047 | "requires": { 2048 | "agent-base": "6", 2049 | "debug": "4" 2050 | } 2051 | }, 2052 | "human-signals": { 2053 | "version": "2.1.0", 2054 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", 2055 | "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", 2056 | "dev": true 2057 | }, 2058 | "husky": { 2059 | "version": "6.0.0", 2060 | "resolved": "https://registry.npmjs.org/husky/-/husky-6.0.0.tgz", 2061 | "integrity": "sha512-SQS2gDTB7tBN486QSoKPKQItZw97BMOd+Kdb6ghfpBc0yXyzrddI0oDV5MkDAbuB4X2mO3/nj60TRMcYxwzZeQ==", 2062 | "dev": true 2063 | }, 2064 | "iconv-lite": { 2065 | "version": "0.4.24", 2066 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 2067 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 2068 | "requires": { 2069 | "safer-buffer": ">= 2.1.2 < 3" 2070 | } 2071 | }, 2072 | "ignore": { 2073 | "version": "5.1.8", 2074 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.8.tgz", 2075 | "integrity": "sha512-BMpfD7PpiETpBl/A6S498BaIJ6Y/ABT93ETbby2fP00v4EbvPBXWEoaR1UBPKs3iR53pJY7EtZk5KACI57i1Uw==", 2076 | "dev": true 2077 | }, 2078 | "import-fresh": { 2079 | "version": "3.3.0", 2080 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2081 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2082 | "dev": true, 2083 | "requires": { 2084 | "parent-module": "^1.0.0", 2085 | "resolve-from": "^4.0.0" 2086 | } 2087 | }, 2088 | "imurmurhash": { 2089 | "version": "0.1.4", 2090 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2091 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 2092 | "dev": true 2093 | }, 2094 | "indent-string": { 2095 | "version": "4.0.0", 2096 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 2097 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 2098 | "dev": true 2099 | }, 2100 | "inflight": { 2101 | "version": "1.0.6", 2102 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2103 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 2104 | "requires": { 2105 | "once": "^1.3.0", 2106 | "wrappy": "1" 2107 | } 2108 | }, 2109 | "inherits": { 2110 | "version": "2.0.4", 2111 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2112 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 2113 | }, 2114 | "ipaddr.js": { 2115 | "version": "1.9.1", 2116 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 2117 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 2118 | }, 2119 | "is-arrayish": { 2120 | "version": "0.2.1", 2121 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 2122 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 2123 | "dev": true 2124 | }, 2125 | "is-binary-path": { 2126 | "version": "2.1.0", 2127 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2128 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2129 | "dev": true, 2130 | "requires": { 2131 | "binary-extensions": "^2.0.0" 2132 | } 2133 | }, 2134 | "is-extglob": { 2135 | "version": "2.1.1", 2136 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2137 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 2138 | "dev": true 2139 | }, 2140 | "is-fullwidth-code-point": { 2141 | "version": "3.0.0", 2142 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2143 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2144 | "dev": true 2145 | }, 2146 | "is-glob": { 2147 | "version": "4.0.1", 2148 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 2149 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 2150 | "dev": true, 2151 | "requires": { 2152 | "is-extglob": "^2.1.1" 2153 | } 2154 | }, 2155 | "is-number": { 2156 | "version": "7.0.0", 2157 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2158 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2159 | "dev": true 2160 | }, 2161 | "is-obj": { 2162 | "version": "1.0.1", 2163 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", 2164 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=", 2165 | "dev": true 2166 | }, 2167 | "is-plain-obj": { 2168 | "version": "2.1.0", 2169 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 2170 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 2171 | "dev": true 2172 | }, 2173 | "is-regexp": { 2174 | "version": "1.0.0", 2175 | "resolved": "https://registry.npmjs.org/is-regexp/-/is-regexp-1.0.0.tgz", 2176 | "integrity": "sha1-/S2INUXEa6xaYz57mgnof6LLUGk=", 2177 | "dev": true 2178 | }, 2179 | "is-retry-allowed": { 2180 | "version": "1.2.0", 2181 | "resolved": "https://registry.npmjs.org/is-retry-allowed/-/is-retry-allowed-1.2.0.tgz", 2182 | "integrity": "sha512-RUbUeKwvm3XG2VYamhJL1xFktgjvPzL0Hq8C+6yrWIswDy3BIXGqCxhxkc30N9jqK311gVU137K8Ei55/zVJRg==" 2183 | }, 2184 | "is-stream": { 2185 | "version": "2.0.0", 2186 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", 2187 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==" 2188 | }, 2189 | "is-unicode-supported": { 2190 | "version": "0.1.0", 2191 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 2192 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 2193 | "dev": true 2194 | }, 2195 | "isarray": { 2196 | "version": "1.0.0", 2197 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2198 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 2199 | }, 2200 | "isexe": { 2201 | "version": "2.0.0", 2202 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2203 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 2204 | "dev": true 2205 | }, 2206 | "js-tokens": { 2207 | "version": "4.0.0", 2208 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2209 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 2210 | "dev": true 2211 | }, 2212 | "js-yaml": { 2213 | "version": "3.14.1", 2214 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 2215 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 2216 | "dev": true, 2217 | "requires": { 2218 | "argparse": "^1.0.7", 2219 | "esprima": "^4.0.0" 2220 | } 2221 | }, 2222 | "json-parse-even-better-errors": { 2223 | "version": "2.3.1", 2224 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", 2225 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", 2226 | "dev": true 2227 | }, 2228 | "json-schema-traverse": { 2229 | "version": "0.4.1", 2230 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2231 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2232 | "dev": true 2233 | }, 2234 | "json-stable-stringify-without-jsonify": { 2235 | "version": "1.0.1", 2236 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2237 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 2238 | "dev": true 2239 | }, 2240 | "jsonwebtoken": { 2241 | "version": "8.5.1", 2242 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", 2243 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", 2244 | "requires": { 2245 | "jws": "^3.2.2", 2246 | "lodash.includes": "^4.3.0", 2247 | "lodash.isboolean": "^3.0.3", 2248 | "lodash.isinteger": "^4.0.4", 2249 | "lodash.isnumber": "^3.0.3", 2250 | "lodash.isplainobject": "^4.0.6", 2251 | "lodash.isstring": "^4.0.1", 2252 | "lodash.once": "^4.0.0", 2253 | "ms": "^2.1.1", 2254 | "semver": "^5.6.0" 2255 | }, 2256 | "dependencies": { 2257 | "semver": { 2258 | "version": "5.7.1", 2259 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 2260 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 2261 | } 2262 | } 2263 | }, 2264 | "just-extend": { 2265 | "version": "4.2.1", 2266 | "resolved": "https://registry.npmjs.org/just-extend/-/just-extend-4.2.1.tgz", 2267 | "integrity": "sha512-g3UB796vUFIY90VIv/WX3L2c8CS2MdWUww3CNrYmqza1Fg0DURc2K/O4YrnklBdQarSJ/y8JnJYDGc+1iumQjg==", 2268 | "dev": true 2269 | }, 2270 | "jwa": { 2271 | "version": "1.4.1", 2272 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 2273 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 2274 | "requires": { 2275 | "buffer-equal-constant-time": "1.0.1", 2276 | "ecdsa-sig-formatter": "1.0.11", 2277 | "safe-buffer": "^5.0.1" 2278 | } 2279 | }, 2280 | "jws": { 2281 | "version": "3.2.2", 2282 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 2283 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 2284 | "requires": { 2285 | "jwa": "^1.4.1", 2286 | "safe-buffer": "^5.0.1" 2287 | } 2288 | }, 2289 | "kareem": { 2290 | "version": "2.3.1", 2291 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.1.tgz", 2292 | "integrity": "sha512-l3hLhffs9zqoDe8zjmb/mAN4B8VT3L56EUvKNqLFVs9YlFA+zx7ke1DO8STAdDyYNkeSo1nKmjuvQeI12So8Xw==" 2293 | }, 2294 | "kuler": { 2295 | "version": "2.0.0", 2296 | "resolved": "https://registry.npmjs.org/kuler/-/kuler-2.0.0.tgz", 2297 | "integrity": "sha512-Xq9nH7KlWZmXAtodXDDRE7vs6DU1gTU8zYDHDiWLSip45Egwq3plLHzPn27NgvzL2r1LMPC1vdqh98sQxtqj4A==" 2298 | }, 2299 | "levn": { 2300 | "version": "0.4.1", 2301 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2302 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2303 | "dev": true, 2304 | "requires": { 2305 | "prelude-ls": "^1.2.1", 2306 | "type-check": "~0.4.0" 2307 | } 2308 | }, 2309 | "lines-and-columns": { 2310 | "version": "1.1.6", 2311 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.1.6.tgz", 2312 | "integrity": "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=", 2313 | "dev": true 2314 | }, 2315 | "lint-staged": { 2316 | "version": "11.0.0", 2317 | "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-11.0.0.tgz", 2318 | "integrity": "sha512-3rsRIoyaE8IphSUtO1RVTFl1e0SLBtxxUOPBtHxQgBHS5/i6nqvjcUfNioMa4BU9yGnPzbO+xkfLtXtxBpCzjw==", 2319 | "dev": true, 2320 | "requires": { 2321 | "chalk": "^4.1.1", 2322 | "cli-truncate": "^2.1.0", 2323 | "commander": "^7.2.0", 2324 | "cosmiconfig": "^7.0.0", 2325 | "debug": "^4.3.1", 2326 | "dedent": "^0.7.0", 2327 | "enquirer": "^2.3.6", 2328 | "execa": "^5.0.0", 2329 | "listr2": "^3.8.2", 2330 | "log-symbols": "^4.1.0", 2331 | "micromatch": "^4.0.4", 2332 | "normalize-path": "^3.0.0", 2333 | "please-upgrade-node": "^3.2.0", 2334 | "string-argv": "0.3.1", 2335 | "stringify-object": "^3.3.0" 2336 | } 2337 | }, 2338 | "listr2": { 2339 | "version": "3.8.2", 2340 | "resolved": "https://registry.npmjs.org/listr2/-/listr2-3.8.2.tgz", 2341 | "integrity": "sha512-E28Fw7Zd3HQlCJKzb9a8C8M0HtFWQeucE+S8YrSrqZObuCLPRHMRrR8gNmYt65cU9orXYHwvN5agXC36lYt7VQ==", 2342 | "dev": true, 2343 | "requires": { 2344 | "chalk": "^4.1.1", 2345 | "cli-truncate": "^2.1.0", 2346 | "figures": "^3.2.0", 2347 | "indent-string": "^4.0.0", 2348 | "log-update": "^4.0.0", 2349 | "p-map": "^4.0.0", 2350 | "rxjs": "^6.6.7", 2351 | "through": "^2.3.8", 2352 | "wrap-ansi": "^7.0.0" 2353 | } 2354 | }, 2355 | "locate-path": { 2356 | "version": "6.0.0", 2357 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2358 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2359 | "dev": true, 2360 | "requires": { 2361 | "p-locate": "^5.0.0" 2362 | } 2363 | }, 2364 | "lodash": { 2365 | "version": "4.17.21", 2366 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 2367 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 2368 | "dev": true 2369 | }, 2370 | "lodash.clonedeep": { 2371 | "version": "4.5.0", 2372 | "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", 2373 | "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=", 2374 | "dev": true 2375 | }, 2376 | "lodash.get": { 2377 | "version": "4.4.2", 2378 | "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", 2379 | "integrity": "sha1-LRd/ZS+jHpObRDjVNBSZ36OCXpk=", 2380 | "dev": true 2381 | }, 2382 | "lodash.includes": { 2383 | "version": "4.3.0", 2384 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 2385 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 2386 | }, 2387 | "lodash.isboolean": { 2388 | "version": "3.0.3", 2389 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 2390 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 2391 | }, 2392 | "lodash.isinteger": { 2393 | "version": "4.0.4", 2394 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 2395 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 2396 | }, 2397 | "lodash.isnumber": { 2398 | "version": "3.0.3", 2399 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 2400 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 2401 | }, 2402 | "lodash.isplainobject": { 2403 | "version": "4.0.6", 2404 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 2405 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 2406 | }, 2407 | "lodash.isstring": { 2408 | "version": "4.0.1", 2409 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 2410 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 2411 | }, 2412 | "lodash.merge": { 2413 | "version": "4.6.2", 2414 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2415 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2416 | "dev": true 2417 | }, 2418 | "lodash.once": { 2419 | "version": "4.1.1", 2420 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 2421 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 2422 | }, 2423 | "lodash.truncate": { 2424 | "version": "4.4.2", 2425 | "resolved": "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz", 2426 | "integrity": "sha1-WjUNoLERO4N+z//VgSy+WNbq4ZM=", 2427 | "dev": true 2428 | }, 2429 | "log-symbols": { 2430 | "version": "4.1.0", 2431 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 2432 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 2433 | "dev": true, 2434 | "requires": { 2435 | "chalk": "^4.1.0", 2436 | "is-unicode-supported": "^0.1.0" 2437 | } 2438 | }, 2439 | "log-update": { 2440 | "version": "4.0.0", 2441 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-4.0.0.tgz", 2442 | "integrity": "sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg==", 2443 | "dev": true, 2444 | "requires": { 2445 | "ansi-escapes": "^4.3.0", 2446 | "cli-cursor": "^3.1.0", 2447 | "slice-ansi": "^4.0.0", 2448 | "wrap-ansi": "^6.2.0" 2449 | }, 2450 | "dependencies": { 2451 | "ansi-styles": { 2452 | "version": "4.3.0", 2453 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2454 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2455 | "dev": true, 2456 | "requires": { 2457 | "color-convert": "^2.0.1" 2458 | } 2459 | }, 2460 | "color-convert": { 2461 | "version": "2.0.1", 2462 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2463 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2464 | "dev": true, 2465 | "requires": { 2466 | "color-name": "~1.1.4" 2467 | } 2468 | }, 2469 | "color-name": { 2470 | "version": "1.1.4", 2471 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2472 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2473 | "dev": true 2474 | }, 2475 | "wrap-ansi": { 2476 | "version": "6.2.0", 2477 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 2478 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 2479 | "dev": true, 2480 | "requires": { 2481 | "ansi-styles": "^4.0.0", 2482 | "string-width": "^4.1.0", 2483 | "strip-ansi": "^6.0.0" 2484 | } 2485 | } 2486 | } 2487 | }, 2488 | "logform": { 2489 | "version": "2.2.0", 2490 | "resolved": "https://registry.npmjs.org/logform/-/logform-2.2.0.tgz", 2491 | "integrity": "sha512-N0qPlqfypFx7UHNn4B3lzS/b0uLqt2hmuoa+PpuXNYgozdJYAyauF5Ky0BWVjrxDlMWiT3qN4zPq3vVAfZy7Yg==", 2492 | "requires": { 2493 | "colors": "^1.2.1", 2494 | "fast-safe-stringify": "^2.0.4", 2495 | "fecha": "^4.2.0", 2496 | "ms": "^2.1.1", 2497 | "triple-beam": "^1.3.0" 2498 | } 2499 | }, 2500 | "lru-cache": { 2501 | "version": "6.0.0", 2502 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2503 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2504 | "requires": { 2505 | "yallist": "^4.0.0" 2506 | } 2507 | }, 2508 | "make-dir": { 2509 | "version": "3.1.0", 2510 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 2511 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 2512 | "requires": { 2513 | "semver": "^6.0.0" 2514 | }, 2515 | "dependencies": { 2516 | "semver": { 2517 | "version": "6.3.0", 2518 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2519 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 2520 | } 2521 | } 2522 | }, 2523 | "make-error": { 2524 | "version": "1.3.6", 2525 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 2526 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 2527 | "dev": true 2528 | }, 2529 | "media-typer": { 2530 | "version": "0.3.0", 2531 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 2532 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 2533 | }, 2534 | "memory-pager": { 2535 | "version": "1.5.0", 2536 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 2537 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 2538 | "optional": true 2539 | }, 2540 | "merge-descriptors": { 2541 | "version": "1.0.1", 2542 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 2543 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 2544 | }, 2545 | "merge-stream": { 2546 | "version": "2.0.0", 2547 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 2548 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 2549 | "dev": true 2550 | }, 2551 | "merge2": { 2552 | "version": "1.4.1", 2553 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 2554 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 2555 | "dev": true 2556 | }, 2557 | "methods": { 2558 | "version": "1.1.2", 2559 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 2560 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 2561 | }, 2562 | "micromatch": { 2563 | "version": "4.0.4", 2564 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", 2565 | "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", 2566 | "dev": true, 2567 | "requires": { 2568 | "braces": "^3.0.1", 2569 | "picomatch": "^2.2.3" 2570 | } 2571 | }, 2572 | "mime": { 2573 | "version": "1.6.0", 2574 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 2575 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 2576 | }, 2577 | "mime-db": { 2578 | "version": "1.47.0", 2579 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.47.0.tgz", 2580 | "integrity": "sha512-QBmA/G2y+IfeS4oktet3qRZ+P5kPhCKRXxXnQEudYqUaEioAU1/Lq2us3D/t1Jfo4hE9REQPrbB7K5sOczJVIw==" 2581 | }, 2582 | "mime-types": { 2583 | "version": "2.1.30", 2584 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.30.tgz", 2585 | "integrity": "sha512-crmjA4bLtR8m9qLpHvgxSChT+XoSlZi8J4n/aIdn3z92e/U47Z0V/yl+Wh9W046GgFVAmoNR/fmdbZYcSSIUeg==", 2586 | "requires": { 2587 | "mime-db": "1.47.0" 2588 | } 2589 | }, 2590 | "mimic-fn": { 2591 | "version": "2.1.0", 2592 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 2593 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 2594 | "dev": true 2595 | }, 2596 | "minimatch": { 2597 | "version": "3.0.4", 2598 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2599 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2600 | "requires": { 2601 | "brace-expansion": "^1.1.7" 2602 | } 2603 | }, 2604 | "minipass": { 2605 | "version": "3.1.3", 2606 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.1.3.tgz", 2607 | "integrity": "sha512-Mgd2GdMVzY+x3IJ+oHnVM+KG3lA5c8tnabyJKmHSaG2kAGpudxuOf8ToDkhumF7UzME7DecbQE9uOZhNm7PuJg==", 2608 | "requires": { 2609 | "yallist": "^4.0.0" 2610 | } 2611 | }, 2612 | "minizlib": { 2613 | "version": "2.1.2", 2614 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", 2615 | "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", 2616 | "requires": { 2617 | "minipass": "^3.0.0", 2618 | "yallist": "^4.0.0" 2619 | } 2620 | }, 2621 | "mkdirp": { 2622 | "version": "1.0.4", 2623 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 2624 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==" 2625 | }, 2626 | "mocha": { 2627 | "version": "8.4.0", 2628 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-8.4.0.tgz", 2629 | "integrity": "sha512-hJaO0mwDXmZS4ghXsvPVriOhsxQ7ofcpQdm8dE+jISUOKopitvnXFQmpRR7jd2K6VBG6E26gU3IAbXXGIbu4sQ==", 2630 | "dev": true, 2631 | "requires": { 2632 | "@ungap/promise-all-settled": "1.1.2", 2633 | "ansi-colors": "4.1.1", 2634 | "browser-stdout": "1.3.1", 2635 | "chokidar": "3.5.1", 2636 | "debug": "4.3.1", 2637 | "diff": "5.0.0", 2638 | "escape-string-regexp": "4.0.0", 2639 | "find-up": "5.0.0", 2640 | "glob": "7.1.6", 2641 | "growl": "1.10.5", 2642 | "he": "1.2.0", 2643 | "js-yaml": "4.0.0", 2644 | "log-symbols": "4.0.0", 2645 | "minimatch": "3.0.4", 2646 | "ms": "2.1.3", 2647 | "nanoid": "3.1.20", 2648 | "serialize-javascript": "5.0.1", 2649 | "strip-json-comments": "3.1.1", 2650 | "supports-color": "8.1.1", 2651 | "which": "2.0.2", 2652 | "wide-align": "1.1.3", 2653 | "workerpool": "6.1.0", 2654 | "yargs": "16.2.0", 2655 | "yargs-parser": "20.2.4", 2656 | "yargs-unparser": "2.0.0" 2657 | }, 2658 | "dependencies": { 2659 | "argparse": { 2660 | "version": "2.0.1", 2661 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 2662 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 2663 | "dev": true 2664 | }, 2665 | "diff": { 2666 | "version": "5.0.0", 2667 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 2668 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 2669 | "dev": true 2670 | }, 2671 | "glob": { 2672 | "version": "7.1.6", 2673 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 2674 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 2675 | "dev": true, 2676 | "requires": { 2677 | "fs.realpath": "^1.0.0", 2678 | "inflight": "^1.0.4", 2679 | "inherits": "2", 2680 | "minimatch": "^3.0.4", 2681 | "once": "^1.3.0", 2682 | "path-is-absolute": "^1.0.0" 2683 | } 2684 | }, 2685 | "has-flag": { 2686 | "version": "4.0.0", 2687 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2688 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2689 | "dev": true 2690 | }, 2691 | "js-yaml": { 2692 | "version": "4.0.0", 2693 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.0.0.tgz", 2694 | "integrity": "sha512-pqon0s+4ScYUvX30wxQi3PogGFAlUyH0awepWvwkj4jD4v+ova3RiYw8bmA6x2rDrEaj8i/oWKoRxpVNW+Re8Q==", 2695 | "dev": true, 2696 | "requires": { 2697 | "argparse": "^2.0.1" 2698 | } 2699 | }, 2700 | "log-symbols": { 2701 | "version": "4.0.0", 2702 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.0.0.tgz", 2703 | "integrity": "sha512-FN8JBzLx6CzeMrB0tg6pqlGU1wCrXW+ZXGH481kfsBqer0hToTIiHdjH4Mq8xJUbvATujKCvaREGWpGUionraA==", 2704 | "dev": true, 2705 | "requires": { 2706 | "chalk": "^4.0.0" 2707 | } 2708 | }, 2709 | "ms": { 2710 | "version": "2.1.3", 2711 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2712 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2713 | "dev": true 2714 | }, 2715 | "supports-color": { 2716 | "version": "8.1.1", 2717 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 2718 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 2719 | "dev": true, 2720 | "requires": { 2721 | "has-flag": "^4.0.0" 2722 | } 2723 | } 2724 | } 2725 | }, 2726 | "mongodb": { 2727 | "version": "3.6.2", 2728 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.6.2.tgz", 2729 | "integrity": "sha512-sSZOb04w3HcnrrXC82NEh/YGCmBuRgR+C1hZgmmv4L6dBz4BkRse6Y8/q/neXer9i95fKUBbFi4KgeceXmbsOA==", 2730 | "requires": { 2731 | "bl": "^2.2.1", 2732 | "bson": "^1.1.4", 2733 | "denque": "^1.4.1", 2734 | "require_optional": "^1.0.1", 2735 | "safe-buffer": "^5.1.2", 2736 | "saslprep": "^1.0.0" 2737 | } 2738 | }, 2739 | "mongoose": { 2740 | "version": "5.10.5", 2741 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.10.5.tgz", 2742 | "integrity": "sha512-BOQZsZn9Y79f3rWZFLD1gvOLNN5gOiGvGr5raqQ5v/T4fdAmnjXGCVynpW4SRnQLtrcCeLXyaaXVRT75863Q0w==", 2743 | "requires": { 2744 | "bson": "^1.1.4", 2745 | "kareem": "2.3.1", 2746 | "mongodb": "3.6.2", 2747 | "mongoose-legacy-pluralize": "1.0.2", 2748 | "mpath": "0.7.0", 2749 | "mquery": "3.2.2", 2750 | "ms": "2.1.2", 2751 | "regexp-clone": "1.0.0", 2752 | "safe-buffer": "5.2.1", 2753 | "sift": "7.0.1", 2754 | "sliced": "1.0.1" 2755 | } 2756 | }, 2757 | "mongoose-legacy-pluralize": { 2758 | "version": "1.0.2", 2759 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz", 2760 | "integrity": "sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ==" 2761 | }, 2762 | "mpath": { 2763 | "version": "0.7.0", 2764 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.7.0.tgz", 2765 | "integrity": "sha512-Aiq04hILxhz1L+f7sjGyn7IxYzWm1zLNNXcfhDtx04kZ2Gk7uvFdgZ8ts1cWa/6d0TQmag2yR8zSGZUmp0tFNg==" 2766 | }, 2767 | "mquery": { 2768 | "version": "3.2.2", 2769 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.2.2.tgz", 2770 | "integrity": "sha512-XB52992COp0KP230I3qloVUbkLUxJIu328HBP2t2EsxSFtf4W1HPSOBWOXf1bqxK4Xbb66lfMJ+Bpfd9/yZE1Q==", 2771 | "requires": { 2772 | "bluebird": "3.5.1", 2773 | "debug": "3.1.0", 2774 | "regexp-clone": "^1.0.0", 2775 | "safe-buffer": "5.1.2", 2776 | "sliced": "1.0.1" 2777 | }, 2778 | "dependencies": { 2779 | "debug": { 2780 | "version": "3.1.0", 2781 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 2782 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 2783 | "requires": { 2784 | "ms": "2.0.0" 2785 | } 2786 | }, 2787 | "ms": { 2788 | "version": "2.0.0", 2789 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2790 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2791 | }, 2792 | "safe-buffer": { 2793 | "version": "5.1.2", 2794 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2795 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2796 | } 2797 | } 2798 | }, 2799 | "ms": { 2800 | "version": "2.1.2", 2801 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2802 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2803 | }, 2804 | "nanoid": { 2805 | "version": "3.1.20", 2806 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.20.tgz", 2807 | "integrity": "sha512-a1cQNyczgKbLX9jwbS/+d7W8fX/RfgYR7lVWwWOGIPNgK2m0MWvrGF6/m4kk6U3QcFMnZf3RIhL0v2Jgh/0Uxw==", 2808 | "dev": true 2809 | }, 2810 | "natural-compare": { 2811 | "version": "1.4.0", 2812 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2813 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2814 | "dev": true 2815 | }, 2816 | "negotiator": { 2817 | "version": "0.6.2", 2818 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 2819 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 2820 | }, 2821 | "nise": { 2822 | "version": "4.1.0", 2823 | "resolved": "https://registry.npmjs.org/nise/-/nise-4.1.0.tgz", 2824 | "integrity": "sha512-eQMEmGN/8arp0xsvGoQ+B1qvSkR73B1nWSCh7nOt5neMCtwcQVYQGdzQMhcNscktTsWB54xnlSQFzOAPJD8nXA==", 2825 | "dev": true, 2826 | "requires": { 2827 | "@sinonjs/commons": "^1.7.0", 2828 | "@sinonjs/fake-timers": "^6.0.0", 2829 | "@sinonjs/text-encoding": "^0.7.1", 2830 | "just-extend": "^4.0.2", 2831 | "path-to-regexp": "^1.7.0" 2832 | } 2833 | }, 2834 | "node-addon-api": { 2835 | "version": "3.2.0", 2836 | "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-3.2.0.tgz", 2837 | "integrity": "sha512-kcwSAWhPi4+QzAtsL2+2s/awvDo2GKLsvMCwNRxb5BUshteXU8U97NCyvQDsGKs/m0He9WcG4YWew/BnuLx++w==" 2838 | }, 2839 | "node-fetch": { 2840 | "version": "2.6.1", 2841 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.1.tgz", 2842 | "integrity": "sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw==" 2843 | }, 2844 | "nopt": { 2845 | "version": "5.0.0", 2846 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz", 2847 | "integrity": "sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==", 2848 | "requires": { 2849 | "abbrev": "1" 2850 | } 2851 | }, 2852 | "normalize-path": { 2853 | "version": "3.0.0", 2854 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2855 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2856 | "dev": true 2857 | }, 2858 | "npm-run-path": { 2859 | "version": "4.0.1", 2860 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", 2861 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", 2862 | "dev": true, 2863 | "requires": { 2864 | "path-key": "^3.0.0" 2865 | } 2866 | }, 2867 | "npmlog": { 2868 | "version": "4.1.2", 2869 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 2870 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 2871 | "requires": { 2872 | "are-we-there-yet": "~1.1.2", 2873 | "console-control-strings": "~1.1.0", 2874 | "gauge": "~2.7.3", 2875 | "set-blocking": "~2.0.0" 2876 | } 2877 | }, 2878 | "number-is-nan": { 2879 | "version": "1.0.1", 2880 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 2881 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 2882 | }, 2883 | "object-assign": { 2884 | "version": "4.1.1", 2885 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2886 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 2887 | }, 2888 | "on-finished": { 2889 | "version": "2.3.0", 2890 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 2891 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 2892 | "requires": { 2893 | "ee-first": "1.1.1" 2894 | } 2895 | }, 2896 | "on-headers": { 2897 | "version": "1.0.2", 2898 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", 2899 | "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==" 2900 | }, 2901 | "once": { 2902 | "version": "1.4.0", 2903 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2904 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2905 | "requires": { 2906 | "wrappy": "1" 2907 | } 2908 | }, 2909 | "one-time": { 2910 | "version": "1.0.0", 2911 | "resolved": "https://registry.npmjs.org/one-time/-/one-time-1.0.0.tgz", 2912 | "integrity": "sha512-5DXOiRKwuSEcQ/l0kGCF6Q3jcADFv5tSmRaJck/OqkVFcOzutB134KRSfF0xDrL39MNnqxbHBbUUcjZIhTgb2g==", 2913 | "requires": { 2914 | "fn.name": "1.x.x" 2915 | } 2916 | }, 2917 | "onetime": { 2918 | "version": "5.1.2", 2919 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 2920 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 2921 | "dev": true, 2922 | "requires": { 2923 | "mimic-fn": "^2.1.0" 2924 | } 2925 | }, 2926 | "optionator": { 2927 | "version": "0.9.1", 2928 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 2929 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 2930 | "dev": true, 2931 | "requires": { 2932 | "deep-is": "^0.1.3", 2933 | "fast-levenshtein": "^2.0.6", 2934 | "levn": "^0.4.1", 2935 | "prelude-ls": "^1.2.1", 2936 | "type-check": "^0.4.0", 2937 | "word-wrap": "^1.2.3" 2938 | } 2939 | }, 2940 | "p-limit": { 2941 | "version": "3.1.0", 2942 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2943 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2944 | "dev": true, 2945 | "requires": { 2946 | "yocto-queue": "^0.1.0" 2947 | } 2948 | }, 2949 | "p-locate": { 2950 | "version": "5.0.0", 2951 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2952 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2953 | "dev": true, 2954 | "requires": { 2955 | "p-limit": "^3.0.2" 2956 | } 2957 | }, 2958 | "p-map": { 2959 | "version": "4.0.0", 2960 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", 2961 | "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", 2962 | "dev": true, 2963 | "requires": { 2964 | "aggregate-error": "^3.0.0" 2965 | } 2966 | }, 2967 | "parent-module": { 2968 | "version": "1.0.1", 2969 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2970 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2971 | "dev": true, 2972 | "requires": { 2973 | "callsites": "^3.0.0" 2974 | } 2975 | }, 2976 | "parse-json": { 2977 | "version": "5.2.0", 2978 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", 2979 | "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", 2980 | "dev": true, 2981 | "requires": { 2982 | "@babel/code-frame": "^7.0.0", 2983 | "error-ex": "^1.3.1", 2984 | "json-parse-even-better-errors": "^2.3.0", 2985 | "lines-and-columns": "^1.1.6" 2986 | } 2987 | }, 2988 | "parseurl": { 2989 | "version": "1.3.3", 2990 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 2991 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 2992 | }, 2993 | "path-exists": { 2994 | "version": "4.0.0", 2995 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2996 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2997 | "dev": true 2998 | }, 2999 | "path-is-absolute": { 3000 | "version": "1.0.1", 3001 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3002 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 3003 | }, 3004 | "path-key": { 3005 | "version": "3.1.1", 3006 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3007 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3008 | "dev": true 3009 | }, 3010 | "path-to-regexp": { 3011 | "version": "1.8.0", 3012 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-1.8.0.tgz", 3013 | "integrity": "sha512-n43JRhlUKUAlibEJhPeir1ncUID16QnEjNpwzNdO3Lm4ywrBpBZ5oLD0I6br9evr1Y9JTqwRtAh7JLoOzAQdVA==", 3014 | "dev": true, 3015 | "requires": { 3016 | "isarray": "0.0.1" 3017 | }, 3018 | "dependencies": { 3019 | "isarray": { 3020 | "version": "0.0.1", 3021 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 3022 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 3023 | "dev": true 3024 | } 3025 | } 3026 | }, 3027 | "path-type": { 3028 | "version": "4.0.0", 3029 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 3030 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 3031 | "dev": true 3032 | }, 3033 | "pathval": { 3034 | "version": "1.1.1", 3035 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 3036 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 3037 | "dev": true 3038 | }, 3039 | "picomatch": { 3040 | "version": "2.3.0", 3041 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 3042 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 3043 | "dev": true 3044 | }, 3045 | "please-upgrade-node": { 3046 | "version": "3.2.0", 3047 | "resolved": "https://registry.npmjs.org/please-upgrade-node/-/please-upgrade-node-3.2.0.tgz", 3048 | "integrity": "sha512-gQR3WpIgNIKwBMVLkpMUeR3e1/E1y42bqDQZfql+kDeXd8COYfM8PQA4X6y7a8u9Ua9FHmsrrmirW2vHs45hWg==", 3049 | "dev": true, 3050 | "requires": { 3051 | "semver-compare": "^1.0.0" 3052 | } 3053 | }, 3054 | "prelude-ls": { 3055 | "version": "1.2.1", 3056 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 3057 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 3058 | "dev": true 3059 | }, 3060 | "prettier": { 3061 | "version": "2.3.0", 3062 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.3.0.tgz", 3063 | "integrity": "sha512-kXtO4s0Lz/DW/IJ9QdWhAf7/NmPWQXkFr/r/WkR3vyI+0v8amTDxiaQSLzs8NBlytfLWX/7uQUMIW677yLKl4w==", 3064 | "dev": true 3065 | }, 3066 | "prettier-linter-helpers": { 3067 | "version": "1.0.0", 3068 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 3069 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 3070 | "dev": true, 3071 | "requires": { 3072 | "fast-diff": "^1.1.2" 3073 | } 3074 | }, 3075 | "process-nextick-args": { 3076 | "version": "2.0.1", 3077 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 3078 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 3079 | }, 3080 | "progress": { 3081 | "version": "2.0.3", 3082 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 3083 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 3084 | "dev": true 3085 | }, 3086 | "proxy-addr": { 3087 | "version": "2.0.6", 3088 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz", 3089 | "integrity": "sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw==", 3090 | "requires": { 3091 | "forwarded": "~0.1.2", 3092 | "ipaddr.js": "1.9.1" 3093 | } 3094 | }, 3095 | "punycode": { 3096 | "version": "2.1.1", 3097 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 3098 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 3099 | "dev": true 3100 | }, 3101 | "qs": { 3102 | "version": "6.7.0", 3103 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 3104 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 3105 | }, 3106 | "querystringify": { 3107 | "version": "2.2.0", 3108 | "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz", 3109 | "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==" 3110 | }, 3111 | "queue-microtask": { 3112 | "version": "1.2.3", 3113 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 3114 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 3115 | "dev": true 3116 | }, 3117 | "randombytes": { 3118 | "version": "2.1.0", 3119 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 3120 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 3121 | "dev": true, 3122 | "requires": { 3123 | "safe-buffer": "^5.1.0" 3124 | } 3125 | }, 3126 | "range-parser": { 3127 | "version": "1.2.1", 3128 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 3129 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 3130 | }, 3131 | "raw-body": { 3132 | "version": "2.4.0", 3133 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 3134 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 3135 | "requires": { 3136 | "bytes": "3.1.0", 3137 | "http-errors": "1.7.2", 3138 | "iconv-lite": "0.4.24", 3139 | "unpipe": "1.0.0" 3140 | }, 3141 | "dependencies": { 3142 | "bytes": { 3143 | "version": "3.1.0", 3144 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 3145 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 3146 | } 3147 | } 3148 | }, 3149 | "readable-stream": { 3150 | "version": "3.6.0", 3151 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 3152 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 3153 | "requires": { 3154 | "inherits": "^2.0.3", 3155 | "string_decoder": "^1.1.1", 3156 | "util-deprecate": "^1.0.1" 3157 | } 3158 | }, 3159 | "readdirp": { 3160 | "version": "3.5.0", 3161 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.5.0.tgz", 3162 | "integrity": "sha512-cMhu7c/8rdhkHXWsY+osBhfSy0JikwpHK/5+imo+LpeasTF8ouErHrlYkwT0++njiyuDvc7OFY5T3ukvZ8qmFQ==", 3163 | "dev": true, 3164 | "requires": { 3165 | "picomatch": "^2.2.1" 3166 | } 3167 | }, 3168 | "redis": { 3169 | "version": "3.1.2", 3170 | "resolved": "https://registry.npmjs.org/redis/-/redis-3.1.2.tgz", 3171 | "integrity": "sha512-grn5KoZLr/qrRQVwoSkmzdbw6pwF+/rwODtrOr6vuBRiR/f3rjSTGupbF90Zpqm2oenix8Do6RV7pYEkGwlKkw==", 3172 | "requires": { 3173 | "denque": "^1.5.0", 3174 | "redis-commands": "^1.7.0", 3175 | "redis-errors": "^1.2.0", 3176 | "redis-parser": "^3.0.0" 3177 | } 3178 | }, 3179 | "redis-commands": { 3180 | "version": "1.7.0", 3181 | "resolved": "https://registry.npmjs.org/redis-commands/-/redis-commands-1.7.0.tgz", 3182 | "integrity": "sha512-nJWqw3bTFy21hX/CPKHth6sfhZbdiHP6bTawSgQBlKOVRG7EZkfHbbHwQJnrE4vsQf0CMNE+3gJ4Fmm16vdVlQ==" 3183 | }, 3184 | "redis-errors": { 3185 | "version": "1.2.0", 3186 | "resolved": "https://registry.npmjs.org/redis-errors/-/redis-errors-1.2.0.tgz", 3187 | "integrity": "sha1-62LSrbFeTq9GEMBK/hUpOEJQq60=" 3188 | }, 3189 | "redis-parser": { 3190 | "version": "3.0.0", 3191 | "resolved": "https://registry.npmjs.org/redis-parser/-/redis-parser-3.0.0.tgz", 3192 | "integrity": "sha1-tm2CjNyv5rS4pCin3vTGvKwxyLQ=", 3193 | "requires": { 3194 | "redis-errors": "^1.0.0" 3195 | } 3196 | }, 3197 | "regexp-clone": { 3198 | "version": "1.0.0", 3199 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-1.0.0.tgz", 3200 | "integrity": "sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw==" 3201 | }, 3202 | "regexpp": { 3203 | "version": "3.1.0", 3204 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 3205 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 3206 | "dev": true 3207 | }, 3208 | "require-directory": { 3209 | "version": "2.1.1", 3210 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 3211 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 3212 | "dev": true 3213 | }, 3214 | "require-from-string": { 3215 | "version": "2.0.2", 3216 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 3217 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 3218 | "dev": true 3219 | }, 3220 | "require_optional": { 3221 | "version": "1.0.1", 3222 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 3223 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 3224 | "requires": { 3225 | "resolve-from": "^2.0.0", 3226 | "semver": "^5.1.0" 3227 | }, 3228 | "dependencies": { 3229 | "resolve-from": { 3230 | "version": "2.0.0", 3231 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 3232 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=" 3233 | }, 3234 | "semver": { 3235 | "version": "5.7.1", 3236 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 3237 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 3238 | } 3239 | } 3240 | }, 3241 | "requires-port": { 3242 | "version": "1.0.0", 3243 | "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", 3244 | "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=" 3245 | }, 3246 | "resolve-from": { 3247 | "version": "4.0.0", 3248 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 3249 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 3250 | "dev": true 3251 | }, 3252 | "restore-cursor": { 3253 | "version": "3.1.0", 3254 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 3255 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 3256 | "dev": true, 3257 | "requires": { 3258 | "onetime": "^5.1.0", 3259 | "signal-exit": "^3.0.2" 3260 | } 3261 | }, 3262 | "reusify": { 3263 | "version": "1.0.4", 3264 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 3265 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 3266 | "dev": true 3267 | }, 3268 | "rimraf": { 3269 | "version": "3.0.2", 3270 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 3271 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 3272 | "requires": { 3273 | "glob": "^7.1.3" 3274 | } 3275 | }, 3276 | "run-parallel": { 3277 | "version": "1.2.0", 3278 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 3279 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 3280 | "dev": true, 3281 | "requires": { 3282 | "queue-microtask": "^1.2.2" 3283 | } 3284 | }, 3285 | "rxjs": { 3286 | "version": "6.6.7", 3287 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.6.7.tgz", 3288 | "integrity": "sha512-hTdwr+7yYNIT5n4AMYp85KA6yw2Va0FLa3Rguvbpa4W3I5xynaBZo41cM3XM+4Q6fRMj3sBYIR1VAmZMXYJvRQ==", 3289 | "dev": true, 3290 | "requires": { 3291 | "tslib": "^1.9.0" 3292 | } 3293 | }, 3294 | "safe-buffer": { 3295 | "version": "5.2.1", 3296 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 3297 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 3298 | }, 3299 | "safer-buffer": { 3300 | "version": "2.1.2", 3301 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 3302 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 3303 | }, 3304 | "saslprep": { 3305 | "version": "1.0.3", 3306 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 3307 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 3308 | "optional": true, 3309 | "requires": { 3310 | "sparse-bitfield": "^3.0.3" 3311 | } 3312 | }, 3313 | "semver": { 3314 | "version": "7.3.5", 3315 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 3316 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 3317 | "requires": { 3318 | "lru-cache": "^6.0.0" 3319 | } 3320 | }, 3321 | "semver-compare": { 3322 | "version": "1.0.0", 3323 | "resolved": "https://registry.npmjs.org/semver-compare/-/semver-compare-1.0.0.tgz", 3324 | "integrity": "sha1-De4hahyUGrN+nvsXiPavxf9VN/w=", 3325 | "dev": true 3326 | }, 3327 | "send": { 3328 | "version": "0.17.1", 3329 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 3330 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 3331 | "requires": { 3332 | "debug": "2.6.9", 3333 | "depd": "~1.1.2", 3334 | "destroy": "~1.0.4", 3335 | "encodeurl": "~1.0.2", 3336 | "escape-html": "~1.0.3", 3337 | "etag": "~1.8.1", 3338 | "fresh": "0.5.2", 3339 | "http-errors": "~1.7.2", 3340 | "mime": "1.6.0", 3341 | "ms": "2.1.1", 3342 | "on-finished": "~2.3.0", 3343 | "range-parser": "~1.2.1", 3344 | "statuses": "~1.5.0" 3345 | }, 3346 | "dependencies": { 3347 | "debug": { 3348 | "version": "2.6.9", 3349 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 3350 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 3351 | "requires": { 3352 | "ms": "2.0.0" 3353 | }, 3354 | "dependencies": { 3355 | "ms": { 3356 | "version": "2.0.0", 3357 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 3358 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 3359 | } 3360 | } 3361 | }, 3362 | "ms": { 3363 | "version": "2.1.1", 3364 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 3365 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 3366 | } 3367 | } 3368 | }, 3369 | "serialize-javascript": { 3370 | "version": "5.0.1", 3371 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-5.0.1.tgz", 3372 | "integrity": "sha512-SaaNal9imEO737H2c05Og0/8LUXG7EnsZyMa8MzkmuHoELfT6txuj0cMqRj6zfPKnmQ1yasR4PCJc8x+M4JSPA==", 3373 | "dev": true, 3374 | "requires": { 3375 | "randombytes": "^2.1.0" 3376 | } 3377 | }, 3378 | "serve-static": { 3379 | "version": "1.14.1", 3380 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 3381 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 3382 | "requires": { 3383 | "encodeurl": "~1.0.2", 3384 | "escape-html": "~1.0.3", 3385 | "parseurl": "~1.3.3", 3386 | "send": "0.17.1" 3387 | } 3388 | }, 3389 | "set-blocking": { 3390 | "version": "2.0.0", 3391 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 3392 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 3393 | }, 3394 | "setprototypeof": { 3395 | "version": "1.1.1", 3396 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 3397 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 3398 | }, 3399 | "shebang-command": { 3400 | "version": "2.0.0", 3401 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3402 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3403 | "dev": true, 3404 | "requires": { 3405 | "shebang-regex": "^3.0.0" 3406 | } 3407 | }, 3408 | "shebang-regex": { 3409 | "version": "3.0.0", 3410 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3411 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3412 | "dev": true 3413 | }, 3414 | "sift": { 3415 | "version": "7.0.1", 3416 | "resolved": "https://registry.npmjs.org/sift/-/sift-7.0.1.tgz", 3417 | "integrity": "sha512-oqD7PMJ+uO6jV9EQCl0LrRw1OwsiPsiFQR5AR30heR+4Dl7jBBbDLnNvWiak20tzZlSE1H7RB30SX/1j/YYT7g==" 3418 | }, 3419 | "signal-exit": { 3420 | "version": "3.0.3", 3421 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 3422 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==" 3423 | }, 3424 | "simple-swizzle": { 3425 | "version": "0.2.2", 3426 | "resolved": "https://registry.npmjs.org/simple-swizzle/-/simple-swizzle-0.2.2.tgz", 3427 | "integrity": "sha1-pNprY1/8zMoz9w0Xy5JZLeleVXo=", 3428 | "requires": { 3429 | "is-arrayish": "^0.3.1" 3430 | }, 3431 | "dependencies": { 3432 | "is-arrayish": { 3433 | "version": "0.3.2", 3434 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.3.2.tgz", 3435 | "integrity": "sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==" 3436 | } 3437 | } 3438 | }, 3439 | "sinon": { 3440 | "version": "10.0.0", 3441 | "resolved": "https://registry.npmjs.org/sinon/-/sinon-10.0.0.tgz", 3442 | "integrity": "sha512-XAn5DxtGVJBlBWYrcYKEhWCz7FLwZGdyvANRyK06419hyEpdT0dMc5A8Vcxg5SCGHc40CsqoKsc1bt1CbJPfNw==", 3443 | "dev": true, 3444 | "requires": { 3445 | "@sinonjs/commons": "^1.8.1", 3446 | "@sinonjs/fake-timers": "^6.0.1", 3447 | "@sinonjs/samsam": "^5.3.1", 3448 | "diff": "^4.0.2", 3449 | "nise": "^4.1.0", 3450 | "supports-color": "^7.1.0" 3451 | }, 3452 | "dependencies": { 3453 | "has-flag": { 3454 | "version": "4.0.0", 3455 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 3456 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 3457 | "dev": true 3458 | }, 3459 | "supports-color": { 3460 | "version": "7.2.0", 3461 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3462 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3463 | "dev": true, 3464 | "requires": { 3465 | "has-flag": "^4.0.0" 3466 | } 3467 | } 3468 | } 3469 | }, 3470 | "slash": { 3471 | "version": "3.0.0", 3472 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 3473 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 3474 | "dev": true 3475 | }, 3476 | "slice-ansi": { 3477 | "version": "4.0.0", 3478 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 3479 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 3480 | "dev": true, 3481 | "requires": { 3482 | "ansi-styles": "^4.0.0", 3483 | "astral-regex": "^2.0.0", 3484 | "is-fullwidth-code-point": "^3.0.0" 3485 | }, 3486 | "dependencies": { 3487 | "ansi-styles": { 3488 | "version": "4.3.0", 3489 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 3490 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 3491 | "dev": true, 3492 | "requires": { 3493 | "color-convert": "^2.0.1" 3494 | } 3495 | }, 3496 | "color-convert": { 3497 | "version": "2.0.1", 3498 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 3499 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 3500 | "dev": true, 3501 | "requires": { 3502 | "color-name": "~1.1.4" 3503 | } 3504 | }, 3505 | "color-name": { 3506 | "version": "1.1.4", 3507 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 3508 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 3509 | "dev": true 3510 | } 3511 | } 3512 | }, 3513 | "sliced": { 3514 | "version": "1.0.1", 3515 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", 3516 | "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E=" 3517 | }, 3518 | "source-map": { 3519 | "version": "0.6.1", 3520 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3521 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3522 | "dev": true 3523 | }, 3524 | "source-map-support": { 3525 | "version": "0.5.19", 3526 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.19.tgz", 3527 | "integrity": "sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw==", 3528 | "dev": true, 3529 | "requires": { 3530 | "buffer-from": "^1.0.0", 3531 | "source-map": "^0.6.0" 3532 | } 3533 | }, 3534 | "sparse-bitfield": { 3535 | "version": "3.0.3", 3536 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 3537 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 3538 | "optional": true, 3539 | "requires": { 3540 | "memory-pager": "^1.0.2" 3541 | } 3542 | }, 3543 | "sprintf-js": { 3544 | "version": "1.0.3", 3545 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 3546 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 3547 | "dev": true 3548 | }, 3549 | "stack-trace": { 3550 | "version": "0.0.10", 3551 | "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz", 3552 | "integrity": "sha1-VHxws0fo0ytOEI6hoqFZ5f3eGcA=" 3553 | }, 3554 | "statuses": { 3555 | "version": "1.5.0", 3556 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 3557 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 3558 | }, 3559 | "string-argv": { 3560 | "version": "0.3.1", 3561 | "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.1.tgz", 3562 | "integrity": "sha512-a1uQGz7IyVy9YwhqjZIZu1c8JO8dNIe20xBmSS6qu9kv++k3JGzCVmprbNN5Kn+BgzD5E7YYwg1CcjuJMRNsvg==", 3563 | "dev": true 3564 | }, 3565 | "string-width": { 3566 | "version": "4.2.2", 3567 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 3568 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 3569 | "dev": true, 3570 | "requires": { 3571 | "emoji-regex": "^8.0.0", 3572 | "is-fullwidth-code-point": "^3.0.0", 3573 | "strip-ansi": "^6.0.0" 3574 | } 3575 | }, 3576 | "string_decoder": { 3577 | "version": "1.3.0", 3578 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 3579 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 3580 | "requires": { 3581 | "safe-buffer": "~5.2.0" 3582 | } 3583 | }, 3584 | "stringify-object": { 3585 | "version": "3.3.0", 3586 | "resolved": "https://registry.npmjs.org/stringify-object/-/stringify-object-3.3.0.tgz", 3587 | "integrity": "sha512-rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw==", 3588 | "dev": true, 3589 | "requires": { 3590 | "get-own-enumerable-property-symbols": "^3.0.0", 3591 | "is-obj": "^1.0.1", 3592 | "is-regexp": "^1.0.0" 3593 | } 3594 | }, 3595 | "strip-ansi": { 3596 | "version": "6.0.0", 3597 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 3598 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 3599 | "dev": true, 3600 | "requires": { 3601 | "ansi-regex": "^5.0.0" 3602 | } 3603 | }, 3604 | "strip-final-newline": { 3605 | "version": "2.0.0", 3606 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 3607 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 3608 | "dev": true 3609 | }, 3610 | "strip-json-comments": { 3611 | "version": "3.1.1", 3612 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3613 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3614 | "dev": true 3615 | }, 3616 | "supports-color": { 3617 | "version": "5.5.0", 3618 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3619 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3620 | "dev": true, 3621 | "requires": { 3622 | "has-flag": "^3.0.0" 3623 | } 3624 | }, 3625 | "table": { 3626 | "version": "6.7.1", 3627 | "resolved": "https://registry.npmjs.org/table/-/table-6.7.1.tgz", 3628 | "integrity": "sha512-ZGum47Yi6KOOFDE8m223td53ath2enHcYLgOCjGr5ngu8bdIARQk6mN/wRMv4yMRcHnCSnHbCEha4sobQx5yWg==", 3629 | "dev": true, 3630 | "requires": { 3631 | "ajv": "^8.0.1", 3632 | "lodash.clonedeep": "^4.5.0", 3633 | "lodash.truncate": "^4.4.2", 3634 | "slice-ansi": "^4.0.0", 3635 | "string-width": "^4.2.0", 3636 | "strip-ansi": "^6.0.0" 3637 | }, 3638 | "dependencies": { 3639 | "ajv": { 3640 | "version": "8.5.0", 3641 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.5.0.tgz", 3642 | "integrity": "sha512-Y2l399Tt1AguU3BPRP9Fn4eN+Or+StUGWCUpbnFyXSo8NZ9S4uj+AG2pjs5apK+ZMOwYOz1+a+VKvKH7CudXgQ==", 3643 | "dev": true, 3644 | "requires": { 3645 | "fast-deep-equal": "^3.1.1", 3646 | "json-schema-traverse": "^1.0.0", 3647 | "require-from-string": "^2.0.2", 3648 | "uri-js": "^4.2.2" 3649 | } 3650 | }, 3651 | "json-schema-traverse": { 3652 | "version": "1.0.0", 3653 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 3654 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 3655 | "dev": true 3656 | } 3657 | } 3658 | }, 3659 | "tar": { 3660 | "version": "6.1.0", 3661 | "resolved": "https://registry.npmjs.org/tar/-/tar-6.1.0.tgz", 3662 | "integrity": "sha512-DUCttfhsnLCjwoDoFcI+B2iJgYa93vBnDUATYEeRx6sntCTdN01VnqsIuTlALXla/LWooNg0yEGeB+Y8WdFxGA==", 3663 | "requires": { 3664 | "chownr": "^2.0.0", 3665 | "fs-minipass": "^2.0.0", 3666 | "minipass": "^3.0.0", 3667 | "minizlib": "^2.1.1", 3668 | "mkdirp": "^1.0.3", 3669 | "yallist": "^4.0.0" 3670 | } 3671 | }, 3672 | "text-hex": { 3673 | "version": "1.0.0", 3674 | "resolved": "https://registry.npmjs.org/text-hex/-/text-hex-1.0.0.tgz", 3675 | "integrity": "sha512-uuVGNWzgJ4yhRaNSiubPY7OjISw4sw4E5Uv0wbjp+OzcbmVU/rsT8ujgcXJhn9ypzsgr5vlzpPqP+MBBKcGvbg==" 3676 | }, 3677 | "text-table": { 3678 | "version": "0.2.0", 3679 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3680 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 3681 | "dev": true 3682 | }, 3683 | "through": { 3684 | "version": "2.3.8", 3685 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 3686 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 3687 | "dev": true 3688 | }, 3689 | "to-regex-range": { 3690 | "version": "5.0.1", 3691 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3692 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3693 | "dev": true, 3694 | "requires": { 3695 | "is-number": "^7.0.0" 3696 | } 3697 | }, 3698 | "toidentifier": { 3699 | "version": "1.0.0", 3700 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 3701 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 3702 | }, 3703 | "triple-beam": { 3704 | "version": "1.3.0", 3705 | "resolved": "https://registry.npmjs.org/triple-beam/-/triple-beam-1.3.0.tgz", 3706 | "integrity": "sha512-XrHUvV5HpdLmIj4uVMxHggLbFSZYIn7HEWsqePZcI50pco+MPqJ50wMGY794X7AOOhxOBAjbkqfAbEe/QMp2Lw==" 3707 | }, 3708 | "ts-node": { 3709 | "version": "9.1.1", 3710 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-9.1.1.tgz", 3711 | "integrity": "sha512-hPlt7ZACERQGf03M253ytLY3dHbGNGrAq9qIHWUY9XHYl1z7wYngSr3OQ5xmui8o2AaxsONxIzjafLUiWBo1Fg==", 3712 | "dev": true, 3713 | "requires": { 3714 | "arg": "^4.1.0", 3715 | "create-require": "^1.1.0", 3716 | "diff": "^4.0.1", 3717 | "make-error": "^1.1.1", 3718 | "source-map-support": "^0.5.17", 3719 | "yn": "3.1.1" 3720 | } 3721 | }, 3722 | "tslib": { 3723 | "version": "1.14.1", 3724 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 3725 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 3726 | "dev": true 3727 | }, 3728 | "tsutils": { 3729 | "version": "3.21.0", 3730 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", 3731 | "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", 3732 | "dev": true, 3733 | "requires": { 3734 | "tslib": "^1.8.1" 3735 | } 3736 | }, 3737 | "type-check": { 3738 | "version": "0.4.0", 3739 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3740 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3741 | "dev": true, 3742 | "requires": { 3743 | "prelude-ls": "^1.2.1" 3744 | } 3745 | }, 3746 | "type-detect": { 3747 | "version": "4.0.8", 3748 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 3749 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 3750 | "dev": true 3751 | }, 3752 | "type-fest": { 3753 | "version": "0.8.1", 3754 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 3755 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 3756 | "dev": true 3757 | }, 3758 | "type-is": { 3759 | "version": "1.6.18", 3760 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 3761 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 3762 | "requires": { 3763 | "media-typer": "0.3.0", 3764 | "mime-types": "~2.1.24" 3765 | } 3766 | }, 3767 | "typescript": { 3768 | "version": "4.2.4", 3769 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.2.4.tgz", 3770 | "integrity": "sha512-V+evlYHZnQkaz8TRBuxTA92yZBPotr5H+WhQ7bD3hZUndx5tGOa1fuCgeSjxAzM1RiN5IzvadIXTVefuuwZCRg==", 3771 | "dev": true 3772 | }, 3773 | "unpipe": { 3774 | "version": "1.0.0", 3775 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 3776 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 3777 | }, 3778 | "uri-js": { 3779 | "version": "4.4.1", 3780 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3781 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3782 | "dev": true, 3783 | "requires": { 3784 | "punycode": "^2.1.0" 3785 | } 3786 | }, 3787 | "url-parse": { 3788 | "version": "1.5.1", 3789 | "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.1.tgz", 3790 | "integrity": "sha512-HOfCOUJt7iSYzEx/UqgtwKRMC6EU91NFhsCHMv9oM03VJcVo2Qrp8T8kI9D7amFf1cu+/3CEhgb3rF9zL7k85Q==", 3791 | "requires": { 3792 | "querystringify": "^2.1.1", 3793 | "requires-port": "^1.0.0" 3794 | } 3795 | }, 3796 | "util-deprecate": { 3797 | "version": "1.0.2", 3798 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3799 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 3800 | }, 3801 | "utils-merge": { 3802 | "version": "1.0.1", 3803 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 3804 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 3805 | }, 3806 | "v8-compile-cache": { 3807 | "version": "2.3.0", 3808 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 3809 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 3810 | "dev": true 3811 | }, 3812 | "vary": { 3813 | "version": "1.1.2", 3814 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 3815 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 3816 | }, 3817 | "which": { 3818 | "version": "2.0.2", 3819 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3820 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3821 | "dev": true, 3822 | "requires": { 3823 | "isexe": "^2.0.0" 3824 | } 3825 | }, 3826 | "wide-align": { 3827 | "version": "1.1.3", 3828 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 3829 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 3830 | "requires": { 3831 | "string-width": "^1.0.2 || 2" 3832 | }, 3833 | "dependencies": { 3834 | "ansi-regex": { 3835 | "version": "3.0.0", 3836 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 3837 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 3838 | }, 3839 | "is-fullwidth-code-point": { 3840 | "version": "2.0.0", 3841 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 3842 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 3843 | }, 3844 | "string-width": { 3845 | "version": "2.1.1", 3846 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 3847 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 3848 | "requires": { 3849 | "is-fullwidth-code-point": "^2.0.0", 3850 | "strip-ansi": "^4.0.0" 3851 | } 3852 | }, 3853 | "strip-ansi": { 3854 | "version": "4.0.0", 3855 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 3856 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 3857 | "requires": { 3858 | "ansi-regex": "^3.0.0" 3859 | } 3860 | } 3861 | } 3862 | }, 3863 | "winston": { 3864 | "version": "3.3.3", 3865 | "resolved": "https://registry.npmjs.org/winston/-/winston-3.3.3.tgz", 3866 | "integrity": "sha512-oEXTISQnC8VlSAKf1KYSSd7J6IWuRPQqDdo8eoRNaYKLvwSb5+79Z3Yi1lrl6KDpU6/VWaxpakDAtb1oQ4n9aw==", 3867 | "requires": { 3868 | "@dabh/diagnostics": "^2.0.2", 3869 | "async": "^3.1.0", 3870 | "is-stream": "^2.0.0", 3871 | "logform": "^2.2.0", 3872 | "one-time": "^1.0.0", 3873 | "readable-stream": "^3.4.0", 3874 | "stack-trace": "0.0.x", 3875 | "triple-beam": "^1.3.0", 3876 | "winston-transport": "^4.4.0" 3877 | } 3878 | }, 3879 | "winston-transport": { 3880 | "version": "4.4.0", 3881 | "resolved": "https://registry.npmjs.org/winston-transport/-/winston-transport-4.4.0.tgz", 3882 | "integrity": "sha512-Lc7/p3GtqtqPBYYtS6KCN3c77/2QCev51DvcJKbkFPQNoj1sinkGwLGFDxkXY9J6p9+EPnYs+D90uwbnaiURTw==", 3883 | "requires": { 3884 | "readable-stream": "^2.3.7", 3885 | "triple-beam": "^1.2.0" 3886 | }, 3887 | "dependencies": { 3888 | "readable-stream": { 3889 | "version": "2.3.7", 3890 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 3891 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 3892 | "requires": { 3893 | "core-util-is": "~1.0.0", 3894 | "inherits": "~2.0.3", 3895 | "isarray": "~1.0.0", 3896 | "process-nextick-args": "~2.0.0", 3897 | "safe-buffer": "~5.1.1", 3898 | "string_decoder": "~1.1.1", 3899 | "util-deprecate": "~1.0.1" 3900 | } 3901 | }, 3902 | "safe-buffer": { 3903 | "version": "5.1.2", 3904 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 3905 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 3906 | }, 3907 | "string_decoder": { 3908 | "version": "1.1.1", 3909 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 3910 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 3911 | "requires": { 3912 | "safe-buffer": "~5.1.0" 3913 | } 3914 | } 3915 | } 3916 | }, 3917 | "word-wrap": { 3918 | "version": "1.2.3", 3919 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 3920 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 3921 | "dev": true 3922 | }, 3923 | "workerpool": { 3924 | "version": "6.1.0", 3925 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.1.0.tgz", 3926 | "integrity": "sha512-toV7q9rWNYha963Pl/qyeZ6wG+3nnsyvolaNUS8+R5Wtw6qJPTxIlOP1ZSvcGhEJw+l3HMMmtiNo9Gl61G4GVg==", 3927 | "dev": true 3928 | }, 3929 | "wrap-ansi": { 3930 | "version": "7.0.0", 3931 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3932 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3933 | "dev": true, 3934 | "requires": { 3935 | "ansi-styles": "^4.0.0", 3936 | "string-width": "^4.1.0", 3937 | "strip-ansi": "^6.0.0" 3938 | }, 3939 | "dependencies": { 3940 | "ansi-styles": { 3941 | "version": "4.3.0", 3942 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 3943 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 3944 | "dev": true, 3945 | "requires": { 3946 | "color-convert": "^2.0.1" 3947 | } 3948 | }, 3949 | "color-convert": { 3950 | "version": "2.0.1", 3951 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 3952 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 3953 | "dev": true, 3954 | "requires": { 3955 | "color-name": "~1.1.4" 3956 | } 3957 | }, 3958 | "color-name": { 3959 | "version": "1.1.4", 3960 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 3961 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 3962 | "dev": true 3963 | } 3964 | } 3965 | }, 3966 | "wrappy": { 3967 | "version": "1.0.2", 3968 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3969 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 3970 | }, 3971 | "y18n": { 3972 | "version": "5.0.8", 3973 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3974 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3975 | "dev": true 3976 | }, 3977 | "yallist": { 3978 | "version": "4.0.0", 3979 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3980 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 3981 | }, 3982 | "yaml": { 3983 | "version": "1.10.2", 3984 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", 3985 | "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", 3986 | "dev": true 3987 | }, 3988 | "yargs": { 3989 | "version": "16.2.0", 3990 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3991 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3992 | "dev": true, 3993 | "requires": { 3994 | "cliui": "^7.0.2", 3995 | "escalade": "^3.1.1", 3996 | "get-caller-file": "^2.0.5", 3997 | "require-directory": "^2.1.1", 3998 | "string-width": "^4.2.0", 3999 | "y18n": "^5.0.5", 4000 | "yargs-parser": "^20.2.2" 4001 | } 4002 | }, 4003 | "yargs-parser": { 4004 | "version": "20.2.4", 4005 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 4006 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 4007 | "dev": true 4008 | }, 4009 | "yargs-unparser": { 4010 | "version": "2.0.0", 4011 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 4012 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 4013 | "dev": true, 4014 | "requires": { 4015 | "camelcase": "^6.0.0", 4016 | "decamelize": "^4.0.0", 4017 | "flat": "^5.0.2", 4018 | "is-plain-obj": "^2.1.0" 4019 | } 4020 | }, 4021 | "yn": { 4022 | "version": "3.1.1", 4023 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 4024 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 4025 | "dev": true 4026 | }, 4027 | "yocto-queue": { 4028 | "version": "0.1.0", 4029 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 4030 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 4031 | "dev": true 4032 | } 4033 | } 4034 | } 4035 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "typescript-solid-architecture", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "build": "tsc", 8 | "dev": "NODE_ENV=development nodemon --exec ts-node -r ./src/index.ts", 9 | "start": "node ./dist/src/index.js", 10 | "prod": "npm run build && npm run start", 11 | "test": "NODE_ENV=development env TS_NODE_COMPILER_OPTIONS='{\"module\": \"commonjs\" }' mocha -r ts-node/register '*/**/*.test.ts'", 12 | "format": "npx prettier --write .", 13 | "lint": "eslint . --ext .js,.jsx,.ts,.tsx", 14 | "prepare": "husky install" 15 | }, 16 | "keywords": [], 17 | "author": "", 18 | "license": "ISC", 19 | "dependencies": { 20 | "@vtjs/auth": "^0.2.0", 21 | "@vtjs/cache": "^0.1.5", 22 | "@vtjs/common": "^0.1.9", 23 | "@vtjs/core": "^0.2.6", 24 | "@vtjs/mongoose": "^0.1.8", 25 | "@vtjs/rabbitmq": "^0.1.0", 26 | "axios-retry": "^3.1.9", 27 | "bcrypt": "^5.0.1", 28 | "dotenv": "^9.0.2" 29 | }, 30 | "devDependencies": { 31 | "@types/bcrypt": "^5.0.0", 32 | "@types/chai": "^4.2.18", 33 | "@types/express": "^4.17.11", 34 | "@types/mocha": "^8.2.2", 35 | "@types/mongoose": "^5.10.5", 36 | "@types/node": "^15.0.3", 37 | "@types/sinon": "^10.0.0", 38 | "@typescript-eslint/eslint-plugin": "^4.23.0", 39 | "@typescript-eslint/parser": "^4.23.0", 40 | "chai": "^4.3.4", 41 | "eslint": "^7.26.0", 42 | "eslint-config-prettier": "^8.3.0", 43 | "eslint-plugin-prettier": "^3.4.0", 44 | "husky": "^6.0.0", 45 | "lint-staged": "^11.0.0", 46 | "mocha": "^8.4.0", 47 | "prettier": "^2.3.0", 48 | "sinon": "^10.0.0", 49 | "ts-node": "^9.1.1", 50 | "typescript": "^4.2.4" 51 | }, 52 | "lint-staged": { 53 | "*.{js,ts,md}": [ 54 | "prettier --write", 55 | "git add" 56 | ], 57 | "*.{js,jsx,ts,tsx}": "eslint --cache --fix" 58 | } 59 | } 60 | -------------------------------------------------------------------------------- /src/app.ts: -------------------------------------------------------------------------------- 1 | import { MainApplication } from '@vtjs/core'; 2 | import { IEventBus } from '@vtjs/rabbitmq'; 3 | import { ILogger } from '@vtjs/common'; 4 | 5 | import { IActivityService, IAuthService, ITaskService, IUserService } from './services/definations'; 6 | 7 | import AuthController from './controllers/auth.controller'; 8 | import ActivityController from './controllers/activity.controller'; 9 | import TaskController from './controllers/task.controller'; 10 | import UserController from './controllers/user.controller'; 11 | 12 | type ApplicationProp = { 13 | authService: IAuthService; 14 | activityService: IActivityService; 15 | taskService: ITaskService; 16 | userService: IUserService; 17 | eventBus: IEventBus; 18 | logger: ILogger; 19 | appName: string; 20 | appVersion: string; 21 | debug: boolean; 22 | }; 23 | 24 | export default class Application extends MainApplication { 25 | constructor({ 26 | authService, 27 | activityService, 28 | taskService, 29 | userService, 30 | eventBus, 31 | logger, 32 | appName, 33 | appVersion, 34 | debug 35 | }: ApplicationProp) { 36 | super(logger, { name: appName, version: appVersion, debug }); 37 | 38 | const authController = new AuthController(authService, eventBus, logger); 39 | const activityController = new ActivityController(activityService, authController); 40 | const taskController = new TaskController(taskService, authController, eventBus, logger); 41 | const userController = new UserController(userService); 42 | 43 | this.setupControllers(authController, activityController, taskController, userController); 44 | } 45 | } 46 | -------------------------------------------------------------------------------- /src/configs.ts: -------------------------------------------------------------------------------- 1 | import { name as appName, version as appVersion } from '../package.json'; 2 | export { name as appName, version as appVersion } from '../package.json'; 3 | 4 | export const BCRYPT_HASH_SALT = 10; 5 | 6 | export const MONGODB_CONNECTION_STRING = 7 | process.env.MONGODB_CONNECTION_STRING || 'mongodb://localhost:27017/typescriptSOLIDArchitecture'; 8 | export const MONGODB_USER = process.env.MONGODB_USER; 9 | export const MONGODB_PASSWORD = process.env.MONGODB_PASSWORD; 10 | 11 | export const REDIS_HOST = process.env.REDIS_HOST; 12 | export const REDIS_PORT = process.env.REDIS_PORT && +process.env.REDIS_PORT; 13 | export const REDIS_PASSWORD = process.env.REDIS_PASSWORD; 14 | 15 | export const SERVICE_CACHE_SECOND = 60 * 60 * 2; //2H 16 | 17 | // head -n 4096 /dev/urandom | openssl sha1 18 | export const JWT_SECRET_KEY = 19 | process.env.JWT_SECRET_KEY || 't8#58bd54647e37585902db6b6b1c1b9e4ef31357d6'; 20 | // Use JWt_EXPIRES_DAYS to calculate token's expiration time 21 | // When the token had expired, the user will be automatically logged out 22 | export const JWt_EXPIRES_DAYS = process.env.JWt_EXPIRES_DAYS ? +process.env.JWt_EXPIRES_DAYS : 1; 23 | export const JWt_EXPIRES_IN = `${JWt_EXPIRES_DAYS}d`; 24 | 25 | export const RABBITMQ_HOST = process.env.RABBITMQ_HOST; 26 | export const RABBITMQ_PORT = process.env.RABBITMQ_PORT && +process.env.RABBITMQ_PORT; 27 | export const RABBITMQ_USER = process.env.RABBITMQ_USER; 28 | export const RABBITMQ_PASSWORD = process.env.RABBITMQ_PASSWORD; 29 | 30 | export const ACTIVITY_CREATE_EVENT = `${appName}|activity.create`; 31 | -------------------------------------------------------------------------------- /src/controllers/activity.controller.ts: -------------------------------------------------------------------------------- 1 | import { Controller, Response, NextFunction, sendSuccessReponse } from '@vtjs/core'; 2 | import { NotFoundError } from '@vtjs/common'; 3 | 4 | import { IActivityService } from '../services/definations'; 5 | 6 | import { RequestWithUser, IAuthController } from './definations'; 7 | 8 | export default class ActivityController extends Controller { 9 | constructor(private activityService: IActivityService, private authController: IAuthController) { 10 | super(); 11 | this.setupRouter(); 12 | } 13 | 14 | setupRouter(): void { 15 | this.router.use('/activitys', this.authController.requiredAuth); 16 | this.router.get('/activitys', this.wrapTryCatch(this.getList)); 17 | this.router.get('/activitys/:id', this.wrapTryCatch(this.get)); 18 | } 19 | 20 | private async getList(req: RequestWithUser, res: Response, next: NextFunction) { 21 | const list = await this.activityService.findAll({ userId: req.user.id }); 22 | sendSuccessReponse(list, res); 23 | } 24 | 25 | private async get(req: RequestWithUser, res: Response, next: NextFunction) { 26 | const id = req.params.id; 27 | const activity = await this.activityService.findOne({ userId: req.user.id, id }); 28 | 29 | if (!activity) return next(new NotFoundError()); 30 | sendSuccessReponse(activity, res); 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /src/controllers/auth.controller.ts: -------------------------------------------------------------------------------- 1 | import { Controller, Request, Response, NextFunction, sendSuccessReponse } from '@vtjs/core'; 2 | import { UnauthorizedError, ValidationError, ILogger } from '@vtjs/common'; 3 | import { IEventBus } from '@vtjs/rabbitmq'; 4 | 5 | import { ActivityAction } from '../entities/activity.entity'; 6 | import User from '../entities/user.entity'; 7 | 8 | import { IAuthService } from '../services/definations'; 9 | import { ActivityCreateEvent } from '../events/definations'; 10 | 11 | import { RequestWithUser, IAuthController } from './definations'; 12 | 13 | export default class AuthController extends Controller implements IAuthController { 14 | constructor( 15 | private authService: IAuthService, 16 | private eventBus: IEventBus, 17 | private logger: ILogger 18 | ) { 19 | super(); 20 | this.requiredAuth = this.requiredAuth.bind(this); 21 | this.setupRouter(); 22 | } 23 | 24 | setupRouter(): void { 25 | this.router.post('/auth/login', this.wrapTryCatch(this.login)); 26 | } 27 | 28 | private async login(req: Request, res: Response, next: NextFunction) { 29 | const { email, password } = req.body as User; 30 | 31 | if (!email || !password) { 32 | return next(new ValidationError()); 33 | } 34 | 35 | const user = await this.authService.login(email, password); 36 | if (!user) { 37 | return next(new UnauthorizedError()); 38 | } 39 | 40 | this.eventBus 41 | .publish( 42 | new ActivityCreateEvent({ 43 | userId: user.id, 44 | action: ActivityAction.USER_LOGIN, 45 | refId: user.id, 46 | data: null 47 | }) 48 | ) 49 | .catch((e) => this.logger.error('Publish event error: ', e)); 50 | 51 | sendSuccessReponse(user, res); 52 | } 53 | 54 | async requiredAuth(req: RequestWithUser, res: Response, next: NextFunction): Promise { 55 | try { 56 | if (!req.headers['access-token']) { 57 | return next(new ValidationError('Missing token in header')); 58 | } 59 | 60 | const user = await this.authService.verifyJWTToken(req.headers['access-token'] as string); 61 | if (!user) { 62 | return next(new UnauthorizedError()); 63 | } 64 | 65 | req.user = user; 66 | next(); 67 | } catch (e) { 68 | next(e); 69 | } 70 | } 71 | } 72 | -------------------------------------------------------------------------------- /src/controllers/definations.ts: -------------------------------------------------------------------------------- 1 | import { Request, Response, NextFunction } from '@vtjs/core'; 2 | import User from '../entities/user.entity'; 3 | 4 | export type RequestWithUser = Request & { user: User }; 5 | 6 | export interface IAuthController { 7 | requiredAuth(req: Request, res: Response, next: NextFunction): Promise; 8 | } 9 | -------------------------------------------------------------------------------- /src/controllers/task.controller.ts: -------------------------------------------------------------------------------- 1 | import { Controller, Response, NextFunction, sendSuccessReponse } from '@vtjs/core'; 2 | import { ServerError, NotFoundError, ILogger } from '@vtjs/common'; 3 | import { IEventBus } from '@vtjs/rabbitmq'; 4 | 5 | import { ActivityAction } from '../entities/activity.entity'; 6 | import Task from '../entities/task.entity'; 7 | import User from '../entities/user.entity'; 8 | 9 | import { ITaskService } from '../services/definations'; 10 | import { ActivityCreateEvent } from '../events/definations'; 11 | 12 | import { RequestWithUser, IAuthController } from './definations'; 13 | 14 | export default class TaskController extends Controller { 15 | constructor( 16 | private taskService: ITaskService, 17 | private authController: IAuthController, 18 | private eventBus: IEventBus, 19 | private logger: ILogger 20 | ) { 21 | super(); 22 | this.setupRouter(); 23 | } 24 | 25 | setupRouter(): void { 26 | this.router.use('/tasks', this.authController.requiredAuth); 27 | this.router.post('/tasks', this.wrapTryCatch(this.create)); 28 | this.router.get('/tasks', this.wrapTryCatch(this.getList)); 29 | this.router.get('/tasks/:id', this.wrapTryCatch(this.get)); 30 | this.router.delete('/tasks/:id', this.wrapTryCatch(this.delete)); 31 | this.router.put('/tasks/:id', this.wrapTryCatch(this.update)); 32 | } 33 | 34 | private async create(req: RequestWithUser, res: Response, next: NextFunction) { 35 | const task = req.body as Task; 36 | task.userId = req.user.id; 37 | 38 | const newTask = await this.taskService.create(task); 39 | this.publishEvent(req.user, ActivityAction.CREATE_TASK, task); 40 | sendSuccessReponse(newTask, res); 41 | } 42 | 43 | private async getList(req: RequestWithUser, res: Response, next: NextFunction) { 44 | const list = await this.taskService.findAll({ userId: req.user.id }); 45 | sendSuccessReponse(list, res); 46 | } 47 | 48 | private async get(req: RequestWithUser, res: Response, next: NextFunction) { 49 | const id = req.params.id; 50 | const task = await this.taskService.findOne({ userId: req.user.id, id }); 51 | 52 | if (!task) return next(new NotFoundError()); 53 | sendSuccessReponse(task, res); 54 | } 55 | 56 | private async delete(req: RequestWithUser, res: Response, next: NextFunction) { 57 | const id = req.params.id; 58 | const raw = await this.taskService.deleteTask(req.user, { id }); 59 | 60 | if (!raw) return next(new ServerError()); 61 | this.publishEvent(req.user, ActivityAction.DELETE_TASK); 62 | sendSuccessReponse(raw, res); 63 | } 64 | 65 | private async update(req: RequestWithUser, res: Response, next: NextFunction) { 66 | const id = req.params.id; 67 | const task = await this.taskService.updateTask(req.user, { id }, req.body); 68 | 69 | if (!task) return next(new ServerError()); 70 | this.publishEvent(req.user, ActivityAction.UPDATE_TASK, task); 71 | sendSuccessReponse(task, res); 72 | } 73 | 74 | private publishEvent(user: User, action: ActivityAction, task?: Task) { 75 | this.eventBus 76 | .publish( 77 | new ActivityCreateEvent({ 78 | userId: user.id, 79 | action: action, 80 | refId: user.id, 81 | data: task || null 82 | }) 83 | ) 84 | .catch((e) => this.logger.error('Publish event error: ', e)); 85 | } 86 | } 87 | -------------------------------------------------------------------------------- /src/controllers/user.controller.ts: -------------------------------------------------------------------------------- 1 | import { Controller, Request, Response, NextFunction, sendSuccessReponse } from '@vtjs/core'; 2 | 3 | import User from '../entities/user.entity'; 4 | import { IUserService } from '../services/definations'; 5 | 6 | export default class UserController extends Controller { 7 | constructor(private userService: IUserService) { 8 | super(); 9 | this.setupRouter(); 10 | } 11 | 12 | setupRouter(): void { 13 | this.router.post('/users', this.wrapTryCatch(this.create)); 14 | } 15 | 16 | async create(req: Request, res: Response, next: NextFunction) { 17 | const { email, password } = req.body as User; 18 | 19 | const user = await this.userService.createUser({ email, password }); 20 | sendSuccessReponse(user, res); 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /src/entities/activity.entity.ts: -------------------------------------------------------------------------------- 1 | import { BaseEntity } from '@vtjs/common'; 2 | 3 | export enum ActivityAction { 4 | CREATE_TASK = 'task.create', 5 | UPDATE_TASK = 'task.update', 6 | DELETE_TASK = 'task.delete', 7 | 8 | USER_LOGIN = 'user.login' 9 | } 10 | 11 | export default class Activity extends BaseEntity { 12 | userId: string; 13 | action: ActivityAction; 14 | refId: string; 15 | data: any; 16 | } 17 | -------------------------------------------------------------------------------- /src/entities/task.entity.ts: -------------------------------------------------------------------------------- 1 | import { BaseEntity } from '@vtjs/common'; 2 | 3 | export default class Task extends BaseEntity { 4 | userId: string; 5 | title: string; 6 | description: string; 7 | startTime: string | Date; 8 | endTime: string | Date; 9 | deadline: string | Date; 10 | } 11 | -------------------------------------------------------------------------------- /src/entities/user.entity.ts: -------------------------------------------------------------------------------- 1 | import { BaseEntity } from '@vtjs/common'; 2 | 3 | export default class User extends BaseEntity { 4 | email: string; 5 | password: string; 6 | } 7 | -------------------------------------------------------------------------------- /src/env.ts: -------------------------------------------------------------------------------- 1 | import dotenv from 'dotenv'; 2 | 3 | dotenv.config(); 4 | -------------------------------------------------------------------------------- /src/events/activity.event.ts: -------------------------------------------------------------------------------- 1 | import { BaseEvent } from '@vtjs/rabbitmq'; 2 | import { ILogger } from '@vtjs/common'; 3 | import { ActivityCreateEvent } from './definations'; 4 | import { IActivityService } from '../services/definations'; 5 | 6 | export default class ActivityEvent extends BaseEvent { 7 | constructor(private activityService: IActivityService, private logger: ILogger) { 8 | super(); 9 | } 10 | 11 | async handle(event: ActivityCreateEvent, done: (arg?: Error) => void): Promise { 12 | try { 13 | await this.activityService.create(event.data); 14 | } catch (error) { 15 | this.logger.warn('Create activity error', error); 16 | } finally { 17 | done(); 18 | } 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /src/events/definations.ts: -------------------------------------------------------------------------------- 1 | import { IntegrationEvent, IIntegrationEvent } from '@vtjs/rabbitmq'; 2 | import { ACTIVITY_CREATE_EVENT } from '../configs'; 3 | import { ActivityAction } from '../entities/activity.entity'; 4 | 5 | export class ActivityCreateEvent extends IntegrationEvent { 6 | constructor({ 7 | userId, 8 | action, 9 | refId, 10 | data 11 | }: { 12 | userId: string; 13 | action: ActivityAction; 14 | refId: string; 15 | data: any; 16 | }) { 17 | super({ 18 | name: ACTIVITY_CREATE_EVENT, 19 | data: { 20 | userId, 21 | action, 22 | refId, 23 | data 24 | } 25 | }); 26 | } 27 | } 28 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | import { EventEmitter } from 'events'; 2 | import { MongoDB } from '@vtjs/mongoose'; 3 | import { RedisCache } from '@vtjs/cache'; 4 | import { Logger } from '@vtjs/common'; 5 | import { RabbitMQ } from '@vtjs/rabbitmq'; 6 | 7 | import './env'; 8 | import * as config from './configs'; 9 | 10 | import UserRepository from './repositories/user.repository'; 11 | import TaskRepository from './repositories/task.repository'; 12 | import ActivityRepository from './repositories/activity.repository'; 13 | 14 | import UserService from './services/user.service'; 15 | import AuthService from './services/auth.service'; 16 | import TaskService from './services/task.service'; 17 | import ActivityService from './services/activity.service'; 18 | 19 | import ActivityEvent from './events/activity.event'; 20 | 21 | import Application from './app'; 22 | 23 | const logger = new Logger({ service: config.appName }); 24 | 25 | const mongodb = new MongoDB( 26 | { 27 | connectionString: config.MONGODB_CONNECTION_STRING, 28 | user: config.MONGODB_USER, 29 | password: config.MONGODB_PASSWORD 30 | }, 31 | logger 32 | ); 33 | 34 | const redisCache = new RedisCache( 35 | { 36 | host: config.REDIS_HOST, 37 | port: config.REDIS_PORT, 38 | password: config.REDIS_PASSWORD 39 | }, 40 | logger 41 | ); 42 | 43 | // Event, Queue 44 | const eventEmitter = new EventEmitter(); 45 | const eventBus = new RabbitMQ({ 46 | config: { 47 | consumer: config.appName, 48 | exchange: 'example.eventBus', 49 | hostname: config.RABBITMQ_HOST, 50 | port: config.RABBITMQ_PORT, 51 | username: config.RABBITMQ_USER, 52 | password: config.RABBITMQ_PASSWORD 53 | }, 54 | logger, 55 | eventEmitter 56 | }); 57 | 58 | // Repository 59 | const userRepository = new UserRepository(); 60 | const taskRepository = new TaskRepository(); 61 | const activityRepository = new ActivityRepository(); 62 | 63 | // Service 64 | const userService = new UserService({ 65 | repo: userRepository, 66 | logger, 67 | serviceCache: { 68 | cache: redisCache, 69 | appName: config.appName, 70 | uniqueKey: 'user', 71 | second: config.SERVICE_CACHE_SECOND 72 | } 73 | }); 74 | const authService = new AuthService({ 75 | logger, 76 | userService 77 | }); 78 | const taskService = new TaskService({ 79 | repo: taskRepository, 80 | logger, 81 | serviceCache: { 82 | cache: redisCache, 83 | appName: config.appName, 84 | uniqueKey: 'task', 85 | second: config.SERVICE_CACHE_SECOND 86 | } 87 | }); 88 | const activityService = new ActivityService({ 89 | repo: activityRepository, 90 | logger 91 | }); 92 | 93 | const activityEvent = new ActivityEvent(activityService, logger); 94 | 95 | const app = new Application({ 96 | authService, 97 | activityService, 98 | taskService, 99 | userService, 100 | eventBus, 101 | logger, 102 | appName: config.appName, 103 | appVersion: config.appVersion, 104 | debug: true 105 | }); 106 | 107 | // MAIN CONTROLLER 108 | async function main() { 109 | await mongodb.connect(); 110 | await eventBus.connect(); 111 | 112 | await eventBus.subscribe(config.ACTIVITY_CREATE_EVENT, activityEvent.handle); 113 | 114 | app.showInfo(); 115 | app.start(); 116 | } 117 | 118 | main().catch((e) => { 119 | logger.error('Running app error: ', e); 120 | process.exit(1); 121 | }); 122 | 123 | process.on('beforeExit', async (code) => { 124 | logger.error(`Process beforeExit event with code ${code}`); 125 | process.exit(1); 126 | }); 127 | 128 | process.on('SIGTERM', async () => { 129 | logger.error(`Process ${process.pid} received a SIGTERM signal`); 130 | process.exit(0); 131 | }); 132 | 133 | process.on('SIGINT', async () => { 134 | logger.error(`Process ${process.pid} has been interrupted`); 135 | process.exit(0); 136 | }); 137 | -------------------------------------------------------------------------------- /src/repositories/activity.repository.ts: -------------------------------------------------------------------------------- 1 | import { Schema, BaseRepository, Mixed } from '@vtjs/mongoose'; 2 | import Activity from '../entities/activity.entity'; 3 | 4 | const activitySchema = new Schema( 5 | { 6 | userId: String, 7 | action: String, 8 | refId: String, 9 | data: Mixed 10 | }, 11 | { 12 | timestamps: true, 13 | versionKey: false, 14 | autoCreate: true 15 | } 16 | ); 17 | 18 | export default class ActivityRepository extends BaseRepository { 19 | constructor() { 20 | super('activity', activitySchema, 'activities'); 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /src/repositories/definations.ts: -------------------------------------------------------------------------------- 1 | import { IBaseRepository, DeleteResponse } from '@vtjs/mongoose'; 2 | 3 | import User from '../entities/user.entity'; 4 | import Task from '../entities/task.entity'; 5 | import Activity from '../entities/activity.entity'; 6 | 7 | export interface IUserRepository extends IBaseRepository { 8 | // Example handling another function that is NOT found in the Base Repository 9 | deleteByEmail(email: string): Promise; 10 | } 11 | 12 | export interface ITaskRepository extends IBaseRepository {} 13 | 14 | export interface IActivityRepository extends IBaseRepository {} 15 | -------------------------------------------------------------------------------- /src/repositories/task.repository.ts: -------------------------------------------------------------------------------- 1 | import { Schema, BaseRepository } from '@vtjs/mongoose'; 2 | import Task from '../entities/task.entity'; 3 | 4 | const taskSchema = new Schema( 5 | { 6 | userId: String, 7 | title: String, 8 | description: String, 9 | startTime: { 10 | type: Date, 11 | default: Date.now 12 | }, 13 | endTime: { 14 | type: Date, 15 | default: Date.now 16 | }, 17 | deadline: { 18 | type: Date, 19 | default: Date.now 20 | } 21 | }, 22 | { 23 | timestamps: true, 24 | versionKey: false, 25 | autoCreate: true 26 | } 27 | ); 28 | 29 | export default class TaskRepository extends BaseRepository { 30 | constructor() { 31 | super('task', taskSchema, 'tasks'); 32 | } 33 | } 34 | -------------------------------------------------------------------------------- /src/repositories/user.repository.ts: -------------------------------------------------------------------------------- 1 | import { Schema, BaseRepository, Repository, DeleteResponse } from '@vtjs/mongoose'; 2 | import { IUserRepository } from './definations'; 3 | import User from '../entities/user.entity'; 4 | 5 | const userSchema = new Schema( 6 | { 7 | email: { 8 | type: String, 9 | index: true, 10 | unique: true, 11 | lowercase: true, 12 | trim: true 13 | }, 14 | password: String 15 | }, 16 | { 17 | timestamps: true, 18 | versionKey: false, 19 | autoCreate: true 20 | } 21 | ); 22 | 23 | export default class UserRepository extends BaseRepository implements IUserRepository { 24 | constructor() { 25 | super('user', userSchema, 'users'); 26 | } 27 | 28 | // Example handling another function that is NOT found in the Base Repository 29 | @Repository() 30 | async deleteByEmail(email: string): Promise { 31 | return this.model.deleteOne({ email }); 32 | } 33 | } 34 | -------------------------------------------------------------------------------- /src/services/activity.service.ts: -------------------------------------------------------------------------------- 1 | import { BaseService, ILogger, ServiceCache } from '@vtjs/common'; 2 | 3 | import { IActivityService } from './definations'; 4 | import Activity from '../entities/activity.entity'; 5 | import { IActivityRepository } from '../repositories/definations'; 6 | 7 | type ActivityServiceProp = { 8 | repo: IActivityRepository; 9 | logger: ILogger; 10 | }; 11 | 12 | export default class ActivityService extends BaseService implements IActivityService { 13 | // Declare repo type if you need handle another function 14 | // repo: IActivityRepository; 15 | constructor({ repo, logger }: ActivityServiceProp) { 16 | // Set cache = undefined if you don't need using cache 17 | super(repo, undefined, logger); 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /src/services/auth.service.test.ts: -------------------------------------------------------------------------------- 1 | import { describe, it, before } from 'mocha'; 2 | import { expect } from 'chai'; 3 | import { stub } from 'sinon'; 4 | 5 | import UserRepository from '../repositories/user.repository'; 6 | 7 | import AuthService from './auth.service'; 8 | import UserService from './user.service'; 9 | 10 | // Fake data 11 | const user = { 12 | id: '60a9f5909119ff4a7f7824bd', 13 | email: 'vantuan130393@gmail.com', 14 | password: '$2b$10$SQ7.jKTDx740GKQc0YcFo.VkMl1Q7oeDiAnYh0e27i3yvls.Y6dVu', 15 | createdAt: '2021-05-23T06:26:24.823Z', 16 | updatedAt: '2021-05-23T06:26:24.823Z' 17 | }; 18 | 19 | const loginObj = { 20 | email: 'vantuan130393@gmail.com', 21 | password: '123456' 22 | }; 23 | 24 | // Fake Repositlry 25 | const userRepository = new UserRepository(); 26 | stub(userRepository, 'findOne').resolves(user); 27 | 28 | // Initialization 29 | const userService = new UserService({ 30 | repo: userRepository, 31 | logger: console, 32 | serviceCache: null 33 | }); 34 | 35 | const authService = new AuthService({ 36 | logger: console, 37 | userService 38 | }); 39 | 40 | let accessToken; 41 | describe('User login', () => { 42 | it('should be return user info', (done) => { 43 | authService 44 | .login(loginObj.email, loginObj.password) 45 | .then((result) => { 46 | expect(result).has.ownProperty('id'); 47 | expect(result.email).to.eqls(user.email); 48 | expect(result).has.ownProperty('token'); 49 | accessToken = result.token.accessKey; 50 | done(); 51 | }) 52 | .catch((err) => done(err)); 53 | }); 54 | }); 55 | 56 | describe('Verify token', () => { 57 | it('should be verify token', (done) => { 58 | authService 59 | .verifyJWTToken(accessToken) 60 | .then((result) => { 61 | expect(result).has.ownProperty('id'); 62 | expect(result.email).to.eqls(user.email); 63 | done(); 64 | }) 65 | .catch((err) => done(err)); 66 | }); 67 | }); 68 | -------------------------------------------------------------------------------- /src/services/auth.service.ts: -------------------------------------------------------------------------------- 1 | import { compare } from 'bcrypt'; 2 | 3 | import { ILogger, NotFoundError, ValidationError } from '@vtjs/common'; 4 | import { verifyJWT, generateJWt } from '@vtjs/auth'; 5 | 6 | import { IUserService, IAuthService, JWTToken } from './definations'; 7 | 8 | import User from '../entities/user.entity'; 9 | import { JWT_SECRET_KEY, JWt_EXPIRES_IN, JWt_EXPIRES_DAYS } from '../configs'; 10 | 11 | type AuthServiceProp = { 12 | logger: ILogger; 13 | userService: IUserService; 14 | }; 15 | 16 | type JWTDecoded = { 17 | id: string; 18 | exp: number; 19 | }; 20 | 21 | export default class AuthService implements IAuthService { 22 | logger: ILogger; 23 | userService: IUserService; 24 | 25 | constructor({ logger, userService }: AuthServiceProp) { 26 | this.logger = logger; 27 | this.userService = userService; 28 | } 29 | 30 | async login(email: string, password: string): Promise { 31 | const findUser = await this.userService.findOne({ email }); 32 | if (!findUser) throw new NotFoundError(); 33 | 34 | await compare(password, findUser.password).catch((e) => { 35 | throw new ValidationError(); 36 | }); 37 | 38 | delete findUser.password; 39 | const token = this.generateJWTToken(findUser.id); 40 | 41 | return { 42 | ...findUser, 43 | token 44 | }; 45 | } 46 | 47 | private generateJWTToken(id: string): JWTToken { 48 | const today = new Date(); 49 | const exp = new Date(today); 50 | exp.setDate(today.getDate() + JWt_EXPIRES_DAYS); 51 | const convertExpToNumber = Math.floor(exp.getTime() / 1000); 52 | 53 | const accessKey = generateJWt( 54 | { 55 | id 56 | }, 57 | { 58 | secretKey: JWT_SECRET_KEY, 59 | expiresIn: JWt_EXPIRES_IN 60 | } 61 | ); 62 | 63 | return { 64 | accessKey, 65 | exp: convertExpToNumber 66 | }; 67 | } 68 | 69 | async verifyJWTToken(accessKey: string): Promise { 70 | const decoded: JWTDecoded = verifyJWT({ 71 | token: accessKey, 72 | secretKey: JWT_SECRET_KEY 73 | }); 74 | 75 | if (!decoded?.id) throw new ValidationError(); 76 | const findUser = await this.userService.findOne({ id: decoded.id }); 77 | 78 | return findUser; 79 | } 80 | } 81 | -------------------------------------------------------------------------------- /src/services/definations.ts: -------------------------------------------------------------------------------- 1 | import { IBaseService } from '@vtjs/common'; 2 | 3 | import User from '../entities/user.entity'; 4 | import Task from '../entities/task.entity'; 5 | import Activity from '../entities/activity.entity'; 6 | 7 | export type JWTToken = { 8 | accessKey: string; 9 | exp: number; 10 | }; 11 | export interface IAuthService { 12 | login(email: string, password: string): Promise; 13 | verifyJWTToken(accessKey: string): Promise; 14 | } 15 | 16 | export interface IUserService extends IBaseService { 17 | createUser(user: Pick): Promise; 18 | } 19 | 20 | export interface ITaskService extends IBaseService { 21 | deleteTask(user: User, cond: Partial): Promise; 22 | updateTask(user: User, cond: Partial, task: Partial): Promise; 23 | } 24 | 25 | export interface IActivityService extends IBaseService {} 26 | -------------------------------------------------------------------------------- /src/services/task.service.ts: -------------------------------------------------------------------------------- 1 | import { 2 | BaseService, 3 | ILogger, 4 | ServiceCache, 5 | NotFoundError, 6 | PermissionDeniedError 7 | } from '@vtjs/common'; 8 | 9 | import { ITaskService } from './definations'; 10 | 11 | import User from '../entities/user.entity'; 12 | import Task from '../entities/task.entity'; 13 | 14 | import { ITaskRepository } from '../repositories/definations'; 15 | 16 | type TaskServiceProp = { 17 | repo: ITaskRepository; 18 | logger: ILogger; 19 | serviceCache: ServiceCache; 20 | }; 21 | 22 | export default class TaskService extends BaseService implements ITaskService { 23 | repo: ITaskRepository; 24 | constructor({ repo, logger, serviceCache }: TaskServiceProp) { 25 | super(repo, serviceCache, logger); 26 | } 27 | 28 | async deleteTask(user: User, cond: Partial): Promise { 29 | const findTask = await this.findOne(cond); 30 | if (!findTask) throw new NotFoundError(); 31 | 32 | if (findTask.userId !== user.id) throw new PermissionDeniedError(); 33 | return this.deleteById(findTask.id); 34 | } 35 | 36 | async updateTask(user: User, cond: Partial, task: Partial): Promise { 37 | const findTask = await this.findOne(cond); 38 | if (!findTask) throw new NotFoundError(); 39 | 40 | if (findTask.userId !== user.id) throw new PermissionDeniedError(); 41 | 42 | delete task.userId; 43 | return this.findOneAndUpdate({ id: findTask.id }, task); 44 | } 45 | } 46 | -------------------------------------------------------------------------------- /src/services/user.service.ts: -------------------------------------------------------------------------------- 1 | import bcrypt from 'bcrypt'; 2 | 3 | import { BaseService, ILogger, ServiceCache, AlreadyExistsError } from '@vtjs/common'; 4 | 5 | import { IUserService } from './definations'; 6 | 7 | import { BCRYPT_HASH_SALT } from '../configs'; 8 | import User from '../entities/user.entity'; 9 | import { IUserRepository } from '../repositories/definations'; 10 | 11 | type UserServiceProp = { 12 | repo: IUserRepository; 13 | logger: ILogger; 14 | serviceCache: ServiceCache; 15 | }; 16 | 17 | export default class UserService extends BaseService implements IUserService { 18 | repo: IUserRepository; 19 | 20 | constructor({ repo, logger, serviceCache }: UserServiceProp) { 21 | super(repo, serviceCache, logger); 22 | } 23 | 24 | async createUser({ email, password }: Pick): Promise { 25 | const findUser = await this.findOne({ email }); 26 | if (findUser) throw new AlreadyExistsError(); 27 | 28 | const hashPassword = await bcrypt.hash(password, BCRYPT_HASH_SALT); 29 | return this.create({ 30 | email, 31 | password: hashPassword 32 | }); 33 | } 34 | 35 | // Example handling another function that is NOT found in the Base Repository 36 | async deleteUserByEmail(email: string): Promise { 37 | // Cache is build-in with all function in the Base Service 38 | // If you want handle it, please follow structure 39 | // Get Cache 40 | // const exampleHanleGetCache = await this.getCache({ email }); 41 | // Set Cache 42 | // this.setCache({ email }, user) 43 | 44 | const raw = await this.repo.deleteByEmail(email); 45 | 46 | if (raw.ok == 1) { 47 | // Handle delete cache because you not using function in Base Service 48 | this.deleteCache({ email }); 49 | return true; 50 | } 51 | return false; 52 | } 53 | } 54 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "moduleResolution": "node", 5 | "pretty": false, 6 | "sourceMap": true, 7 | "target": "es6", 8 | "outDir": "dist", 9 | "baseUrl": "src", 10 | "paths": {}, 11 | "allowJs": true, 12 | "noImplicitAny": false, 13 | "experimentalDecorators": true, 14 | "resolveJsonModule": true, 15 | "emitDecoratorMetadata": true, 16 | "esModuleInterop": true 17 | }, 18 | // Add more include file if you want. Like static file, images... 19 | // Example: public/**/* 20 | "include": ["src/index.ts", "src/**/*.json"], 21 | "exclude": ["node_modules"] 22 | } 23 | --------------------------------------------------------------------------------