├── README.md ├── backend ├── .gitignore ├── package-lock.json ├── package.json └── src │ ├── database.js │ ├── index.js │ ├── models │ └── User.js │ └── routes │ └── index.js ├── frontend ├── .editorconfig ├── .gitignore ├── README.md ├── angular.json ├── browserslist ├── e2e │ ├── protractor.conf.js │ ├── src │ │ ├── app.e2e-spec.ts │ │ └── app.po.ts │ └── tsconfig.json ├── karma.conf.js ├── package-lock.json ├── package.json ├── src │ ├── app │ │ ├── app-routing.module.ts │ │ ├── app.component.css │ │ ├── app.component.html │ │ ├── app.component.spec.ts │ │ ├── app.component.ts │ │ ├── app.module.ts │ │ ├── auth.guard.spec.ts │ │ ├── auth.guard.ts │ │ ├── components │ │ │ ├── private-tasks │ │ │ │ ├── private-tasks.component.css │ │ │ │ ├── private-tasks.component.html │ │ │ │ ├── private-tasks.component.spec.ts │ │ │ │ └── private-tasks.component.ts │ │ │ ├── signin │ │ │ │ ├── signin.component.css │ │ │ │ ├── signin.component.html │ │ │ │ ├── signin.component.spec.ts │ │ │ │ └── signin.component.ts │ │ │ ├── signup │ │ │ │ ├── signup.component.css │ │ │ │ ├── signup.component.html │ │ │ │ ├── signup.component.spec.ts │ │ │ │ └── signup.component.ts │ │ │ └── tasks │ │ │ │ ├── tasks.component.css │ │ │ │ ├── tasks.component.html │ │ │ │ ├── tasks.component.spec.ts │ │ │ │ └── tasks.component.ts │ │ └── services │ │ │ ├── auth.service.spec.ts │ │ │ ├── auth.service.ts │ │ │ ├── task.service.spec.ts │ │ │ ├── task.service.ts │ │ │ ├── token-interceptor.service.spec.ts │ │ │ └── token-interceptor.service.ts │ ├── assets │ │ └── .gitkeep │ ├── environments │ │ ├── environment.prod.ts │ │ └── environment.ts │ ├── favicon.ico │ ├── index.html │ ├── main.ts │ ├── polyfills.ts │ ├── styles.css │ └── test.ts ├── tsconfig.app.json ├── tsconfig.json ├── tsconfig.spec.json └── tslint.json └── screenshot.png /README.md: -------------------------------------------------------------------------------- 1 | # Angular & Nodejs JWT Auth 2 | 3 | ![](./screenshot.png) 4 | 5 | 6 | -------------------------------------------------------------------------------- /backend/.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | -------------------------------------------------------------------------------- /backend/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "backend", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "abbrev": { 8 | "version": "1.1.1", 9 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 10 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 11 | "dev": true 12 | }, 13 | "accepts": { 14 | "version": "1.3.7", 15 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 16 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 17 | "requires": { 18 | "mime-types": "~2.1.24", 19 | "negotiator": "0.6.2" 20 | } 21 | }, 22 | "ansi-align": { 23 | "version": "2.0.0", 24 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-2.0.0.tgz", 25 | "integrity": "sha1-w2rsy6VjuJzrVW82kPCx2eNUf38=", 26 | "dev": true, 27 | "requires": { 28 | "string-width": "^2.0.0" 29 | } 30 | }, 31 | "ansi-regex": { 32 | "version": "3.0.0", 33 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 34 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 35 | "dev": true 36 | }, 37 | "ansi-styles": { 38 | "version": "3.2.1", 39 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 40 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 41 | "dev": true, 42 | "requires": { 43 | "color-convert": "^1.9.0" 44 | } 45 | }, 46 | "anymatch": { 47 | "version": "2.0.0", 48 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", 49 | "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", 50 | "dev": true, 51 | "requires": { 52 | "micromatch": "^3.1.4", 53 | "normalize-path": "^2.1.1" 54 | }, 55 | "dependencies": { 56 | "normalize-path": { 57 | "version": "2.1.1", 58 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 59 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 60 | "dev": true, 61 | "requires": { 62 | "remove-trailing-separator": "^1.0.1" 63 | } 64 | } 65 | } 66 | }, 67 | "arr-diff": { 68 | "version": "4.0.0", 69 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", 70 | "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", 71 | "dev": true 72 | }, 73 | "arr-flatten": { 74 | "version": "1.1.0", 75 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 76 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", 77 | "dev": true 78 | }, 79 | "arr-union": { 80 | "version": "3.1.0", 81 | "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", 82 | "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", 83 | "dev": true 84 | }, 85 | "array-flatten": { 86 | "version": "1.1.1", 87 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 88 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 89 | }, 90 | "array-unique": { 91 | "version": "0.3.2", 92 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", 93 | "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", 94 | "dev": true 95 | }, 96 | "assign-symbols": { 97 | "version": "1.0.0", 98 | "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", 99 | "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=", 100 | "dev": true 101 | }, 102 | "async-each": { 103 | "version": "1.0.3", 104 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz", 105 | "integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==", 106 | "dev": true 107 | }, 108 | "atob": { 109 | "version": "2.1.2", 110 | "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", 111 | "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==", 112 | "dev": true 113 | }, 114 | "balanced-match": { 115 | "version": "1.0.0", 116 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 117 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 118 | "dev": true 119 | }, 120 | "base": { 121 | "version": "0.11.2", 122 | "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", 123 | "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", 124 | "dev": true, 125 | "requires": { 126 | "cache-base": "^1.0.1", 127 | "class-utils": "^0.3.5", 128 | "component-emitter": "^1.2.1", 129 | "define-property": "^1.0.0", 130 | "isobject": "^3.0.1", 131 | "mixin-deep": "^1.2.0", 132 | "pascalcase": "^0.1.1" 133 | }, 134 | "dependencies": { 135 | "define-property": { 136 | "version": "1.0.0", 137 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 138 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 139 | "dev": true, 140 | "requires": { 141 | "is-descriptor": "^1.0.0" 142 | } 143 | }, 144 | "is-accessor-descriptor": { 145 | "version": "1.0.0", 146 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 147 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 148 | "dev": true, 149 | "requires": { 150 | "kind-of": "^6.0.0" 151 | } 152 | }, 153 | "is-data-descriptor": { 154 | "version": "1.0.0", 155 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 156 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 157 | "dev": true, 158 | "requires": { 159 | "kind-of": "^6.0.0" 160 | } 161 | }, 162 | "is-descriptor": { 163 | "version": "1.0.2", 164 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 165 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 166 | "dev": true, 167 | "requires": { 168 | "is-accessor-descriptor": "^1.0.0", 169 | "is-data-descriptor": "^1.0.0", 170 | "kind-of": "^6.0.2" 171 | } 172 | } 173 | } 174 | }, 175 | "binary-extensions": { 176 | "version": "1.13.1", 177 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz", 178 | "integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==", 179 | "dev": true 180 | }, 181 | "bluebird": { 182 | "version": "3.5.1", 183 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", 184 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" 185 | }, 186 | "body-parser": { 187 | "version": "1.19.0", 188 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 189 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 190 | "requires": { 191 | "bytes": "3.1.0", 192 | "content-type": "~1.0.4", 193 | "debug": "2.6.9", 194 | "depd": "~1.1.2", 195 | "http-errors": "1.7.2", 196 | "iconv-lite": "0.4.24", 197 | "on-finished": "~2.3.0", 198 | "qs": "6.7.0", 199 | "raw-body": "2.4.0", 200 | "type-is": "~1.6.17" 201 | } 202 | }, 203 | "boxen": { 204 | "version": "1.3.0", 205 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-1.3.0.tgz", 206 | "integrity": "sha512-TNPjfTr432qx7yOjQyaXm3dSR0MH9vXp7eT1BFSl/C51g+EFnOR9hTg1IreahGBmDNCehscshe45f+C1TBZbLw==", 207 | "dev": true, 208 | "requires": { 209 | "ansi-align": "^2.0.0", 210 | "camelcase": "^4.0.0", 211 | "chalk": "^2.0.1", 212 | "cli-boxes": "^1.0.0", 213 | "string-width": "^2.0.0", 214 | "term-size": "^1.2.0", 215 | "widest-line": "^2.0.0" 216 | } 217 | }, 218 | "brace-expansion": { 219 | "version": "1.1.11", 220 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 221 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 222 | "dev": true, 223 | "requires": { 224 | "balanced-match": "^1.0.0", 225 | "concat-map": "0.0.1" 226 | } 227 | }, 228 | "braces": { 229 | "version": "2.3.2", 230 | "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", 231 | "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", 232 | "dev": true, 233 | "requires": { 234 | "arr-flatten": "^1.1.0", 235 | "array-unique": "^0.3.2", 236 | "extend-shallow": "^2.0.1", 237 | "fill-range": "^4.0.0", 238 | "isobject": "^3.0.1", 239 | "repeat-element": "^1.1.2", 240 | "snapdragon": "^0.8.1", 241 | "snapdragon-node": "^2.0.1", 242 | "split-string": "^3.0.2", 243 | "to-regex": "^3.0.1" 244 | }, 245 | "dependencies": { 246 | "extend-shallow": { 247 | "version": "2.0.1", 248 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 249 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 250 | "dev": true, 251 | "requires": { 252 | "is-extendable": "^0.1.0" 253 | } 254 | } 255 | } 256 | }, 257 | "bson": { 258 | "version": "1.1.1", 259 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.1.tgz", 260 | "integrity": "sha512-jCGVYLoYMHDkOsbwJZBCqwMHyH4c+wzgI9hG7Z6SZJRXWr+x58pdIbm2i9a/jFGCkRJqRUr8eoI7lDWa0hTkxg==" 261 | }, 262 | "buffer-equal-constant-time": { 263 | "version": "1.0.1", 264 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 265 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 266 | }, 267 | "bytes": { 268 | "version": "3.1.0", 269 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 270 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 271 | }, 272 | "cache-base": { 273 | "version": "1.0.1", 274 | "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", 275 | "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", 276 | "dev": true, 277 | "requires": { 278 | "collection-visit": "^1.0.0", 279 | "component-emitter": "^1.2.1", 280 | "get-value": "^2.0.6", 281 | "has-value": "^1.0.0", 282 | "isobject": "^3.0.1", 283 | "set-value": "^2.0.0", 284 | "to-object-path": "^0.3.0", 285 | "union-value": "^1.0.0", 286 | "unset-value": "^1.0.0" 287 | } 288 | }, 289 | "camelcase": { 290 | "version": "4.1.0", 291 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", 292 | "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", 293 | "dev": true 294 | }, 295 | "capture-stack-trace": { 296 | "version": "1.0.1", 297 | "resolved": "https://registry.npmjs.org/capture-stack-trace/-/capture-stack-trace-1.0.1.tgz", 298 | "integrity": "sha512-mYQLZnx5Qt1JgB1WEiMCf2647plpGeQ2NMR/5L0HNZzGQo4fuSPnK+wjfPnKZV0aiJDgzmWqqkV/g7JD+DW0qw==", 299 | "dev": true 300 | }, 301 | "chalk": { 302 | "version": "2.4.2", 303 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 304 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 305 | "dev": true, 306 | "requires": { 307 | "ansi-styles": "^3.2.1", 308 | "escape-string-regexp": "^1.0.5", 309 | "supports-color": "^5.3.0" 310 | } 311 | }, 312 | "chokidar": { 313 | "version": "2.1.8", 314 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz", 315 | "integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==", 316 | "dev": true, 317 | "requires": { 318 | "anymatch": "^2.0.0", 319 | "async-each": "^1.0.1", 320 | "braces": "^2.3.2", 321 | "fsevents": "^1.2.7", 322 | "glob-parent": "^3.1.0", 323 | "inherits": "^2.0.3", 324 | "is-binary-path": "^1.0.0", 325 | "is-glob": "^4.0.0", 326 | "normalize-path": "^3.0.0", 327 | "path-is-absolute": "^1.0.0", 328 | "readdirp": "^2.2.1", 329 | "upath": "^1.1.1" 330 | } 331 | }, 332 | "ci-info": { 333 | "version": "1.6.0", 334 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-1.6.0.tgz", 335 | "integrity": "sha512-vsGdkwSCDpWmP80ncATX7iea5DWQemg1UgCW5J8tqjU3lYw4FBYuj89J0CTVomA7BEfvSZd84GmHko+MxFQU2A==", 336 | "dev": true 337 | }, 338 | "class-utils": { 339 | "version": "0.3.6", 340 | "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", 341 | "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", 342 | "dev": true, 343 | "requires": { 344 | "arr-union": "^3.1.0", 345 | "define-property": "^0.2.5", 346 | "isobject": "^3.0.0", 347 | "static-extend": "^0.1.1" 348 | }, 349 | "dependencies": { 350 | "define-property": { 351 | "version": "0.2.5", 352 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 353 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 354 | "dev": true, 355 | "requires": { 356 | "is-descriptor": "^0.1.0" 357 | } 358 | } 359 | } 360 | }, 361 | "cli-boxes": { 362 | "version": "1.0.0", 363 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-1.0.0.tgz", 364 | "integrity": "sha1-T6kXw+WclKAEzWH47lCdplFocUM=", 365 | "dev": true 366 | }, 367 | "collection-visit": { 368 | "version": "1.0.0", 369 | "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", 370 | "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", 371 | "dev": true, 372 | "requires": { 373 | "map-visit": "^1.0.0", 374 | "object-visit": "^1.0.0" 375 | } 376 | }, 377 | "color-convert": { 378 | "version": "1.9.3", 379 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 380 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 381 | "dev": true, 382 | "requires": { 383 | "color-name": "1.1.3" 384 | } 385 | }, 386 | "color-name": { 387 | "version": "1.1.3", 388 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 389 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 390 | "dev": true 391 | }, 392 | "component-emitter": { 393 | "version": "1.3.0", 394 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", 395 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==", 396 | "dev": true 397 | }, 398 | "concat-map": { 399 | "version": "0.0.1", 400 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 401 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 402 | "dev": true 403 | }, 404 | "configstore": { 405 | "version": "3.1.2", 406 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-3.1.2.tgz", 407 | "integrity": "sha512-vtv5HtGjcYUgFrXc6Kx747B83MRRVS5R1VTEQoXvuP+kMI+if6uywV0nDGoiydJRy4yk7h9od5Og0kxx4zUXmw==", 408 | "dev": true, 409 | "requires": { 410 | "dot-prop": "^4.1.0", 411 | "graceful-fs": "^4.1.2", 412 | "make-dir": "^1.0.0", 413 | "unique-string": "^1.0.0", 414 | "write-file-atomic": "^2.0.0", 415 | "xdg-basedir": "^3.0.0" 416 | } 417 | }, 418 | "content-disposition": { 419 | "version": "0.5.3", 420 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 421 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 422 | "requires": { 423 | "safe-buffer": "5.1.2" 424 | } 425 | }, 426 | "content-type": { 427 | "version": "1.0.4", 428 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 429 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 430 | }, 431 | "cookie": { 432 | "version": "0.4.0", 433 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 434 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 435 | }, 436 | "cookie-signature": { 437 | "version": "1.0.6", 438 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 439 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 440 | }, 441 | "copy-descriptor": { 442 | "version": "0.1.1", 443 | "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", 444 | "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", 445 | "dev": true 446 | }, 447 | "core-util-is": { 448 | "version": "1.0.2", 449 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 450 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 451 | "dev": true 452 | }, 453 | "cors": { 454 | "version": "2.8.5", 455 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 456 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 457 | "requires": { 458 | "object-assign": "^4", 459 | "vary": "^1" 460 | } 461 | }, 462 | "create-error-class": { 463 | "version": "3.0.2", 464 | "resolved": "https://registry.npmjs.org/create-error-class/-/create-error-class-3.0.2.tgz", 465 | "integrity": "sha1-Br56vvlHo/FKMP1hBnHUAbyot7Y=", 466 | "dev": true, 467 | "requires": { 468 | "capture-stack-trace": "^1.0.0" 469 | } 470 | }, 471 | "cross-spawn": { 472 | "version": "5.1.0", 473 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", 474 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", 475 | "dev": true, 476 | "requires": { 477 | "lru-cache": "^4.0.1", 478 | "shebang-command": "^1.2.0", 479 | "which": "^1.2.9" 480 | } 481 | }, 482 | "crypto-random-string": { 483 | "version": "1.0.0", 484 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-1.0.0.tgz", 485 | "integrity": "sha1-ojD2T1aDEOFJgAmUB5DsmVRbyn4=", 486 | "dev": true 487 | }, 488 | "debug": { 489 | "version": "2.6.9", 490 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 491 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 492 | "requires": { 493 | "ms": "2.0.0" 494 | } 495 | }, 496 | "decode-uri-component": { 497 | "version": "0.2.0", 498 | "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", 499 | "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", 500 | "dev": true 501 | }, 502 | "deep-extend": { 503 | "version": "0.6.0", 504 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 505 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 506 | "dev": true 507 | }, 508 | "define-property": { 509 | "version": "2.0.2", 510 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", 511 | "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", 512 | "dev": true, 513 | "requires": { 514 | "is-descriptor": "^1.0.2", 515 | "isobject": "^3.0.1" 516 | }, 517 | "dependencies": { 518 | "is-accessor-descriptor": { 519 | "version": "1.0.0", 520 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 521 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 522 | "dev": true, 523 | "requires": { 524 | "kind-of": "^6.0.0" 525 | } 526 | }, 527 | "is-data-descriptor": { 528 | "version": "1.0.0", 529 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 530 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 531 | "dev": true, 532 | "requires": { 533 | "kind-of": "^6.0.0" 534 | } 535 | }, 536 | "is-descriptor": { 537 | "version": "1.0.2", 538 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 539 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 540 | "dev": true, 541 | "requires": { 542 | "is-accessor-descriptor": "^1.0.0", 543 | "is-data-descriptor": "^1.0.0", 544 | "kind-of": "^6.0.2" 545 | } 546 | } 547 | } 548 | }, 549 | "depd": { 550 | "version": "1.1.2", 551 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 552 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 553 | }, 554 | "destroy": { 555 | "version": "1.0.4", 556 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 557 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 558 | }, 559 | "dot-prop": { 560 | "version": "4.2.0", 561 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-4.2.0.tgz", 562 | "integrity": "sha512-tUMXrxlExSW6U2EXiiKGSBVdYgtV8qlHL+C10TsW4PURY/ic+eaysnSkwB4kA/mBlCyy/IKDJ+Lc3wbWeaXtuQ==", 563 | "dev": true, 564 | "requires": { 565 | "is-obj": "^1.0.0" 566 | } 567 | }, 568 | "duplexer3": { 569 | "version": "0.1.4", 570 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 571 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=", 572 | "dev": true 573 | }, 574 | "ecdsa-sig-formatter": { 575 | "version": "1.0.11", 576 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 577 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 578 | "requires": { 579 | "safe-buffer": "^5.0.1" 580 | } 581 | }, 582 | "ee-first": { 583 | "version": "1.1.1", 584 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 585 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 586 | }, 587 | "encodeurl": { 588 | "version": "1.0.2", 589 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 590 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 591 | }, 592 | "escape-html": { 593 | "version": "1.0.3", 594 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 595 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 596 | }, 597 | "escape-string-regexp": { 598 | "version": "1.0.5", 599 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 600 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 601 | "dev": true 602 | }, 603 | "etag": { 604 | "version": "1.8.1", 605 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 606 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 607 | }, 608 | "execa": { 609 | "version": "0.7.0", 610 | "resolved": "https://registry.npmjs.org/execa/-/execa-0.7.0.tgz", 611 | "integrity": "sha1-lEvs00zEHuMqY6n68nrVpl/Fl3c=", 612 | "dev": true, 613 | "requires": { 614 | "cross-spawn": "^5.0.1", 615 | "get-stream": "^3.0.0", 616 | "is-stream": "^1.1.0", 617 | "npm-run-path": "^2.0.0", 618 | "p-finally": "^1.0.0", 619 | "signal-exit": "^3.0.0", 620 | "strip-eof": "^1.0.0" 621 | } 622 | }, 623 | "expand-brackets": { 624 | "version": "2.1.4", 625 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", 626 | "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", 627 | "dev": true, 628 | "requires": { 629 | "debug": "^2.3.3", 630 | "define-property": "^0.2.5", 631 | "extend-shallow": "^2.0.1", 632 | "posix-character-classes": "^0.1.0", 633 | "regex-not": "^1.0.0", 634 | "snapdragon": "^0.8.1", 635 | "to-regex": "^3.0.1" 636 | }, 637 | "dependencies": { 638 | "define-property": { 639 | "version": "0.2.5", 640 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 641 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 642 | "dev": true, 643 | "requires": { 644 | "is-descriptor": "^0.1.0" 645 | } 646 | }, 647 | "extend-shallow": { 648 | "version": "2.0.1", 649 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 650 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 651 | "dev": true, 652 | "requires": { 653 | "is-extendable": "^0.1.0" 654 | } 655 | } 656 | } 657 | }, 658 | "express": { 659 | "version": "4.17.1", 660 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 661 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 662 | "requires": { 663 | "accepts": "~1.3.7", 664 | "array-flatten": "1.1.1", 665 | "body-parser": "1.19.0", 666 | "content-disposition": "0.5.3", 667 | "content-type": "~1.0.4", 668 | "cookie": "0.4.0", 669 | "cookie-signature": "1.0.6", 670 | "debug": "2.6.9", 671 | "depd": "~1.1.2", 672 | "encodeurl": "~1.0.2", 673 | "escape-html": "~1.0.3", 674 | "etag": "~1.8.1", 675 | "finalhandler": "~1.1.2", 676 | "fresh": "0.5.2", 677 | "merge-descriptors": "1.0.1", 678 | "methods": "~1.1.2", 679 | "on-finished": "~2.3.0", 680 | "parseurl": "~1.3.3", 681 | "path-to-regexp": "0.1.7", 682 | "proxy-addr": "~2.0.5", 683 | "qs": "6.7.0", 684 | "range-parser": "~1.2.1", 685 | "safe-buffer": "5.1.2", 686 | "send": "0.17.1", 687 | "serve-static": "1.14.1", 688 | "setprototypeof": "1.1.1", 689 | "statuses": "~1.5.0", 690 | "type-is": "~1.6.18", 691 | "utils-merge": "1.0.1", 692 | "vary": "~1.1.2" 693 | } 694 | }, 695 | "extend-shallow": { 696 | "version": "3.0.2", 697 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", 698 | "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", 699 | "dev": true, 700 | "requires": { 701 | "assign-symbols": "^1.0.0", 702 | "is-extendable": "^1.0.1" 703 | }, 704 | "dependencies": { 705 | "is-extendable": { 706 | "version": "1.0.1", 707 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", 708 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", 709 | "dev": true, 710 | "requires": { 711 | "is-plain-object": "^2.0.4" 712 | } 713 | } 714 | } 715 | }, 716 | "extglob": { 717 | "version": "2.0.4", 718 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", 719 | "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", 720 | "dev": true, 721 | "requires": { 722 | "array-unique": "^0.3.2", 723 | "define-property": "^1.0.0", 724 | "expand-brackets": "^2.1.4", 725 | "extend-shallow": "^2.0.1", 726 | "fragment-cache": "^0.2.1", 727 | "regex-not": "^1.0.0", 728 | "snapdragon": "^0.8.1", 729 | "to-regex": "^3.0.1" 730 | }, 731 | "dependencies": { 732 | "define-property": { 733 | "version": "1.0.0", 734 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 735 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 736 | "dev": true, 737 | "requires": { 738 | "is-descriptor": "^1.0.0" 739 | } 740 | }, 741 | "extend-shallow": { 742 | "version": "2.0.1", 743 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 744 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 745 | "dev": true, 746 | "requires": { 747 | "is-extendable": "^0.1.0" 748 | } 749 | }, 750 | "is-accessor-descriptor": { 751 | "version": "1.0.0", 752 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 753 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 754 | "dev": true, 755 | "requires": { 756 | "kind-of": "^6.0.0" 757 | } 758 | }, 759 | "is-data-descriptor": { 760 | "version": "1.0.0", 761 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 762 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 763 | "dev": true, 764 | "requires": { 765 | "kind-of": "^6.0.0" 766 | } 767 | }, 768 | "is-descriptor": { 769 | "version": "1.0.2", 770 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 771 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 772 | "dev": true, 773 | "requires": { 774 | "is-accessor-descriptor": "^1.0.0", 775 | "is-data-descriptor": "^1.0.0", 776 | "kind-of": "^6.0.2" 777 | } 778 | } 779 | } 780 | }, 781 | "fill-range": { 782 | "version": "4.0.0", 783 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", 784 | "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", 785 | "dev": true, 786 | "requires": { 787 | "extend-shallow": "^2.0.1", 788 | "is-number": "^3.0.0", 789 | "repeat-string": "^1.6.1", 790 | "to-regex-range": "^2.1.0" 791 | }, 792 | "dependencies": { 793 | "extend-shallow": { 794 | "version": "2.0.1", 795 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 796 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 797 | "dev": true, 798 | "requires": { 799 | "is-extendable": "^0.1.0" 800 | } 801 | } 802 | } 803 | }, 804 | "finalhandler": { 805 | "version": "1.1.2", 806 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 807 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 808 | "requires": { 809 | "debug": "2.6.9", 810 | "encodeurl": "~1.0.2", 811 | "escape-html": "~1.0.3", 812 | "on-finished": "~2.3.0", 813 | "parseurl": "~1.3.3", 814 | "statuses": "~1.5.0", 815 | "unpipe": "~1.0.0" 816 | } 817 | }, 818 | "for-in": { 819 | "version": "1.0.2", 820 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 821 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", 822 | "dev": true 823 | }, 824 | "forwarded": { 825 | "version": "0.1.2", 826 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 827 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 828 | }, 829 | "fragment-cache": { 830 | "version": "0.2.1", 831 | "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", 832 | "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", 833 | "dev": true, 834 | "requires": { 835 | "map-cache": "^0.2.2" 836 | } 837 | }, 838 | "fresh": { 839 | "version": "0.5.2", 840 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 841 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 842 | }, 843 | "fsevents": { 844 | "version": "1.2.9", 845 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.9.tgz", 846 | "integrity": "sha512-oeyj2H3EjjonWcFjD5NvZNE9Rqe4UW+nQBU2HNeKw0koVLEFIhtyETyAakeAM3de7Z/SW5kcA+fZUait9EApnw==", 847 | "dev": true, 848 | "optional": true, 849 | "requires": { 850 | "nan": "^2.12.1", 851 | "node-pre-gyp": "^0.12.0" 852 | }, 853 | "dependencies": { 854 | "abbrev": { 855 | "version": "1.1.1", 856 | "bundled": true, 857 | "dev": true, 858 | "optional": true 859 | }, 860 | "ansi-regex": { 861 | "version": "2.1.1", 862 | "bundled": true, 863 | "dev": true, 864 | "optional": true 865 | }, 866 | "aproba": { 867 | "version": "1.2.0", 868 | "bundled": true, 869 | "dev": true, 870 | "optional": true 871 | }, 872 | "are-we-there-yet": { 873 | "version": "1.1.5", 874 | "bundled": true, 875 | "dev": true, 876 | "optional": true, 877 | "requires": { 878 | "delegates": "^1.0.0", 879 | "readable-stream": "^2.0.6" 880 | } 881 | }, 882 | "balanced-match": { 883 | "version": "1.0.0", 884 | "bundled": true, 885 | "dev": true, 886 | "optional": true 887 | }, 888 | "brace-expansion": { 889 | "version": "1.1.11", 890 | "bundled": true, 891 | "dev": true, 892 | "optional": true, 893 | "requires": { 894 | "balanced-match": "^1.0.0", 895 | "concat-map": "0.0.1" 896 | } 897 | }, 898 | "chownr": { 899 | "version": "1.1.1", 900 | "bundled": true, 901 | "dev": true, 902 | "optional": true 903 | }, 904 | "code-point-at": { 905 | "version": "1.1.0", 906 | "bundled": true, 907 | "dev": true, 908 | "optional": true 909 | }, 910 | "concat-map": { 911 | "version": "0.0.1", 912 | "bundled": true, 913 | "dev": true, 914 | "optional": true 915 | }, 916 | "console-control-strings": { 917 | "version": "1.1.0", 918 | "bundled": true, 919 | "dev": true, 920 | "optional": true 921 | }, 922 | "core-util-is": { 923 | "version": "1.0.2", 924 | "bundled": true, 925 | "dev": true, 926 | "optional": true 927 | }, 928 | "debug": { 929 | "version": "4.1.1", 930 | "bundled": true, 931 | "dev": true, 932 | "optional": true, 933 | "requires": { 934 | "ms": "^2.1.1" 935 | } 936 | }, 937 | "deep-extend": { 938 | "version": "0.6.0", 939 | "bundled": true, 940 | "dev": true, 941 | "optional": true 942 | }, 943 | "delegates": { 944 | "version": "1.0.0", 945 | "bundled": true, 946 | "dev": true, 947 | "optional": true 948 | }, 949 | "detect-libc": { 950 | "version": "1.0.3", 951 | "bundled": true, 952 | "dev": true, 953 | "optional": true 954 | }, 955 | "fs-minipass": { 956 | "version": "1.2.5", 957 | "bundled": true, 958 | "dev": true, 959 | "optional": true, 960 | "requires": { 961 | "minipass": "^2.2.1" 962 | } 963 | }, 964 | "fs.realpath": { 965 | "version": "1.0.0", 966 | "bundled": true, 967 | "dev": true, 968 | "optional": true 969 | }, 970 | "gauge": { 971 | "version": "2.7.4", 972 | "bundled": true, 973 | "dev": true, 974 | "optional": true, 975 | "requires": { 976 | "aproba": "^1.0.3", 977 | "console-control-strings": "^1.0.0", 978 | "has-unicode": "^2.0.0", 979 | "object-assign": "^4.1.0", 980 | "signal-exit": "^3.0.0", 981 | "string-width": "^1.0.1", 982 | "strip-ansi": "^3.0.1", 983 | "wide-align": "^1.1.0" 984 | } 985 | }, 986 | "glob": { 987 | "version": "7.1.3", 988 | "bundled": true, 989 | "dev": true, 990 | "optional": true, 991 | "requires": { 992 | "fs.realpath": "^1.0.0", 993 | "inflight": "^1.0.4", 994 | "inherits": "2", 995 | "minimatch": "^3.0.4", 996 | "once": "^1.3.0", 997 | "path-is-absolute": "^1.0.0" 998 | } 999 | }, 1000 | "has-unicode": { 1001 | "version": "2.0.1", 1002 | "bundled": true, 1003 | "dev": true, 1004 | "optional": true 1005 | }, 1006 | "iconv-lite": { 1007 | "version": "0.4.24", 1008 | "bundled": true, 1009 | "dev": true, 1010 | "optional": true, 1011 | "requires": { 1012 | "safer-buffer": ">= 2.1.2 < 3" 1013 | } 1014 | }, 1015 | "ignore-walk": { 1016 | "version": "3.0.1", 1017 | "bundled": true, 1018 | "dev": true, 1019 | "optional": true, 1020 | "requires": { 1021 | "minimatch": "^3.0.4" 1022 | } 1023 | }, 1024 | "inflight": { 1025 | "version": "1.0.6", 1026 | "bundled": true, 1027 | "dev": true, 1028 | "optional": true, 1029 | "requires": { 1030 | "once": "^1.3.0", 1031 | "wrappy": "1" 1032 | } 1033 | }, 1034 | "inherits": { 1035 | "version": "2.0.3", 1036 | "bundled": true, 1037 | "dev": true, 1038 | "optional": true 1039 | }, 1040 | "ini": { 1041 | "version": "1.3.5", 1042 | "bundled": true, 1043 | "dev": true, 1044 | "optional": true 1045 | }, 1046 | "is-fullwidth-code-point": { 1047 | "version": "1.0.0", 1048 | "bundled": true, 1049 | "dev": true, 1050 | "optional": true, 1051 | "requires": { 1052 | "number-is-nan": "^1.0.0" 1053 | } 1054 | }, 1055 | "isarray": { 1056 | "version": "1.0.0", 1057 | "bundled": true, 1058 | "dev": true, 1059 | "optional": true 1060 | }, 1061 | "minimatch": { 1062 | "version": "3.0.4", 1063 | "bundled": true, 1064 | "dev": true, 1065 | "optional": true, 1066 | "requires": { 1067 | "brace-expansion": "^1.1.7" 1068 | } 1069 | }, 1070 | "minimist": { 1071 | "version": "0.0.8", 1072 | "bundled": true, 1073 | "dev": true, 1074 | "optional": true 1075 | }, 1076 | "minipass": { 1077 | "version": "2.3.5", 1078 | "bundled": true, 1079 | "dev": true, 1080 | "optional": true, 1081 | "requires": { 1082 | "safe-buffer": "^5.1.2", 1083 | "yallist": "^3.0.0" 1084 | } 1085 | }, 1086 | "minizlib": { 1087 | "version": "1.2.1", 1088 | "bundled": true, 1089 | "dev": true, 1090 | "optional": true, 1091 | "requires": { 1092 | "minipass": "^2.2.1" 1093 | } 1094 | }, 1095 | "mkdirp": { 1096 | "version": "0.5.1", 1097 | "bundled": true, 1098 | "dev": true, 1099 | "optional": true, 1100 | "requires": { 1101 | "minimist": "0.0.8" 1102 | } 1103 | }, 1104 | "ms": { 1105 | "version": "2.1.1", 1106 | "bundled": true, 1107 | "dev": true, 1108 | "optional": true 1109 | }, 1110 | "needle": { 1111 | "version": "2.3.0", 1112 | "bundled": true, 1113 | "dev": true, 1114 | "optional": true, 1115 | "requires": { 1116 | "debug": "^4.1.0", 1117 | "iconv-lite": "^0.4.4", 1118 | "sax": "^1.2.4" 1119 | } 1120 | }, 1121 | "node-pre-gyp": { 1122 | "version": "0.12.0", 1123 | "bundled": true, 1124 | "dev": true, 1125 | "optional": true, 1126 | "requires": { 1127 | "detect-libc": "^1.0.2", 1128 | "mkdirp": "^0.5.1", 1129 | "needle": "^2.2.1", 1130 | "nopt": "^4.0.1", 1131 | "npm-packlist": "^1.1.6", 1132 | "npmlog": "^4.0.2", 1133 | "rc": "^1.2.7", 1134 | "rimraf": "^2.6.1", 1135 | "semver": "^5.3.0", 1136 | "tar": "^4" 1137 | } 1138 | }, 1139 | "nopt": { 1140 | "version": "4.0.1", 1141 | "bundled": true, 1142 | "dev": true, 1143 | "optional": true, 1144 | "requires": { 1145 | "abbrev": "1", 1146 | "osenv": "^0.1.4" 1147 | } 1148 | }, 1149 | "npm-bundled": { 1150 | "version": "1.0.6", 1151 | "bundled": true, 1152 | "dev": true, 1153 | "optional": true 1154 | }, 1155 | "npm-packlist": { 1156 | "version": "1.4.1", 1157 | "bundled": true, 1158 | "dev": true, 1159 | "optional": true, 1160 | "requires": { 1161 | "ignore-walk": "^3.0.1", 1162 | "npm-bundled": "^1.0.1" 1163 | } 1164 | }, 1165 | "npmlog": { 1166 | "version": "4.1.2", 1167 | "bundled": true, 1168 | "dev": true, 1169 | "optional": true, 1170 | "requires": { 1171 | "are-we-there-yet": "~1.1.2", 1172 | "console-control-strings": "~1.1.0", 1173 | "gauge": "~2.7.3", 1174 | "set-blocking": "~2.0.0" 1175 | } 1176 | }, 1177 | "number-is-nan": { 1178 | "version": "1.0.1", 1179 | "bundled": true, 1180 | "dev": true, 1181 | "optional": true 1182 | }, 1183 | "object-assign": { 1184 | "version": "4.1.1", 1185 | "bundled": true, 1186 | "dev": true, 1187 | "optional": true 1188 | }, 1189 | "once": { 1190 | "version": "1.4.0", 1191 | "bundled": true, 1192 | "dev": true, 1193 | "optional": true, 1194 | "requires": { 1195 | "wrappy": "1" 1196 | } 1197 | }, 1198 | "os-homedir": { 1199 | "version": "1.0.2", 1200 | "bundled": true, 1201 | "dev": true, 1202 | "optional": true 1203 | }, 1204 | "os-tmpdir": { 1205 | "version": "1.0.2", 1206 | "bundled": true, 1207 | "dev": true, 1208 | "optional": true 1209 | }, 1210 | "osenv": { 1211 | "version": "0.1.5", 1212 | "bundled": true, 1213 | "dev": true, 1214 | "optional": true, 1215 | "requires": { 1216 | "os-homedir": "^1.0.0", 1217 | "os-tmpdir": "^1.0.0" 1218 | } 1219 | }, 1220 | "path-is-absolute": { 1221 | "version": "1.0.1", 1222 | "bundled": true, 1223 | "dev": true, 1224 | "optional": true 1225 | }, 1226 | "process-nextick-args": { 1227 | "version": "2.0.0", 1228 | "bundled": true, 1229 | "dev": true, 1230 | "optional": true 1231 | }, 1232 | "rc": { 1233 | "version": "1.2.8", 1234 | "bundled": true, 1235 | "dev": true, 1236 | "optional": true, 1237 | "requires": { 1238 | "deep-extend": "^0.6.0", 1239 | "ini": "~1.3.0", 1240 | "minimist": "^1.2.0", 1241 | "strip-json-comments": "~2.0.1" 1242 | }, 1243 | "dependencies": { 1244 | "minimist": { 1245 | "version": "1.2.0", 1246 | "bundled": true, 1247 | "dev": true, 1248 | "optional": true 1249 | } 1250 | } 1251 | }, 1252 | "readable-stream": { 1253 | "version": "2.3.6", 1254 | "bundled": true, 1255 | "dev": true, 1256 | "optional": true, 1257 | "requires": { 1258 | "core-util-is": "~1.0.0", 1259 | "inherits": "~2.0.3", 1260 | "isarray": "~1.0.0", 1261 | "process-nextick-args": "~2.0.0", 1262 | "safe-buffer": "~5.1.1", 1263 | "string_decoder": "~1.1.1", 1264 | "util-deprecate": "~1.0.1" 1265 | } 1266 | }, 1267 | "rimraf": { 1268 | "version": "2.6.3", 1269 | "bundled": true, 1270 | "dev": true, 1271 | "optional": true, 1272 | "requires": { 1273 | "glob": "^7.1.3" 1274 | } 1275 | }, 1276 | "safe-buffer": { 1277 | "version": "5.1.2", 1278 | "bundled": true, 1279 | "dev": true, 1280 | "optional": true 1281 | }, 1282 | "safer-buffer": { 1283 | "version": "2.1.2", 1284 | "bundled": true, 1285 | "dev": true, 1286 | "optional": true 1287 | }, 1288 | "sax": { 1289 | "version": "1.2.4", 1290 | "bundled": true, 1291 | "dev": true, 1292 | "optional": true 1293 | }, 1294 | "semver": { 1295 | "version": "5.7.0", 1296 | "bundled": true, 1297 | "dev": true, 1298 | "optional": true 1299 | }, 1300 | "set-blocking": { 1301 | "version": "2.0.0", 1302 | "bundled": true, 1303 | "dev": true, 1304 | "optional": true 1305 | }, 1306 | "signal-exit": { 1307 | "version": "3.0.2", 1308 | "bundled": true, 1309 | "dev": true, 1310 | "optional": true 1311 | }, 1312 | "string-width": { 1313 | "version": "1.0.2", 1314 | "bundled": true, 1315 | "dev": true, 1316 | "optional": true, 1317 | "requires": { 1318 | "code-point-at": "^1.0.0", 1319 | "is-fullwidth-code-point": "^1.0.0", 1320 | "strip-ansi": "^3.0.0" 1321 | } 1322 | }, 1323 | "string_decoder": { 1324 | "version": "1.1.1", 1325 | "bundled": true, 1326 | "dev": true, 1327 | "optional": true, 1328 | "requires": { 1329 | "safe-buffer": "~5.1.0" 1330 | } 1331 | }, 1332 | "strip-ansi": { 1333 | "version": "3.0.1", 1334 | "bundled": true, 1335 | "dev": true, 1336 | "optional": true, 1337 | "requires": { 1338 | "ansi-regex": "^2.0.0" 1339 | } 1340 | }, 1341 | "strip-json-comments": { 1342 | "version": "2.0.1", 1343 | "bundled": true, 1344 | "dev": true, 1345 | "optional": true 1346 | }, 1347 | "tar": { 1348 | "version": "4.4.8", 1349 | "bundled": true, 1350 | "dev": true, 1351 | "optional": true, 1352 | "requires": { 1353 | "chownr": "^1.1.1", 1354 | "fs-minipass": "^1.2.5", 1355 | "minipass": "^2.3.4", 1356 | "minizlib": "^1.1.1", 1357 | "mkdirp": "^0.5.0", 1358 | "safe-buffer": "^5.1.2", 1359 | "yallist": "^3.0.2" 1360 | } 1361 | }, 1362 | "util-deprecate": { 1363 | "version": "1.0.2", 1364 | "bundled": true, 1365 | "dev": true, 1366 | "optional": true 1367 | }, 1368 | "wide-align": { 1369 | "version": "1.1.3", 1370 | "bundled": true, 1371 | "dev": true, 1372 | "optional": true, 1373 | "requires": { 1374 | "string-width": "^1.0.2 || 2" 1375 | } 1376 | }, 1377 | "wrappy": { 1378 | "version": "1.0.2", 1379 | "bundled": true, 1380 | "dev": true, 1381 | "optional": true 1382 | }, 1383 | "yallist": { 1384 | "version": "3.0.3", 1385 | "bundled": true, 1386 | "dev": true, 1387 | "optional": true 1388 | } 1389 | } 1390 | }, 1391 | "get-stream": { 1392 | "version": "3.0.0", 1393 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", 1394 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=", 1395 | "dev": true 1396 | }, 1397 | "get-value": { 1398 | "version": "2.0.6", 1399 | "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", 1400 | "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=", 1401 | "dev": true 1402 | }, 1403 | "glob-parent": { 1404 | "version": "3.1.0", 1405 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", 1406 | "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", 1407 | "dev": true, 1408 | "requires": { 1409 | "is-glob": "^3.1.0", 1410 | "path-dirname": "^1.0.0" 1411 | }, 1412 | "dependencies": { 1413 | "is-glob": { 1414 | "version": "3.1.0", 1415 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", 1416 | "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", 1417 | "dev": true, 1418 | "requires": { 1419 | "is-extglob": "^2.1.0" 1420 | } 1421 | } 1422 | } 1423 | }, 1424 | "global-dirs": { 1425 | "version": "0.1.1", 1426 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-0.1.1.tgz", 1427 | "integrity": "sha1-sxnA3UYH81PzvpzKTHL8FIxJ9EU=", 1428 | "dev": true, 1429 | "requires": { 1430 | "ini": "^1.3.4" 1431 | } 1432 | }, 1433 | "got": { 1434 | "version": "6.7.1", 1435 | "resolved": "https://registry.npmjs.org/got/-/got-6.7.1.tgz", 1436 | "integrity": "sha1-JAzQV4WpoY5WHcG0S0HHY+8ejbA=", 1437 | "dev": true, 1438 | "requires": { 1439 | "create-error-class": "^3.0.0", 1440 | "duplexer3": "^0.1.4", 1441 | "get-stream": "^3.0.0", 1442 | "is-redirect": "^1.0.0", 1443 | "is-retry-allowed": "^1.0.0", 1444 | "is-stream": "^1.0.0", 1445 | "lowercase-keys": "^1.0.0", 1446 | "safe-buffer": "^5.0.1", 1447 | "timed-out": "^4.0.0", 1448 | "unzip-response": "^2.0.1", 1449 | "url-parse-lax": "^1.0.0" 1450 | } 1451 | }, 1452 | "graceful-fs": { 1453 | "version": "4.2.3", 1454 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.3.tgz", 1455 | "integrity": "sha512-a30VEBm4PEdx1dRB7MFK7BejejvCvBronbLjht+sHuGYj8PHs7M/5Z+rt5lw551vZ7yfTCj4Vuyy3mSJytDWRQ==", 1456 | "dev": true 1457 | }, 1458 | "has-flag": { 1459 | "version": "3.0.0", 1460 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1461 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1462 | "dev": true 1463 | }, 1464 | "has-value": { 1465 | "version": "1.0.0", 1466 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", 1467 | "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", 1468 | "dev": true, 1469 | "requires": { 1470 | "get-value": "^2.0.6", 1471 | "has-values": "^1.0.0", 1472 | "isobject": "^3.0.0" 1473 | } 1474 | }, 1475 | "has-values": { 1476 | "version": "1.0.0", 1477 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", 1478 | "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", 1479 | "dev": true, 1480 | "requires": { 1481 | "is-number": "^3.0.0", 1482 | "kind-of": "^4.0.0" 1483 | }, 1484 | "dependencies": { 1485 | "kind-of": { 1486 | "version": "4.0.0", 1487 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", 1488 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", 1489 | "dev": true, 1490 | "requires": { 1491 | "is-buffer": "^1.1.5" 1492 | } 1493 | } 1494 | } 1495 | }, 1496 | "http-errors": { 1497 | "version": "1.7.2", 1498 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 1499 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 1500 | "requires": { 1501 | "depd": "~1.1.2", 1502 | "inherits": "2.0.3", 1503 | "setprototypeof": "1.1.1", 1504 | "statuses": ">= 1.5.0 < 2", 1505 | "toidentifier": "1.0.0" 1506 | } 1507 | }, 1508 | "iconv-lite": { 1509 | "version": "0.4.24", 1510 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1511 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1512 | "requires": { 1513 | "safer-buffer": ">= 2.1.2 < 3" 1514 | } 1515 | }, 1516 | "ignore-by-default": { 1517 | "version": "1.0.1", 1518 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 1519 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 1520 | "dev": true 1521 | }, 1522 | "import-lazy": { 1523 | "version": "2.1.0", 1524 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 1525 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=", 1526 | "dev": true 1527 | }, 1528 | "imurmurhash": { 1529 | "version": "0.1.4", 1530 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1531 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1532 | "dev": true 1533 | }, 1534 | "inherits": { 1535 | "version": "2.0.3", 1536 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1537 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1538 | }, 1539 | "ini": { 1540 | "version": "1.3.5", 1541 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 1542 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", 1543 | "dev": true 1544 | }, 1545 | "ipaddr.js": { 1546 | "version": "1.9.0", 1547 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.0.tgz", 1548 | "integrity": "sha512-M4Sjn6N/+O6/IXSJseKqHoFc+5FdGJ22sXqnjTpdZweHK64MzEPAyQZyEU3R/KRv2GLoa7nNtg/C2Ev6m7z+eA==" 1549 | }, 1550 | "is-accessor-descriptor": { 1551 | "version": "0.1.6", 1552 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", 1553 | "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", 1554 | "dev": true, 1555 | "requires": { 1556 | "kind-of": "^3.0.2" 1557 | }, 1558 | "dependencies": { 1559 | "kind-of": { 1560 | "version": "3.2.2", 1561 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1562 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1563 | "dev": true, 1564 | "requires": { 1565 | "is-buffer": "^1.1.5" 1566 | } 1567 | } 1568 | } 1569 | }, 1570 | "is-binary-path": { 1571 | "version": "1.0.1", 1572 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", 1573 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", 1574 | "dev": true, 1575 | "requires": { 1576 | "binary-extensions": "^1.0.0" 1577 | } 1578 | }, 1579 | "is-buffer": { 1580 | "version": "1.1.6", 1581 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 1582 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 1583 | "dev": true 1584 | }, 1585 | "is-ci": { 1586 | "version": "1.2.1", 1587 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-1.2.1.tgz", 1588 | "integrity": "sha512-s6tfsaQaQi3JNciBH6shVqEDvhGut0SUXr31ag8Pd8BBbVVlcGfWhpPmEOoM6RJ5TFhbypvf5yyRw/VXW1IiWg==", 1589 | "dev": true, 1590 | "requires": { 1591 | "ci-info": "^1.5.0" 1592 | } 1593 | }, 1594 | "is-data-descriptor": { 1595 | "version": "0.1.4", 1596 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", 1597 | "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", 1598 | "dev": true, 1599 | "requires": { 1600 | "kind-of": "^3.0.2" 1601 | }, 1602 | "dependencies": { 1603 | "kind-of": { 1604 | "version": "3.2.2", 1605 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1606 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1607 | "dev": true, 1608 | "requires": { 1609 | "is-buffer": "^1.1.5" 1610 | } 1611 | } 1612 | } 1613 | }, 1614 | "is-descriptor": { 1615 | "version": "0.1.6", 1616 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", 1617 | "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", 1618 | "dev": true, 1619 | "requires": { 1620 | "is-accessor-descriptor": "^0.1.6", 1621 | "is-data-descriptor": "^0.1.4", 1622 | "kind-of": "^5.0.0" 1623 | }, 1624 | "dependencies": { 1625 | "kind-of": { 1626 | "version": "5.1.0", 1627 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", 1628 | "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", 1629 | "dev": true 1630 | } 1631 | } 1632 | }, 1633 | "is-extendable": { 1634 | "version": "0.1.1", 1635 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 1636 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", 1637 | "dev": true 1638 | }, 1639 | "is-extglob": { 1640 | "version": "2.1.1", 1641 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1642 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1643 | "dev": true 1644 | }, 1645 | "is-fullwidth-code-point": { 1646 | "version": "2.0.0", 1647 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1648 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1649 | "dev": true 1650 | }, 1651 | "is-glob": { 1652 | "version": "4.0.1", 1653 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1654 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1655 | "dev": true, 1656 | "requires": { 1657 | "is-extglob": "^2.1.1" 1658 | } 1659 | }, 1660 | "is-installed-globally": { 1661 | "version": "0.1.0", 1662 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.1.0.tgz", 1663 | "integrity": "sha1-Df2Y9akRFxbdU13aZJL2e/PSWoA=", 1664 | "dev": true, 1665 | "requires": { 1666 | "global-dirs": "^0.1.0", 1667 | "is-path-inside": "^1.0.0" 1668 | } 1669 | }, 1670 | "is-npm": { 1671 | "version": "1.0.0", 1672 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-1.0.0.tgz", 1673 | "integrity": "sha1-8vtjpl5JBbQGyGBydloaTceTufQ=", 1674 | "dev": true 1675 | }, 1676 | "is-number": { 1677 | "version": "3.0.0", 1678 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", 1679 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", 1680 | "dev": true, 1681 | "requires": { 1682 | "kind-of": "^3.0.2" 1683 | }, 1684 | "dependencies": { 1685 | "kind-of": { 1686 | "version": "3.2.2", 1687 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1688 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1689 | "dev": true, 1690 | "requires": { 1691 | "is-buffer": "^1.1.5" 1692 | } 1693 | } 1694 | } 1695 | }, 1696 | "is-obj": { 1697 | "version": "1.0.1", 1698 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", 1699 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=", 1700 | "dev": true 1701 | }, 1702 | "is-path-inside": { 1703 | "version": "1.0.1", 1704 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz", 1705 | "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=", 1706 | "dev": true, 1707 | "requires": { 1708 | "path-is-inside": "^1.0.1" 1709 | } 1710 | }, 1711 | "is-plain-object": { 1712 | "version": "2.0.4", 1713 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", 1714 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", 1715 | "dev": true, 1716 | "requires": { 1717 | "isobject": "^3.0.1" 1718 | } 1719 | }, 1720 | "is-redirect": { 1721 | "version": "1.0.0", 1722 | "resolved": "https://registry.npmjs.org/is-redirect/-/is-redirect-1.0.0.tgz", 1723 | "integrity": "sha1-HQPd7VO9jbDzDCbk+V02/HyH3CQ=", 1724 | "dev": true 1725 | }, 1726 | "is-retry-allowed": { 1727 | "version": "1.2.0", 1728 | "resolved": "https://registry.npmjs.org/is-retry-allowed/-/is-retry-allowed-1.2.0.tgz", 1729 | "integrity": "sha512-RUbUeKwvm3XG2VYamhJL1xFktgjvPzL0Hq8C+6yrWIswDy3BIXGqCxhxkc30N9jqK311gVU137K8Ei55/zVJRg==", 1730 | "dev": true 1731 | }, 1732 | "is-stream": { 1733 | "version": "1.1.0", 1734 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 1735 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", 1736 | "dev": true 1737 | }, 1738 | "is-windows": { 1739 | "version": "1.0.2", 1740 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", 1741 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", 1742 | "dev": true 1743 | }, 1744 | "isarray": { 1745 | "version": "1.0.0", 1746 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1747 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1748 | "dev": true 1749 | }, 1750 | "isexe": { 1751 | "version": "2.0.0", 1752 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1753 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1754 | "dev": true 1755 | }, 1756 | "isobject": { 1757 | "version": "3.0.1", 1758 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", 1759 | "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", 1760 | "dev": true 1761 | }, 1762 | "jsonwebtoken": { 1763 | "version": "8.5.1", 1764 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", 1765 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", 1766 | "requires": { 1767 | "jws": "^3.2.2", 1768 | "lodash.includes": "^4.3.0", 1769 | "lodash.isboolean": "^3.0.3", 1770 | "lodash.isinteger": "^4.0.4", 1771 | "lodash.isnumber": "^3.0.3", 1772 | "lodash.isplainobject": "^4.0.6", 1773 | "lodash.isstring": "^4.0.1", 1774 | "lodash.once": "^4.0.0", 1775 | "ms": "^2.1.1", 1776 | "semver": "^5.6.0" 1777 | }, 1778 | "dependencies": { 1779 | "ms": { 1780 | "version": "2.1.2", 1781 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1782 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1783 | } 1784 | } 1785 | }, 1786 | "jwa": { 1787 | "version": "1.4.1", 1788 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 1789 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 1790 | "requires": { 1791 | "buffer-equal-constant-time": "1.0.1", 1792 | "ecdsa-sig-formatter": "1.0.11", 1793 | "safe-buffer": "^5.0.1" 1794 | } 1795 | }, 1796 | "jws": { 1797 | "version": "3.2.2", 1798 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 1799 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 1800 | "requires": { 1801 | "jwa": "^1.4.1", 1802 | "safe-buffer": "^5.0.1" 1803 | } 1804 | }, 1805 | "kareem": { 1806 | "version": "2.3.1", 1807 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.1.tgz", 1808 | "integrity": "sha512-l3hLhffs9zqoDe8zjmb/mAN4B8VT3L56EUvKNqLFVs9YlFA+zx7ke1DO8STAdDyYNkeSo1nKmjuvQeI12So8Xw==" 1809 | }, 1810 | "kind-of": { 1811 | "version": "6.0.2", 1812 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", 1813 | "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", 1814 | "dev": true 1815 | }, 1816 | "latest-version": { 1817 | "version": "3.1.0", 1818 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-3.1.0.tgz", 1819 | "integrity": "sha1-ogU4P+oyKzO1rjsYq+4NwvNW7hU=", 1820 | "dev": true, 1821 | "requires": { 1822 | "package-json": "^4.0.0" 1823 | } 1824 | }, 1825 | "lodash.includes": { 1826 | "version": "4.3.0", 1827 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 1828 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 1829 | }, 1830 | "lodash.isboolean": { 1831 | "version": "3.0.3", 1832 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 1833 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 1834 | }, 1835 | "lodash.isinteger": { 1836 | "version": "4.0.4", 1837 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 1838 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 1839 | }, 1840 | "lodash.isnumber": { 1841 | "version": "3.0.3", 1842 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 1843 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 1844 | }, 1845 | "lodash.isplainobject": { 1846 | "version": "4.0.6", 1847 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 1848 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 1849 | }, 1850 | "lodash.isstring": { 1851 | "version": "4.0.1", 1852 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 1853 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 1854 | }, 1855 | "lodash.once": { 1856 | "version": "4.1.1", 1857 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1858 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 1859 | }, 1860 | "lowercase-keys": { 1861 | "version": "1.0.1", 1862 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 1863 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==", 1864 | "dev": true 1865 | }, 1866 | "lru-cache": { 1867 | "version": "4.1.5", 1868 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", 1869 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", 1870 | "dev": true, 1871 | "requires": { 1872 | "pseudomap": "^1.0.2", 1873 | "yallist": "^2.1.2" 1874 | } 1875 | }, 1876 | "make-dir": { 1877 | "version": "1.3.0", 1878 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.3.0.tgz", 1879 | "integrity": "sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ==", 1880 | "dev": true, 1881 | "requires": { 1882 | "pify": "^3.0.0" 1883 | } 1884 | }, 1885 | "map-cache": { 1886 | "version": "0.2.2", 1887 | "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", 1888 | "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", 1889 | "dev": true 1890 | }, 1891 | "map-visit": { 1892 | "version": "1.0.0", 1893 | "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", 1894 | "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", 1895 | "dev": true, 1896 | "requires": { 1897 | "object-visit": "^1.0.0" 1898 | } 1899 | }, 1900 | "media-typer": { 1901 | "version": "0.3.0", 1902 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1903 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1904 | }, 1905 | "memory-pager": { 1906 | "version": "1.5.0", 1907 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1908 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 1909 | "optional": true 1910 | }, 1911 | "merge-descriptors": { 1912 | "version": "1.0.1", 1913 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1914 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1915 | }, 1916 | "methods": { 1917 | "version": "1.1.2", 1918 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1919 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1920 | }, 1921 | "micromatch": { 1922 | "version": "3.1.10", 1923 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", 1924 | "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", 1925 | "dev": true, 1926 | "requires": { 1927 | "arr-diff": "^4.0.0", 1928 | "array-unique": "^0.3.2", 1929 | "braces": "^2.3.1", 1930 | "define-property": "^2.0.2", 1931 | "extend-shallow": "^3.0.2", 1932 | "extglob": "^2.0.4", 1933 | "fragment-cache": "^0.2.1", 1934 | "kind-of": "^6.0.2", 1935 | "nanomatch": "^1.2.9", 1936 | "object.pick": "^1.3.0", 1937 | "regex-not": "^1.0.0", 1938 | "snapdragon": "^0.8.1", 1939 | "to-regex": "^3.0.2" 1940 | } 1941 | }, 1942 | "mime": { 1943 | "version": "1.6.0", 1944 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1945 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 1946 | }, 1947 | "mime-db": { 1948 | "version": "1.40.0", 1949 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", 1950 | "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==" 1951 | }, 1952 | "mime-types": { 1953 | "version": "2.1.24", 1954 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", 1955 | "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", 1956 | "requires": { 1957 | "mime-db": "1.40.0" 1958 | } 1959 | }, 1960 | "minimatch": { 1961 | "version": "3.0.4", 1962 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1963 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1964 | "dev": true, 1965 | "requires": { 1966 | "brace-expansion": "^1.1.7" 1967 | } 1968 | }, 1969 | "minimist": { 1970 | "version": "1.2.0", 1971 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1972 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 1973 | "dev": true 1974 | }, 1975 | "mixin-deep": { 1976 | "version": "1.3.2", 1977 | "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.2.tgz", 1978 | "integrity": "sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA==", 1979 | "dev": true, 1980 | "requires": { 1981 | "for-in": "^1.0.2", 1982 | "is-extendable": "^1.0.1" 1983 | }, 1984 | "dependencies": { 1985 | "is-extendable": { 1986 | "version": "1.0.1", 1987 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", 1988 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", 1989 | "dev": true, 1990 | "requires": { 1991 | "is-plain-object": "^2.0.4" 1992 | } 1993 | } 1994 | } 1995 | }, 1996 | "mongodb": { 1997 | "version": "3.3.3", 1998 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.3.3.tgz", 1999 | "integrity": "sha512-MdRnoOjstmnrKJsK8PY0PjP6fyF/SBS4R8coxmhsfEU7tQ46/J6j+aSHF2n4c2/H8B+Hc/Klbfp8vggZfI0mmA==", 2000 | "requires": { 2001 | "bson": "^1.1.1", 2002 | "require_optional": "^1.0.1", 2003 | "safe-buffer": "^5.1.2", 2004 | "saslprep": "^1.0.0" 2005 | } 2006 | }, 2007 | "mongoose": { 2008 | "version": "5.7.8", 2009 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.7.8.tgz", 2010 | "integrity": "sha512-GsFXYo7z3ebnIDdnqlDJYQXQFqEGS+yxfdY9G0B7fxpvUJchDpwLGuGJdVd1QbGxu2l0DscCYBO0ntl3G6OACA==", 2011 | "requires": { 2012 | "bson": "~1.1.1", 2013 | "kareem": "2.3.1", 2014 | "mongodb": "3.3.3", 2015 | "mongoose-legacy-pluralize": "1.0.2", 2016 | "mpath": "0.6.0", 2017 | "mquery": "3.2.2", 2018 | "ms": "2.1.2", 2019 | "regexp-clone": "1.0.0", 2020 | "safe-buffer": "5.1.2", 2021 | "sift": "7.0.1", 2022 | "sliced": "1.0.1" 2023 | }, 2024 | "dependencies": { 2025 | "ms": { 2026 | "version": "2.1.2", 2027 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2028 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2029 | } 2030 | } 2031 | }, 2032 | "mongoose-legacy-pluralize": { 2033 | "version": "1.0.2", 2034 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz", 2035 | "integrity": "sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ==" 2036 | }, 2037 | "mpath": { 2038 | "version": "0.6.0", 2039 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.6.0.tgz", 2040 | "integrity": "sha512-i75qh79MJ5Xo/sbhxrDrPSEG0H/mr1kcZXJ8dH6URU5jD/knFxCVqVC/gVSW7GIXL/9hHWlT9haLbCXWOll3qw==" 2041 | }, 2042 | "mquery": { 2043 | "version": "3.2.2", 2044 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.2.2.tgz", 2045 | "integrity": "sha512-XB52992COp0KP230I3qloVUbkLUxJIu328HBP2t2EsxSFtf4W1HPSOBWOXf1bqxK4Xbb66lfMJ+Bpfd9/yZE1Q==", 2046 | "requires": { 2047 | "bluebird": "3.5.1", 2048 | "debug": "3.1.0", 2049 | "regexp-clone": "^1.0.0", 2050 | "safe-buffer": "5.1.2", 2051 | "sliced": "1.0.1" 2052 | }, 2053 | "dependencies": { 2054 | "debug": { 2055 | "version": "3.1.0", 2056 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 2057 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 2058 | "requires": { 2059 | "ms": "2.0.0" 2060 | } 2061 | } 2062 | } 2063 | }, 2064 | "ms": { 2065 | "version": "2.0.0", 2066 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2067 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2068 | }, 2069 | "nan": { 2070 | "version": "2.14.0", 2071 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.0.tgz", 2072 | "integrity": "sha512-INOFj37C7k3AfaNTtX8RhsTw7qRy7eLET14cROi9+5HAVbbHuIWUHEauBv5qT4Av2tWasiTY1Jw6puUNqRJXQg==", 2073 | "dev": true, 2074 | "optional": true 2075 | }, 2076 | "nanomatch": { 2077 | "version": "1.2.13", 2078 | "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", 2079 | "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", 2080 | "dev": true, 2081 | "requires": { 2082 | "arr-diff": "^4.0.0", 2083 | "array-unique": "^0.3.2", 2084 | "define-property": "^2.0.2", 2085 | "extend-shallow": "^3.0.2", 2086 | "fragment-cache": "^0.2.1", 2087 | "is-windows": "^1.0.2", 2088 | "kind-of": "^6.0.2", 2089 | "object.pick": "^1.3.0", 2090 | "regex-not": "^1.0.0", 2091 | "snapdragon": "^0.8.1", 2092 | "to-regex": "^3.0.1" 2093 | } 2094 | }, 2095 | "negotiator": { 2096 | "version": "0.6.2", 2097 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 2098 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 2099 | }, 2100 | "nodemon": { 2101 | "version": "1.19.4", 2102 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-1.19.4.tgz", 2103 | "integrity": "sha512-VGPaqQBNk193lrJFotBU8nvWZPqEZY2eIzymy2jjY0fJ9qIsxA0sxQ8ATPl0gZC645gijYEc1jtZvpS8QWzJGQ==", 2104 | "dev": true, 2105 | "requires": { 2106 | "chokidar": "^2.1.8", 2107 | "debug": "^3.2.6", 2108 | "ignore-by-default": "^1.0.1", 2109 | "minimatch": "^3.0.4", 2110 | "pstree.remy": "^1.1.7", 2111 | "semver": "^5.7.1", 2112 | "supports-color": "^5.5.0", 2113 | "touch": "^3.1.0", 2114 | "undefsafe": "^2.0.2", 2115 | "update-notifier": "^2.5.0" 2116 | }, 2117 | "dependencies": { 2118 | "debug": { 2119 | "version": "3.2.6", 2120 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 2121 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 2122 | "dev": true, 2123 | "requires": { 2124 | "ms": "^2.1.1" 2125 | } 2126 | }, 2127 | "ms": { 2128 | "version": "2.1.2", 2129 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2130 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2131 | "dev": true 2132 | } 2133 | } 2134 | }, 2135 | "nopt": { 2136 | "version": "1.0.10", 2137 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 2138 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 2139 | "dev": true, 2140 | "requires": { 2141 | "abbrev": "1" 2142 | } 2143 | }, 2144 | "normalize-path": { 2145 | "version": "3.0.0", 2146 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2147 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2148 | "dev": true 2149 | }, 2150 | "npm-run-path": { 2151 | "version": "2.0.2", 2152 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 2153 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 2154 | "dev": true, 2155 | "requires": { 2156 | "path-key": "^2.0.0" 2157 | } 2158 | }, 2159 | "object-assign": { 2160 | "version": "4.1.1", 2161 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2162 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 2163 | }, 2164 | "object-copy": { 2165 | "version": "0.1.0", 2166 | "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", 2167 | "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", 2168 | "dev": true, 2169 | "requires": { 2170 | "copy-descriptor": "^0.1.0", 2171 | "define-property": "^0.2.5", 2172 | "kind-of": "^3.0.3" 2173 | }, 2174 | "dependencies": { 2175 | "define-property": { 2176 | "version": "0.2.5", 2177 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 2178 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 2179 | "dev": true, 2180 | "requires": { 2181 | "is-descriptor": "^0.1.0" 2182 | } 2183 | }, 2184 | "kind-of": { 2185 | "version": "3.2.2", 2186 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2187 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2188 | "dev": true, 2189 | "requires": { 2190 | "is-buffer": "^1.1.5" 2191 | } 2192 | } 2193 | } 2194 | }, 2195 | "object-visit": { 2196 | "version": "1.0.1", 2197 | "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", 2198 | "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", 2199 | "dev": true, 2200 | "requires": { 2201 | "isobject": "^3.0.0" 2202 | } 2203 | }, 2204 | "object.pick": { 2205 | "version": "1.3.0", 2206 | "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", 2207 | "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", 2208 | "dev": true, 2209 | "requires": { 2210 | "isobject": "^3.0.1" 2211 | } 2212 | }, 2213 | "on-finished": { 2214 | "version": "2.3.0", 2215 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 2216 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 2217 | "requires": { 2218 | "ee-first": "1.1.1" 2219 | } 2220 | }, 2221 | "p-finally": { 2222 | "version": "1.0.0", 2223 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 2224 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=", 2225 | "dev": true 2226 | }, 2227 | "package-json": { 2228 | "version": "4.0.1", 2229 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-4.0.1.tgz", 2230 | "integrity": "sha1-iGmgQBJTZhxMTKPabCEh7VVfXu0=", 2231 | "dev": true, 2232 | "requires": { 2233 | "got": "^6.7.1", 2234 | "registry-auth-token": "^3.0.1", 2235 | "registry-url": "^3.0.3", 2236 | "semver": "^5.1.0" 2237 | } 2238 | }, 2239 | "parseurl": { 2240 | "version": "1.3.3", 2241 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 2242 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 2243 | }, 2244 | "pascalcase": { 2245 | "version": "0.1.1", 2246 | "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", 2247 | "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=", 2248 | "dev": true 2249 | }, 2250 | "path-dirname": { 2251 | "version": "1.0.2", 2252 | "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", 2253 | "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", 2254 | "dev": true 2255 | }, 2256 | "path-is-absolute": { 2257 | "version": "1.0.1", 2258 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2259 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2260 | "dev": true 2261 | }, 2262 | "path-is-inside": { 2263 | "version": "1.0.2", 2264 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 2265 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 2266 | "dev": true 2267 | }, 2268 | "path-key": { 2269 | "version": "2.0.1", 2270 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 2271 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 2272 | "dev": true 2273 | }, 2274 | "path-to-regexp": { 2275 | "version": "0.1.7", 2276 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 2277 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 2278 | }, 2279 | "pify": { 2280 | "version": "3.0.0", 2281 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 2282 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 2283 | "dev": true 2284 | }, 2285 | "posix-character-classes": { 2286 | "version": "0.1.1", 2287 | "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", 2288 | "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=", 2289 | "dev": true 2290 | }, 2291 | "prepend-http": { 2292 | "version": "1.0.4", 2293 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz", 2294 | "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=", 2295 | "dev": true 2296 | }, 2297 | "process-nextick-args": { 2298 | "version": "2.0.1", 2299 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2300 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 2301 | "dev": true 2302 | }, 2303 | "proxy-addr": { 2304 | "version": "2.0.5", 2305 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.5.tgz", 2306 | "integrity": "sha512-t/7RxHXPH6cJtP0pRG6smSr9QJidhB+3kXu0KgXnbGYMgzEnUxRQ4/LDdfOwZEMyIh3/xHb8PX3t+lfL9z+YVQ==", 2307 | "requires": { 2308 | "forwarded": "~0.1.2", 2309 | "ipaddr.js": "1.9.0" 2310 | } 2311 | }, 2312 | "pseudomap": { 2313 | "version": "1.0.2", 2314 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 2315 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", 2316 | "dev": true 2317 | }, 2318 | "pstree.remy": { 2319 | "version": "1.1.7", 2320 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.7.tgz", 2321 | "integrity": "sha512-xsMgrUwRpuGskEzBFkH8NmTimbZ5PcPup0LA8JJkHIm2IMUbQcpo3yeLNWVrufEYjh8YwtSVh0xz6UeWc5Oh5A==", 2322 | "dev": true 2323 | }, 2324 | "qs": { 2325 | "version": "6.7.0", 2326 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 2327 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 2328 | }, 2329 | "range-parser": { 2330 | "version": "1.2.1", 2331 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 2332 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 2333 | }, 2334 | "raw-body": { 2335 | "version": "2.4.0", 2336 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 2337 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 2338 | "requires": { 2339 | "bytes": "3.1.0", 2340 | "http-errors": "1.7.2", 2341 | "iconv-lite": "0.4.24", 2342 | "unpipe": "1.0.0" 2343 | } 2344 | }, 2345 | "rc": { 2346 | "version": "1.2.8", 2347 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 2348 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 2349 | "dev": true, 2350 | "requires": { 2351 | "deep-extend": "^0.6.0", 2352 | "ini": "~1.3.0", 2353 | "minimist": "^1.2.0", 2354 | "strip-json-comments": "~2.0.1" 2355 | } 2356 | }, 2357 | "readable-stream": { 2358 | "version": "2.3.6", 2359 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 2360 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 2361 | "dev": true, 2362 | "requires": { 2363 | "core-util-is": "~1.0.0", 2364 | "inherits": "~2.0.3", 2365 | "isarray": "~1.0.0", 2366 | "process-nextick-args": "~2.0.0", 2367 | "safe-buffer": "~5.1.1", 2368 | "string_decoder": "~1.1.1", 2369 | "util-deprecate": "~1.0.1" 2370 | } 2371 | }, 2372 | "readdirp": { 2373 | "version": "2.2.1", 2374 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz", 2375 | "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==", 2376 | "dev": true, 2377 | "requires": { 2378 | "graceful-fs": "^4.1.11", 2379 | "micromatch": "^3.1.10", 2380 | "readable-stream": "^2.0.2" 2381 | } 2382 | }, 2383 | "regex-not": { 2384 | "version": "1.0.2", 2385 | "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", 2386 | "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", 2387 | "dev": true, 2388 | "requires": { 2389 | "extend-shallow": "^3.0.2", 2390 | "safe-regex": "^1.1.0" 2391 | } 2392 | }, 2393 | "regexp-clone": { 2394 | "version": "1.0.0", 2395 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-1.0.0.tgz", 2396 | "integrity": "sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw==" 2397 | }, 2398 | "registry-auth-token": { 2399 | "version": "3.4.0", 2400 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-3.4.0.tgz", 2401 | "integrity": "sha512-4LM6Fw8eBQdwMYcES4yTnn2TqIasbXuwDx3um+QRs7S55aMKCBKBxvPXl2RiUjHwuJLTyYfxSpmfSAjQpcuP+A==", 2402 | "dev": true, 2403 | "requires": { 2404 | "rc": "^1.1.6", 2405 | "safe-buffer": "^5.0.1" 2406 | } 2407 | }, 2408 | "registry-url": { 2409 | "version": "3.1.0", 2410 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-3.1.0.tgz", 2411 | "integrity": "sha1-PU74cPc93h138M+aOBQyRE4XSUI=", 2412 | "dev": true, 2413 | "requires": { 2414 | "rc": "^1.0.1" 2415 | } 2416 | }, 2417 | "remove-trailing-separator": { 2418 | "version": "1.1.0", 2419 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 2420 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", 2421 | "dev": true 2422 | }, 2423 | "repeat-element": { 2424 | "version": "1.1.3", 2425 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz", 2426 | "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==", 2427 | "dev": true 2428 | }, 2429 | "repeat-string": { 2430 | "version": "1.6.1", 2431 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 2432 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", 2433 | "dev": true 2434 | }, 2435 | "require_optional": { 2436 | "version": "1.0.1", 2437 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 2438 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 2439 | "requires": { 2440 | "resolve-from": "^2.0.0", 2441 | "semver": "^5.1.0" 2442 | } 2443 | }, 2444 | "resolve-from": { 2445 | "version": "2.0.0", 2446 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 2447 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=" 2448 | }, 2449 | "resolve-url": { 2450 | "version": "0.2.1", 2451 | "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", 2452 | "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=", 2453 | "dev": true 2454 | }, 2455 | "ret": { 2456 | "version": "0.1.15", 2457 | "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", 2458 | "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==", 2459 | "dev": true 2460 | }, 2461 | "safe-buffer": { 2462 | "version": "5.1.2", 2463 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2464 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2465 | }, 2466 | "safe-regex": { 2467 | "version": "1.1.0", 2468 | "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", 2469 | "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", 2470 | "dev": true, 2471 | "requires": { 2472 | "ret": "~0.1.10" 2473 | } 2474 | }, 2475 | "safer-buffer": { 2476 | "version": "2.1.2", 2477 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2478 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2479 | }, 2480 | "saslprep": { 2481 | "version": "1.0.3", 2482 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 2483 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 2484 | "optional": true, 2485 | "requires": { 2486 | "sparse-bitfield": "^3.0.3" 2487 | } 2488 | }, 2489 | "semver": { 2490 | "version": "5.7.1", 2491 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 2492 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 2493 | }, 2494 | "semver-diff": { 2495 | "version": "2.1.0", 2496 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-2.1.0.tgz", 2497 | "integrity": "sha1-S7uEN8jTfksM8aaP1ybsbWRdbTY=", 2498 | "dev": true, 2499 | "requires": { 2500 | "semver": "^5.0.3" 2501 | } 2502 | }, 2503 | "send": { 2504 | "version": "0.17.1", 2505 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 2506 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 2507 | "requires": { 2508 | "debug": "2.6.9", 2509 | "depd": "~1.1.2", 2510 | "destroy": "~1.0.4", 2511 | "encodeurl": "~1.0.2", 2512 | "escape-html": "~1.0.3", 2513 | "etag": "~1.8.1", 2514 | "fresh": "0.5.2", 2515 | "http-errors": "~1.7.2", 2516 | "mime": "1.6.0", 2517 | "ms": "2.1.1", 2518 | "on-finished": "~2.3.0", 2519 | "range-parser": "~1.2.1", 2520 | "statuses": "~1.5.0" 2521 | }, 2522 | "dependencies": { 2523 | "ms": { 2524 | "version": "2.1.1", 2525 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 2526 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 2527 | } 2528 | } 2529 | }, 2530 | "serve-static": { 2531 | "version": "1.14.1", 2532 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 2533 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 2534 | "requires": { 2535 | "encodeurl": "~1.0.2", 2536 | "escape-html": "~1.0.3", 2537 | "parseurl": "~1.3.3", 2538 | "send": "0.17.1" 2539 | } 2540 | }, 2541 | "set-value": { 2542 | "version": "2.0.1", 2543 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.1.tgz", 2544 | "integrity": "sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw==", 2545 | "dev": true, 2546 | "requires": { 2547 | "extend-shallow": "^2.0.1", 2548 | "is-extendable": "^0.1.1", 2549 | "is-plain-object": "^2.0.3", 2550 | "split-string": "^3.0.1" 2551 | }, 2552 | "dependencies": { 2553 | "extend-shallow": { 2554 | "version": "2.0.1", 2555 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2556 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2557 | "dev": true, 2558 | "requires": { 2559 | "is-extendable": "^0.1.0" 2560 | } 2561 | } 2562 | } 2563 | }, 2564 | "setprototypeof": { 2565 | "version": "1.1.1", 2566 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 2567 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 2568 | }, 2569 | "shebang-command": { 2570 | "version": "1.2.0", 2571 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2572 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2573 | "dev": true, 2574 | "requires": { 2575 | "shebang-regex": "^1.0.0" 2576 | } 2577 | }, 2578 | "shebang-regex": { 2579 | "version": "1.0.0", 2580 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2581 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2582 | "dev": true 2583 | }, 2584 | "sift": { 2585 | "version": "7.0.1", 2586 | "resolved": "https://registry.npmjs.org/sift/-/sift-7.0.1.tgz", 2587 | "integrity": "sha512-oqD7PMJ+uO6jV9EQCl0LrRw1OwsiPsiFQR5AR30heR+4Dl7jBBbDLnNvWiak20tzZlSE1H7RB30SX/1j/YYT7g==" 2588 | }, 2589 | "signal-exit": { 2590 | "version": "3.0.2", 2591 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2592 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 2593 | "dev": true 2594 | }, 2595 | "sliced": { 2596 | "version": "1.0.1", 2597 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", 2598 | "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E=" 2599 | }, 2600 | "snapdragon": { 2601 | "version": "0.8.2", 2602 | "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", 2603 | "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", 2604 | "dev": true, 2605 | "requires": { 2606 | "base": "^0.11.1", 2607 | "debug": "^2.2.0", 2608 | "define-property": "^0.2.5", 2609 | "extend-shallow": "^2.0.1", 2610 | "map-cache": "^0.2.2", 2611 | "source-map": "^0.5.6", 2612 | "source-map-resolve": "^0.5.0", 2613 | "use": "^3.1.0" 2614 | }, 2615 | "dependencies": { 2616 | "define-property": { 2617 | "version": "0.2.5", 2618 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 2619 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 2620 | "dev": true, 2621 | "requires": { 2622 | "is-descriptor": "^0.1.0" 2623 | } 2624 | }, 2625 | "extend-shallow": { 2626 | "version": "2.0.1", 2627 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2628 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2629 | "dev": true, 2630 | "requires": { 2631 | "is-extendable": "^0.1.0" 2632 | } 2633 | } 2634 | } 2635 | }, 2636 | "snapdragon-node": { 2637 | "version": "2.1.1", 2638 | "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", 2639 | "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", 2640 | "dev": true, 2641 | "requires": { 2642 | "define-property": "^1.0.0", 2643 | "isobject": "^3.0.0", 2644 | "snapdragon-util": "^3.0.1" 2645 | }, 2646 | "dependencies": { 2647 | "define-property": { 2648 | "version": "1.0.0", 2649 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 2650 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 2651 | "dev": true, 2652 | "requires": { 2653 | "is-descriptor": "^1.0.0" 2654 | } 2655 | }, 2656 | "is-accessor-descriptor": { 2657 | "version": "1.0.0", 2658 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 2659 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 2660 | "dev": true, 2661 | "requires": { 2662 | "kind-of": "^6.0.0" 2663 | } 2664 | }, 2665 | "is-data-descriptor": { 2666 | "version": "1.0.0", 2667 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 2668 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 2669 | "dev": true, 2670 | "requires": { 2671 | "kind-of": "^6.0.0" 2672 | } 2673 | }, 2674 | "is-descriptor": { 2675 | "version": "1.0.2", 2676 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 2677 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 2678 | "dev": true, 2679 | "requires": { 2680 | "is-accessor-descriptor": "^1.0.0", 2681 | "is-data-descriptor": "^1.0.0", 2682 | "kind-of": "^6.0.2" 2683 | } 2684 | } 2685 | } 2686 | }, 2687 | "snapdragon-util": { 2688 | "version": "3.0.1", 2689 | "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", 2690 | "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", 2691 | "dev": true, 2692 | "requires": { 2693 | "kind-of": "^3.2.0" 2694 | }, 2695 | "dependencies": { 2696 | "kind-of": { 2697 | "version": "3.2.2", 2698 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2699 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2700 | "dev": true, 2701 | "requires": { 2702 | "is-buffer": "^1.1.5" 2703 | } 2704 | } 2705 | } 2706 | }, 2707 | "source-map": { 2708 | "version": "0.5.7", 2709 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2710 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 2711 | "dev": true 2712 | }, 2713 | "source-map-resolve": { 2714 | "version": "0.5.2", 2715 | "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.2.tgz", 2716 | "integrity": "sha512-MjqsvNwyz1s0k81Goz/9vRBe9SZdB09Bdw+/zYyO+3CuPk6fouTaxscHkgtE8jKvf01kVfl8riHzERQ/kefaSA==", 2717 | "dev": true, 2718 | "requires": { 2719 | "atob": "^2.1.1", 2720 | "decode-uri-component": "^0.2.0", 2721 | "resolve-url": "^0.2.1", 2722 | "source-map-url": "^0.4.0", 2723 | "urix": "^0.1.0" 2724 | } 2725 | }, 2726 | "source-map-url": { 2727 | "version": "0.4.0", 2728 | "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz", 2729 | "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=", 2730 | "dev": true 2731 | }, 2732 | "sparse-bitfield": { 2733 | "version": "3.0.3", 2734 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 2735 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 2736 | "optional": true, 2737 | "requires": { 2738 | "memory-pager": "^1.0.2" 2739 | } 2740 | }, 2741 | "split-string": { 2742 | "version": "3.1.0", 2743 | "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", 2744 | "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", 2745 | "dev": true, 2746 | "requires": { 2747 | "extend-shallow": "^3.0.0" 2748 | } 2749 | }, 2750 | "static-extend": { 2751 | "version": "0.1.2", 2752 | "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", 2753 | "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", 2754 | "dev": true, 2755 | "requires": { 2756 | "define-property": "^0.2.5", 2757 | "object-copy": "^0.1.0" 2758 | }, 2759 | "dependencies": { 2760 | "define-property": { 2761 | "version": "0.2.5", 2762 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 2763 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 2764 | "dev": true, 2765 | "requires": { 2766 | "is-descriptor": "^0.1.0" 2767 | } 2768 | } 2769 | } 2770 | }, 2771 | "statuses": { 2772 | "version": "1.5.0", 2773 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 2774 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 2775 | }, 2776 | "string-width": { 2777 | "version": "2.1.1", 2778 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2779 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2780 | "dev": true, 2781 | "requires": { 2782 | "is-fullwidth-code-point": "^2.0.0", 2783 | "strip-ansi": "^4.0.0" 2784 | } 2785 | }, 2786 | "string_decoder": { 2787 | "version": "1.1.1", 2788 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2789 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2790 | "dev": true, 2791 | "requires": { 2792 | "safe-buffer": "~5.1.0" 2793 | } 2794 | }, 2795 | "strip-ansi": { 2796 | "version": "4.0.0", 2797 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2798 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2799 | "dev": true, 2800 | "requires": { 2801 | "ansi-regex": "^3.0.0" 2802 | } 2803 | }, 2804 | "strip-eof": { 2805 | "version": "1.0.0", 2806 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 2807 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", 2808 | "dev": true 2809 | }, 2810 | "strip-json-comments": { 2811 | "version": "2.0.1", 2812 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2813 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 2814 | "dev": true 2815 | }, 2816 | "supports-color": { 2817 | "version": "5.5.0", 2818 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2819 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2820 | "dev": true, 2821 | "requires": { 2822 | "has-flag": "^3.0.0" 2823 | } 2824 | }, 2825 | "term-size": { 2826 | "version": "1.2.0", 2827 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-1.2.0.tgz", 2828 | "integrity": "sha1-RYuDiH8oj8Vtb/+/rSYuJmOO+mk=", 2829 | "dev": true, 2830 | "requires": { 2831 | "execa": "^0.7.0" 2832 | } 2833 | }, 2834 | "timed-out": { 2835 | "version": "4.0.1", 2836 | "resolved": "https://registry.npmjs.org/timed-out/-/timed-out-4.0.1.tgz", 2837 | "integrity": "sha1-8y6srFoXW+ol1/q1Zas+2HQe9W8=", 2838 | "dev": true 2839 | }, 2840 | "to-object-path": { 2841 | "version": "0.3.0", 2842 | "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", 2843 | "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", 2844 | "dev": true, 2845 | "requires": { 2846 | "kind-of": "^3.0.2" 2847 | }, 2848 | "dependencies": { 2849 | "kind-of": { 2850 | "version": "3.2.2", 2851 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2852 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2853 | "dev": true, 2854 | "requires": { 2855 | "is-buffer": "^1.1.5" 2856 | } 2857 | } 2858 | } 2859 | }, 2860 | "to-regex": { 2861 | "version": "3.0.2", 2862 | "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", 2863 | "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", 2864 | "dev": true, 2865 | "requires": { 2866 | "define-property": "^2.0.2", 2867 | "extend-shallow": "^3.0.2", 2868 | "regex-not": "^1.0.2", 2869 | "safe-regex": "^1.1.0" 2870 | } 2871 | }, 2872 | "to-regex-range": { 2873 | "version": "2.1.1", 2874 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", 2875 | "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", 2876 | "dev": true, 2877 | "requires": { 2878 | "is-number": "^3.0.0", 2879 | "repeat-string": "^1.6.1" 2880 | } 2881 | }, 2882 | "toidentifier": { 2883 | "version": "1.0.0", 2884 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 2885 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 2886 | }, 2887 | "touch": { 2888 | "version": "3.1.0", 2889 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 2890 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 2891 | "dev": true, 2892 | "requires": { 2893 | "nopt": "~1.0.10" 2894 | } 2895 | }, 2896 | "type-is": { 2897 | "version": "1.6.18", 2898 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2899 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2900 | "requires": { 2901 | "media-typer": "0.3.0", 2902 | "mime-types": "~2.1.24" 2903 | } 2904 | }, 2905 | "undefsafe": { 2906 | "version": "2.0.2", 2907 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.2.tgz", 2908 | "integrity": "sha1-Il9rngM3Zj4Njnz9aG/Cg2zKznY=", 2909 | "dev": true, 2910 | "requires": { 2911 | "debug": "^2.2.0" 2912 | } 2913 | }, 2914 | "union-value": { 2915 | "version": "1.0.1", 2916 | "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz", 2917 | "integrity": "sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg==", 2918 | "dev": true, 2919 | "requires": { 2920 | "arr-union": "^3.1.0", 2921 | "get-value": "^2.0.6", 2922 | "is-extendable": "^0.1.1", 2923 | "set-value": "^2.0.1" 2924 | } 2925 | }, 2926 | "unique-string": { 2927 | "version": "1.0.0", 2928 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-1.0.0.tgz", 2929 | "integrity": "sha1-nhBXzKhRq7kzmPizOuGHuZyuwRo=", 2930 | "dev": true, 2931 | "requires": { 2932 | "crypto-random-string": "^1.0.0" 2933 | } 2934 | }, 2935 | "unpipe": { 2936 | "version": "1.0.0", 2937 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2938 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 2939 | }, 2940 | "unset-value": { 2941 | "version": "1.0.0", 2942 | "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", 2943 | "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", 2944 | "dev": true, 2945 | "requires": { 2946 | "has-value": "^0.3.1", 2947 | "isobject": "^3.0.0" 2948 | }, 2949 | "dependencies": { 2950 | "has-value": { 2951 | "version": "0.3.1", 2952 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", 2953 | "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", 2954 | "dev": true, 2955 | "requires": { 2956 | "get-value": "^2.0.3", 2957 | "has-values": "^0.1.4", 2958 | "isobject": "^2.0.0" 2959 | }, 2960 | "dependencies": { 2961 | "isobject": { 2962 | "version": "2.1.0", 2963 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 2964 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 2965 | "dev": true, 2966 | "requires": { 2967 | "isarray": "1.0.0" 2968 | } 2969 | } 2970 | } 2971 | }, 2972 | "has-values": { 2973 | "version": "0.1.4", 2974 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", 2975 | "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", 2976 | "dev": true 2977 | } 2978 | } 2979 | }, 2980 | "unzip-response": { 2981 | "version": "2.0.1", 2982 | "resolved": "https://registry.npmjs.org/unzip-response/-/unzip-response-2.0.1.tgz", 2983 | "integrity": "sha1-0vD3N9FrBhXnKmk17QQhRXLVb5c=", 2984 | "dev": true 2985 | }, 2986 | "upath": { 2987 | "version": "1.2.0", 2988 | "resolved": "https://registry.npmjs.org/upath/-/upath-1.2.0.tgz", 2989 | "integrity": "sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg==", 2990 | "dev": true 2991 | }, 2992 | "update-notifier": { 2993 | "version": "2.5.0", 2994 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-2.5.0.tgz", 2995 | "integrity": "sha512-gwMdhgJHGuj/+wHJJs9e6PcCszpxR1b236igrOkUofGhqJuG+amlIKwApH1IW1WWl7ovZxsX49lMBWLxSdm5Dw==", 2996 | "dev": true, 2997 | "requires": { 2998 | "boxen": "^1.2.1", 2999 | "chalk": "^2.0.1", 3000 | "configstore": "^3.0.0", 3001 | "import-lazy": "^2.1.0", 3002 | "is-ci": "^1.0.10", 3003 | "is-installed-globally": "^0.1.0", 3004 | "is-npm": "^1.0.0", 3005 | "latest-version": "^3.0.0", 3006 | "semver-diff": "^2.0.0", 3007 | "xdg-basedir": "^3.0.0" 3008 | } 3009 | }, 3010 | "urix": { 3011 | "version": "0.1.0", 3012 | "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", 3013 | "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=", 3014 | "dev": true 3015 | }, 3016 | "url-parse-lax": { 3017 | "version": "1.0.0", 3018 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-1.0.0.tgz", 3019 | "integrity": "sha1-evjzA2Rem9eaJy56FKxovAYJ2nM=", 3020 | "dev": true, 3021 | "requires": { 3022 | "prepend-http": "^1.0.1" 3023 | } 3024 | }, 3025 | "use": { 3026 | "version": "3.1.1", 3027 | "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", 3028 | "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==", 3029 | "dev": true 3030 | }, 3031 | "util-deprecate": { 3032 | "version": "1.0.2", 3033 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3034 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 3035 | "dev": true 3036 | }, 3037 | "utils-merge": { 3038 | "version": "1.0.1", 3039 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 3040 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 3041 | }, 3042 | "vary": { 3043 | "version": "1.1.2", 3044 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 3045 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 3046 | }, 3047 | "which": { 3048 | "version": "1.3.1", 3049 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 3050 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 3051 | "dev": true, 3052 | "requires": { 3053 | "isexe": "^2.0.0" 3054 | } 3055 | }, 3056 | "widest-line": { 3057 | "version": "2.0.1", 3058 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-2.0.1.tgz", 3059 | "integrity": "sha512-Ba5m9/Fa4Xt9eb2ELXt77JxVDV8w7qQrH0zS/TWSJdLyAwQjWoOzpzj5lwVftDz6n/EOu3tNACS84v509qwnJA==", 3060 | "dev": true, 3061 | "requires": { 3062 | "string-width": "^2.1.1" 3063 | } 3064 | }, 3065 | "write-file-atomic": { 3066 | "version": "2.4.3", 3067 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.4.3.tgz", 3068 | "integrity": "sha512-GaETH5wwsX+GcnzhPgKcKjJ6M2Cq3/iZp1WyY/X1CSqrW+jVNM9Y7D8EC2sM4ZG/V8wZlSniJnCKWPmBYAucRQ==", 3069 | "dev": true, 3070 | "requires": { 3071 | "graceful-fs": "^4.1.11", 3072 | "imurmurhash": "^0.1.4", 3073 | "signal-exit": "^3.0.2" 3074 | } 3075 | }, 3076 | "xdg-basedir": { 3077 | "version": "3.0.0", 3078 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-3.0.0.tgz", 3079 | "integrity": "sha1-SWsswQnsqNus/i3HK2A8F8WHCtQ=", 3080 | "dev": true 3081 | }, 3082 | "yallist": { 3083 | "version": "2.1.2", 3084 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 3085 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", 3086 | "dev": true 3087 | } 3088 | } 3089 | } 3090 | -------------------------------------------------------------------------------- /backend/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "backend", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "keywords": [], 10 | "author": "", 11 | "license": "ISC", 12 | "dependencies": { 13 | "cors": "^2.8.5", 14 | "express": "^4.17.1", 15 | "jsonwebtoken": "^8.5.1", 16 | "mongoose": "^5.7.8" 17 | }, 18 | "devDependencies": { 19 | "nodemon": "^1.19.4" 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /backend/src/database.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | 3 | mongoose.connect('mongodb://localhost/angular-auth', { 4 | useNewUrlParser: true, 5 | useUnifiedTopology: true 6 | }) 7 | .then(db => console.log('Database is connected')) 8 | .catch(err => console.log(err)); -------------------------------------------------------------------------------- /backend/src/index.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const cors = require('cors'); 3 | const app = express(); 4 | 5 | require('./database'); 6 | 7 | // settings 8 | app.set('port', process.env.PORT || 4000) 9 | 10 | // middlewares 11 | app.use(express.json()); 12 | app.use(cors()); 13 | 14 | // routes 15 | app.use('/api', require('./routes/index')); 16 | 17 | app.listen(app.get('port')); 18 | console.log('Server on port', app.get('port')); 19 | -------------------------------------------------------------------------------- /backend/src/models/User.js: -------------------------------------------------------------------------------- 1 | const { Schema, model } = require('mongoose'); 2 | 3 | const userSchema = new Schema({ 4 | email: String, 5 | password: String 6 | }, { 7 | timestamps: true 8 | }); 9 | 10 | module.exports = model('User', userSchema, 'users'); -------------------------------------------------------------------------------- /backend/src/routes/index.js: -------------------------------------------------------------------------------- 1 | const { Router } = require('express'); 2 | const router = Router(); 3 | 4 | const User = require('../models/User'); 5 | 6 | const jwt = require('jsonwebtoken'); 7 | 8 | router.get('/', (req, res) => { 9 | res.send('hello') 10 | }); 11 | 12 | router.post('/signup', async (req, res) => { 13 | const { email, password } = req.body; 14 | const newUser = new User({email, password}); 15 | await newUser.save(); 16 | const token = await jwt.sign({_id: newUser._id}, 'secretkey'); 17 | res.status(200).json({token}); 18 | }); 19 | 20 | router.post('/signin', async (req, res) => { 21 | const { email, password } = req.body; 22 | 23 | const user = await User.findOne({email}); 24 | if (!user) return res.status(401).send('The email doen\' exists'); 25 | if (user.password !== password) return res.status(401).send('Wrong Password'); 26 | 27 | const token = jwt.sign({_id: user._id}, 'secretkey'); 28 | 29 | return res.status(200).json({token}); 30 | }); 31 | 32 | router.get('/tasks', (req, res) => { 33 | res.json([ 34 | { 35 | _id: '1', 36 | name: "task one", 37 | description: 'asdadasd', 38 | date: "2019-11-06T15:50:18.921Z" 39 | }, 40 | { 41 | _id: '2', 42 | name: "task two", 43 | description: 'asdadasd', 44 | date: "2019-11-06T15:50:18.921Z" 45 | }, 46 | { 47 | _id: '3', 48 | name: "task three", 49 | description: 'asdadasd', 50 | date: "2019-11-06T15:50:18.921Z" 51 | }, 52 | ]) 53 | }); 54 | 55 | router.get('/private-tasks', verifyToken, (req, res) => { 56 | res.json([ 57 | { 58 | _id: '1', 59 | name: "task one", 60 | description: 'asdadasd', 61 | date: "2019-11-06T15:50:18.921Z" 62 | }, 63 | { 64 | _id: '2', 65 | name: "task two", 66 | description: 'asdadasd', 67 | date: "2019-11-06T15:50:18.921Z" 68 | }, 69 | { 70 | _id: '3', 71 | name: "task three", 72 | description: 'asdadasd', 73 | date: "2019-11-06T15:50:18.921Z" 74 | }, 75 | ]) 76 | }); 77 | 78 | async function verifyToken(req, res, next) { 79 | try { 80 | if (!req.headers.authorization) { 81 | return res.status(401).send('Unauhtorized Request'); 82 | } 83 | let token = req.headers.authorization.split(' ')[1]; 84 | if (token === 'null') { 85 | return res.status(401).send('Unauhtorized Request'); 86 | } 87 | 88 | const payload = await jwt.verify(token, 'secretkey'); 89 | if (!payload) { 90 | return res.status(401).send('Unauhtorized Request'); 91 | } 92 | req.userId = payload._id; 93 | next(); 94 | } catch(e) { 95 | //console.log(e) 96 | return res.status(401).send('Unauhtorized Request'); 97 | } 98 | } 99 | 100 | module.exports = router; 101 | -------------------------------------------------------------------------------- /frontend/.editorconfig: -------------------------------------------------------------------------------- 1 | # Editor configuration, see https://editorconfig.org 2 | root = true 3 | 4 | [*] 5 | charset = utf-8 6 | indent_style = space 7 | indent_size = 2 8 | insert_final_newline = true 9 | trim_trailing_whitespace = true 10 | 11 | [*.md] 12 | max_line_length = off 13 | trim_trailing_whitespace = false 14 | -------------------------------------------------------------------------------- /frontend/.gitignore: -------------------------------------------------------------------------------- 1 | # See http://help.github.com/ignore-files/ for more about ignoring files. 2 | 3 | # compiled output 4 | /dist 5 | /tmp 6 | /out-tsc 7 | # Only exists if Bazel was run 8 | /bazel-out 9 | 10 | # dependencies 11 | /node_modules 12 | 13 | # profiling files 14 | chrome-profiler-events*.json 15 | speed-measure-plugin*.json 16 | 17 | # IDEs and editors 18 | /.idea 19 | .project 20 | .classpath 21 | .c9/ 22 | *.launch 23 | .settings/ 24 | *.sublime-workspace 25 | 26 | # IDE - VSCode 27 | .vscode/* 28 | !.vscode/settings.json 29 | !.vscode/tasks.json 30 | !.vscode/launch.json 31 | !.vscode/extensions.json 32 | .history/* 33 | 34 | # misc 35 | /.sass-cache 36 | /connect.lock 37 | /coverage 38 | /libpeerconnection.log 39 | npm-debug.log 40 | yarn-error.log 41 | testem.log 42 | /typings 43 | 44 | # System Files 45 | .DS_Store 46 | Thumbs.db 47 | -------------------------------------------------------------------------------- /frontend/README.md: -------------------------------------------------------------------------------- 1 | # Frontend 2 | 3 | This project was generated with [Angular CLI](https://github.com/angular/angular-cli) version 8.3.17. 4 | 5 | ## Development server 6 | 7 | Run `ng serve` for a dev server. Navigate to `http://localhost:4200/`. The app will automatically reload if you change any of the source files. 8 | 9 | ## Code scaffolding 10 | 11 | Run `ng generate component component-name` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module`. 12 | 13 | ## Build 14 | 15 | Run `ng build` to build the project. The build artifacts will be stored in the `dist/` directory. Use the `--prod` flag for a production build. 16 | 17 | ## Running unit tests 18 | 19 | Run `ng test` to execute the unit tests via [Karma](https://karma-runner.github.io). 20 | 21 | ## Running end-to-end tests 22 | 23 | Run `ng e2e` to execute the end-to-end tests via [Protractor](http://www.protractortest.org/). 24 | 25 | ## Further help 26 | 27 | To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI README](https://github.com/angular/angular-cli/blob/master/README.md). 28 | -------------------------------------------------------------------------------- /frontend/angular.json: -------------------------------------------------------------------------------- 1 | { 2 | "$schema": "./node_modules/@angular/cli/lib/config/schema.json", 3 | "version": 1, 4 | "newProjectRoot": "projects", 5 | "projects": { 6 | "frontend": { 7 | "projectType": "application", 8 | "schematics": {}, 9 | "root": "", 10 | "sourceRoot": "src", 11 | "prefix": "app", 12 | "architect": { 13 | "build": { 14 | "builder": "@angular-devkit/build-angular:browser", 15 | "options": { 16 | "outputPath": "dist/frontend", 17 | "index": "src/index.html", 18 | "main": "src/main.ts", 19 | "polyfills": "src/polyfills.ts", 20 | "tsConfig": "tsconfig.app.json", 21 | "aot": false, 22 | "assets": [ 23 | "src/favicon.ico", 24 | "src/assets" 25 | ], 26 | "styles": [ 27 | "src/styles.css" 28 | ], 29 | "scripts": [] 30 | }, 31 | "configurations": { 32 | "production": { 33 | "fileReplacements": [ 34 | { 35 | "replace": "src/environments/environment.ts", 36 | "with": "src/environments/environment.prod.ts" 37 | } 38 | ], 39 | "optimization": true, 40 | "outputHashing": "all", 41 | "sourceMap": false, 42 | "extractCss": true, 43 | "namedChunks": false, 44 | "aot": true, 45 | "extractLicenses": true, 46 | "vendorChunk": false, 47 | "buildOptimizer": true, 48 | "budgets": [ 49 | { 50 | "type": "initial", 51 | "maximumWarning": "2mb", 52 | "maximumError": "5mb" 53 | }, 54 | { 55 | "type": "anyComponentStyle", 56 | "maximumWarning": "6kb", 57 | "maximumError": "10kb" 58 | } 59 | ] 60 | } 61 | } 62 | }, 63 | "serve": { 64 | "builder": "@angular-devkit/build-angular:dev-server", 65 | "options": { 66 | "browserTarget": "frontend:build" 67 | }, 68 | "configurations": { 69 | "production": { 70 | "browserTarget": "frontend:build:production" 71 | } 72 | } 73 | }, 74 | "extract-i18n": { 75 | "builder": "@angular-devkit/build-angular:extract-i18n", 76 | "options": { 77 | "browserTarget": "frontend:build" 78 | } 79 | }, 80 | "test": { 81 | "builder": "@angular-devkit/build-angular:karma", 82 | "options": { 83 | "main": "src/test.ts", 84 | "polyfills": "src/polyfills.ts", 85 | "tsConfig": "tsconfig.spec.json", 86 | "karmaConfig": "karma.conf.js", 87 | "assets": [ 88 | "src/favicon.ico", 89 | "src/assets" 90 | ], 91 | "styles": [ 92 | "src/styles.css" 93 | ], 94 | "scripts": [] 95 | } 96 | }, 97 | "lint": { 98 | "builder": "@angular-devkit/build-angular:tslint", 99 | "options": { 100 | "tsConfig": [ 101 | "tsconfig.app.json", 102 | "tsconfig.spec.json", 103 | "e2e/tsconfig.json" 104 | ], 105 | "exclude": [ 106 | "**/node_modules/**" 107 | ] 108 | } 109 | }, 110 | "e2e": { 111 | "builder": "@angular-devkit/build-angular:protractor", 112 | "options": { 113 | "protractorConfig": "e2e/protractor.conf.js", 114 | "devServerTarget": "frontend:serve" 115 | }, 116 | "configurations": { 117 | "production": { 118 | "devServerTarget": "frontend:serve:production" 119 | } 120 | } 121 | } 122 | } 123 | }}, 124 | "defaultProject": "frontend" 125 | } -------------------------------------------------------------------------------- /frontend/browserslist: -------------------------------------------------------------------------------- 1 | # This file is used by the build system to adjust CSS and JS output to support the specified browsers below. 2 | # For additional information regarding the format and rule options, please see: 3 | # https://github.com/browserslist/browserslist#queries 4 | 5 | # You can see what browsers were selected by your queries by running: 6 | # npx browserslist 7 | 8 | > 0.5% 9 | last 2 versions 10 | Firefox ESR 11 | not dead 12 | not IE 9-11 # For IE 9-11 support, remove 'not'. -------------------------------------------------------------------------------- /frontend/e2e/protractor.conf.js: -------------------------------------------------------------------------------- 1 | // @ts-check 2 | // Protractor configuration file, see link for more information 3 | // https://github.com/angular/protractor/blob/master/lib/config.ts 4 | 5 | const { SpecReporter } = require('jasmine-spec-reporter'); 6 | 7 | /** 8 | * @type { import("protractor").Config } 9 | */ 10 | exports.config = { 11 | allScriptsTimeout: 11000, 12 | specs: [ 13 | './src/**/*.e2e-spec.ts' 14 | ], 15 | capabilities: { 16 | browserName: 'chrome' 17 | }, 18 | directConnect: true, 19 | baseUrl: 'http://localhost:4200/', 20 | framework: 'jasmine', 21 | jasmineNodeOpts: { 22 | showColors: true, 23 | defaultTimeoutInterval: 30000, 24 | print: function() {} 25 | }, 26 | onPrepare() { 27 | require('ts-node').register({ 28 | project: require('path').join(__dirname, './tsconfig.json') 29 | }); 30 | jasmine.getEnv().addReporter(new SpecReporter({ spec: { displayStacktrace: true } })); 31 | } 32 | }; -------------------------------------------------------------------------------- /frontend/e2e/src/app.e2e-spec.ts: -------------------------------------------------------------------------------- 1 | import { AppPage } from './app.po'; 2 | import { browser, logging } from 'protractor'; 3 | 4 | describe('workspace-project App', () => { 5 | let page: AppPage; 6 | 7 | beforeEach(() => { 8 | page = new AppPage(); 9 | }); 10 | 11 | it('should display welcome message', () => { 12 | page.navigateTo(); 13 | expect(page.getTitleText()).toEqual('frontend app is running!'); 14 | }); 15 | 16 | afterEach(async () => { 17 | // Assert that there are no errors emitted from the browser 18 | const logs = await browser.manage().logs().get(logging.Type.BROWSER); 19 | expect(logs).not.toContain(jasmine.objectContaining({ 20 | level: logging.Level.SEVERE, 21 | } as logging.Entry)); 22 | }); 23 | }); 24 | -------------------------------------------------------------------------------- /frontend/e2e/src/app.po.ts: -------------------------------------------------------------------------------- 1 | import { browser, by, element } from 'protractor'; 2 | 3 | export class AppPage { 4 | navigateTo() { 5 | return browser.get(browser.baseUrl) as Promise; 6 | } 7 | 8 | getTitleText() { 9 | return element(by.css('app-root .content span')).getText() as Promise; 10 | } 11 | } 12 | -------------------------------------------------------------------------------- /frontend/e2e/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "../tsconfig.json", 3 | "compilerOptions": { 4 | "outDir": "../out-tsc/e2e", 5 | "module": "commonjs", 6 | "target": "es5", 7 | "types": [ 8 | "jasmine", 9 | "jasminewd2", 10 | "node" 11 | ] 12 | } 13 | } 14 | -------------------------------------------------------------------------------- /frontend/karma.conf.js: -------------------------------------------------------------------------------- 1 | // Karma configuration file, see link for more information 2 | // https://karma-runner.github.io/1.0/config/configuration-file.html 3 | 4 | module.exports = function (config) { 5 | config.set({ 6 | basePath: '', 7 | frameworks: ['jasmine', '@angular-devkit/build-angular'], 8 | plugins: [ 9 | require('karma-jasmine'), 10 | require('karma-chrome-launcher'), 11 | require('karma-jasmine-html-reporter'), 12 | require('karma-coverage-istanbul-reporter'), 13 | require('@angular-devkit/build-angular/plugins/karma') 14 | ], 15 | client: { 16 | clearContext: false // leave Jasmine Spec Runner output visible in browser 17 | }, 18 | coverageIstanbulReporter: { 19 | dir: require('path').join(__dirname, './coverage/frontend'), 20 | reports: ['html', 'lcovonly', 'text-summary'], 21 | fixWebpackSourcePaths: true 22 | }, 23 | reporters: ['progress', 'kjhtml'], 24 | port: 9876, 25 | colors: true, 26 | logLevel: config.LOG_INFO, 27 | autoWatch: true, 28 | browsers: ['Chrome'], 29 | singleRun: false, 30 | restartOnFileChange: true 31 | }); 32 | }; 33 | -------------------------------------------------------------------------------- /frontend/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "frontend", 3 | "version": "0.0.0", 4 | "scripts": { 5 | "ng": "ng", 6 | "start": "ng serve", 7 | "build": "ng build", 8 | "test": "ng test", 9 | "lint": "ng lint", 10 | "e2e": "ng e2e" 11 | }, 12 | "private": true, 13 | "dependencies": { 14 | "@angular/animations": "~8.2.13", 15 | "@angular/common": "~8.2.13", 16 | "@angular/compiler": "~8.2.13", 17 | "@angular/core": "~8.2.13", 18 | "@angular/forms": "~8.2.13", 19 | "@angular/platform-browser": "~8.2.13", 20 | "@angular/platform-browser-dynamic": "~8.2.13", 21 | "@angular/router": "~8.2.13", 22 | "rxjs": "~6.4.0", 23 | "tslib": "^1.10.0", 24 | "zone.js": "~0.9.1" 25 | }, 26 | "devDependencies": { 27 | "@angular-devkit/build-angular": "~0.803.17", 28 | "@angular/cli": "~8.3.17", 29 | "@angular/compiler-cli": "~8.2.13", 30 | "@angular/language-service": "~8.2.13", 31 | "@types/node": "~8.9.4", 32 | "@types/jasmine": "~3.3.8", 33 | "@types/jasminewd2": "~2.0.3", 34 | "codelyzer": "^5.0.0", 35 | "jasmine-core": "~3.4.0", 36 | "jasmine-spec-reporter": "~4.2.1", 37 | "karma": "~4.1.0", 38 | "karma-chrome-launcher": "~2.2.0", 39 | "karma-coverage-istanbul-reporter": "~2.0.1", 40 | "karma-jasmine": "~2.0.1", 41 | "karma-jasmine-html-reporter": "^1.4.0", 42 | "protractor": "~5.4.0", 43 | "ts-node": "~7.0.0", 44 | "tslint": "~5.15.0", 45 | "typescript": "~3.5.3" 46 | } 47 | } 48 | -------------------------------------------------------------------------------- /frontend/src/app/app-routing.module.ts: -------------------------------------------------------------------------------- 1 | import { NgModule } from '@angular/core'; 2 | import { Routes, RouterModule } from '@angular/router'; 3 | // Components 4 | import { TasksComponent } from './components/tasks/tasks.component'; 5 | import { PrivateTasksComponent } from './components/private-tasks/private-tasks.component'; 6 | import { SigninComponent } from './components/signin/signin.component'; 7 | import { SignupComponent } from './components/signup/signup.component'; 8 | import { AuthGuard } from './auth.guard'; 9 | 10 | const routes: Routes = [ 11 | { 12 | path: '', 13 | redirectTo: '/tasks', 14 | pathMatch: 'full' 15 | }, 16 | { 17 | path: 'tasks', 18 | component: TasksComponent 19 | }, 20 | { 21 | path: 'private', 22 | component: PrivateTasksComponent, 23 | canActivate: [AuthGuard] 24 | }, 25 | { 26 | path: 'signin', 27 | component: SigninComponent 28 | }, 29 | { 30 | path: 'signup', 31 | component: SignupComponent 32 | } 33 | ]; 34 | 35 | @NgModule({ 36 | imports: [RouterModule.forRoot(routes)], 37 | exports: [RouterModule] 38 | }) 39 | export class AppRoutingModule { } 40 | -------------------------------------------------------------------------------- /frontend/src/app/app.component.css: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/FaztWeb/angular-node-jwt/4177c09478daee3618f9aee93a2fcea614b6dcc1/frontend/src/app/app.component.css -------------------------------------------------------------------------------- /frontend/src/app/app.component.html: -------------------------------------------------------------------------------- 1 | 35 | 36 |
37 | 38 |
-------------------------------------------------------------------------------- /frontend/src/app/app.component.spec.ts: -------------------------------------------------------------------------------- 1 | import { TestBed, async } from '@angular/core/testing'; 2 | import { RouterTestingModule } from '@angular/router/testing'; 3 | import { AppComponent } from './app.component'; 4 | 5 | describe('AppComponent', () => { 6 | beforeEach(async(() => { 7 | TestBed.configureTestingModule({ 8 | imports: [ 9 | RouterTestingModule 10 | ], 11 | declarations: [ 12 | AppComponent 13 | ], 14 | }).compileComponents(); 15 | })); 16 | 17 | it('should create the app', () => { 18 | const fixture = TestBed.createComponent(AppComponent); 19 | const app = fixture.debugElement.componentInstance; 20 | expect(app).toBeTruthy(); 21 | }); 22 | 23 | it(`should have as title 'frontend'`, () => { 24 | const fixture = TestBed.createComponent(AppComponent); 25 | const app = fixture.debugElement.componentInstance; 26 | expect(app.title).toEqual('frontend'); 27 | }); 28 | 29 | it('should render title', () => { 30 | const fixture = TestBed.createComponent(AppComponent); 31 | fixture.detectChanges(); 32 | const compiled = fixture.debugElement.nativeElement; 33 | expect(compiled.querySelector('.content span').textContent).toContain('frontend app is running!'); 34 | }); 35 | }); 36 | -------------------------------------------------------------------------------- /frontend/src/app/app.component.ts: -------------------------------------------------------------------------------- 1 | import { Component } from '@angular/core'; 2 | import { AuthService } from './services/auth.service'; 3 | 4 | @Component({ 5 | selector: 'app-root', 6 | templateUrl: './app.component.html', 7 | styleUrls: ['./app.component.css'] 8 | }) 9 | export class AppComponent { 10 | 11 | constructor(private authService: AuthService) {} 12 | 13 | title = 'frontend'; 14 | } 15 | -------------------------------------------------------------------------------- /frontend/src/app/app.module.ts: -------------------------------------------------------------------------------- 1 | import { BrowserModule } from '@angular/platform-browser'; 2 | import { NgModule } from '@angular/core'; 3 | import { AppRoutingModule } from './app-routing.module'; 4 | import { FormsModule } from '@angular/forms' 5 | import { HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http' 6 | 7 | import { AppComponent } from './app.component'; 8 | import { SignupComponent } from './components/signup/signup.component'; 9 | import { SigninComponent } from './components/signin/signin.component'; 10 | import { TasksComponent } from './components/tasks/tasks.component'; 11 | import { PrivateTasksComponent } from './components/private-tasks/private-tasks.component'; 12 | import { AuthGuard } from './auth.guard'; 13 | import { TokenInterceptorService } from './services/token-interceptor.service'; 14 | 15 | @NgModule({ 16 | declarations: [ 17 | AppComponent, 18 | SignupComponent, 19 | SigninComponent, 20 | TasksComponent, 21 | PrivateTasksComponent 22 | ], 23 | imports: [ 24 | BrowserModule, 25 | AppRoutingModule, 26 | FormsModule, 27 | HttpClientModule 28 | ], 29 | providers: [ 30 | AuthGuard, 31 | { 32 | provide: HTTP_INTERCEPTORS, 33 | useClass: TokenInterceptorService, 34 | multi: true 35 | } 36 | ], 37 | bootstrap: [AppComponent] 38 | }) 39 | export class AppModule { } 40 | -------------------------------------------------------------------------------- /frontend/src/app/auth.guard.spec.ts: -------------------------------------------------------------------------------- 1 | import { TestBed, async, inject } from '@angular/core/testing'; 2 | 3 | import { AuthGuard } from './auth.guard'; 4 | 5 | describe('AuthGuard', () => { 6 | beforeEach(() => { 7 | TestBed.configureTestingModule({ 8 | providers: [AuthGuard] 9 | }); 10 | }); 11 | 12 | it('should ...', inject([AuthGuard], (guard: AuthGuard) => { 13 | expect(guard).toBeTruthy(); 14 | })); 15 | }); 16 | -------------------------------------------------------------------------------- /frontend/src/app/auth.guard.ts: -------------------------------------------------------------------------------- 1 | import { Injectable } from '@angular/core'; 2 | import { CanActivate, Router } from '@angular/router'; 3 | import { AuthService } from './services/auth.service'; 4 | 5 | @Injectable({ 6 | providedIn: 'root' 7 | }) 8 | export class AuthGuard implements CanActivate { 9 | 10 | constructor( 11 | private authService: AuthService, 12 | private router: Router 13 | ) { } 14 | 15 | canActivate(): boolean { 16 | if (this.authService.loggedIn()) { 17 | return true; 18 | } 19 | 20 | this.router.navigate(['/signin']); 21 | return false; 22 | } 23 | 24 | } 25 | -------------------------------------------------------------------------------- /frontend/src/app/components/private-tasks/private-tasks.component.css: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/FaztWeb/angular-node-jwt/4177c09478daee3618f9aee93a2fcea614b6dcc1/frontend/src/app/components/private-tasks/private-tasks.component.css -------------------------------------------------------------------------------- /frontend/src/app/components/private-tasks/private-tasks.component.html: -------------------------------------------------------------------------------- 1 |
2 |
3 |
4 |
5 |

{{task.name}}

6 |

{{task.description}}

7 |
8 | 11 |
12 |
13 |
-------------------------------------------------------------------------------- /frontend/src/app/components/private-tasks/private-tasks.component.spec.ts: -------------------------------------------------------------------------------- 1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing'; 2 | 3 | import { PrivateTasksComponent } from './private-tasks.component'; 4 | 5 | describe('PrivateTasksComponent', () => { 6 | let component: PrivateTasksComponent; 7 | let fixture: ComponentFixture; 8 | 9 | beforeEach(async(() => { 10 | TestBed.configureTestingModule({ 11 | declarations: [ PrivateTasksComponent ] 12 | }) 13 | .compileComponents(); 14 | })); 15 | 16 | beforeEach(() => { 17 | fixture = TestBed.createComponent(PrivateTasksComponent); 18 | component = fixture.componentInstance; 19 | fixture.detectChanges(); 20 | }); 21 | 22 | it('should create', () => { 23 | expect(component).toBeTruthy(); 24 | }); 25 | }); 26 | -------------------------------------------------------------------------------- /frontend/src/app/components/private-tasks/private-tasks.component.ts: -------------------------------------------------------------------------------- 1 | import { Component, OnInit } from '@angular/core'; 2 | import { TaskService } from '../../services/task.service' 3 | import { HttpErrorResponse } from '@angular/common/http'; 4 | import { Router } from '@angular/router'; 5 | 6 | @Component({ 7 | selector: 'app-private-tasks', 8 | templateUrl: './private-tasks.component.html', 9 | styleUrls: ['./private-tasks.component.css'] 10 | }) 11 | export class PrivateTasksComponent implements OnInit { 12 | 13 | privateTasks = []; 14 | constructor(private taskService: TaskService, private router: Router) { } 15 | 16 | ngOnInit() { 17 | this.taskService.getPrivateTasks() 18 | .subscribe( 19 | res => this.privateTasks = res, 20 | err => { 21 | if (err instanceof HttpErrorResponse) { 22 | if (err.status === 401) { 23 | this.router.navigate(['/signin']); 24 | } 25 | } 26 | } 27 | ) 28 | } 29 | 30 | } 31 | -------------------------------------------------------------------------------- /frontend/src/app/components/signin/signin.component.css: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/FaztWeb/angular-node-jwt/4177c09478daee3618f9aee93a2fcea614b6dcc1/frontend/src/app/components/signin/signin.component.css -------------------------------------------------------------------------------- /frontend/src/app/components/signin/signin.component.html: -------------------------------------------------------------------------------- 1 |
2 |
3 |
4 |
5 | SignIn 6 |
7 |
8 |
9 |
10 | 11 |
12 |
13 | 14 |
15 | 18 |
19 |
20 |
21 |
22 |
-------------------------------------------------------------------------------- /frontend/src/app/components/signin/signin.component.spec.ts: -------------------------------------------------------------------------------- 1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing'; 2 | 3 | import { SigninComponent } from './signin.component'; 4 | 5 | describe('SigninComponent', () => { 6 | let component: SigninComponent; 7 | let fixture: ComponentFixture; 8 | 9 | beforeEach(async(() => { 10 | TestBed.configureTestingModule({ 11 | declarations: [ SigninComponent ] 12 | }) 13 | .compileComponents(); 14 | })); 15 | 16 | beforeEach(() => { 17 | fixture = TestBed.createComponent(SigninComponent); 18 | component = fixture.componentInstance; 19 | fixture.detectChanges(); 20 | }); 21 | 22 | it('should create', () => { 23 | expect(component).toBeTruthy(); 24 | }); 25 | }); 26 | -------------------------------------------------------------------------------- /frontend/src/app/components/signin/signin.component.ts: -------------------------------------------------------------------------------- 1 | import { Component, OnInit } from '@angular/core'; 2 | import { AuthService } from '../../services/auth.service' 3 | import { Router } from '@angular/router' 4 | 5 | @Component({ 6 | selector: 'app-signin', 7 | templateUrl: './signin.component.html', 8 | styleUrls: ['./signin.component.css'] 9 | }) 10 | export class SigninComponent implements OnInit { 11 | user = {}; 12 | 13 | constructor( 14 | private authService: AuthService, 15 | private router: Router 16 | ) { } 17 | 18 | ngOnInit() { 19 | } 20 | 21 | signIn() { 22 | this.authService.signInUser(this.user) 23 | .subscribe( 24 | res => { 25 | console.log(res); 26 | localStorage.setItem('token', res.token); 27 | this.router.navigate(['/private']); 28 | }, 29 | err => console.log(err) 30 | ) 31 | } 32 | 33 | } 34 | -------------------------------------------------------------------------------- /frontend/src/app/components/signup/signup.component.css: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/FaztWeb/angular-node-jwt/4177c09478daee3618f9aee93a2fcea614b6dcc1/frontend/src/app/components/signup/signup.component.css -------------------------------------------------------------------------------- /frontend/src/app/components/signup/signup.component.html: -------------------------------------------------------------------------------- 1 |
2 |
3 |
4 |
5 | SignUp 6 |
7 |
8 |
9 |
10 | 11 |
12 |
13 | 14 |
15 | 18 |
19 |
20 |
21 |
22 |
-------------------------------------------------------------------------------- /frontend/src/app/components/signup/signup.component.spec.ts: -------------------------------------------------------------------------------- 1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing'; 2 | 3 | import { SignupComponent } from './signup.component'; 4 | 5 | describe('SignupComponent', () => { 6 | let component: SignupComponent; 7 | let fixture: ComponentFixture; 8 | 9 | beforeEach(async(() => { 10 | TestBed.configureTestingModule({ 11 | declarations: [ SignupComponent ] 12 | }) 13 | .compileComponents(); 14 | })); 15 | 16 | beforeEach(() => { 17 | fixture = TestBed.createComponent(SignupComponent); 18 | component = fixture.componentInstance; 19 | fixture.detectChanges(); 20 | }); 21 | 22 | it('should create', () => { 23 | expect(component).toBeTruthy(); 24 | }); 25 | }); 26 | -------------------------------------------------------------------------------- /frontend/src/app/components/signup/signup.component.ts: -------------------------------------------------------------------------------- 1 | import { Component, OnInit } from '@angular/core'; 2 | import { AuthService } from '../../services/auth.service' 3 | import { Router } from '@angular/router' 4 | 5 | @Component({ 6 | selector: 'app-signup', 7 | templateUrl: './signup.component.html', 8 | styleUrls: ['./signup.component.css'] 9 | }) 10 | export class SignupComponent implements OnInit { 11 | 12 | user = {} 13 | constructor( 14 | private authService: AuthService, 15 | private router: Router 16 | ) { } 17 | 18 | ngOnInit() { 19 | } 20 | 21 | signUp() { 22 | this.authService.signUpUser(this.user) 23 | .subscribe( 24 | res => { 25 | console.log(res); 26 | localStorage.setItem('token', res.token); 27 | this.router.navigate(['/private']); 28 | }, 29 | err => console.log(err) 30 | ) 31 | } 32 | 33 | } 34 | -------------------------------------------------------------------------------- /frontend/src/app/components/tasks/tasks.component.css: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/FaztWeb/angular-node-jwt/4177c09478daee3618f9aee93a2fcea614b6dcc1/frontend/src/app/components/tasks/tasks.component.css -------------------------------------------------------------------------------- /frontend/src/app/components/tasks/tasks.component.html: -------------------------------------------------------------------------------- 1 |
2 |
3 |
4 |
5 |

{{task.name}}

6 |

{{task.description}}

7 |
8 | 11 |
12 |
13 |
-------------------------------------------------------------------------------- /frontend/src/app/components/tasks/tasks.component.spec.ts: -------------------------------------------------------------------------------- 1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing'; 2 | 3 | import { TasksComponent } from './tasks.component'; 4 | 5 | describe('TasksComponent', () => { 6 | let component: TasksComponent; 7 | let fixture: ComponentFixture; 8 | 9 | beforeEach(async(() => { 10 | TestBed.configureTestingModule({ 11 | declarations: [ TasksComponent ] 12 | }) 13 | .compileComponents(); 14 | })); 15 | 16 | beforeEach(() => { 17 | fixture = TestBed.createComponent(TasksComponent); 18 | component = fixture.componentInstance; 19 | fixture.detectChanges(); 20 | }); 21 | 22 | it('should create', () => { 23 | expect(component).toBeTruthy(); 24 | }); 25 | }); 26 | -------------------------------------------------------------------------------- /frontend/src/app/components/tasks/tasks.component.ts: -------------------------------------------------------------------------------- 1 | import { Component, OnInit } from '@angular/core'; 2 | import {TaskService} from '../../services/task.service' 3 | 4 | @Component({ 5 | selector: 'app-tasks', 6 | templateUrl: './tasks.component.html', 7 | styleUrls: ['./tasks.component.css'] 8 | }) 9 | export class TasksComponent implements OnInit { 10 | 11 | tasks = []; 12 | constructor(private taskService: TaskService) { } 13 | 14 | ngOnInit() { 15 | this.taskService.getTasks() 16 | .subscribe( 17 | res => { 18 | this.tasks = res; 19 | }, 20 | err => console.log(err) 21 | ) 22 | } 23 | 24 | } 25 | -------------------------------------------------------------------------------- /frontend/src/app/services/auth.service.spec.ts: -------------------------------------------------------------------------------- 1 | import { TestBed } from '@angular/core/testing'; 2 | 3 | import { AuthService } from './auth.service'; 4 | 5 | describe('AuthService', () => { 6 | beforeEach(() => TestBed.configureTestingModule({})); 7 | 8 | it('should be created', () => { 9 | const service: AuthService = TestBed.get(AuthService); 10 | expect(service).toBeTruthy(); 11 | }); 12 | }); 13 | -------------------------------------------------------------------------------- /frontend/src/app/services/auth.service.ts: -------------------------------------------------------------------------------- 1 | import { Injectable } from '@angular/core'; 2 | import { HttpClient } from '@angular/common/http' 3 | import { Router } from '@angular/router'; 4 | 5 | @Injectable({ 6 | providedIn: 'root' 7 | }) 8 | export class AuthService { 9 | 10 | private URL = 'http://localhost:4000/api'; 11 | constructor(private http: HttpClient, private router: Router) { } 12 | 13 | signUpUser(user) { 14 | return this.http.post(this.URL + '/signup', user); 15 | } 16 | 17 | signInUser(user) { 18 | return this.http.post(this.URL + '/signin', user); 19 | } 20 | 21 | loggedIn() { 22 | return !!localStorage.getItem('token'); 23 | } 24 | 25 | logout() { 26 | localStorage.removeItem('token'); 27 | this.router.navigate(['/tasks']); 28 | } 29 | 30 | getToken() { 31 | return localStorage.getItem('token'); 32 | } 33 | 34 | } 35 | -------------------------------------------------------------------------------- /frontend/src/app/services/task.service.spec.ts: -------------------------------------------------------------------------------- 1 | import { TestBed } from '@angular/core/testing'; 2 | 3 | import { TaskService } from './task.service'; 4 | 5 | describe('TaskService', () => { 6 | beforeEach(() => TestBed.configureTestingModule({})); 7 | 8 | it('should be created', () => { 9 | const service: TaskService = TestBed.get(TaskService); 10 | expect(service).toBeTruthy(); 11 | }); 12 | }); 13 | -------------------------------------------------------------------------------- /frontend/src/app/services/task.service.ts: -------------------------------------------------------------------------------- 1 | import { Injectable } from '@angular/core'; 2 | import {HttpClient} from '@angular/common/http' 3 | 4 | @Injectable({ 5 | providedIn: 'root' 6 | }) 7 | export class TaskService { 8 | 9 | private URL = 'http://localhost:4000/api'; 10 | constructor(private http: HttpClient) { } 11 | 12 | getTasks() { 13 | return this.http.get(this.URL + '/tasks'); 14 | } 15 | 16 | getPrivateTasks() { 17 | return this.http.get(this.URL + '/private-tasks'); 18 | } 19 | 20 | } 21 | -------------------------------------------------------------------------------- /frontend/src/app/services/token-interceptor.service.spec.ts: -------------------------------------------------------------------------------- 1 | import { TestBed } from '@angular/core/testing'; 2 | 3 | import { TokenInterceptorService } from './token-interceptor.service'; 4 | 5 | describe('TokenInterceptorService', () => { 6 | beforeEach(() => TestBed.configureTestingModule({})); 7 | 8 | it('should be created', () => { 9 | const service: TokenInterceptorService = TestBed.get(TokenInterceptorService); 10 | expect(service).toBeTruthy(); 11 | }); 12 | }); 13 | -------------------------------------------------------------------------------- /frontend/src/app/services/token-interceptor.service.ts: -------------------------------------------------------------------------------- 1 | import { Injectable } from '@angular/core'; 2 | import { HttpInterceptor } from '@angular/common/http' 3 | import {AuthService} from './auth.service' 4 | 5 | 6 | @Injectable({ 7 | providedIn: 'root' 8 | }) 9 | export class TokenInterceptorService implements HttpInterceptor { 10 | 11 | constructor(private authService: AuthService) { } 12 | 13 | intercept(req, next) { 14 | let tokenizeReq = req.clone({ 15 | setHeaders: { 16 | Authorization: `Bearer ${this.authService.getToken()}` 17 | } 18 | }); 19 | return next.handle(tokenizeReq); 20 | } 21 | 22 | } -------------------------------------------------------------------------------- /frontend/src/assets/.gitkeep: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/FaztWeb/angular-node-jwt/4177c09478daee3618f9aee93a2fcea614b6dcc1/frontend/src/assets/.gitkeep -------------------------------------------------------------------------------- /frontend/src/environments/environment.prod.ts: -------------------------------------------------------------------------------- 1 | export const environment = { 2 | production: true 3 | }; 4 | -------------------------------------------------------------------------------- /frontend/src/environments/environment.ts: -------------------------------------------------------------------------------- 1 | // This file can be replaced during build by using the `fileReplacements` array. 2 | // `ng build --prod` replaces `environment.ts` with `environment.prod.ts`. 3 | // The list of file replacements can be found in `angular.json`. 4 | 5 | export const environment = { 6 | production: false 7 | }; 8 | 9 | /* 10 | * For easier debugging in development mode, you can import the following file 11 | * to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`. 12 | * 13 | * This import should be commented out in production mode because it will have a negative impact 14 | * on performance if an error is thrown. 15 | */ 16 | // import 'zone.js/dist/zone-error'; // Included with Angular CLI. 17 | -------------------------------------------------------------------------------- /frontend/src/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/FaztWeb/angular-node-jwt/4177c09478daee3618f9aee93a2fcea614b6dcc1/frontend/src/favicon.ico -------------------------------------------------------------------------------- /frontend/src/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | Frontend 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | -------------------------------------------------------------------------------- /frontend/src/main.ts: -------------------------------------------------------------------------------- 1 | import { enableProdMode } from '@angular/core'; 2 | import { platformBrowserDynamic } from '@angular/platform-browser-dynamic'; 3 | 4 | import { AppModule } from './app/app.module'; 5 | import { environment } from './environments/environment'; 6 | 7 | if (environment.production) { 8 | enableProdMode(); 9 | } 10 | 11 | platformBrowserDynamic().bootstrapModule(AppModule) 12 | .catch(err => console.error(err)); 13 | -------------------------------------------------------------------------------- /frontend/src/polyfills.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * This file includes polyfills needed by Angular and is loaded before the app. 3 | * You can add your own extra polyfills to this file. 4 | * 5 | * This file is divided into 2 sections: 6 | * 1. Browser polyfills. These are applied before loading ZoneJS and are sorted by browsers. 7 | * 2. Application imports. Files imported after ZoneJS that should be loaded before your main 8 | * file. 9 | * 10 | * The current setup is for so-called "evergreen" browsers; the last versions of browsers that 11 | * automatically update themselves. This includes Safari >= 10, Chrome >= 55 (including Opera), 12 | * Edge >= 13 on the desktop, and iOS 10 and Chrome on mobile. 13 | * 14 | * Learn more in https://angular.io/guide/browser-support 15 | */ 16 | 17 | /*************************************************************************************************** 18 | * BROWSER POLYFILLS 19 | */ 20 | 21 | /** IE10 and IE11 requires the following for NgClass support on SVG elements */ 22 | // import 'classlist.js'; // Run `npm install --save classlist.js`. 23 | 24 | /** 25 | * Web Animations `@angular/platform-browser/animations` 26 | * Only required if AnimationBuilder is used within the application and using IE/Edge or Safari. 27 | * Standard animation support in Angular DOES NOT require any polyfills (as of Angular 6.0). 28 | */ 29 | // import 'web-animations-js'; // Run `npm install --save web-animations-js`. 30 | 31 | /** 32 | * By default, zone.js will patch all possible macroTask and DomEvents 33 | * user can disable parts of macroTask/DomEvents patch by setting following flags 34 | * because those flags need to be set before `zone.js` being loaded, and webpack 35 | * will put import in the top of bundle, so user need to create a separate file 36 | * in this directory (for example: zone-flags.ts), and put the following flags 37 | * into that file, and then add the following code before importing zone.js. 38 | * import './zone-flags.ts'; 39 | * 40 | * The flags allowed in zone-flags.ts are listed here. 41 | * 42 | * The following flags will work for all browsers. 43 | * 44 | * (window as any).__Zone_disable_requestAnimationFrame = true; // disable patch requestAnimationFrame 45 | * (window as any).__Zone_disable_on_property = true; // disable patch onProperty such as onclick 46 | * (window as any).__zone_symbol__UNPATCHED_EVENTS = ['scroll', 'mousemove']; // disable patch specified eventNames 47 | * 48 | * in IE/Edge developer tools, the addEventListener will also be wrapped by zone.js 49 | * with the following flag, it will bypass `zone.js` patch for IE/Edge 50 | * 51 | * (window as any).__Zone_enable_cross_context_check = true; 52 | * 53 | */ 54 | 55 | /*************************************************************************************************** 56 | * Zone JS is required by default for Angular itself. 57 | */ 58 | import 'zone.js/dist/zone'; // Included with Angular CLI. 59 | 60 | 61 | /*************************************************************************************************** 62 | * APPLICATION IMPORTS 63 | */ 64 | -------------------------------------------------------------------------------- /frontend/src/styles.css: -------------------------------------------------------------------------------- 1 | /* You can add global styles to this file, and also import other style files */ 2 | -------------------------------------------------------------------------------- /frontend/src/test.ts: -------------------------------------------------------------------------------- 1 | // This file is required by karma.conf.js and loads recursively all the .spec and framework files 2 | 3 | import 'zone.js/dist/zone-testing'; 4 | import { getTestBed } from '@angular/core/testing'; 5 | import { 6 | BrowserDynamicTestingModule, 7 | platformBrowserDynamicTesting 8 | } from '@angular/platform-browser-dynamic/testing'; 9 | 10 | declare const require: any; 11 | 12 | // First, initialize the Angular testing environment. 13 | getTestBed().initTestEnvironment( 14 | BrowserDynamicTestingModule, 15 | platformBrowserDynamicTesting() 16 | ); 17 | // Then we find all the tests. 18 | const context = require.context('./', true, /\.spec\.ts$/); 19 | // And load the modules. 20 | context.keys().map(context); 21 | -------------------------------------------------------------------------------- /frontend/tsconfig.app.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "./tsconfig.json", 3 | "compilerOptions": { 4 | "outDir": "./out-tsc/app", 5 | "types": [] 6 | }, 7 | "files": [ 8 | "src/main.ts", 9 | "src/polyfills.ts" 10 | ], 11 | "include": [ 12 | "src/**/*.ts" 13 | ], 14 | "exclude": [ 15 | "src/test.ts", 16 | "src/**/*.spec.ts" 17 | ] 18 | } 19 | -------------------------------------------------------------------------------- /frontend/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compileOnSave": false, 3 | "compilerOptions": { 4 | "baseUrl": "./", 5 | "outDir": "./dist/out-tsc", 6 | "sourceMap": true, 7 | "declaration": false, 8 | "downlevelIteration": true, 9 | "experimentalDecorators": true, 10 | "module": "esnext", 11 | "moduleResolution": "node", 12 | "importHelpers": true, 13 | "target": "es2015", 14 | "typeRoots": [ 15 | "node_modules/@types" 16 | ], 17 | "lib": [ 18 | "es2018", 19 | "dom" 20 | ] 21 | }, 22 | "angularCompilerOptions": { 23 | "fullTemplateTypeCheck": true, 24 | "strictInjectionParameters": true 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /frontend/tsconfig.spec.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "./tsconfig.json", 3 | "compilerOptions": { 4 | "outDir": "./out-tsc/spec", 5 | "types": [ 6 | "jasmine", 7 | "node" 8 | ] 9 | }, 10 | "files": [ 11 | "src/test.ts", 12 | "src/polyfills.ts" 13 | ], 14 | "include": [ 15 | "src/**/*.spec.ts", 16 | "src/**/*.d.ts" 17 | ] 18 | } 19 | -------------------------------------------------------------------------------- /frontend/tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "tslint:recommended", 3 | "rules": { 4 | "array-type": false, 5 | "arrow-parens": false, 6 | "deprecation": { 7 | "severity": "warning" 8 | }, 9 | "component-class-suffix": true, 10 | "contextual-lifecycle": true, 11 | "directive-class-suffix": true, 12 | "directive-selector": [ 13 | true, 14 | "attribute", 15 | "app", 16 | "camelCase" 17 | ], 18 | "component-selector": [ 19 | true, 20 | "element", 21 | "app", 22 | "kebab-case" 23 | ], 24 | "import-blacklist": [ 25 | true, 26 | "rxjs/Rx" 27 | ], 28 | "interface-name": false, 29 | "max-classes-per-file": false, 30 | "max-line-length": [ 31 | true, 32 | 140 33 | ], 34 | "member-access": false, 35 | "member-ordering": [ 36 | true, 37 | { 38 | "order": [ 39 | "static-field", 40 | "instance-field", 41 | "static-method", 42 | "instance-method" 43 | ] 44 | } 45 | ], 46 | "no-consecutive-blank-lines": false, 47 | "no-console": [ 48 | true, 49 | "debug", 50 | "info", 51 | "time", 52 | "timeEnd", 53 | "trace" 54 | ], 55 | "no-empty": false, 56 | "no-inferrable-types": [ 57 | true, 58 | "ignore-params" 59 | ], 60 | "no-non-null-assertion": true, 61 | "no-redundant-jsdoc": true, 62 | "no-switch-case-fall-through": true, 63 | "no-var-requires": false, 64 | "object-literal-key-quotes": [ 65 | true, 66 | "as-needed" 67 | ], 68 | "object-literal-sort-keys": false, 69 | "ordered-imports": false, 70 | "quotemark": [ 71 | true, 72 | "single" 73 | ], 74 | "trailing-comma": false, 75 | "no-conflicting-lifecycle": true, 76 | "no-host-metadata-property": true, 77 | "no-input-rename": true, 78 | "no-inputs-metadata-property": true, 79 | "no-output-native": true, 80 | "no-output-on-prefix": true, 81 | "no-output-rename": true, 82 | "no-outputs-metadata-property": true, 83 | "template-banana-in-box": true, 84 | "template-no-negated-async": true, 85 | "use-lifecycle-interface": true, 86 | "use-pipe-transform-interface": true 87 | }, 88 | "rulesDirectory": [ 89 | "codelyzer" 90 | ] 91 | } -------------------------------------------------------------------------------- /screenshot.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/FaztWeb/angular-node-jwt/4177c09478daee3618f9aee93a2fcea614b6dcc1/screenshot.png --------------------------------------------------------------------------------