├── .env ├── .gitignore ├── README.md ├── knexfile.ts ├── package-lock.json ├── package.json ├── src ├── app.module.ts ├── database │ ├── database.module.ts │ ├── migration.stub │ ├── migrations │ │ ├── 20190609143930_CreateTags.ts │ │ ├── 20190609144745_CreateThemes.ts │ │ ├── 20190609144752_CreateNotes.ts │ │ └── 20190609144759_CreateNoteTags.ts │ ├── models │ │ ├── base.model.ts │ │ ├── note-tag.model.ts │ │ ├── note.model.ts │ │ ├── tag.model.ts │ │ └── theme.model.ts │ ├── seed.stub │ └── seeds │ │ ├── 01-Tags.ts │ │ ├── 02-Themes.ts │ │ ├── 03-Notes.ts │ │ └── 04-NoteTags.ts ├── main.ts ├── notes │ ├── note-tags.service.ts │ ├── notes.controller.ts │ ├── notes.module.ts │ └── notes.service.ts ├── tags │ ├── tags.controller.ts │ ├── tags.module.ts │ └── tags.service.ts └── themes │ ├── themes.controller.ts │ ├── themes.module.ts │ └── themes.service.ts ├── tsconfig.build.json ├── tsconfig.json └── tslint.json /.env: -------------------------------------------------------------------------------- 1 | DATABASE_URL=postgres://postgres:docker@localhost:5432/postgres -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # dependencies 2 | /node_modules 3 | 4 | # IDE 5 | /.idea 6 | /.awcache 7 | /.vscode 8 | 9 | # misc 10 | npm-debug.log 11 | 12 | # example 13 | /quick-start 14 | 15 | # tests 16 | /test 17 | /coverage 18 | /.nyc_output 19 | 20 | # dist 21 | /dist 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Reducing mental fatigue: NestJS + Objection.js 2 | 3 | This is a companion repository for my article. 4 | 5 | Practical part of this article shows how to use NestJS with Objection.js ORM. 6 | There I've developed a toy API, which purpose is to show concepts I've described. 7 | 8 | ## Prerequisites 9 | 10 | ## Hot to run 11 | 12 | - `npm i` 13 | - `npm run run:pg-docker` 14 | - `npm run migrate && npm run seed` 15 | - `npm run start` 16 | 17 | API is accessible at `http://localhost:3001` 18 | 19 | ## Example API requests 20 | 21 | ### Themes 22 | 23 | ```bash 24 | # findAll 25 | curl http://localhost:3001/api/themes 26 | 27 | # findOne 28 | curl http://localhost:3001/api/themes/1 29 | 30 | # create 31 | curl -X POST http://localhost:3001/api/themes -d '{ "name": "my" }' -H "Content-Type: application/json" 32 | 33 | # update 34 | curl -X PUT http://localhost:3001/api/themes/6 -d '{ "name": "baz", "fontFamily": "DejaVu Sans Mono" }' -H "Content-Type: application/json" 35 | 36 | # delete 37 | curl -X DELETE http://localhost:3001/api/themes/6 38 | ``` 39 | 40 | ### Tags 41 | 42 | ```bash 43 | # findAll 44 | curl http://localhost:3001/api/tags 45 | 46 | # findOne 47 | curl http://localhost:3001/api/tags/1 48 | 49 | # create 50 | curl -X POST http://localhost:3001/api/tags -d '{ "name": "foobar" }' -H "Content-Type: application/json" 51 | 52 | # update 53 | curl -X PUT http://localhost:3001/api/tags/6 -d '{ "name": "foobar42" }' -H "Content-Type: application/json" 54 | 55 | # delete 56 | curl -X DELETE http://localhost:3001/api/tags/6 57 | ``` 58 | 59 | ### Notes 60 | 61 | ```bash 62 | # findAll 63 | curl http://localhost:3001/api/notes 64 | 65 | # findOne 66 | curl http://localhost:3001/api/notes/1 67 | 68 | # create 69 | curl -X POST http://localhost:3001/api/notes -d '{ "text": "foobar", "themeId": 2 }' -H "Content-Type: application/json" 70 | 71 | # update 72 | curl -X PUT http://localhost:3001/api/notes/1 -d '{ "text": "hello42" }' -H "Content-Type: application/json" 73 | 74 | # delete 75 | curl -X DELETE http://localhost:3001/api/notes/2 76 | 77 | # setTheme 78 | curl -X PUT http://localhost:3001/api/notes/1/theme/6 79 | 80 | # addTag 81 | curl -X PUT http://localhost:3001/api/notes/1/tags/6 82 | 83 | # removeTag 84 | curl -X DELETE http://localhost:3001/api/notes/1/tags/6 85 | ``` 86 | 87 | -------------------------------------------------------------------------------- /knexfile.ts: -------------------------------------------------------------------------------- 1 | import 'dotenv/config'; 2 | import * as Knex from 'knex'; 3 | import { knexSnakeCaseMappers } from 'objection'; 4 | 5 | module.exports = { 6 | client: 'pg', 7 | connection: process.env.DATABASE_URL, 8 | migrations: { 9 | directory: './src/database/migrations', 10 | stub: './src/database/migration.stub', 11 | }, 12 | seeds: { 13 | directory: './src/database/seeds', 14 | stub: './src/database/seed.stub' 15 | }, 16 | ...knexSnakeCaseMappers() 17 | } as Knex.Config; 18 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "nest-objection-article", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.0.0", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.0.0.tgz", 10 | "integrity": "sha512-OfC2uemaknXr87bdLUkWog7nYuliM9Ij5HUcajsVcMCpQrcLmtxRbVFTIqmcSkSeYRBFBRxs2FiUqFJDLdiebA==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.0.0" 14 | } 15 | }, 16 | "@babel/highlight": { 17 | "version": "7.0.0", 18 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.0.0.tgz", 19 | "integrity": "sha512-UFMC4ZeFC48Tpvj7C8UgLvtkaUuovQX+5xNWrsIoMG8o2z+XFKjKaN9iVmS84dPwVN00W4wPmqvYoZF3EGAsfw==", 20 | "dev": true, 21 | "requires": { 22 | "chalk": "^2.0.0", 23 | "esutils": "^2.0.2", 24 | "js-tokens": "^4.0.0" 25 | } 26 | }, 27 | "@babel/polyfill": { 28 | "version": "7.4.4", 29 | "resolved": "https://registry.npmjs.org/@babel/polyfill/-/polyfill-7.4.4.tgz", 30 | "integrity": "sha512-WlthFLfhQQhh+A2Gn5NSFl0Huxz36x86Jn+E9OW7ibK8edKPq+KLy4apM1yDpQ8kJOVi1OVjpP4vSDLdrI04dg==", 31 | "requires": { 32 | "core-js": "^2.6.5", 33 | "regenerator-runtime": "^0.13.2" 34 | } 35 | }, 36 | "@nestjs/common": { 37 | "version": "6.2.4", 38 | "resolved": "https://registry.npmjs.org/@nestjs/common/-/common-6.2.4.tgz", 39 | "integrity": "sha512-YZvJ6/S7yVQZK+9rupCzMCg4tpbc9DyVvLoTx0NBDqExTCUNcNEcCtn0AZrO/hLqbeYODnJwGE2NxkH1R/qw+w==", 40 | "requires": { 41 | "axios": "0.18.0", 42 | "cli-color": "1.4.0", 43 | "uuid": "3.3.2" 44 | } 45 | }, 46 | "@nestjs/core": { 47 | "version": "6.2.4", 48 | "resolved": "https://registry.npmjs.org/@nestjs/core/-/core-6.2.4.tgz", 49 | "integrity": "sha512-aYKi3QGKmpxF6w32STAcobIqOHFqSUXrU8nF+Y9dOlStRkXFBTuVchsoJk94sY+3y4SJAlHH4Q/8R4yFaixrug==", 50 | "requires": { 51 | "@nuxtjs/opencollective": "0.2.1", 52 | "fast-safe-stringify": "2.0.6", 53 | "iterare": "1.1.2", 54 | "object-hash": "1.3.1", 55 | "optional": "0.1.4", 56 | "uuid": "3.3.2" 57 | } 58 | }, 59 | "@nestjs/platform-express": { 60 | "version": "6.2.4", 61 | "resolved": "https://registry.npmjs.org/@nestjs/platform-express/-/platform-express-6.2.4.tgz", 62 | "integrity": "sha512-MmoQqFWO7nmgEvBIeO6ddz1CFVx3RIQluX1LMIzyfiyRghQzcZCGqTQsZSpck5ZnXNQNxrrI9bz/6a6cTwovmQ==", 63 | "requires": { 64 | "body-parser": "1.19.0", 65 | "cors": "2.8.5", 66 | "express": "4.17.0", 67 | "multer": "1.4.1" 68 | } 69 | }, 70 | "@nuxtjs/opencollective": { 71 | "version": "0.2.1", 72 | "resolved": "https://registry.npmjs.org/@nuxtjs/opencollective/-/opencollective-0.2.1.tgz", 73 | "integrity": "sha512-pzSib8NKquaTt/ns5Cc2G0BGRVJXaD+p1qfF6q7vNIMvRysorn/VF3y7gAuQpcxfF7wBbGE+dXjhIieWOUsWSw==", 74 | "requires": { 75 | "chalk": "^2.4.1", 76 | "consola": "^2.3.0", 77 | "node-fetch": "^2.3.0" 78 | } 79 | }, 80 | "@types/bluebird": { 81 | "version": "3.5.27", 82 | "resolved": "https://registry.npmjs.org/@types/bluebird/-/bluebird-3.5.27.tgz", 83 | "integrity": "sha512-6BmYWSBea18+tSjjSC3QIyV93ZKAeNWGM7R6aYt1ryTZXrlHF+QLV0G2yV0viEGVyRkyQsWfMoJ0k/YghBX5sQ==" 84 | }, 85 | "@types/dotenv": { 86 | "version": "6.1.1", 87 | "resolved": "https://registry.npmjs.org/@types/dotenv/-/dotenv-6.1.1.tgz", 88 | "integrity": "sha512-ftQl3DtBvqHl9L16tpqqzA4YzCSXZfi7g8cQceTz5rOlYtk/IZbFjAv3mLOQlNIgOaylCQWQoBdDQHPgEBJPHg==", 89 | "requires": { 90 | "@types/node": "*" 91 | } 92 | }, 93 | "@types/node": { 94 | "version": "10.14.7", 95 | "resolved": "https://registry.npmjs.org/@types/node/-/node-10.14.7.tgz", 96 | "integrity": "sha512-on4MmIDgHXiuJDELPk1NFaKVUxxCFr37tm8E9yN6rAiF5Pzp/9bBfBHkoexqRiY+hk/Z04EJU9kKEb59YqJ82A==" 97 | }, 98 | "accepts": { 99 | "version": "1.3.7", 100 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 101 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 102 | "requires": { 103 | "mime-types": "~2.1.24", 104 | "negotiator": "0.6.2" 105 | } 106 | }, 107 | "ajv": { 108 | "version": "6.10.0", 109 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.0.tgz", 110 | "integrity": "sha512-nffhOpkymDECQyR0mnsUtoCE8RlX38G0rYP+wgLWFyZuUyuuojSSvi/+euOiQBIn63whYwYVIIH1TvE3tu4OEg==", 111 | "requires": { 112 | "fast-deep-equal": "^2.0.1", 113 | "fast-json-stable-stringify": "^2.0.0", 114 | "json-schema-traverse": "^0.4.1", 115 | "uri-js": "^4.2.2" 116 | } 117 | }, 118 | "ansi-regex": { 119 | "version": "2.1.1", 120 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 121 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 122 | }, 123 | "ansi-styles": { 124 | "version": "3.2.1", 125 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 126 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 127 | "requires": { 128 | "color-convert": "^1.9.0" 129 | } 130 | }, 131 | "append-field": { 132 | "version": "1.0.0", 133 | "resolved": "https://registry.npmjs.org/append-field/-/append-field-1.0.0.tgz", 134 | "integrity": "sha1-HjRA6RXwsSA9I3SOeO3XubW0PlY=" 135 | }, 136 | "arg": { 137 | "version": "4.1.0", 138 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.0.tgz", 139 | "integrity": "sha512-ZWc51jO3qegGkVh8Hwpv636EkbesNV5ZNQPCtRa+0qytRYPEs9IYT9qITY9buezqUH5uqyzlWLcufrzU2rffdg==", 140 | "dev": true 141 | }, 142 | "argparse": { 143 | "version": "1.0.10", 144 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 145 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 146 | "dev": true, 147 | "requires": { 148 | "sprintf-js": "~1.0.2" 149 | } 150 | }, 151 | "arr-diff": { 152 | "version": "4.0.0", 153 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", 154 | "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=" 155 | }, 156 | "arr-flatten": { 157 | "version": "1.1.0", 158 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 159 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==" 160 | }, 161 | "arr-union": { 162 | "version": "3.1.0", 163 | "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", 164 | "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=" 165 | }, 166 | "array-each": { 167 | "version": "1.0.1", 168 | "resolved": "https://registry.npmjs.org/array-each/-/array-each-1.0.1.tgz", 169 | "integrity": "sha1-p5SvDAWrF1KEbudTofIRoFugxE8=" 170 | }, 171 | "array-flatten": { 172 | "version": "1.1.1", 173 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 174 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 175 | }, 176 | "array-slice": { 177 | "version": "1.1.0", 178 | "resolved": "https://registry.npmjs.org/array-slice/-/array-slice-1.1.0.tgz", 179 | "integrity": "sha512-B1qMD3RBP7O8o0H2KbrXDyB0IccejMF15+87Lvlor12ONPRHP6gTjXMNkt/d3ZuOGbAe66hFmaCfECI24Ufp6w==" 180 | }, 181 | "array-unique": { 182 | "version": "0.3.2", 183 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", 184 | "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=" 185 | }, 186 | "assign-symbols": { 187 | "version": "1.0.0", 188 | "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", 189 | "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=" 190 | }, 191 | "atob": { 192 | "version": "2.1.2", 193 | "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", 194 | "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==" 195 | }, 196 | "axios": { 197 | "version": "0.18.0", 198 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.18.0.tgz", 199 | "integrity": "sha1-MtU+SFHv3AoRmTts0AB4nXDAUQI=", 200 | "requires": { 201 | "follow-redirects": "^1.3.0", 202 | "is-buffer": "^1.1.5" 203 | } 204 | }, 205 | "balanced-match": { 206 | "version": "1.0.0", 207 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 208 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 209 | "dev": true 210 | }, 211 | "base": { 212 | "version": "0.11.2", 213 | "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", 214 | "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", 215 | "requires": { 216 | "cache-base": "^1.0.1", 217 | "class-utils": "^0.3.5", 218 | "component-emitter": "^1.2.1", 219 | "define-property": "^1.0.0", 220 | "isobject": "^3.0.1", 221 | "mixin-deep": "^1.2.0", 222 | "pascalcase": "^0.1.1" 223 | }, 224 | "dependencies": { 225 | "define-property": { 226 | "version": "1.0.0", 227 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 228 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 229 | "requires": { 230 | "is-descriptor": "^1.0.0" 231 | } 232 | }, 233 | "is-accessor-descriptor": { 234 | "version": "1.0.0", 235 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 236 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 237 | "requires": { 238 | "kind-of": "^6.0.0" 239 | } 240 | }, 241 | "is-data-descriptor": { 242 | "version": "1.0.0", 243 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 244 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 245 | "requires": { 246 | "kind-of": "^6.0.0" 247 | } 248 | }, 249 | "is-descriptor": { 250 | "version": "1.0.2", 251 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 252 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 253 | "requires": { 254 | "is-accessor-descriptor": "^1.0.0", 255 | "is-data-descriptor": "^1.0.0", 256 | "kind-of": "^6.0.2" 257 | } 258 | } 259 | } 260 | }, 261 | "bluebird": { 262 | "version": "3.5.5", 263 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.5.tgz", 264 | "integrity": "sha512-5am6HnnfN+urzt4yfg7IgTbotDjIT/u8AJpEt0sIU9FtXfVeezXAPKswrG+xKUCOYAINpSdgZVDU6QFh+cuH3w==" 265 | }, 266 | "body-parser": { 267 | "version": "1.19.0", 268 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 269 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 270 | "requires": { 271 | "bytes": "3.1.0", 272 | "content-type": "~1.0.4", 273 | "debug": "2.6.9", 274 | "depd": "~1.1.2", 275 | "http-errors": "1.7.2", 276 | "iconv-lite": "0.4.24", 277 | "on-finished": "~2.3.0", 278 | "qs": "6.7.0", 279 | "raw-body": "2.4.0", 280 | "type-is": "~1.6.17" 281 | }, 282 | "dependencies": { 283 | "debug": { 284 | "version": "2.6.9", 285 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 286 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 287 | "requires": { 288 | "ms": "2.0.0" 289 | } 290 | }, 291 | "ms": { 292 | "version": "2.0.0", 293 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 294 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 295 | } 296 | } 297 | }, 298 | "brace-expansion": { 299 | "version": "1.1.11", 300 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 301 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 302 | "dev": true, 303 | "requires": { 304 | "balanced-match": "^1.0.0", 305 | "concat-map": "0.0.1" 306 | } 307 | }, 308 | "braces": { 309 | "version": "2.3.2", 310 | "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", 311 | "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", 312 | "requires": { 313 | "arr-flatten": "^1.1.0", 314 | "array-unique": "^0.3.2", 315 | "extend-shallow": "^2.0.1", 316 | "fill-range": "^4.0.0", 317 | "isobject": "^3.0.1", 318 | "repeat-element": "^1.1.2", 319 | "snapdragon": "^0.8.1", 320 | "snapdragon-node": "^2.0.1", 321 | "split-string": "^3.0.2", 322 | "to-regex": "^3.0.1" 323 | }, 324 | "dependencies": { 325 | "extend-shallow": { 326 | "version": "2.0.1", 327 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 328 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 329 | "requires": { 330 | "is-extendable": "^0.1.0" 331 | } 332 | } 333 | } 334 | }, 335 | "buffer-from": { 336 | "version": "1.1.1", 337 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 338 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==" 339 | }, 340 | "buffer-writer": { 341 | "version": "2.0.0", 342 | "resolved": "https://registry.npmjs.org/buffer-writer/-/buffer-writer-2.0.0.tgz", 343 | "integrity": "sha512-a7ZpuTZU1TRtnwyCNW3I5dc0wWNC3VR9S++Ewyk2HHZdrO3CQJqSpd+95Us590V6AL7JqUAH2IwZ/398PmNFgw==" 344 | }, 345 | "builtin-modules": { 346 | "version": "1.1.1", 347 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 348 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", 349 | "dev": true 350 | }, 351 | "busboy": { 352 | "version": "0.2.14", 353 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-0.2.14.tgz", 354 | "integrity": "sha1-bCpiLvz0fFe7vh4qnDetNseSVFM=", 355 | "requires": { 356 | "dicer": "0.2.5", 357 | "readable-stream": "1.1.x" 358 | } 359 | }, 360 | "bytes": { 361 | "version": "3.1.0", 362 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 363 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 364 | }, 365 | "cache-base": { 366 | "version": "1.0.1", 367 | "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", 368 | "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", 369 | "requires": { 370 | "collection-visit": "^1.0.0", 371 | "component-emitter": "^1.2.1", 372 | "get-value": "^2.0.6", 373 | "has-value": "^1.0.0", 374 | "isobject": "^3.0.1", 375 | "set-value": "^2.0.0", 376 | "to-object-path": "^0.3.0", 377 | "union-value": "^1.0.0", 378 | "unset-value": "^1.0.0" 379 | } 380 | }, 381 | "chalk": { 382 | "version": "2.4.2", 383 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 384 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 385 | "requires": { 386 | "ansi-styles": "^3.2.1", 387 | "escape-string-regexp": "^1.0.5", 388 | "supports-color": "^5.3.0" 389 | } 390 | }, 391 | "class-utils": { 392 | "version": "0.3.6", 393 | "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", 394 | "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", 395 | "requires": { 396 | "arr-union": "^3.1.0", 397 | "define-property": "^0.2.5", 398 | "isobject": "^3.0.0", 399 | "static-extend": "^0.1.1" 400 | }, 401 | "dependencies": { 402 | "define-property": { 403 | "version": "0.2.5", 404 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 405 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 406 | "requires": { 407 | "is-descriptor": "^0.1.0" 408 | } 409 | } 410 | } 411 | }, 412 | "cli-color": { 413 | "version": "1.4.0", 414 | "resolved": "https://registry.npmjs.org/cli-color/-/cli-color-1.4.0.tgz", 415 | "integrity": "sha512-xu6RvQqqrWEo6MPR1eixqGPywhYBHRs653F9jfXB2Hx4jdM/3WxiNE1vppRmxtMIfl16SFYTpYlrnqH/HsK/2w==", 416 | "requires": { 417 | "ansi-regex": "^2.1.1", 418 | "d": "1", 419 | "es5-ext": "^0.10.46", 420 | "es6-iterator": "^2.0.3", 421 | "memoizee": "^0.4.14", 422 | "timers-ext": "^0.1.5" 423 | } 424 | }, 425 | "collection-visit": { 426 | "version": "1.0.0", 427 | "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", 428 | "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", 429 | "requires": { 430 | "map-visit": "^1.0.0", 431 | "object-visit": "^1.0.0" 432 | } 433 | }, 434 | "color-convert": { 435 | "version": "1.9.3", 436 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 437 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 438 | "requires": { 439 | "color-name": "1.1.3" 440 | } 441 | }, 442 | "color-name": { 443 | "version": "1.1.3", 444 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 445 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 446 | }, 447 | "colorette": { 448 | "version": "1.0.8", 449 | "resolved": "https://registry.npmjs.org/colorette/-/colorette-1.0.8.tgz", 450 | "integrity": "sha512-X6Ck90ReaF+EfKdVGB7vdIQ3dr651BbIrBwY5YBKg13fjH+940sTtp7/Pkx33C6ntYfQcRumOs/aUQhaRPpbTQ==" 451 | }, 452 | "commander": { 453 | "version": "2.20.0", 454 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.0.tgz", 455 | "integrity": "sha512-7j2y+40w61zy6YC2iRNpUe/NwhNyoXrYpHMrSunaMG64nRnaf96zO/KMQR4OyN/UnE5KLyEBnKHd4aG3rskjpQ==" 456 | }, 457 | "component-emitter": { 458 | "version": "1.3.0", 459 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", 460 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==" 461 | }, 462 | "concat-map": { 463 | "version": "0.0.1", 464 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 465 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 466 | "dev": true 467 | }, 468 | "concat-stream": { 469 | "version": "1.6.2", 470 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", 471 | "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", 472 | "requires": { 473 | "buffer-from": "^1.0.0", 474 | "inherits": "^2.0.3", 475 | "readable-stream": "^2.2.2", 476 | "typedarray": "^0.0.6" 477 | }, 478 | "dependencies": { 479 | "isarray": { 480 | "version": "1.0.0", 481 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 482 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 483 | }, 484 | "readable-stream": { 485 | "version": "2.3.6", 486 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 487 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 488 | "requires": { 489 | "core-util-is": "~1.0.0", 490 | "inherits": "~2.0.3", 491 | "isarray": "~1.0.0", 492 | "process-nextick-args": "~2.0.0", 493 | "safe-buffer": "~5.1.1", 494 | "string_decoder": "~1.1.1", 495 | "util-deprecate": "~1.0.1" 496 | } 497 | }, 498 | "string_decoder": { 499 | "version": "1.1.1", 500 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 501 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 502 | "requires": { 503 | "safe-buffer": "~5.1.0" 504 | } 505 | } 506 | } 507 | }, 508 | "consola": { 509 | "version": "2.7.1", 510 | "resolved": "https://registry.npmjs.org/consola/-/consola-2.7.1.tgz", 511 | "integrity": "sha512-u7JYs+HnMbZPD2cEuS1XHsLeqtazA0kd5lAk8r8DnnGdgNhOdb7DSubJ+QLdQkbtpmmxgp7gs8Ug44sCyY4FCQ==" 512 | }, 513 | "content-disposition": { 514 | "version": "0.5.3", 515 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 516 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 517 | "requires": { 518 | "safe-buffer": "5.1.2" 519 | } 520 | }, 521 | "content-type": { 522 | "version": "1.0.4", 523 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 524 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 525 | }, 526 | "cookie": { 527 | "version": "0.4.0", 528 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 529 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 530 | }, 531 | "cookie-signature": { 532 | "version": "1.0.6", 533 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 534 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 535 | }, 536 | "copy-descriptor": { 537 | "version": "0.1.1", 538 | "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", 539 | "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=" 540 | }, 541 | "core-js": { 542 | "version": "2.6.9", 543 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.6.9.tgz", 544 | "integrity": "sha512-HOpZf6eXmnl7la+cUdMnLvUxKNqLUzJvgIziQ0DiF3JwSImNphIqdGqzj6hIKyX04MmV0poclQ7+wjWvxQyR2A==" 545 | }, 546 | "core-util-is": { 547 | "version": "1.0.2", 548 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 549 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 550 | }, 551 | "cors": { 552 | "version": "2.8.5", 553 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 554 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 555 | "requires": { 556 | "object-assign": "^4", 557 | "vary": "^1" 558 | } 559 | }, 560 | "d": { 561 | "version": "1.0.0", 562 | "resolved": "https://registry.npmjs.org/d/-/d-1.0.0.tgz", 563 | "integrity": "sha1-dUu1v+VUUdpppYuU1F9MWwRi1Y8=", 564 | "requires": { 565 | "es5-ext": "^0.10.9" 566 | } 567 | }, 568 | "debug": { 569 | "version": "3.2.6", 570 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 571 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 572 | "requires": { 573 | "ms": "^2.1.1" 574 | } 575 | }, 576 | "decode-uri-component": { 577 | "version": "0.2.0", 578 | "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", 579 | "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=" 580 | }, 581 | "define-property": { 582 | "version": "2.0.2", 583 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", 584 | "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", 585 | "requires": { 586 | "is-descriptor": "^1.0.2", 587 | "isobject": "^3.0.1" 588 | }, 589 | "dependencies": { 590 | "is-accessor-descriptor": { 591 | "version": "1.0.0", 592 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 593 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 594 | "requires": { 595 | "kind-of": "^6.0.0" 596 | } 597 | }, 598 | "is-data-descriptor": { 599 | "version": "1.0.0", 600 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 601 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 602 | "requires": { 603 | "kind-of": "^6.0.0" 604 | } 605 | }, 606 | "is-descriptor": { 607 | "version": "1.0.2", 608 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 609 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 610 | "requires": { 611 | "is-accessor-descriptor": "^1.0.0", 612 | "is-data-descriptor": "^1.0.0", 613 | "kind-of": "^6.0.2" 614 | } 615 | } 616 | } 617 | }, 618 | "depd": { 619 | "version": "1.1.2", 620 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 621 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 622 | }, 623 | "destroy": { 624 | "version": "1.0.4", 625 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 626 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 627 | }, 628 | "detect-file": { 629 | "version": "1.0.0", 630 | "resolved": "https://registry.npmjs.org/detect-file/-/detect-file-1.0.0.tgz", 631 | "integrity": "sha1-8NZtA2cqglyxtzvbP+YjEMjlUrc=" 632 | }, 633 | "dicer": { 634 | "version": "0.2.5", 635 | "resolved": "https://registry.npmjs.org/dicer/-/dicer-0.2.5.tgz", 636 | "integrity": "sha1-WZbAhrszIYyBLAkL3cCc0S+stw8=", 637 | "requires": { 638 | "readable-stream": "1.1.x", 639 | "streamsearch": "0.1.2" 640 | } 641 | }, 642 | "diff": { 643 | "version": "4.0.1", 644 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.1.tgz", 645 | "integrity": "sha512-s2+XdvhPCOF01LRQBC8hf4vhbVmI2CGS5aZnxLJlT5FtdhPCDFq80q++zK2KlrVorVDdL5BOGZ/VfLrVtYNF+Q==", 646 | "dev": true 647 | }, 648 | "dotenv": { 649 | "version": "8.0.0", 650 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.0.0.tgz", 651 | "integrity": "sha512-30xVGqjLjiUOArT4+M5q9sYdvuR4riM6yK9wMcas9Vbp6zZa+ocC9dp6QoftuhTPhFAiLK/0C5Ni2nou/Bk8lg==" 652 | }, 653 | "ee-first": { 654 | "version": "1.1.1", 655 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 656 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 657 | }, 658 | "encodeurl": { 659 | "version": "1.0.2", 660 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 661 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 662 | }, 663 | "es5-ext": { 664 | "version": "0.10.50", 665 | "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.50.tgz", 666 | "integrity": "sha512-KMzZTPBkeQV/JcSQhI5/z6d9VWJ3EnQ194USTUwIYZ2ZbpN8+SGXQKt1h68EX44+qt+Fzr8DO17vnxrw7c3agw==", 667 | "requires": { 668 | "es6-iterator": "~2.0.3", 669 | "es6-symbol": "~3.1.1", 670 | "next-tick": "^1.0.0" 671 | } 672 | }, 673 | "es6-iterator": { 674 | "version": "2.0.3", 675 | "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.3.tgz", 676 | "integrity": "sha1-p96IkUGgWpSwhUQDstCg+/qY87c=", 677 | "requires": { 678 | "d": "1", 679 | "es5-ext": "^0.10.35", 680 | "es6-symbol": "^3.1.1" 681 | } 682 | }, 683 | "es6-symbol": { 684 | "version": "3.1.1", 685 | "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.1.tgz", 686 | "integrity": "sha1-vwDvT9q2uhtG7Le2KbTH7VcVzHc=", 687 | "requires": { 688 | "d": "1", 689 | "es5-ext": "~0.10.14" 690 | } 691 | }, 692 | "es6-weak-map": { 693 | "version": "2.0.3", 694 | "resolved": "https://registry.npmjs.org/es6-weak-map/-/es6-weak-map-2.0.3.tgz", 695 | "integrity": "sha512-p5um32HOTO1kP+w7PRnB+5lQ43Z6muuMuIMffvDN8ZB4GcnjLBV6zGStpbASIMk4DCAvEaamhe2zhyCb/QXXsA==", 696 | "requires": { 697 | "d": "1", 698 | "es5-ext": "^0.10.46", 699 | "es6-iterator": "^2.0.3", 700 | "es6-symbol": "^3.1.1" 701 | } 702 | }, 703 | "escape-html": { 704 | "version": "1.0.3", 705 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 706 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 707 | }, 708 | "escape-string-regexp": { 709 | "version": "1.0.5", 710 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 711 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" 712 | }, 713 | "esprima": { 714 | "version": "4.0.1", 715 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 716 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 717 | "dev": true 718 | }, 719 | "esutils": { 720 | "version": "2.0.2", 721 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 722 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 723 | "dev": true 724 | }, 725 | "etag": { 726 | "version": "1.8.1", 727 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 728 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 729 | }, 730 | "event-emitter": { 731 | "version": "0.3.5", 732 | "resolved": "https://registry.npmjs.org/event-emitter/-/event-emitter-0.3.5.tgz", 733 | "integrity": "sha1-34xp7vFkeSPHFXuc6DhAYQsCzDk=", 734 | "requires": { 735 | "d": "1", 736 | "es5-ext": "~0.10.14" 737 | } 738 | }, 739 | "expand-brackets": { 740 | "version": "2.1.4", 741 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", 742 | "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", 743 | "requires": { 744 | "debug": "^2.3.3", 745 | "define-property": "^0.2.5", 746 | "extend-shallow": "^2.0.1", 747 | "posix-character-classes": "^0.1.0", 748 | "regex-not": "^1.0.0", 749 | "snapdragon": "^0.8.1", 750 | "to-regex": "^3.0.1" 751 | }, 752 | "dependencies": { 753 | "debug": { 754 | "version": "2.6.9", 755 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 756 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 757 | "requires": { 758 | "ms": "2.0.0" 759 | } 760 | }, 761 | "define-property": { 762 | "version": "0.2.5", 763 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 764 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 765 | "requires": { 766 | "is-descriptor": "^0.1.0" 767 | } 768 | }, 769 | "extend-shallow": { 770 | "version": "2.0.1", 771 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 772 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 773 | "requires": { 774 | "is-extendable": "^0.1.0" 775 | } 776 | }, 777 | "ms": { 778 | "version": "2.0.0", 779 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 780 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 781 | } 782 | } 783 | }, 784 | "expand-tilde": { 785 | "version": "2.0.2", 786 | "resolved": "https://registry.npmjs.org/expand-tilde/-/expand-tilde-2.0.2.tgz", 787 | "integrity": "sha1-l+gBqgUt8CRU3kawK/YhZCzchQI=", 788 | "requires": { 789 | "homedir-polyfill": "^1.0.1" 790 | } 791 | }, 792 | "express": { 793 | "version": "4.17.0", 794 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.0.tgz", 795 | "integrity": "sha512-1Z7/t3Z5ZnBG252gKUPyItc4xdeaA0X934ca2ewckAsVsw9EG71i++ZHZPYnus8g/s5Bty8IMpSVEuRkmwwPRQ==", 796 | "requires": { 797 | "accepts": "~1.3.7", 798 | "array-flatten": "1.1.1", 799 | "body-parser": "1.19.0", 800 | "content-disposition": "0.5.3", 801 | "content-type": "~1.0.4", 802 | "cookie": "0.4.0", 803 | "cookie-signature": "1.0.6", 804 | "debug": "2.6.9", 805 | "depd": "~1.1.2", 806 | "encodeurl": "~1.0.2", 807 | "escape-html": "~1.0.3", 808 | "etag": "~1.8.1", 809 | "finalhandler": "~1.1.2", 810 | "fresh": "0.5.2", 811 | "merge-descriptors": "1.0.1", 812 | "methods": "~1.1.2", 813 | "on-finished": "~2.3.0", 814 | "parseurl": "~1.3.3", 815 | "path-to-regexp": "0.1.7", 816 | "proxy-addr": "~2.0.5", 817 | "qs": "6.7.0", 818 | "range-parser": "~1.2.1", 819 | "safe-buffer": "5.1.2", 820 | "send": "0.17.1", 821 | "serve-static": "1.14.1", 822 | "setprototypeof": "1.1.1", 823 | "statuses": "~1.5.0", 824 | "type-is": "~1.6.18", 825 | "utils-merge": "1.0.1", 826 | "vary": "~1.1.2" 827 | }, 828 | "dependencies": { 829 | "debug": { 830 | "version": "2.6.9", 831 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 832 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 833 | "requires": { 834 | "ms": "2.0.0" 835 | } 836 | }, 837 | "ms": { 838 | "version": "2.0.0", 839 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 840 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 841 | } 842 | } 843 | }, 844 | "extend": { 845 | "version": "3.0.2", 846 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 847 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 848 | }, 849 | "extend-shallow": { 850 | "version": "3.0.2", 851 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", 852 | "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", 853 | "requires": { 854 | "assign-symbols": "^1.0.0", 855 | "is-extendable": "^1.0.1" 856 | }, 857 | "dependencies": { 858 | "is-extendable": { 859 | "version": "1.0.1", 860 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", 861 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", 862 | "requires": { 863 | "is-plain-object": "^2.0.4" 864 | } 865 | } 866 | } 867 | }, 868 | "extglob": { 869 | "version": "2.0.4", 870 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", 871 | "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", 872 | "requires": { 873 | "array-unique": "^0.3.2", 874 | "define-property": "^1.0.0", 875 | "expand-brackets": "^2.1.4", 876 | "extend-shallow": "^2.0.1", 877 | "fragment-cache": "^0.2.1", 878 | "regex-not": "^1.0.0", 879 | "snapdragon": "^0.8.1", 880 | "to-regex": "^3.0.1" 881 | }, 882 | "dependencies": { 883 | "define-property": { 884 | "version": "1.0.0", 885 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 886 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 887 | "requires": { 888 | "is-descriptor": "^1.0.0" 889 | } 890 | }, 891 | "extend-shallow": { 892 | "version": "2.0.1", 893 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 894 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 895 | "requires": { 896 | "is-extendable": "^0.1.0" 897 | } 898 | }, 899 | "is-accessor-descriptor": { 900 | "version": "1.0.0", 901 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 902 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 903 | "requires": { 904 | "kind-of": "^6.0.0" 905 | } 906 | }, 907 | "is-data-descriptor": { 908 | "version": "1.0.0", 909 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 910 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 911 | "requires": { 912 | "kind-of": "^6.0.0" 913 | } 914 | }, 915 | "is-descriptor": { 916 | "version": "1.0.2", 917 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 918 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 919 | "requires": { 920 | "is-accessor-descriptor": "^1.0.0", 921 | "is-data-descriptor": "^1.0.0", 922 | "kind-of": "^6.0.2" 923 | } 924 | } 925 | } 926 | }, 927 | "fast-deep-equal": { 928 | "version": "2.0.1", 929 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 930 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=" 931 | }, 932 | "fast-json-stable-stringify": { 933 | "version": "2.0.0", 934 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 935 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" 936 | }, 937 | "fast-safe-stringify": { 938 | "version": "2.0.6", 939 | "resolved": "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.0.6.tgz", 940 | "integrity": "sha512-q8BZ89jjc+mz08rSxROs8VsrBBcn1SIw1kq9NjolL509tkABRk9io01RAjSaEv1Xb2uFLt8VtRiZbGp5H8iDtg==" 941 | }, 942 | "fill-range": { 943 | "version": "4.0.0", 944 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", 945 | "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", 946 | "requires": { 947 | "extend-shallow": "^2.0.1", 948 | "is-number": "^3.0.0", 949 | "repeat-string": "^1.6.1", 950 | "to-regex-range": "^2.1.0" 951 | }, 952 | "dependencies": { 953 | "extend-shallow": { 954 | "version": "2.0.1", 955 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 956 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 957 | "requires": { 958 | "is-extendable": "^0.1.0" 959 | } 960 | } 961 | } 962 | }, 963 | "finalhandler": { 964 | "version": "1.1.2", 965 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 966 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 967 | "requires": { 968 | "debug": "2.6.9", 969 | "encodeurl": "~1.0.2", 970 | "escape-html": "~1.0.3", 971 | "on-finished": "~2.3.0", 972 | "parseurl": "~1.3.3", 973 | "statuses": "~1.5.0", 974 | "unpipe": "~1.0.0" 975 | }, 976 | "dependencies": { 977 | "debug": { 978 | "version": "2.6.9", 979 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 980 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 981 | "requires": { 982 | "ms": "2.0.0" 983 | } 984 | }, 985 | "ms": { 986 | "version": "2.0.0", 987 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 988 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 989 | } 990 | } 991 | }, 992 | "findup-sync": { 993 | "version": "3.0.0", 994 | "resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-3.0.0.tgz", 995 | "integrity": "sha512-YbffarhcicEhOrm4CtrwdKBdCuz576RLdhJDsIfvNtxUuhdRet1qZcsMjqbePtAseKdAnDyM/IyXbu7PRPRLYg==", 996 | "requires": { 997 | "detect-file": "^1.0.0", 998 | "is-glob": "^4.0.0", 999 | "micromatch": "^3.0.4", 1000 | "resolve-dir": "^1.0.1" 1001 | } 1002 | }, 1003 | "fined": { 1004 | "version": "1.2.0", 1005 | "resolved": "https://registry.npmjs.org/fined/-/fined-1.2.0.tgz", 1006 | "integrity": "sha512-ZYDqPLGxDkDhDZBjZBb+oD1+j0rA4E0pXY50eplAAOPg2N/gUBSSk5IM1/QhPfyVo19lJ+CvXpqfvk+b2p/8Ng==", 1007 | "requires": { 1008 | "expand-tilde": "^2.0.2", 1009 | "is-plain-object": "^2.0.3", 1010 | "object.defaults": "^1.1.0", 1011 | "object.pick": "^1.2.0", 1012 | "parse-filepath": "^1.0.1" 1013 | } 1014 | }, 1015 | "flagged-respawn": { 1016 | "version": "1.0.1", 1017 | "resolved": "https://registry.npmjs.org/flagged-respawn/-/flagged-respawn-1.0.1.tgz", 1018 | "integrity": "sha512-lNaHNVymajmk0OJMBn8fVUAU1BtDeKIqKoVhk4xAALB57aALg6b4W0MfJ/cUE0g9YBXy5XhSlPIpYIJ7HaY/3Q==" 1019 | }, 1020 | "follow-redirects": { 1021 | "version": "1.7.0", 1022 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.7.0.tgz", 1023 | "integrity": "sha512-m/pZQy4Gj287eNy94nivy5wchN3Kp+Q5WgUPNy5lJSZ3sgkVKSYV/ZChMAQVIgx1SqfZ2zBZtPA2YlXIWxxJOQ==", 1024 | "requires": { 1025 | "debug": "^3.2.6" 1026 | } 1027 | }, 1028 | "for-in": { 1029 | "version": "1.0.2", 1030 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 1031 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=" 1032 | }, 1033 | "for-own": { 1034 | "version": "1.0.0", 1035 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-1.0.0.tgz", 1036 | "integrity": "sha1-xjMy9BXO3EsE2/5wz4NklMU8tEs=", 1037 | "requires": { 1038 | "for-in": "^1.0.1" 1039 | } 1040 | }, 1041 | "forwarded": { 1042 | "version": "0.1.2", 1043 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 1044 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 1045 | }, 1046 | "fragment-cache": { 1047 | "version": "0.2.1", 1048 | "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", 1049 | "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", 1050 | "requires": { 1051 | "map-cache": "^0.2.2" 1052 | } 1053 | }, 1054 | "fresh": { 1055 | "version": "0.5.2", 1056 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 1057 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 1058 | }, 1059 | "fs.realpath": { 1060 | "version": "1.0.0", 1061 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1062 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1063 | "dev": true 1064 | }, 1065 | "get-value": { 1066 | "version": "2.0.6", 1067 | "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", 1068 | "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=" 1069 | }, 1070 | "getopts": { 1071 | "version": "2.2.4", 1072 | "resolved": "https://registry.npmjs.org/getopts/-/getopts-2.2.4.tgz", 1073 | "integrity": "sha512-Rz7DGyomZjrenu9Jx4qmzdlvJgvrEFHXHvjK0FcZtcTC1U5FmES7OdZHUwMuSnEE6QvBvwse1JODKj7TgbSEjQ==" 1074 | }, 1075 | "glob": { 1076 | "version": "7.1.4", 1077 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz", 1078 | "integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==", 1079 | "dev": true, 1080 | "requires": { 1081 | "fs.realpath": "^1.0.0", 1082 | "inflight": "^1.0.4", 1083 | "inherits": "2", 1084 | "minimatch": "^3.0.4", 1085 | "once": "^1.3.0", 1086 | "path-is-absolute": "^1.0.0" 1087 | } 1088 | }, 1089 | "global-modules": { 1090 | "version": "1.0.0", 1091 | "resolved": "https://registry.npmjs.org/global-modules/-/global-modules-1.0.0.tgz", 1092 | "integrity": "sha512-sKzpEkf11GpOFuw0Zzjzmt4B4UZwjOcG757PPvrfhxcLFbq0wpsgpOqxpxtxFiCG4DtG93M6XRVbF2oGdev7bg==", 1093 | "requires": { 1094 | "global-prefix": "^1.0.1", 1095 | "is-windows": "^1.0.1", 1096 | "resolve-dir": "^1.0.0" 1097 | } 1098 | }, 1099 | "global-prefix": { 1100 | "version": "1.0.2", 1101 | "resolved": "https://registry.npmjs.org/global-prefix/-/global-prefix-1.0.2.tgz", 1102 | "integrity": "sha1-2/dDxsFJklk8ZVVoy2btMsASLr4=", 1103 | "requires": { 1104 | "expand-tilde": "^2.0.2", 1105 | "homedir-polyfill": "^1.0.1", 1106 | "ini": "^1.3.4", 1107 | "is-windows": "^1.0.1", 1108 | "which": "^1.2.14" 1109 | } 1110 | }, 1111 | "has-flag": { 1112 | "version": "3.0.0", 1113 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1114 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 1115 | }, 1116 | "has-value": { 1117 | "version": "1.0.0", 1118 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", 1119 | "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", 1120 | "requires": { 1121 | "get-value": "^2.0.6", 1122 | "has-values": "^1.0.0", 1123 | "isobject": "^3.0.0" 1124 | } 1125 | }, 1126 | "has-values": { 1127 | "version": "1.0.0", 1128 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", 1129 | "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", 1130 | "requires": { 1131 | "is-number": "^3.0.0", 1132 | "kind-of": "^4.0.0" 1133 | }, 1134 | "dependencies": { 1135 | "kind-of": { 1136 | "version": "4.0.0", 1137 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", 1138 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", 1139 | "requires": { 1140 | "is-buffer": "^1.1.5" 1141 | } 1142 | } 1143 | } 1144 | }, 1145 | "homedir-polyfill": { 1146 | "version": "1.0.3", 1147 | "resolved": "https://registry.npmjs.org/homedir-polyfill/-/homedir-polyfill-1.0.3.tgz", 1148 | "integrity": "sha512-eSmmWE5bZTK2Nou4g0AI3zZ9rswp7GRKoKXS1BLUkvPviOqs4YTN1djQIqrXy9k5gEtdLPy86JjRwsNM9tnDcA==", 1149 | "requires": { 1150 | "parse-passwd": "^1.0.0" 1151 | } 1152 | }, 1153 | "http-errors": { 1154 | "version": "1.7.2", 1155 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 1156 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 1157 | "requires": { 1158 | "depd": "~1.1.2", 1159 | "inherits": "2.0.3", 1160 | "setprototypeof": "1.1.1", 1161 | "statuses": ">= 1.5.0 < 2", 1162 | "toidentifier": "1.0.0" 1163 | } 1164 | }, 1165 | "iconv-lite": { 1166 | "version": "0.4.24", 1167 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1168 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1169 | "requires": { 1170 | "safer-buffer": ">= 2.1.2 < 3" 1171 | } 1172 | }, 1173 | "inflight": { 1174 | "version": "1.0.6", 1175 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1176 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1177 | "dev": true, 1178 | "requires": { 1179 | "once": "^1.3.0", 1180 | "wrappy": "1" 1181 | } 1182 | }, 1183 | "inherits": { 1184 | "version": "2.0.3", 1185 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1186 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1187 | }, 1188 | "ini": { 1189 | "version": "1.3.5", 1190 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 1191 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==" 1192 | }, 1193 | "interpret": { 1194 | "version": "1.2.0", 1195 | "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.2.0.tgz", 1196 | "integrity": "sha512-mT34yGKMNceBQUoVn7iCDKDntA7SC6gycMAWzGx1z/CMCTV7b2AAtXlo3nRyHZ1FelRkQbQjprHSYGwzLtkVbw==" 1197 | }, 1198 | "ipaddr.js": { 1199 | "version": "1.9.0", 1200 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.0.tgz", 1201 | "integrity": "sha512-M4Sjn6N/+O6/IXSJseKqHoFc+5FdGJ22sXqnjTpdZweHK64MzEPAyQZyEU3R/KRv2GLoa7nNtg/C2Ev6m7z+eA==" 1202 | }, 1203 | "is-absolute": { 1204 | "version": "1.0.0", 1205 | "resolved": "https://registry.npmjs.org/is-absolute/-/is-absolute-1.0.0.tgz", 1206 | "integrity": "sha512-dOWoqflvcydARa360Gvv18DZ/gRuHKi2NU/wU5X1ZFzdYfH29nkiNZsF3mp4OJ3H4yo9Mx8A/uAGNzpzPN3yBA==", 1207 | "requires": { 1208 | "is-relative": "^1.0.0", 1209 | "is-windows": "^1.0.1" 1210 | } 1211 | }, 1212 | "is-accessor-descriptor": { 1213 | "version": "0.1.6", 1214 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", 1215 | "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", 1216 | "requires": { 1217 | "kind-of": "^3.0.2" 1218 | }, 1219 | "dependencies": { 1220 | "kind-of": { 1221 | "version": "3.2.2", 1222 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1223 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1224 | "requires": { 1225 | "is-buffer": "^1.1.5" 1226 | } 1227 | } 1228 | } 1229 | }, 1230 | "is-buffer": { 1231 | "version": "1.1.6", 1232 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 1233 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" 1234 | }, 1235 | "is-data-descriptor": { 1236 | "version": "0.1.4", 1237 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", 1238 | "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", 1239 | "requires": { 1240 | "kind-of": "^3.0.2" 1241 | }, 1242 | "dependencies": { 1243 | "kind-of": { 1244 | "version": "3.2.2", 1245 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1246 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1247 | "requires": { 1248 | "is-buffer": "^1.1.5" 1249 | } 1250 | } 1251 | } 1252 | }, 1253 | "is-descriptor": { 1254 | "version": "0.1.6", 1255 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", 1256 | "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", 1257 | "requires": { 1258 | "is-accessor-descriptor": "^0.1.6", 1259 | "is-data-descriptor": "^0.1.4", 1260 | "kind-of": "^5.0.0" 1261 | }, 1262 | "dependencies": { 1263 | "kind-of": { 1264 | "version": "5.1.0", 1265 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", 1266 | "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==" 1267 | } 1268 | } 1269 | }, 1270 | "is-extendable": { 1271 | "version": "0.1.1", 1272 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 1273 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=" 1274 | }, 1275 | "is-extglob": { 1276 | "version": "2.1.1", 1277 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1278 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" 1279 | }, 1280 | "is-glob": { 1281 | "version": "4.0.1", 1282 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1283 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1284 | "requires": { 1285 | "is-extglob": "^2.1.1" 1286 | } 1287 | }, 1288 | "is-number": { 1289 | "version": "3.0.0", 1290 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", 1291 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", 1292 | "requires": { 1293 | "kind-of": "^3.0.2" 1294 | }, 1295 | "dependencies": { 1296 | "kind-of": { 1297 | "version": "3.2.2", 1298 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1299 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1300 | "requires": { 1301 | "is-buffer": "^1.1.5" 1302 | } 1303 | } 1304 | } 1305 | }, 1306 | "is-plain-object": { 1307 | "version": "2.0.4", 1308 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", 1309 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", 1310 | "requires": { 1311 | "isobject": "^3.0.1" 1312 | } 1313 | }, 1314 | "is-promise": { 1315 | "version": "2.1.0", 1316 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1317 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=" 1318 | }, 1319 | "is-relative": { 1320 | "version": "1.0.0", 1321 | "resolved": "https://registry.npmjs.org/is-relative/-/is-relative-1.0.0.tgz", 1322 | "integrity": "sha512-Kw/ReK0iqwKeu0MITLFuj0jbPAmEiOsIwyIXvvbfa6QfmN9pkD1M+8pdk7Rl/dTKbH34/XBFMbgD4iMJhLQbGA==", 1323 | "requires": { 1324 | "is-unc-path": "^1.0.0" 1325 | } 1326 | }, 1327 | "is-unc-path": { 1328 | "version": "1.0.0", 1329 | "resolved": "https://registry.npmjs.org/is-unc-path/-/is-unc-path-1.0.0.tgz", 1330 | "integrity": "sha512-mrGpVd0fs7WWLfVsStvgF6iEJnbjDFZh9/emhRDcGWTduTfNHd9CHeUwH3gYIjdbwo4On6hunkztwOaAw0yllQ==", 1331 | "requires": { 1332 | "unc-path-regex": "^0.1.2" 1333 | } 1334 | }, 1335 | "is-windows": { 1336 | "version": "1.0.2", 1337 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", 1338 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==" 1339 | }, 1340 | "isarray": { 1341 | "version": "0.0.1", 1342 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 1343 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=" 1344 | }, 1345 | "isexe": { 1346 | "version": "2.0.0", 1347 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1348 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 1349 | }, 1350 | "isobject": { 1351 | "version": "3.0.1", 1352 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", 1353 | "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" 1354 | }, 1355 | "iterare": { 1356 | "version": "1.1.2", 1357 | "resolved": "https://registry.npmjs.org/iterare/-/iterare-1.1.2.tgz", 1358 | "integrity": "sha512-25rVYmj/dDvTR6zOa9jY1Ihd6USLa0J508Ub2iy7Aga+xu9JMbjDds2Uh03ReDGbva/YN3s3Ybi+Do0nOX6wAg==" 1359 | }, 1360 | "js-tokens": { 1361 | "version": "4.0.0", 1362 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1363 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1364 | "dev": true 1365 | }, 1366 | "js-yaml": { 1367 | "version": "3.13.1", 1368 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1369 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1370 | "dev": true, 1371 | "requires": { 1372 | "argparse": "^1.0.7", 1373 | "esprima": "^4.0.0" 1374 | } 1375 | }, 1376 | "json-schema-traverse": { 1377 | "version": "0.4.1", 1378 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1379 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==" 1380 | }, 1381 | "kind-of": { 1382 | "version": "6.0.2", 1383 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", 1384 | "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" 1385 | }, 1386 | "knex": { 1387 | "version": "0.17.5", 1388 | "resolved": "https://registry.npmjs.org/knex/-/knex-0.17.5.tgz", 1389 | "integrity": "sha512-2BUau9Mg7vE+Isl2MfRhw+XtusTdAj9K5dSzor4N1yxHMLCfvPLIEY7Gmyq4QIz51cLRBNoQETyygdCE9BOmxw==", 1390 | "requires": { 1391 | "@babel/polyfill": "^7.4.4", 1392 | "@types/bluebird": "^3.5.27", 1393 | "bluebird": "^3.5.5", 1394 | "colorette": "1.0.8", 1395 | "commander": "^2.20.0", 1396 | "debug": "4.1.1", 1397 | "getopts": "2.2.4", 1398 | "inherits": "~2.0.3", 1399 | "interpret": "^1.2.0", 1400 | "liftoff": "3.1.0", 1401 | "lodash": "^4.17.11", 1402 | "mkdirp": "^0.5.1", 1403 | "pg-connection-string": "2.0.0", 1404 | "tarn": "^1.1.5", 1405 | "tildify": "1.2.0", 1406 | "uuid": "^3.3.2", 1407 | "v8flags": "^3.1.3" 1408 | }, 1409 | "dependencies": { 1410 | "debug": { 1411 | "version": "4.1.1", 1412 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 1413 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 1414 | "requires": { 1415 | "ms": "^2.1.1" 1416 | } 1417 | } 1418 | } 1419 | }, 1420 | "liftoff": { 1421 | "version": "3.1.0", 1422 | "resolved": "https://registry.npmjs.org/liftoff/-/liftoff-3.1.0.tgz", 1423 | "integrity": "sha512-DlIPlJUkCV0Ips2zf2pJP0unEoT1kwYhiiPUGF3s/jtxTCjziNLoiVVh+jqWOWeFi6mmwQ5fNxvAUyPad4Dfog==", 1424 | "requires": { 1425 | "extend": "^3.0.0", 1426 | "findup-sync": "^3.0.0", 1427 | "fined": "^1.0.1", 1428 | "flagged-respawn": "^1.0.0", 1429 | "is-plain-object": "^2.0.4", 1430 | "object.map": "^1.0.0", 1431 | "rechoir": "^0.6.2", 1432 | "resolve": "^1.1.7" 1433 | } 1434 | }, 1435 | "lodash": { 1436 | "version": "4.17.11", 1437 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 1438 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" 1439 | }, 1440 | "lru-queue": { 1441 | "version": "0.1.0", 1442 | "resolved": "https://registry.npmjs.org/lru-queue/-/lru-queue-0.1.0.tgz", 1443 | "integrity": "sha1-Jzi9nw089PhEkMVzbEhpmsYyzaM=", 1444 | "requires": { 1445 | "es5-ext": "~0.10.2" 1446 | } 1447 | }, 1448 | "make-error": { 1449 | "version": "1.3.5", 1450 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.5.tgz", 1451 | "integrity": "sha512-c3sIjNUow0+8swNwVpqoH4YCShKNFkMaw6oH1mNS2haDZQqkeZFlHS3dhoeEbKKmJB4vXpJucU6oH75aDYeE9g==", 1452 | "dev": true 1453 | }, 1454 | "make-iterator": { 1455 | "version": "1.0.1", 1456 | "resolved": "https://registry.npmjs.org/make-iterator/-/make-iterator-1.0.1.tgz", 1457 | "integrity": "sha512-pxiuXh0iVEq7VM7KMIhs5gxsfxCux2URptUQaXo4iZZJxBAzTPOLE2BumO5dbfVYq/hBJFBR/a1mFDmOx5AGmw==", 1458 | "requires": { 1459 | "kind-of": "^6.0.2" 1460 | } 1461 | }, 1462 | "map-cache": { 1463 | "version": "0.2.2", 1464 | "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", 1465 | "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=" 1466 | }, 1467 | "map-visit": { 1468 | "version": "1.0.0", 1469 | "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", 1470 | "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", 1471 | "requires": { 1472 | "object-visit": "^1.0.0" 1473 | } 1474 | }, 1475 | "media-typer": { 1476 | "version": "0.3.0", 1477 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1478 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1479 | }, 1480 | "memoizee": { 1481 | "version": "0.4.14", 1482 | "resolved": "https://registry.npmjs.org/memoizee/-/memoizee-0.4.14.tgz", 1483 | "integrity": "sha512-/SWFvWegAIYAO4NQMpcX+gcra0yEZu4OntmUdrBaWrJncxOqAziGFlHxc7yjKVK2uu3lpPW27P27wkR82wA8mg==", 1484 | "requires": { 1485 | "d": "1", 1486 | "es5-ext": "^0.10.45", 1487 | "es6-weak-map": "^2.0.2", 1488 | "event-emitter": "^0.3.5", 1489 | "is-promise": "^2.1", 1490 | "lru-queue": "0.1", 1491 | "next-tick": "1", 1492 | "timers-ext": "^0.1.5" 1493 | } 1494 | }, 1495 | "merge-descriptors": { 1496 | "version": "1.0.1", 1497 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1498 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1499 | }, 1500 | "methods": { 1501 | "version": "1.1.2", 1502 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1503 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1504 | }, 1505 | "micromatch": { 1506 | "version": "3.1.10", 1507 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", 1508 | "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", 1509 | "requires": { 1510 | "arr-diff": "^4.0.0", 1511 | "array-unique": "^0.3.2", 1512 | "braces": "^2.3.1", 1513 | "define-property": "^2.0.2", 1514 | "extend-shallow": "^3.0.2", 1515 | "extglob": "^2.0.4", 1516 | "fragment-cache": "^0.2.1", 1517 | "kind-of": "^6.0.2", 1518 | "nanomatch": "^1.2.9", 1519 | "object.pick": "^1.3.0", 1520 | "regex-not": "^1.0.0", 1521 | "snapdragon": "^0.8.1", 1522 | "to-regex": "^3.0.2" 1523 | } 1524 | }, 1525 | "mime": { 1526 | "version": "1.6.0", 1527 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1528 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 1529 | }, 1530 | "mime-db": { 1531 | "version": "1.40.0", 1532 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", 1533 | "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==" 1534 | }, 1535 | "mime-types": { 1536 | "version": "2.1.24", 1537 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", 1538 | "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", 1539 | "requires": { 1540 | "mime-db": "1.40.0" 1541 | } 1542 | }, 1543 | "minimatch": { 1544 | "version": "3.0.4", 1545 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1546 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1547 | "dev": true, 1548 | "requires": { 1549 | "brace-expansion": "^1.1.7" 1550 | } 1551 | }, 1552 | "minimist": { 1553 | "version": "0.0.8", 1554 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1555 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" 1556 | }, 1557 | "mixin-deep": { 1558 | "version": "1.3.1", 1559 | "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.1.tgz", 1560 | "integrity": "sha512-8ZItLHeEgaqEvd5lYBXfm4EZSFCX29Jb9K+lAHhDKzReKBQKj3R+7NOF6tjqYi9t4oI8VUfaWITJQm86wnXGNQ==", 1561 | "requires": { 1562 | "for-in": "^1.0.2", 1563 | "is-extendable": "^1.0.1" 1564 | }, 1565 | "dependencies": { 1566 | "is-extendable": { 1567 | "version": "1.0.1", 1568 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", 1569 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", 1570 | "requires": { 1571 | "is-plain-object": "^2.0.4" 1572 | } 1573 | } 1574 | } 1575 | }, 1576 | "mkdirp": { 1577 | "version": "0.5.1", 1578 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1579 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1580 | "requires": { 1581 | "minimist": "0.0.8" 1582 | } 1583 | }, 1584 | "ms": { 1585 | "version": "2.1.2", 1586 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1587 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1588 | }, 1589 | "multer": { 1590 | "version": "1.4.1", 1591 | "resolved": "https://registry.npmjs.org/multer/-/multer-1.4.1.tgz", 1592 | "integrity": "sha512-zzOLNRxzszwd+61JFuAo0fxdQfvku12aNJgnla0AQ+hHxFmfc/B7jBVuPr5Rmvu46Jze/iJrFpSOsD7afO8SDw==", 1593 | "requires": { 1594 | "append-field": "^1.0.0", 1595 | "busboy": "^0.2.11", 1596 | "concat-stream": "^1.5.2", 1597 | "mkdirp": "^0.5.1", 1598 | "object-assign": "^4.1.1", 1599 | "on-finished": "^2.3.0", 1600 | "type-is": "^1.6.4", 1601 | "xtend": "^4.0.0" 1602 | } 1603 | }, 1604 | "nanomatch": { 1605 | "version": "1.2.13", 1606 | "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", 1607 | "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", 1608 | "requires": { 1609 | "arr-diff": "^4.0.0", 1610 | "array-unique": "^0.3.2", 1611 | "define-property": "^2.0.2", 1612 | "extend-shallow": "^3.0.2", 1613 | "fragment-cache": "^0.2.1", 1614 | "is-windows": "^1.0.2", 1615 | "kind-of": "^6.0.2", 1616 | "object.pick": "^1.3.0", 1617 | "regex-not": "^1.0.0", 1618 | "snapdragon": "^0.8.1", 1619 | "to-regex": "^3.0.1" 1620 | } 1621 | }, 1622 | "negotiator": { 1623 | "version": "0.6.2", 1624 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 1625 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 1626 | }, 1627 | "next-tick": { 1628 | "version": "1.0.0", 1629 | "resolved": "https://registry.npmjs.org/next-tick/-/next-tick-1.0.0.tgz", 1630 | "integrity": "sha1-yobR/ogoFpsBICCOPchCS524NCw=" 1631 | }, 1632 | "node-fetch": { 1633 | "version": "2.6.0", 1634 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.0.tgz", 1635 | "integrity": "sha512-8dG4H5ujfvFiqDmVu9fQ5bOHUC15JMjMY/Zumv26oOvvVJjM67KF8koCWIabKQ1GJIa9r2mMZscBq/TbdOcmNA==" 1636 | }, 1637 | "object-assign": { 1638 | "version": "4.1.1", 1639 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1640 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1641 | }, 1642 | "object-copy": { 1643 | "version": "0.1.0", 1644 | "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", 1645 | "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", 1646 | "requires": { 1647 | "copy-descriptor": "^0.1.0", 1648 | "define-property": "^0.2.5", 1649 | "kind-of": "^3.0.3" 1650 | }, 1651 | "dependencies": { 1652 | "define-property": { 1653 | "version": "0.2.5", 1654 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 1655 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 1656 | "requires": { 1657 | "is-descriptor": "^0.1.0" 1658 | } 1659 | }, 1660 | "kind-of": { 1661 | "version": "3.2.2", 1662 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1663 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1664 | "requires": { 1665 | "is-buffer": "^1.1.5" 1666 | } 1667 | } 1668 | } 1669 | }, 1670 | "object-hash": { 1671 | "version": "1.3.1", 1672 | "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-1.3.1.tgz", 1673 | "integrity": "sha512-OSuu/pU4ENM9kmREg0BdNrUDIl1heYa4mBZacJc+vVWz4GtAwu7jO8s4AIt2aGRUTqxykpWzI3Oqnsm13tTMDA==" 1674 | }, 1675 | "object-visit": { 1676 | "version": "1.0.1", 1677 | "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", 1678 | "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", 1679 | "requires": { 1680 | "isobject": "^3.0.0" 1681 | } 1682 | }, 1683 | "object.defaults": { 1684 | "version": "1.1.0", 1685 | "resolved": "https://registry.npmjs.org/object.defaults/-/object.defaults-1.1.0.tgz", 1686 | "integrity": "sha1-On+GgzS0B96gbaFtiNXNKeQ1/s8=", 1687 | "requires": { 1688 | "array-each": "^1.0.1", 1689 | "array-slice": "^1.0.0", 1690 | "for-own": "^1.0.0", 1691 | "isobject": "^3.0.0" 1692 | } 1693 | }, 1694 | "object.map": { 1695 | "version": "1.0.1", 1696 | "resolved": "https://registry.npmjs.org/object.map/-/object.map-1.0.1.tgz", 1697 | "integrity": "sha1-z4Plncj8wK1fQlDh94s7gb2AHTc=", 1698 | "requires": { 1699 | "for-own": "^1.0.0", 1700 | "make-iterator": "^1.0.0" 1701 | } 1702 | }, 1703 | "object.pick": { 1704 | "version": "1.3.0", 1705 | "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", 1706 | "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", 1707 | "requires": { 1708 | "isobject": "^3.0.1" 1709 | } 1710 | }, 1711 | "objection": { 1712 | "version": "1.6.9", 1713 | "resolved": "https://registry.npmjs.org/objection/-/objection-1.6.9.tgz", 1714 | "integrity": "sha512-4mp2f34Fn+gCOXO5e9YEWbcnAfvFPF3Rd2NAyQWU6CkZQObqm1mFDw8tYZySpkvibnDg6DPMiprUm82yGy6fgQ==", 1715 | "requires": { 1716 | "ajv": "^6.1.1", 1717 | "bluebird": "^3.5.3", 1718 | "lodash": "^4.17.11" 1719 | } 1720 | }, 1721 | "on-finished": { 1722 | "version": "2.3.0", 1723 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1724 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1725 | "requires": { 1726 | "ee-first": "1.1.1" 1727 | } 1728 | }, 1729 | "once": { 1730 | "version": "1.4.0", 1731 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1732 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1733 | "dev": true, 1734 | "requires": { 1735 | "wrappy": "1" 1736 | } 1737 | }, 1738 | "optional": { 1739 | "version": "0.1.4", 1740 | "resolved": "https://registry.npmjs.org/optional/-/optional-0.1.4.tgz", 1741 | "integrity": "sha512-gtvrrCfkE08wKcgXaVwQVgwEQ8vel2dc5DDBn9RLQZ3YtmtkBss6A2HY6BnJH4N/4Ku97Ri/SF8sNWE2225WJw==" 1742 | }, 1743 | "os-homedir": { 1744 | "version": "1.0.2", 1745 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1746 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" 1747 | }, 1748 | "packet-reader": { 1749 | "version": "1.0.0", 1750 | "resolved": "https://registry.npmjs.org/packet-reader/-/packet-reader-1.0.0.tgz", 1751 | "integrity": "sha512-HAKu/fG3HpHFO0AA8WE8q2g+gBJaZ9MG7fcKk+IJPLTGAD6Psw4443l+9DGRbOIh3/aXr7Phy0TjilYivJo5XQ==" 1752 | }, 1753 | "parse-filepath": { 1754 | "version": "1.0.2", 1755 | "resolved": "https://registry.npmjs.org/parse-filepath/-/parse-filepath-1.0.2.tgz", 1756 | "integrity": "sha1-pjISf1Oq89FYdvWHLz/6x2PWyJE=", 1757 | "requires": { 1758 | "is-absolute": "^1.0.0", 1759 | "map-cache": "^0.2.0", 1760 | "path-root": "^0.1.1" 1761 | } 1762 | }, 1763 | "parse-passwd": { 1764 | "version": "1.0.0", 1765 | "resolved": "https://registry.npmjs.org/parse-passwd/-/parse-passwd-1.0.0.tgz", 1766 | "integrity": "sha1-bVuTSkVpk7I9N/QKOC1vFmao5cY=" 1767 | }, 1768 | "parseurl": { 1769 | "version": "1.3.3", 1770 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1771 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 1772 | }, 1773 | "pascalcase": { 1774 | "version": "0.1.1", 1775 | "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", 1776 | "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=" 1777 | }, 1778 | "path-is-absolute": { 1779 | "version": "1.0.1", 1780 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1781 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1782 | "dev": true 1783 | }, 1784 | "path-parse": { 1785 | "version": "1.0.6", 1786 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1787 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" 1788 | }, 1789 | "path-root": { 1790 | "version": "0.1.1", 1791 | "resolved": "https://registry.npmjs.org/path-root/-/path-root-0.1.1.tgz", 1792 | "integrity": "sha1-mkpoFMrBwM1zNgqV8yCDyOpHRbc=", 1793 | "requires": { 1794 | "path-root-regex": "^0.1.0" 1795 | } 1796 | }, 1797 | "path-root-regex": { 1798 | "version": "0.1.2", 1799 | "resolved": "https://registry.npmjs.org/path-root-regex/-/path-root-regex-0.1.2.tgz", 1800 | "integrity": "sha1-v8zcjfWxLcUsi0PsONGNcsBLqW0=" 1801 | }, 1802 | "path-to-regexp": { 1803 | "version": "0.1.7", 1804 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1805 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1806 | }, 1807 | "pg": { 1808 | "version": "7.11.0", 1809 | "resolved": "https://registry.npmjs.org/pg/-/pg-7.11.0.tgz", 1810 | "integrity": "sha512-YO4V7vCmEMGoF390LJaFaohWNKaA2ayoQOEZmiHVcAUF+YsRThpf/TaKCgSvsSE7cDm37Q/Cy3Gz41xiX/XjTw==", 1811 | "requires": { 1812 | "buffer-writer": "2.0.0", 1813 | "packet-reader": "1.0.0", 1814 | "pg-connection-string": "0.1.3", 1815 | "pg-pool": "^2.0.4", 1816 | "pg-types": "~2.0.0", 1817 | "pgpass": "1.x", 1818 | "semver": "4.3.2" 1819 | }, 1820 | "dependencies": { 1821 | "pg-connection-string": { 1822 | "version": "0.1.3", 1823 | "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-0.1.3.tgz", 1824 | "integrity": "sha1-2hhHsglA5C7hSSvq9l1J2RskXfc=" 1825 | } 1826 | } 1827 | }, 1828 | "pg-connection-string": { 1829 | "version": "2.0.0", 1830 | "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-2.0.0.tgz", 1831 | "integrity": "sha1-Pu/lmX4G2Ugh5NUC5CtqHHP434I=" 1832 | }, 1833 | "pg-int8": { 1834 | "version": "1.0.1", 1835 | "resolved": "https://registry.npmjs.org/pg-int8/-/pg-int8-1.0.1.tgz", 1836 | "integrity": "sha512-WCtabS6t3c8SkpDBUlb1kjOs7l66xsGdKpIPZsg4wR+B3+u9UAum2odSsF9tnvxg80h4ZxLWMy4pRjOsFIqQpw==" 1837 | }, 1838 | "pg-pool": { 1839 | "version": "2.0.6", 1840 | "resolved": "https://registry.npmjs.org/pg-pool/-/pg-pool-2.0.6.tgz", 1841 | "integrity": "sha512-hod2zYQxM8Gt482q+qONGTYcg/qVcV32VHVPtktbBJs0us3Dj7xibISw0BAAXVMCzt8A/jhfJvpZaxUlqtqs0g==" 1842 | }, 1843 | "pg-types": { 1844 | "version": "2.0.1", 1845 | "resolved": "https://registry.npmjs.org/pg-types/-/pg-types-2.0.1.tgz", 1846 | "integrity": "sha512-b7y6QM1VF5nOeX9ukMQ0h8a9z89mojrBHXfJeSug4mhL0YpxNBm83ot2TROyoAmX/ZOX3UbwVO4EbH7i1ZZNiw==", 1847 | "requires": { 1848 | "pg-int8": "1.0.1", 1849 | "postgres-array": "~2.0.0", 1850 | "postgres-bytea": "~1.0.0", 1851 | "postgres-date": "~1.0.4", 1852 | "postgres-interval": "^1.1.0" 1853 | } 1854 | }, 1855 | "pgpass": { 1856 | "version": "1.0.2", 1857 | "resolved": "https://registry.npmjs.org/pgpass/-/pgpass-1.0.2.tgz", 1858 | "integrity": "sha1-Knu0G2BltnkH6R2hsHwYR8h3swY=", 1859 | "requires": { 1860 | "split": "^1.0.0" 1861 | } 1862 | }, 1863 | "posix-character-classes": { 1864 | "version": "0.1.1", 1865 | "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", 1866 | "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=" 1867 | }, 1868 | "postgres-array": { 1869 | "version": "2.0.0", 1870 | "resolved": "https://registry.npmjs.org/postgres-array/-/postgres-array-2.0.0.tgz", 1871 | "integrity": "sha512-VpZrUqU5A69eQyW2c5CA1jtLecCsN2U/bD6VilrFDWq5+5UIEVO7nazS3TEcHf1zuPYO/sqGvUvW62g86RXZuA==" 1872 | }, 1873 | "postgres-bytea": { 1874 | "version": "1.0.0", 1875 | "resolved": "https://registry.npmjs.org/postgres-bytea/-/postgres-bytea-1.0.0.tgz", 1876 | "integrity": "sha1-AntTPAqokOJtFy1Hz5zOzFIazTU=" 1877 | }, 1878 | "postgres-date": { 1879 | "version": "1.0.4", 1880 | "resolved": "https://registry.npmjs.org/postgres-date/-/postgres-date-1.0.4.tgz", 1881 | "integrity": "sha512-bESRvKVuTrjoBluEcpv2346+6kgB7UlnqWZsnbnCccTNq/pqfj1j6oBaN5+b/NrDXepYUT/HKadqv3iS9lJuVA==" 1882 | }, 1883 | "postgres-interval": { 1884 | "version": "1.2.0", 1885 | "resolved": "https://registry.npmjs.org/postgres-interval/-/postgres-interval-1.2.0.tgz", 1886 | "integrity": "sha512-9ZhXKM/rw350N1ovuWHbGxnGh/SNJ4cnxHiM0rxE4VN41wsg8P8zWn9hv/buK00RP4WvlOyr/RBDiptyxVbkZQ==", 1887 | "requires": { 1888 | "xtend": "^4.0.0" 1889 | } 1890 | }, 1891 | "process-nextick-args": { 1892 | "version": "2.0.0", 1893 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 1894 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==" 1895 | }, 1896 | "proxy-addr": { 1897 | "version": "2.0.5", 1898 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.5.tgz", 1899 | "integrity": "sha512-t/7RxHXPH6cJtP0pRG6smSr9QJidhB+3kXu0KgXnbGYMgzEnUxRQ4/LDdfOwZEMyIh3/xHb8PX3t+lfL9z+YVQ==", 1900 | "requires": { 1901 | "forwarded": "~0.1.2", 1902 | "ipaddr.js": "1.9.0" 1903 | } 1904 | }, 1905 | "punycode": { 1906 | "version": "2.1.1", 1907 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1908 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" 1909 | }, 1910 | "qs": { 1911 | "version": "6.7.0", 1912 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 1913 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 1914 | }, 1915 | "range-parser": { 1916 | "version": "1.2.1", 1917 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1918 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 1919 | }, 1920 | "raw-body": { 1921 | "version": "2.4.0", 1922 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 1923 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 1924 | "requires": { 1925 | "bytes": "3.1.0", 1926 | "http-errors": "1.7.2", 1927 | "iconv-lite": "0.4.24", 1928 | "unpipe": "1.0.0" 1929 | } 1930 | }, 1931 | "readable-stream": { 1932 | "version": "1.1.14", 1933 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", 1934 | "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", 1935 | "requires": { 1936 | "core-util-is": "~1.0.0", 1937 | "inherits": "~2.0.1", 1938 | "isarray": "0.0.1", 1939 | "string_decoder": "~0.10.x" 1940 | } 1941 | }, 1942 | "rechoir": { 1943 | "version": "0.6.2", 1944 | "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.6.2.tgz", 1945 | "integrity": "sha1-hSBLVNuoLVdC4oyWdW70OvUOM4Q=", 1946 | "requires": { 1947 | "resolve": "^1.1.6" 1948 | } 1949 | }, 1950 | "reflect-metadata": { 1951 | "version": "0.1.13", 1952 | "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz", 1953 | "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" 1954 | }, 1955 | "regenerator-runtime": { 1956 | "version": "0.13.2", 1957 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.2.tgz", 1958 | "integrity": "sha512-S/TQAZJO+D3m9xeN1WTI8dLKBBiRgXBlTJvbWjCThHWZj9EvHK70Ff50/tYj2J/fvBY6JtFVwRuazHN2E7M9BA==" 1959 | }, 1960 | "regex-not": { 1961 | "version": "1.0.2", 1962 | "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", 1963 | "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", 1964 | "requires": { 1965 | "extend-shallow": "^3.0.2", 1966 | "safe-regex": "^1.1.0" 1967 | } 1968 | }, 1969 | "repeat-element": { 1970 | "version": "1.1.3", 1971 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz", 1972 | "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==" 1973 | }, 1974 | "repeat-string": { 1975 | "version": "1.6.1", 1976 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 1977 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=" 1978 | }, 1979 | "resolve": { 1980 | "version": "1.11.1", 1981 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.11.1.tgz", 1982 | "integrity": "sha512-vIpgF6wfuJOZI7KKKSP+HmiKggadPQAdsp5HiC1mvqnfp0gF1vdwgBWZIdrVft9pgqoMFQN+R7BSWZiBxx+BBw==", 1983 | "requires": { 1984 | "path-parse": "^1.0.6" 1985 | } 1986 | }, 1987 | "resolve-dir": { 1988 | "version": "1.0.1", 1989 | "resolved": "https://registry.npmjs.org/resolve-dir/-/resolve-dir-1.0.1.tgz", 1990 | "integrity": "sha1-eaQGRMNivoLybv/nOcm7U4IEb0M=", 1991 | "requires": { 1992 | "expand-tilde": "^2.0.0", 1993 | "global-modules": "^1.0.0" 1994 | } 1995 | }, 1996 | "resolve-url": { 1997 | "version": "0.2.1", 1998 | "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", 1999 | "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=" 2000 | }, 2001 | "ret": { 2002 | "version": "0.1.15", 2003 | "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", 2004 | "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==" 2005 | }, 2006 | "rxjs": { 2007 | "version": "6.5.2", 2008 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.2.tgz", 2009 | "integrity": "sha512-HUb7j3kvb7p7eCUHE3FqjoDsC1xfZQ4AHFWfTKSpZ+sAhhz5X1WX0ZuUqWbzB2QhSLp3DoLUG+hMdEDKqWo2Zg==", 2010 | "requires": { 2011 | "tslib": "^1.9.0" 2012 | } 2013 | }, 2014 | "safe-buffer": { 2015 | "version": "5.1.2", 2016 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2017 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2018 | }, 2019 | "safe-regex": { 2020 | "version": "1.1.0", 2021 | "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", 2022 | "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", 2023 | "requires": { 2024 | "ret": "~0.1.10" 2025 | } 2026 | }, 2027 | "safer-buffer": { 2028 | "version": "2.1.2", 2029 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2030 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2031 | }, 2032 | "semver": { 2033 | "version": "4.3.2", 2034 | "resolved": "https://registry.npmjs.org/semver/-/semver-4.3.2.tgz", 2035 | "integrity": "sha1-x6BxWKgL7dBSNVt3DYLWZA+AO+c=" 2036 | }, 2037 | "send": { 2038 | "version": "0.17.1", 2039 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 2040 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 2041 | "requires": { 2042 | "debug": "2.6.9", 2043 | "depd": "~1.1.2", 2044 | "destroy": "~1.0.4", 2045 | "encodeurl": "~1.0.2", 2046 | "escape-html": "~1.0.3", 2047 | "etag": "~1.8.1", 2048 | "fresh": "0.5.2", 2049 | "http-errors": "~1.7.2", 2050 | "mime": "1.6.0", 2051 | "ms": "2.1.1", 2052 | "on-finished": "~2.3.0", 2053 | "range-parser": "~1.2.1", 2054 | "statuses": "~1.5.0" 2055 | }, 2056 | "dependencies": { 2057 | "debug": { 2058 | "version": "2.6.9", 2059 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2060 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2061 | "requires": { 2062 | "ms": "2.0.0" 2063 | }, 2064 | "dependencies": { 2065 | "ms": { 2066 | "version": "2.0.0", 2067 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2068 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2069 | } 2070 | } 2071 | }, 2072 | "ms": { 2073 | "version": "2.1.1", 2074 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 2075 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 2076 | } 2077 | } 2078 | }, 2079 | "serve-static": { 2080 | "version": "1.14.1", 2081 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 2082 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 2083 | "requires": { 2084 | "encodeurl": "~1.0.2", 2085 | "escape-html": "~1.0.3", 2086 | "parseurl": "~1.3.3", 2087 | "send": "0.17.1" 2088 | } 2089 | }, 2090 | "set-value": { 2091 | "version": "2.0.0", 2092 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.0.tgz", 2093 | "integrity": "sha512-hw0yxk9GT/Hr5yJEYnHNKYXkIA8mVJgd9ditYZCe16ZczcaELYYcfvaXesNACk2O8O0nTiPQcQhGUQj8JLzeeg==", 2094 | "requires": { 2095 | "extend-shallow": "^2.0.1", 2096 | "is-extendable": "^0.1.1", 2097 | "is-plain-object": "^2.0.3", 2098 | "split-string": "^3.0.1" 2099 | }, 2100 | "dependencies": { 2101 | "extend-shallow": { 2102 | "version": "2.0.1", 2103 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2104 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2105 | "requires": { 2106 | "is-extendable": "^0.1.0" 2107 | } 2108 | } 2109 | } 2110 | }, 2111 | "setprototypeof": { 2112 | "version": "1.1.1", 2113 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 2114 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 2115 | }, 2116 | "snapdragon": { 2117 | "version": "0.8.2", 2118 | "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", 2119 | "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", 2120 | "requires": { 2121 | "base": "^0.11.1", 2122 | "debug": "^2.2.0", 2123 | "define-property": "^0.2.5", 2124 | "extend-shallow": "^2.0.1", 2125 | "map-cache": "^0.2.2", 2126 | "source-map": "^0.5.6", 2127 | "source-map-resolve": "^0.5.0", 2128 | "use": "^3.1.0" 2129 | }, 2130 | "dependencies": { 2131 | "debug": { 2132 | "version": "2.6.9", 2133 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2134 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2135 | "requires": { 2136 | "ms": "2.0.0" 2137 | } 2138 | }, 2139 | "define-property": { 2140 | "version": "0.2.5", 2141 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 2142 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 2143 | "requires": { 2144 | "is-descriptor": "^0.1.0" 2145 | } 2146 | }, 2147 | "extend-shallow": { 2148 | "version": "2.0.1", 2149 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2150 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2151 | "requires": { 2152 | "is-extendable": "^0.1.0" 2153 | } 2154 | }, 2155 | "ms": { 2156 | "version": "2.0.0", 2157 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2158 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2159 | } 2160 | } 2161 | }, 2162 | "snapdragon-node": { 2163 | "version": "2.1.1", 2164 | "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", 2165 | "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", 2166 | "requires": { 2167 | "define-property": "^1.0.0", 2168 | "isobject": "^3.0.0", 2169 | "snapdragon-util": "^3.0.1" 2170 | }, 2171 | "dependencies": { 2172 | "define-property": { 2173 | "version": "1.0.0", 2174 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 2175 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 2176 | "requires": { 2177 | "is-descriptor": "^1.0.0" 2178 | } 2179 | }, 2180 | "is-accessor-descriptor": { 2181 | "version": "1.0.0", 2182 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 2183 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 2184 | "requires": { 2185 | "kind-of": "^6.0.0" 2186 | } 2187 | }, 2188 | "is-data-descriptor": { 2189 | "version": "1.0.0", 2190 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 2191 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 2192 | "requires": { 2193 | "kind-of": "^6.0.0" 2194 | } 2195 | }, 2196 | "is-descriptor": { 2197 | "version": "1.0.2", 2198 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 2199 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 2200 | "requires": { 2201 | "is-accessor-descriptor": "^1.0.0", 2202 | "is-data-descriptor": "^1.0.0", 2203 | "kind-of": "^6.0.2" 2204 | } 2205 | } 2206 | } 2207 | }, 2208 | "snapdragon-util": { 2209 | "version": "3.0.1", 2210 | "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", 2211 | "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", 2212 | "requires": { 2213 | "kind-of": "^3.2.0" 2214 | }, 2215 | "dependencies": { 2216 | "kind-of": { 2217 | "version": "3.2.2", 2218 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2219 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2220 | "requires": { 2221 | "is-buffer": "^1.1.5" 2222 | } 2223 | } 2224 | } 2225 | }, 2226 | "source-map": { 2227 | "version": "0.5.7", 2228 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2229 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" 2230 | }, 2231 | "source-map-resolve": { 2232 | "version": "0.5.2", 2233 | "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.2.tgz", 2234 | "integrity": "sha512-MjqsvNwyz1s0k81Goz/9vRBe9SZdB09Bdw+/zYyO+3CuPk6fouTaxscHkgtE8jKvf01kVfl8riHzERQ/kefaSA==", 2235 | "requires": { 2236 | "atob": "^2.1.1", 2237 | "decode-uri-component": "^0.2.0", 2238 | "resolve-url": "^0.2.1", 2239 | "source-map-url": "^0.4.0", 2240 | "urix": "^0.1.0" 2241 | } 2242 | }, 2243 | "source-map-support": { 2244 | "version": "0.5.12", 2245 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.12.tgz", 2246 | "integrity": "sha512-4h2Pbvyy15EE02G+JOZpUCmqWJuqrs+sEkzewTm++BPi7Hvn/HwcqLAcNxYAyI0x13CpPPn+kMjl+hplXMHITQ==", 2247 | "dev": true, 2248 | "requires": { 2249 | "buffer-from": "^1.0.0", 2250 | "source-map": "^0.6.0" 2251 | }, 2252 | "dependencies": { 2253 | "source-map": { 2254 | "version": "0.6.1", 2255 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2256 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2257 | "dev": true 2258 | } 2259 | } 2260 | }, 2261 | "source-map-url": { 2262 | "version": "0.4.0", 2263 | "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz", 2264 | "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=" 2265 | }, 2266 | "split": { 2267 | "version": "1.0.1", 2268 | "resolved": "https://registry.npmjs.org/split/-/split-1.0.1.tgz", 2269 | "integrity": "sha512-mTyOoPbrivtXnwnIxZRFYRrPNtEFKlpB2fvjSnCQUiAA6qAZzqwna5envK4uk6OIeP17CsdF3rSBGYVBsU0Tkg==", 2270 | "requires": { 2271 | "through": "2" 2272 | } 2273 | }, 2274 | "split-string": { 2275 | "version": "3.1.0", 2276 | "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", 2277 | "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", 2278 | "requires": { 2279 | "extend-shallow": "^3.0.0" 2280 | } 2281 | }, 2282 | "sprintf-js": { 2283 | "version": "1.0.3", 2284 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2285 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2286 | "dev": true 2287 | }, 2288 | "static-extend": { 2289 | "version": "0.1.2", 2290 | "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", 2291 | "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", 2292 | "requires": { 2293 | "define-property": "^0.2.5", 2294 | "object-copy": "^0.1.0" 2295 | }, 2296 | "dependencies": { 2297 | "define-property": { 2298 | "version": "0.2.5", 2299 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 2300 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 2301 | "requires": { 2302 | "is-descriptor": "^0.1.0" 2303 | } 2304 | } 2305 | } 2306 | }, 2307 | "statuses": { 2308 | "version": "1.5.0", 2309 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 2310 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 2311 | }, 2312 | "streamsearch": { 2313 | "version": "0.1.2", 2314 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-0.1.2.tgz", 2315 | "integrity": "sha1-gIudDlb8Jz2Am6VzOOkpkZoanxo=" 2316 | }, 2317 | "string_decoder": { 2318 | "version": "0.10.31", 2319 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 2320 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=" 2321 | }, 2322 | "supports-color": { 2323 | "version": "5.5.0", 2324 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2325 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2326 | "requires": { 2327 | "has-flag": "^3.0.0" 2328 | } 2329 | }, 2330 | "tarn": { 2331 | "version": "1.1.5", 2332 | "resolved": "https://registry.npmjs.org/tarn/-/tarn-1.1.5.tgz", 2333 | "integrity": "sha512-PMtJ3HCLAZeedWjJPgGnCvcphbCOMbtZpjKgLq3qM5Qq9aQud+XHrL0WlrlgnTyS8U+jrjGbEXprFcQrxPy52g==" 2334 | }, 2335 | "through": { 2336 | "version": "2.3.8", 2337 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2338 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" 2339 | }, 2340 | "tildify": { 2341 | "version": "1.2.0", 2342 | "resolved": "https://registry.npmjs.org/tildify/-/tildify-1.2.0.tgz", 2343 | "integrity": "sha1-3OwD9V3Km3qj5bBPIYF+tW5jWIo=", 2344 | "requires": { 2345 | "os-homedir": "^1.0.0" 2346 | } 2347 | }, 2348 | "timers-ext": { 2349 | "version": "0.1.7", 2350 | "resolved": "https://registry.npmjs.org/timers-ext/-/timers-ext-0.1.7.tgz", 2351 | "integrity": "sha512-b85NUNzTSdodShTIbky6ZF02e8STtVVfD+fu4aXXShEELpozH+bCpJLYMPZbsABN2wDH7fJpqIoXxJpzbf0NqQ==", 2352 | "requires": { 2353 | "es5-ext": "~0.10.46", 2354 | "next-tick": "1" 2355 | } 2356 | }, 2357 | "to-object-path": { 2358 | "version": "0.3.0", 2359 | "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", 2360 | "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", 2361 | "requires": { 2362 | "kind-of": "^3.0.2" 2363 | }, 2364 | "dependencies": { 2365 | "kind-of": { 2366 | "version": "3.2.2", 2367 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2368 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2369 | "requires": { 2370 | "is-buffer": "^1.1.5" 2371 | } 2372 | } 2373 | } 2374 | }, 2375 | "to-regex": { 2376 | "version": "3.0.2", 2377 | "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", 2378 | "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", 2379 | "requires": { 2380 | "define-property": "^2.0.2", 2381 | "extend-shallow": "^3.0.2", 2382 | "regex-not": "^1.0.2", 2383 | "safe-regex": "^1.1.0" 2384 | } 2385 | }, 2386 | "to-regex-range": { 2387 | "version": "2.1.1", 2388 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", 2389 | "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", 2390 | "requires": { 2391 | "is-number": "^3.0.0", 2392 | "repeat-string": "^1.6.1" 2393 | } 2394 | }, 2395 | "toidentifier": { 2396 | "version": "1.0.0", 2397 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 2398 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 2399 | }, 2400 | "ts-node": { 2401 | "version": "8.2.0", 2402 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-8.2.0.tgz", 2403 | "integrity": "sha512-m8XQwUurkbYqXrKqr3WHCW310utRNvV5OnRVeISeea7LoCWVcdfeB/Ntl8JYWFh+WRoUAdBgESrzKochQt7sMw==", 2404 | "dev": true, 2405 | "requires": { 2406 | "arg": "^4.1.0", 2407 | "diff": "^4.0.1", 2408 | "make-error": "^1.1.1", 2409 | "source-map-support": "^0.5.6", 2410 | "yn": "^3.0.0" 2411 | } 2412 | }, 2413 | "tslib": { 2414 | "version": "1.9.3", 2415 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz", 2416 | "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==" 2417 | }, 2418 | "tslint": { 2419 | "version": "5.16.0", 2420 | "resolved": "https://registry.npmjs.org/tslint/-/tslint-5.16.0.tgz", 2421 | "integrity": "sha512-UxG2yNxJ5pgGwmMzPMYh/CCnCnh0HfPgtlVRDs1ykZklufFBL1ZoTlWFRz2NQjcoEiDoRp+JyT0lhBbbH/obyA==", 2422 | "dev": true, 2423 | "requires": { 2424 | "@babel/code-frame": "^7.0.0", 2425 | "builtin-modules": "^1.1.1", 2426 | "chalk": "^2.3.0", 2427 | "commander": "^2.12.1", 2428 | "diff": "^3.2.0", 2429 | "glob": "^7.1.1", 2430 | "js-yaml": "^3.13.0", 2431 | "minimatch": "^3.0.4", 2432 | "mkdirp": "^0.5.1", 2433 | "resolve": "^1.3.2", 2434 | "semver": "^5.3.0", 2435 | "tslib": "^1.8.0", 2436 | "tsutils": "^2.29.0" 2437 | }, 2438 | "dependencies": { 2439 | "diff": { 2440 | "version": "3.5.0", 2441 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 2442 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 2443 | "dev": true 2444 | }, 2445 | "semver": { 2446 | "version": "5.7.0", 2447 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz", 2448 | "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==", 2449 | "dev": true 2450 | } 2451 | } 2452 | }, 2453 | "tsutils": { 2454 | "version": "2.29.0", 2455 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-2.29.0.tgz", 2456 | "integrity": "sha512-g5JVHCIJwzfISaXpXE1qvNalca5Jwob6FjI4AoPlqMusJ6ftFE7IkkFoMhVLRgK+4Kx3gkzb8UZK5t5yTTvEmA==", 2457 | "dev": true, 2458 | "requires": { 2459 | "tslib": "^1.8.1" 2460 | } 2461 | }, 2462 | "type-is": { 2463 | "version": "1.6.18", 2464 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2465 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2466 | "requires": { 2467 | "media-typer": "0.3.0", 2468 | "mime-types": "~2.1.24" 2469 | } 2470 | }, 2471 | "typedarray": { 2472 | "version": "0.0.6", 2473 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 2474 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=" 2475 | }, 2476 | "typescript": { 2477 | "version": "3.5.1", 2478 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.5.1.tgz", 2479 | "integrity": "sha512-64HkdiRv1yYZsSe4xC1WVgamNigVYjlssIoaH2HcZF0+ijsk5YK2g0G34w9wJkze8+5ow4STd22AynfO6ZYYLw==" 2480 | }, 2481 | "unc-path-regex": { 2482 | "version": "0.1.2", 2483 | "resolved": "https://registry.npmjs.org/unc-path-regex/-/unc-path-regex-0.1.2.tgz", 2484 | "integrity": "sha1-5z3T17DXxe2G+6xrCufYxqadUPo=" 2485 | }, 2486 | "union-value": { 2487 | "version": "1.0.0", 2488 | "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.0.tgz", 2489 | "integrity": "sha1-XHHDTLW61dzr4+oM0IIHulqhrqQ=", 2490 | "requires": { 2491 | "arr-union": "^3.1.0", 2492 | "get-value": "^2.0.6", 2493 | "is-extendable": "^0.1.1", 2494 | "set-value": "^0.4.3" 2495 | }, 2496 | "dependencies": { 2497 | "extend-shallow": { 2498 | "version": "2.0.1", 2499 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2500 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2501 | "requires": { 2502 | "is-extendable": "^0.1.0" 2503 | } 2504 | }, 2505 | "set-value": { 2506 | "version": "0.4.3", 2507 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-0.4.3.tgz", 2508 | "integrity": "sha1-fbCPnT0i3H945Trzw79GZuzfzPE=", 2509 | "requires": { 2510 | "extend-shallow": "^2.0.1", 2511 | "is-extendable": "^0.1.1", 2512 | "is-plain-object": "^2.0.1", 2513 | "to-object-path": "^0.3.0" 2514 | } 2515 | } 2516 | } 2517 | }, 2518 | "unpipe": { 2519 | "version": "1.0.0", 2520 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2521 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 2522 | }, 2523 | "unset-value": { 2524 | "version": "1.0.0", 2525 | "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", 2526 | "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", 2527 | "requires": { 2528 | "has-value": "^0.3.1", 2529 | "isobject": "^3.0.0" 2530 | }, 2531 | "dependencies": { 2532 | "has-value": { 2533 | "version": "0.3.1", 2534 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", 2535 | "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", 2536 | "requires": { 2537 | "get-value": "^2.0.3", 2538 | "has-values": "^0.1.4", 2539 | "isobject": "^2.0.0" 2540 | }, 2541 | "dependencies": { 2542 | "isobject": { 2543 | "version": "2.1.0", 2544 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 2545 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 2546 | "requires": { 2547 | "isarray": "1.0.0" 2548 | } 2549 | } 2550 | } 2551 | }, 2552 | "has-values": { 2553 | "version": "0.1.4", 2554 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", 2555 | "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=" 2556 | }, 2557 | "isarray": { 2558 | "version": "1.0.0", 2559 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2560 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 2561 | } 2562 | } 2563 | }, 2564 | "uri-js": { 2565 | "version": "4.2.2", 2566 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2567 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2568 | "requires": { 2569 | "punycode": "^2.1.0" 2570 | } 2571 | }, 2572 | "urix": { 2573 | "version": "0.1.0", 2574 | "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", 2575 | "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=" 2576 | }, 2577 | "use": { 2578 | "version": "3.1.1", 2579 | "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", 2580 | "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==" 2581 | }, 2582 | "util-deprecate": { 2583 | "version": "1.0.2", 2584 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2585 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 2586 | }, 2587 | "utils-merge": { 2588 | "version": "1.0.1", 2589 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2590 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 2591 | }, 2592 | "uuid": { 2593 | "version": "3.3.2", 2594 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 2595 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==" 2596 | }, 2597 | "v8flags": { 2598 | "version": "3.1.3", 2599 | "resolved": "https://registry.npmjs.org/v8flags/-/v8flags-3.1.3.tgz", 2600 | "integrity": "sha512-amh9CCg3ZxkzQ48Mhcb8iX7xpAfYJgePHxWMQCBWECpOSqJUXgY26ncA61UTV0BkPqfhcy6mzwCIoP4ygxpW8w==", 2601 | "requires": { 2602 | "homedir-polyfill": "^1.0.1" 2603 | } 2604 | }, 2605 | "vary": { 2606 | "version": "1.1.2", 2607 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2608 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 2609 | }, 2610 | "which": { 2611 | "version": "1.3.1", 2612 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2613 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2614 | "requires": { 2615 | "isexe": "^2.0.0" 2616 | } 2617 | }, 2618 | "wrappy": { 2619 | "version": "1.0.2", 2620 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2621 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2622 | "dev": true 2623 | }, 2624 | "xtend": { 2625 | "version": "4.0.1", 2626 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 2627 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=" 2628 | }, 2629 | "yn": { 2630 | "version": "3.1.0", 2631 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.0.tgz", 2632 | "integrity": "sha512-kKfnnYkbTfrAdd0xICNFw7Atm8nKpLcLv9AZGEt+kczL/WQVai4e2V6ZN8U/O+iI6WrNuJjNNOyu4zfhl9D3Hg==", 2633 | "dev": true 2634 | } 2635 | } 2636 | } 2637 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "nest-objection-article", 3 | "version": "1.0.0", 4 | "description": "Companion repo for the article", 5 | "license": "MIT", 6 | "scripts": { 7 | "build": "tsc -p tsconfig.build.json", 8 | "start": "ts-node src/main", 9 | "prestart:prod": "npm run build", 10 | "start:prod": "node dist/main.js", 11 | "knex": "knex --knexfile knexfile.ts", 12 | "migrate": "npm run knex migrate:latest", 13 | "migrate:make": "npm run knex migrate:make -- -x ts", 14 | "seed": "npm run knex seed:run", 15 | "seed:make": "npm run knex seed:make -- -x ts", 16 | "run:pg-docker": "docker run -it --rm --name pg-docker -e POSTGRES_PASSWORD=docker -p 5432:5432 postgres:10", 17 | "stop:pg-docker": "docker kill pg-docker" 18 | }, 19 | "dependencies": { 20 | "@nestjs/common": "6.2.4", 21 | "@nestjs/core": "6.2.4", 22 | "@nestjs/platform-express": "6.2.4", 23 | "@types/dotenv": "^6.1.1", 24 | "dotenv": "^8.0.0", 25 | "knex": "^0.17.5", 26 | "objection": "^1.6.9", 27 | "pg": "^7.11.0", 28 | "reflect-metadata": "0.1.13", 29 | "rxjs": "6.5.2", 30 | "typescript": "3.5.1" 31 | }, 32 | "devDependencies": { 33 | "@types/node": "10.14.7", 34 | "ts-node": "8.2.0", 35 | "tslint": "5.16.0" 36 | } 37 | } 38 | -------------------------------------------------------------------------------- /src/app.module.ts: -------------------------------------------------------------------------------- 1 | import { Module } from '@nestjs/common'; 2 | import { TagsModule } from './tags/tags.module'; 3 | import { ThemesModule } from './themes/themes.module'; 4 | import { NotesModule } from './notes/notes.module'; 5 | import { DatabaseModule } from './database/database.module'; 6 | 7 | @Module({ 8 | imports: [TagsModule, ThemesModule, NotesModule, DatabaseModule], 9 | }) 10 | export class ApplicationModule { 11 | } 12 | -------------------------------------------------------------------------------- /src/database/database.module.ts: -------------------------------------------------------------------------------- 1 | import { Global, Module } from '@nestjs/common'; 2 | import * as Knex from 'knex'; 3 | import { knexSnakeCaseMappers, Model } from 'objection'; 4 | import { TagModel } from './models/tag.model'; 5 | import { NoteModel } from './models/note.model'; 6 | import { ThemeModel } from './models/theme.model'; 7 | import { NoteTagModel } from './models/note-tag.model'; 8 | 9 | const models = [TagModel, NoteModel, ThemeModel, NoteTagModel]; 10 | 11 | const modelProviders = models.map(model => { 12 | return { 13 | provide: model.name, 14 | useValue: model 15 | }; 16 | }); 17 | 18 | const providers = [ 19 | ...modelProviders, 20 | { 21 | provide: 'KnexConnection', 22 | useFactory: async () => { 23 | const knex = Knex({ 24 | client: 'pg', 25 | connection: process.env.DATABASE_URL, 26 | debug: process.env.KNEX_DEBUG === 'true', 27 | ...knexSnakeCaseMappers() 28 | }); 29 | 30 | Model.knex(knex); 31 | return knex; 32 | } 33 | } 34 | ]; 35 | 36 | @Global() 37 | @Module({ 38 | providers: [...providers], 39 | exports: [...providers] 40 | }) 41 | export class DatabaseModule {} 42 | -------------------------------------------------------------------------------- /src/database/migration.stub: -------------------------------------------------------------------------------- 1 | import * as Knex from 'knex'; 2 | 3 | const tableName = ''; 4 | 5 | export async function up(knex: Knex) { 6 | return knex.schema.createTable(tableName, t => { 7 | // this creates an "id" column that gets autoincremented 8 | t.increments(); 9 | 10 | }); 11 | } 12 | 13 | export async function down(knex: Knex) { 14 | return knex.schema.dropTable(tableName); 15 | } 16 | -------------------------------------------------------------------------------- /src/database/migrations/20190609143930_CreateTags.ts: -------------------------------------------------------------------------------- 1 | import * as Knex from 'knex'; 2 | 3 | const tableName = 'tags'; 4 | 5 | export async function up(knex: Knex) { 6 | return knex.schema.createTable(tableName, t => { 7 | // this creates an "id" column that gets auto-incremented 8 | t.increments(); 9 | 10 | t.string('name') 11 | .notNullable() 12 | .unique(); 13 | }); 14 | } 15 | 16 | export async function down(knex: Knex) { 17 | return knex.schema.dropTable(tableName); 18 | } 19 | -------------------------------------------------------------------------------- /src/database/migrations/20190609144745_CreateThemes.ts: -------------------------------------------------------------------------------- 1 | import * as Knex from 'knex'; 2 | 3 | const tableName = 'themes'; 4 | 5 | export async function up(knex: Knex) { 6 | return knex.schema.createTable(tableName, t => { 7 | // this creates an "id" column that gets auto-incremented 8 | t.increments(); 9 | 10 | t.string('name').notNullable(); 11 | 12 | t.text('font_family').defaultTo('monospace'); 13 | t.integer('font_size').defaultTo(14); 14 | 15 | t.string('background').defaultTo('#000000'); 16 | t.string('foreground').defaultTo('#ffffff'); 17 | }); 18 | } 19 | 20 | export async function down(knex: Knex) { 21 | return knex.schema.dropTable(tableName); 22 | } 23 | -------------------------------------------------------------------------------- /src/database/migrations/20190609144752_CreateNotes.ts: -------------------------------------------------------------------------------- 1 | import * as Knex from 'knex'; 2 | 3 | const tableName = 'notes'; 4 | 5 | export async function up(knex: Knex) { 6 | return knex.schema.createTable(tableName, t => { 7 | // this creates an "id" column that gets auto-incremented 8 | t.increments(); 9 | 10 | t.text('text'); 11 | 12 | t.integer('theme_id') 13 | .references('id') 14 | .inTable('themes'); 15 | }); 16 | } 17 | 18 | export async function down(knex: Knex) { 19 | return knex.schema.dropTable(tableName); 20 | } 21 | -------------------------------------------------------------------------------- /src/database/migrations/20190609144759_CreateNoteTags.ts: -------------------------------------------------------------------------------- 1 | import * as Knex from 'knex'; 2 | 3 | const tableName = 'note_tags'; 4 | 5 | export async function up(knex: Knex) { 6 | return knex.schema.createTable(tableName, t => { 7 | // this creates an "id" column that gets auto-incremented 8 | t.increments(); 9 | 10 | t.integer('tag_id') 11 | .references('id') 12 | .inTable('tags'); 13 | 14 | t.integer('note_id') 15 | .references('id') 16 | .inTable('notes'); 17 | 18 | t.unique(['tag_id', 'note_id']); 19 | }); 20 | } 21 | 22 | export async function down(knex: Knex) { 23 | return knex.schema.dropTable(tableName); 24 | } 25 | -------------------------------------------------------------------------------- /src/database/models/base.model.ts: -------------------------------------------------------------------------------- 1 | import { Model } from 'objection'; 2 | 3 | export class BaseModel extends Model { 4 | readonly id: number; 5 | } 6 | -------------------------------------------------------------------------------- /src/database/models/note-tag.model.ts: -------------------------------------------------------------------------------- 1 | import { BaseModel } from './base.model'; 2 | 3 | export class NoteTagModel extends BaseModel { 4 | static tableName = 'note_tags'; 5 | 6 | noteId: number; 7 | tagId: number; 8 | } 9 | -------------------------------------------------------------------------------- /src/database/models/note.model.ts: -------------------------------------------------------------------------------- 1 | import { BaseModel } from './base.model'; 2 | import { ThemeModel } from './theme.model'; 3 | import { TagModel } from './tag.model'; 4 | import { Model } from 'objection'; 5 | 6 | export class NoteModel extends BaseModel { 7 | static tableName = 'notes'; 8 | 9 | text: string; 10 | themeId: number; 11 | 12 | theme: ThemeModel; 13 | tags: TagModel[]; 14 | 15 | static relationMappings = { 16 | theme: { 17 | modelClass: `${__dirname}/theme.model`, 18 | relation: Model.BelongsToOneRelation, 19 | join: { 20 | from: 'notes.themeId', 21 | to: 'themes.id' 22 | } 23 | }, 24 | tags: { 25 | modelClass: `${__dirname}/tag.model`, 26 | relation: Model.ManyToManyRelation, 27 | join: { 28 | from: 'notes.id', 29 | through: { 30 | from: 'note_tags.noteId', 31 | to: 'note_tags.tagId' 32 | }, 33 | to: 'tags.id' 34 | } 35 | } 36 | }; 37 | } 38 | -------------------------------------------------------------------------------- /src/database/models/tag.model.ts: -------------------------------------------------------------------------------- 1 | import { BaseModel } from './base.model'; 2 | 3 | export class TagModel extends BaseModel { 4 | static tableName = 'tags'; 5 | 6 | name: string; 7 | } 8 | -------------------------------------------------------------------------------- /src/database/models/theme.model.ts: -------------------------------------------------------------------------------- 1 | import { BaseModel } from './base.model'; 2 | 3 | export class ThemeModel extends BaseModel { 4 | static tableName = 'themes'; 5 | 6 | name: string; 7 | fontFamily: string; 8 | fontSize: number; 9 | background: string; 10 | foreground: string; 11 | } 12 | -------------------------------------------------------------------------------- /src/database/seed.stub: -------------------------------------------------------------------------------- 1 | import * as Knex from 'knex'; 2 | 3 | export async function seed(knex: Knex): Promise { 4 | } 5 | -------------------------------------------------------------------------------- /src/database/seeds/01-Tags.ts: -------------------------------------------------------------------------------- 1 | import * as Knex from 'knex'; 2 | import { TagModel } from '../models/tag.model'; 3 | 4 | export async function seed(knex: Knex): Promise { 5 | await TagModel.query(knex).insert([ 6 | { 7 | name: 'Workout' 8 | }, 9 | { 10 | name: 'Food' 11 | }, 12 | { 13 | name: 'Diary' 14 | }, 15 | { 16 | name: 'Cinema' 17 | }, 18 | { 19 | name: 'Books' 20 | } 21 | ]); 22 | } 23 | -------------------------------------------------------------------------------- /src/database/seeds/02-Themes.ts: -------------------------------------------------------------------------------- 1 | import * as Knex from 'knex'; 2 | import { ThemeModel } from '../models/theme.model'; 3 | 4 | export async function seed(knex: Knex): Promise { 5 | await ThemeModel.query(knex).insert([ 6 | { 7 | name: 'Dark Purple', 8 | fontSize: 14, 9 | fontFamily: 'Code Saver', 10 | background: '#0b0b14', 11 | foreground: '#d4d4d4' 12 | }, 13 | { 14 | name: 'One Dark', 15 | fontSize: 14, 16 | fontFamily: 'Code Saver', 17 | background: '#282c34', 18 | foreground: '#abb2bf' 19 | }, 20 | { 21 | name: 'Dracula', 22 | fontSize: 14, 23 | fontFamily: 'Code Saver', 24 | background: '#282a36', 25 | foreground: '#f8f8f2' 26 | } 27 | ]); 28 | } 29 | -------------------------------------------------------------------------------- /src/database/seeds/03-Notes.ts: -------------------------------------------------------------------------------- 1 | import * as Knex from 'knex'; 2 | import { NoteModel } from '../models/note.model'; 3 | 4 | export async function seed(knex: Knex): Promise { 5 | await NoteModel.query(knex).insert([ 6 | { 7 | text: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit. Cupiditate, ex.', 8 | themeId: 1 9 | }, 10 | { 11 | text: 12 | 'Aperiam blanditiis distinctio earum et, inventore molestias nihil obcaecati officia quasi quo sed soluta suscipit.', 13 | themeId: 1 14 | }, 15 | { 16 | text: 'Ab animi at consectetur error ex fugiat magni minima minus reiciendis sapiente?', 17 | themeId: 1 18 | }, 19 | { 20 | text: 21 | 'Ab beatae fuga fugiat harum iste iure quaerat quibusdam! Alias aliquid amet aut corporis dolores dolorum et eum ex,', 22 | themeId: 2 23 | }, 24 | { 25 | text: 26 | 'illum laboriosam maxime molestiae neque nesciunt numquam odio odit, quae repellendus tempora velit voluptas.', 27 | themeId: 2 28 | }, 29 | { 30 | text: 31 | 'A asperiores at commodi cumque deleniti, doloremque expedita explicabo facilis harum laudantium, magnam, nesciunt nihil perferendis quia ratione reprehenderit sit ut vel.', 32 | themeId: 3 33 | }, 34 | { 35 | text: 36 | 'Ab aspernatur autem commodi culpa dolore eos, facere minima molestiae odio odit perspiciatis porro qui quidem repudiandae similique tenetur totam velit.', 37 | themeId: 3 38 | }, 39 | { 40 | text: 'Ab autem debitis dicta et illum minima molestiae non nostrum similique veniam.', 41 | themeId: 3 42 | } 43 | ]); 44 | } 45 | -------------------------------------------------------------------------------- /src/database/seeds/04-NoteTags.ts: -------------------------------------------------------------------------------- 1 | import * as Knex from 'knex'; 2 | import { NoteTagModel } from '../models/note-tag.model'; 3 | 4 | export async function seed(knex: Knex): Promise { 5 | await NoteTagModel.query(knex).insert([ 6 | { 7 | noteId: 1, 8 | tagId: 1 9 | }, 10 | { 11 | noteId: 1, 12 | tagId: 2 13 | }, 14 | { 15 | noteId: 1, 16 | tagId: 3 17 | }, 18 | { 19 | noteId: 1, 20 | tagId: 4 21 | }, 22 | { 23 | noteId: 1, 24 | tagId: 5 25 | }, 26 | { 27 | noteId: 2, 28 | tagId: 1 29 | }, 30 | { 31 | noteId: 3, 32 | tagId: 1 33 | }, 34 | { 35 | noteId: 4, 36 | tagId: 2 37 | }, 38 | { 39 | noteId: 5, 40 | tagId: 3 41 | }, 42 | { 43 | noteId: 6, 44 | tagId: 5 45 | }, 46 | { 47 | noteId: 7, 48 | tagId: 3 49 | } 50 | ]); 51 | } 52 | -------------------------------------------------------------------------------- /src/main.ts: -------------------------------------------------------------------------------- 1 | import 'dotenv/config'; 2 | import { NestFactory } from '@nestjs/core'; 3 | import { ApplicationModule } from './app.module'; 4 | 5 | async function bootstrap() { 6 | const app = await NestFactory.create(ApplicationModule); 7 | app.setGlobalPrefix('api'); 8 | await app.listen(3001); 9 | } 10 | 11 | bootstrap(); 12 | -------------------------------------------------------------------------------- /src/notes/note-tags.service.ts: -------------------------------------------------------------------------------- 1 | import { Injectable } from '@nestjs/common'; 2 | import { NoteTagModel } from '../database/models/note-tag.model'; 3 | 4 | @Injectable() 5 | export class NoteTagsService { 6 | constructor() { 7 | return null; 8 | } 9 | 10 | create(props: Partial) { 11 | return null; 12 | } 13 | 14 | async delete(props: Partial) { 15 | return null; 16 | } 17 | 18 | deleteByNoteId(noteId: number) { 19 | return null; 20 | } 21 | 22 | deleteByTagId(tagId: number) { 23 | return null; 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /src/notes/notes.controller.ts: -------------------------------------------------------------------------------- 1 | import { Body, Controller, Delete, Get, Param, ParseIntPipe, Post, Put } from '@nestjs/common'; 2 | import { NoteModel } from '../database/models/note.model'; 3 | import { NotesService } from './notes.service'; 4 | 5 | @Controller('notes') 6 | export class NotesController { 7 | constructor(private notesService: NotesService) {} 8 | 9 | @Get() 10 | async findAll() { 11 | return this.notesService.findAll().eager('[tags]'); 12 | } 13 | 14 | @Get(':id') 15 | async findOne(@Param('id', new ParseIntPipe()) id: number) { 16 | const note = await this.notesService.findOne(id); 17 | await note.$loadRelated('[tags,theme]'); 18 | return note; 19 | } 20 | 21 | @Post() 22 | async create(@Body() props: Partial) { 23 | return this.notesService.create(props); 24 | } 25 | 26 | @Delete(':id') 27 | async delete(@Param('id', new ParseIntPipe()) id: number) { 28 | return this.notesService.delete(id); 29 | } 30 | 31 | @Put(':id') 32 | async edit(@Param('id', new ParseIntPipe()) id: number, @Body('text') text: string) { 33 | const note = await this.notesService.update(id, { text }); 34 | await note.$loadRelated('[tags,theme]'); 35 | return note; 36 | } 37 | 38 | @Put(':id/tags/:tagId') 39 | async addTag(@Param('id', new ParseIntPipe()) id: number, @Param('tagId', new ParseIntPipe()) tagId: number) { 40 | const note = await this.notesService.addTag(id, tagId); 41 | await note.$loadRelated('[tags,theme]'); 42 | return note; 43 | } 44 | 45 | @Delete(':id/tags/:tagId') 46 | async removeTag(@Param('id', new ParseIntPipe()) id: number, @Param('tagId', new ParseIntPipe()) tagId: number) { 47 | const note = await this.notesService.removeTag(id, tagId); 48 | await note.$loadRelated('[tags,theme]'); 49 | return note; 50 | } 51 | 52 | @Put(':id/theme/:themeId') 53 | async setTheme(@Param('id', new ParseIntPipe()) id: number, @Param('themeId', new ParseIntPipe()) themeId: number) { 54 | const note = await this.notesService.update(id, { themeId }); 55 | await note.$loadRelated('[tags,theme]'); 56 | return note; 57 | } 58 | } 59 | -------------------------------------------------------------------------------- /src/notes/notes.module.ts: -------------------------------------------------------------------------------- 1 | import { Global, Module } from '@nestjs/common'; 2 | import { NotesService } from './notes.service'; 3 | import { NotesController } from './notes.controller'; 4 | import { NoteTagsService } from './note-tags.service'; 5 | 6 | @Global() 7 | @Module({ 8 | controllers: [NotesController], 9 | providers: [NotesService, NoteTagsService], 10 | exports: [NotesService, NoteTagsService], 11 | }) 12 | export class NotesModule { 13 | } 14 | -------------------------------------------------------------------------------- /src/notes/notes.service.ts: -------------------------------------------------------------------------------- 1 | import { Inject, Injectable } from '@nestjs/common'; 2 | import { NoteModel } from '../database/models/note.model'; 3 | import { ModelClass, transaction } from 'objection'; 4 | import { NoteTagsService } from './note-tags.service'; 5 | 6 | @Injectable() 7 | export class NotesService { 8 | constructor( 9 | private noteTagsService: NoteTagsService, 10 | @Inject('NoteModel') private modelClass: ModelClass 11 | ) {} 12 | 13 | findAll() { 14 | return this.modelClass.query(); 15 | } 16 | 17 | findOne(id: number) { 18 | return this.modelClass.query().findById(id); 19 | } 20 | 21 | create(props: Partial) { 22 | return this.modelClass 23 | .query() 24 | .insert(props) 25 | .returning('*'); 26 | } 27 | 28 | update(id: number, props: Partial) { 29 | return this.modelClass 30 | .query() 31 | .patch(props) 32 | .where({ id }) 33 | .returning('*') 34 | .first(); 35 | } 36 | 37 | delete(id: number) { 38 | return transaction(this.modelClass, async (_, trx) => { 39 | await this.noteTagsService.deleteByNoteId(id).transacting(trx); 40 | 41 | return this.modelClass 42 | .query() 43 | .delete() 44 | .where({ id }) 45 | .returning('*') 46 | .first() 47 | .transacting(trx); 48 | }); 49 | } 50 | 51 | unsetTheme(themeId: number) { 52 | return this.modelClass 53 | .query() 54 | .patch({ themeId: null }) 55 | .where({ themeId }); 56 | } 57 | 58 | async addTag(noteId: number, tagId: number) { 59 | await this.noteTagsService.create({ noteId, tagId }); 60 | return this.findOne(noteId); 61 | } 62 | 63 | async removeTag(noteId: number, tagId: number) { 64 | await this.noteTagsService.delete({ noteId, tagId }); 65 | return this.findOne(noteId); 66 | } 67 | } 68 | -------------------------------------------------------------------------------- /src/tags/tags.controller.ts: -------------------------------------------------------------------------------- 1 | import { Body, Controller, Delete, Get, Param, ParseIntPipe, Post, Put, } from '@nestjs/common'; 2 | import { TagsService } from './tags.service'; 3 | import { TagModel } from '../database/models/tag.model'; 4 | 5 | @Controller('tags') 6 | export class TagsController { 7 | constructor(private tagsService: TagsService) { 8 | } 9 | 10 | @Get() 11 | async findAll() { 12 | return this.tagsService.findAll(); 13 | } 14 | 15 | @Get(':id') 16 | async findOne(@Param('id', new ParseIntPipe()) id: number) { 17 | return this.tagsService.findOne(id); 18 | } 19 | 20 | @Post() 21 | async create(@Body() props: Partial) { 22 | return this.tagsService.create(props); 23 | } 24 | 25 | @Delete(':id') 26 | async delete(@Param('id', new ParseIntPipe()) id: number) { 27 | return this.tagsService.delete(id); 28 | } 29 | 30 | @Put(':id') 31 | async update( 32 | @Param('id', new ParseIntPipe()) id: number, 33 | @Body() props: Partial, 34 | ) { 35 | return this.tagsService.update(id, props); 36 | } 37 | } 38 | -------------------------------------------------------------------------------- /src/tags/tags.module.ts: -------------------------------------------------------------------------------- 1 | import { Global, Module } from '@nestjs/common'; 2 | import { TagsController } from './tags.controller'; 3 | import { TagsService } from './tags.service'; 4 | 5 | @Global() 6 | @Module({ 7 | controllers: [TagsController], 8 | providers: [TagsService], 9 | exports: [TagsService], 10 | }) 11 | export class TagsModule { 12 | } 13 | -------------------------------------------------------------------------------- /src/tags/tags.service.ts: -------------------------------------------------------------------------------- 1 | import { Inject, Injectable } from '@nestjs/common'; 2 | import { TagModel } from '../database/models/tag.model'; 3 | import { ModelClass, transaction } from 'objection'; 4 | import { NoteTagsService } from '../notes/note-tags.service'; 5 | 6 | @Injectable() 7 | export class TagsService { 8 | constructor(private noteTagsService: NoteTagsService, @Inject('TagModel') private modelClass: ModelClass) {} 9 | 10 | findAll() { 11 | return this.modelClass.query(); 12 | } 13 | 14 | findOne(id: number) { 15 | return this.modelClass.query().findById(id); 16 | } 17 | 18 | create(props: Partial) { 19 | return this.modelClass 20 | .query() 21 | .insert(props) 22 | .returning('*'); 23 | } 24 | 25 | update(id: number, props: Partial) { 26 | return this.modelClass 27 | .query() 28 | .patch(props) 29 | .where({ id }) 30 | .returning('*') 31 | .first(); 32 | } 33 | 34 | delete(id: number) { 35 | return transaction(this.modelClass, async (_, trx) => { 36 | await this.noteTagsService.deleteByTagId(id).transacting(trx); 37 | 38 | return this.modelClass 39 | .query() 40 | .deleteById(id) 41 | .returning('*') 42 | .first() 43 | .transacting(trx); 44 | }); 45 | } 46 | } 47 | -------------------------------------------------------------------------------- /src/themes/themes.controller.ts: -------------------------------------------------------------------------------- 1 | import { Body, Controller, Delete, Get, Param, ParseIntPipe, Post, Put, } from '@nestjs/common'; 2 | import { ThemesService } from './themes.service'; 3 | import { ThemeModel } from '../database/models/theme.model'; 4 | 5 | @Controller('themes') 6 | export class ThemesController { 7 | constructor(private themesService: ThemesService) { 8 | } 9 | 10 | @Get() 11 | async findAll() { 12 | return this.themesService.findAll(); 13 | } 14 | 15 | @Get(':id') 16 | async findOne(@Param('id', new ParseIntPipe()) id: number) { 17 | return this.themesService.findOne(id); 18 | } 19 | 20 | @Post() 21 | async create(@Body() props: Partial) { 22 | return this.themesService.create(props); 23 | } 24 | 25 | @Delete(':id') 26 | async delete(@Param('id', new ParseIntPipe()) id: number) { 27 | return this.themesService.delete(id); 28 | } 29 | 30 | @Put(':id') 31 | async update( 32 | @Param('id', new ParseIntPipe()) id: number, 33 | @Body() props: Partial 34 | ) { 35 | return this.themesService.update(id, props); 36 | } 37 | } 38 | -------------------------------------------------------------------------------- /src/themes/themes.module.ts: -------------------------------------------------------------------------------- 1 | import { Global, Module } from '@nestjs/common'; 2 | import { ThemesController } from './themes.controller'; 3 | import { ThemesService } from './themes.service'; 4 | 5 | @Global() 6 | @Module({ 7 | controllers: [ThemesController], 8 | providers: [ThemesService], 9 | exports: [ThemesService], 10 | }) 11 | export class ThemesModule { 12 | } 13 | -------------------------------------------------------------------------------- /src/themes/themes.service.ts: -------------------------------------------------------------------------------- 1 | import { Inject, Injectable } from '@nestjs/common'; 2 | import { ThemeModel } from '../database/models/theme.model'; 3 | import { ModelClass, transaction } from 'objection'; 4 | import { NotesService } from '../notes/notes.service'; 5 | 6 | @Injectable() 7 | export class ThemesService { 8 | constructor(private noteService: NotesService, @Inject('ThemeModel') private modelClass: ModelClass) {} 9 | 10 | findAll() { 11 | return this.modelClass.query(); 12 | } 13 | 14 | findOne(id: number) { 15 | return this.modelClass.query().findById(id); 16 | } 17 | 18 | create(props: Partial) { 19 | return this.modelClass 20 | .query() 21 | .insert(props) 22 | .returning('*'); 23 | } 24 | 25 | update(id: number, props: Partial) { 26 | return this.modelClass 27 | .query() 28 | .patch(props) 29 | .where({ id }) 30 | .returning('*') 31 | .first(); 32 | } 33 | 34 | delete(id: number) { 35 | return transaction(this.modelClass, async (_, trx) => { 36 | await this.noteService.unsetTheme(id).transacting(trx); 37 | 38 | return this.modelClass 39 | .query() 40 | .delete() 41 | .where({ id }) 42 | .returning('*') 43 | .first() 44 | .transacting(trx); 45 | }); 46 | } 47 | } 48 | -------------------------------------------------------------------------------- /tsconfig.build.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "./tsconfig.json", 3 | "include": ["src/**/*"], 4 | "exclude": ["node_modules", "**/*.spec.ts"] 5 | } 6 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "declaration": true, 5 | "noImplicitAny": false, 6 | "removeComments": true, 7 | "noLib": false, 8 | "allowSyntheticDefaultImports": true, 9 | "emitDecoratorMetadata": true, 10 | "experimentalDecorators": true, 11 | "target": "es6", 12 | "sourceMap": true, 13 | "outDir": "./dist", 14 | "baseUrl": "./" 15 | }, 16 | "exclude": ["node_modules"] 17 | } 18 | -------------------------------------------------------------------------------- /tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "defaultSeverity": "error", 3 | "extends": ["tslint:recommended"], 4 | "jsRules": { 5 | "no-unused-expression": true 6 | }, 7 | "rules": { 8 | "quotemark": [true, "single"], 9 | "member-access": [false], 10 | "ordered-imports": [false], 11 | "max-line-length": [false, 150], 12 | "member-ordering": [false], 13 | "interface-name": [false], 14 | "arrow-parens": false, 15 | "no-console": false, 16 | "trailing-comma": false, 17 | "object-literal-sort-keys": false 18 | }, 19 | "rulesDirectory": [] 20 | } 21 | --------------------------------------------------------------------------------