├── .gitignore ├── package-lock.json ├── package.json ├── src ├── controllers │ ├── auth.controller.ts │ └── products.controller.ts ├── index.ts ├── middlewares │ └── schemaValidator.middleware.ts ├── routes │ ├── auth.routes.ts │ └── products.routes.ts └── schemas │ ├── auth.schema.ts │ └── product.schema.ts └── tsconfig.json /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | dist -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "zod-restapi-tutorial", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "zod-restapi-tutorial", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "express": "^4.17.3", 13 | "zod": "^3.14.4" 14 | }, 15 | "devDependencies": { 16 | "@types/express": "^4.17.13", 17 | "ts-node-dev": "^1.1.8", 18 | "typescript": "^4.6.3" 19 | } 20 | }, 21 | "node_modules/@types/body-parser": { 22 | "version": "1.19.2", 23 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz", 24 | "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==", 25 | "dev": true, 26 | "dependencies": { 27 | "@types/connect": "*", 28 | "@types/node": "*" 29 | } 30 | }, 31 | "node_modules/@types/connect": { 32 | "version": "3.4.35", 33 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", 34 | "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", 35 | "dev": true, 36 | "dependencies": { 37 | "@types/node": "*" 38 | } 39 | }, 40 | "node_modules/@types/express": { 41 | "version": "4.17.13", 42 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz", 43 | "integrity": "sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA==", 44 | "dev": true, 45 | "dependencies": { 46 | "@types/body-parser": "*", 47 | "@types/express-serve-static-core": "^4.17.18", 48 | "@types/qs": "*", 49 | "@types/serve-static": "*" 50 | } 51 | }, 52 | "node_modules/@types/express-serve-static-core": { 53 | "version": "4.17.28", 54 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.28.tgz", 55 | "integrity": "sha512-P1BJAEAW3E2DJUlkgq4tOL3RyMunoWXqbSCygWo5ZIWTjUgN1YnaXWW4VWl/oc8vs/XoYibEGBKP0uZyF4AHig==", 56 | "dev": true, 57 | "dependencies": { 58 | "@types/node": "*", 59 | "@types/qs": "*", 60 | "@types/range-parser": "*" 61 | } 62 | }, 63 | "node_modules/@types/mime": { 64 | "version": "1.3.2", 65 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", 66 | "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==", 67 | "dev": true 68 | }, 69 | "node_modules/@types/node": { 70 | "version": "17.0.24", 71 | "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.24.tgz", 72 | "integrity": "sha512-aveCYRQbgTH9Pssp1voEP7HiuWlD2jW2BO56w+bVrJn04i61yh6mRfoKO6hEYQD9vF+W8Chkwc6j1M36uPkx4g==", 73 | "dev": true 74 | }, 75 | "node_modules/@types/qs": { 76 | "version": "6.9.7", 77 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 78 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==", 79 | "dev": true 80 | }, 81 | "node_modules/@types/range-parser": { 82 | "version": "1.2.4", 83 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", 84 | "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==", 85 | "dev": true 86 | }, 87 | "node_modules/@types/serve-static": { 88 | "version": "1.13.10", 89 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz", 90 | "integrity": "sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ==", 91 | "dev": true, 92 | "dependencies": { 93 | "@types/mime": "^1", 94 | "@types/node": "*" 95 | } 96 | }, 97 | "node_modules/@types/strip-bom": { 98 | "version": "3.0.0", 99 | "resolved": "https://registry.npmjs.org/@types/strip-bom/-/strip-bom-3.0.0.tgz", 100 | "integrity": "sha1-FKjsOVbC6B7bdSB5CuzyHCkK69I=", 101 | "dev": true 102 | }, 103 | "node_modules/@types/strip-json-comments": { 104 | "version": "0.0.30", 105 | "resolved": "https://registry.npmjs.org/@types/strip-json-comments/-/strip-json-comments-0.0.30.tgz", 106 | "integrity": "sha512-7NQmHra/JILCd1QqpSzl8+mJRc8ZHz3uDm8YV1Ks9IhK0epEiTw8aIErbvH9PI+6XbqhyIQy3462nEsn7UVzjQ==", 107 | "dev": true 108 | }, 109 | "node_modules/accepts": { 110 | "version": "1.3.8", 111 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 112 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 113 | "dependencies": { 114 | "mime-types": "~2.1.34", 115 | "negotiator": "0.6.3" 116 | }, 117 | "engines": { 118 | "node": ">= 0.6" 119 | } 120 | }, 121 | "node_modules/anymatch": { 122 | "version": "3.1.2", 123 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 124 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 125 | "dev": true, 126 | "dependencies": { 127 | "normalize-path": "^3.0.0", 128 | "picomatch": "^2.0.4" 129 | }, 130 | "engines": { 131 | "node": ">= 8" 132 | } 133 | }, 134 | "node_modules/arg": { 135 | "version": "4.1.3", 136 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 137 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 138 | "dev": true 139 | }, 140 | "node_modules/array-flatten": { 141 | "version": "1.1.1", 142 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 143 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 144 | }, 145 | "node_modules/balanced-match": { 146 | "version": "1.0.2", 147 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 148 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 149 | "dev": true 150 | }, 151 | "node_modules/binary-extensions": { 152 | "version": "2.2.0", 153 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 154 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 155 | "dev": true, 156 | "engines": { 157 | "node": ">=8" 158 | } 159 | }, 160 | "node_modules/body-parser": { 161 | "version": "1.19.2", 162 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.2.tgz", 163 | "integrity": "sha512-SAAwOxgoCKMGs9uUAUFHygfLAyaniaoun6I8mFY9pRAJL9+Kec34aU+oIjDhTycub1jozEfEwx1W1IuOYxVSFw==", 164 | "dependencies": { 165 | "bytes": "3.1.2", 166 | "content-type": "~1.0.4", 167 | "debug": "2.6.9", 168 | "depd": "~1.1.2", 169 | "http-errors": "1.8.1", 170 | "iconv-lite": "0.4.24", 171 | "on-finished": "~2.3.0", 172 | "qs": "6.9.7", 173 | "raw-body": "2.4.3", 174 | "type-is": "~1.6.18" 175 | }, 176 | "engines": { 177 | "node": ">= 0.8" 178 | } 179 | }, 180 | "node_modules/brace-expansion": { 181 | "version": "1.1.11", 182 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 183 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 184 | "dev": true, 185 | "dependencies": { 186 | "balanced-match": "^1.0.0", 187 | "concat-map": "0.0.1" 188 | } 189 | }, 190 | "node_modules/braces": { 191 | "version": "3.0.2", 192 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 193 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 194 | "dev": true, 195 | "dependencies": { 196 | "fill-range": "^7.0.1" 197 | }, 198 | "engines": { 199 | "node": ">=8" 200 | } 201 | }, 202 | "node_modules/buffer-from": { 203 | "version": "1.1.2", 204 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 205 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 206 | "dev": true 207 | }, 208 | "node_modules/bytes": { 209 | "version": "3.1.2", 210 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 211 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 212 | "engines": { 213 | "node": ">= 0.8" 214 | } 215 | }, 216 | "node_modules/chokidar": { 217 | "version": "3.5.3", 218 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 219 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 220 | "dev": true, 221 | "funding": [ 222 | { 223 | "type": "individual", 224 | "url": "https://paulmillr.com/funding/" 225 | } 226 | ], 227 | "dependencies": { 228 | "anymatch": "~3.1.2", 229 | "braces": "~3.0.2", 230 | "glob-parent": "~5.1.2", 231 | "is-binary-path": "~2.1.0", 232 | "is-glob": "~4.0.1", 233 | "normalize-path": "~3.0.0", 234 | "readdirp": "~3.6.0" 235 | }, 236 | "engines": { 237 | "node": ">= 8.10.0" 238 | }, 239 | "optionalDependencies": { 240 | "fsevents": "~2.3.2" 241 | } 242 | }, 243 | "node_modules/concat-map": { 244 | "version": "0.0.1", 245 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 246 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 247 | "dev": true 248 | }, 249 | "node_modules/content-disposition": { 250 | "version": "0.5.4", 251 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 252 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 253 | "dependencies": { 254 | "safe-buffer": "5.2.1" 255 | }, 256 | "engines": { 257 | "node": ">= 0.6" 258 | } 259 | }, 260 | "node_modules/content-type": { 261 | "version": "1.0.4", 262 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 263 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", 264 | "engines": { 265 | "node": ">= 0.6" 266 | } 267 | }, 268 | "node_modules/cookie": { 269 | "version": "0.4.2", 270 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz", 271 | "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==", 272 | "engines": { 273 | "node": ">= 0.6" 274 | } 275 | }, 276 | "node_modules/cookie-signature": { 277 | "version": "1.0.6", 278 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 279 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 280 | }, 281 | "node_modules/create-require": { 282 | "version": "1.1.1", 283 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 284 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 285 | "dev": true 286 | }, 287 | "node_modules/debug": { 288 | "version": "2.6.9", 289 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 290 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 291 | "dependencies": { 292 | "ms": "2.0.0" 293 | } 294 | }, 295 | "node_modules/depd": { 296 | "version": "1.1.2", 297 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 298 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 299 | "engines": { 300 | "node": ">= 0.6" 301 | } 302 | }, 303 | "node_modules/destroy": { 304 | "version": "1.0.4", 305 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 306 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 307 | }, 308 | "node_modules/diff": { 309 | "version": "4.0.2", 310 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 311 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 312 | "dev": true, 313 | "engines": { 314 | "node": ">=0.3.1" 315 | } 316 | }, 317 | "node_modules/dynamic-dedupe": { 318 | "version": "0.3.0", 319 | "resolved": "https://registry.npmjs.org/dynamic-dedupe/-/dynamic-dedupe-0.3.0.tgz", 320 | "integrity": "sha1-BuRMIj9eTpTXjvnbI6ZRXOL5YqE=", 321 | "dev": true, 322 | "dependencies": { 323 | "xtend": "^4.0.0" 324 | } 325 | }, 326 | "node_modules/ee-first": { 327 | "version": "1.1.1", 328 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 329 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 330 | }, 331 | "node_modules/encodeurl": { 332 | "version": "1.0.2", 333 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 334 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", 335 | "engines": { 336 | "node": ">= 0.8" 337 | } 338 | }, 339 | "node_modules/escape-html": { 340 | "version": "1.0.3", 341 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 342 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 343 | }, 344 | "node_modules/etag": { 345 | "version": "1.8.1", 346 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 347 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", 348 | "engines": { 349 | "node": ">= 0.6" 350 | } 351 | }, 352 | "node_modules/express": { 353 | "version": "4.17.3", 354 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.3.tgz", 355 | "integrity": "sha512-yuSQpz5I+Ch7gFrPCk4/c+dIBKlQUxtgwqzph132bsT6qhuzss6I8cLJQz7B3rFblzd6wtcI0ZbGltH/C4LjUg==", 356 | "dependencies": { 357 | "accepts": "~1.3.8", 358 | "array-flatten": "1.1.1", 359 | "body-parser": "1.19.2", 360 | "content-disposition": "0.5.4", 361 | "content-type": "~1.0.4", 362 | "cookie": "0.4.2", 363 | "cookie-signature": "1.0.6", 364 | "debug": "2.6.9", 365 | "depd": "~1.1.2", 366 | "encodeurl": "~1.0.2", 367 | "escape-html": "~1.0.3", 368 | "etag": "~1.8.1", 369 | "finalhandler": "~1.1.2", 370 | "fresh": "0.5.2", 371 | "merge-descriptors": "1.0.1", 372 | "methods": "~1.1.2", 373 | "on-finished": "~2.3.0", 374 | "parseurl": "~1.3.3", 375 | "path-to-regexp": "0.1.7", 376 | "proxy-addr": "~2.0.7", 377 | "qs": "6.9.7", 378 | "range-parser": "~1.2.1", 379 | "safe-buffer": "5.2.1", 380 | "send": "0.17.2", 381 | "serve-static": "1.14.2", 382 | "setprototypeof": "1.2.0", 383 | "statuses": "~1.5.0", 384 | "type-is": "~1.6.18", 385 | "utils-merge": "1.0.1", 386 | "vary": "~1.1.2" 387 | }, 388 | "engines": { 389 | "node": ">= 0.10.0" 390 | } 391 | }, 392 | "node_modules/fill-range": { 393 | "version": "7.0.1", 394 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 395 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 396 | "dev": true, 397 | "dependencies": { 398 | "to-regex-range": "^5.0.1" 399 | }, 400 | "engines": { 401 | "node": ">=8" 402 | } 403 | }, 404 | "node_modules/finalhandler": { 405 | "version": "1.1.2", 406 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 407 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 408 | "dependencies": { 409 | "debug": "2.6.9", 410 | "encodeurl": "~1.0.2", 411 | "escape-html": "~1.0.3", 412 | "on-finished": "~2.3.0", 413 | "parseurl": "~1.3.3", 414 | "statuses": "~1.5.0", 415 | "unpipe": "~1.0.0" 416 | }, 417 | "engines": { 418 | "node": ">= 0.8" 419 | } 420 | }, 421 | "node_modules/forwarded": { 422 | "version": "0.2.0", 423 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 424 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 425 | "engines": { 426 | "node": ">= 0.6" 427 | } 428 | }, 429 | "node_modules/fresh": { 430 | "version": "0.5.2", 431 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 432 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", 433 | "engines": { 434 | "node": ">= 0.6" 435 | } 436 | }, 437 | "node_modules/fs.realpath": { 438 | "version": "1.0.0", 439 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 440 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 441 | "dev": true 442 | }, 443 | "node_modules/fsevents": { 444 | "version": "2.3.2", 445 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 446 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 447 | "dev": true, 448 | "hasInstallScript": true, 449 | "optional": true, 450 | "os": [ 451 | "darwin" 452 | ], 453 | "engines": { 454 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 455 | } 456 | }, 457 | "node_modules/function-bind": { 458 | "version": "1.1.1", 459 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 460 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 461 | "dev": true 462 | }, 463 | "node_modules/glob": { 464 | "version": "7.2.0", 465 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 466 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 467 | "dev": true, 468 | "dependencies": { 469 | "fs.realpath": "^1.0.0", 470 | "inflight": "^1.0.4", 471 | "inherits": "2", 472 | "minimatch": "^3.0.4", 473 | "once": "^1.3.0", 474 | "path-is-absolute": "^1.0.0" 475 | }, 476 | "engines": { 477 | "node": "*" 478 | }, 479 | "funding": { 480 | "url": "https://github.com/sponsors/isaacs" 481 | } 482 | }, 483 | "node_modules/glob-parent": { 484 | "version": "5.1.2", 485 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 486 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 487 | "dev": true, 488 | "dependencies": { 489 | "is-glob": "^4.0.1" 490 | }, 491 | "engines": { 492 | "node": ">= 6" 493 | } 494 | }, 495 | "node_modules/has": { 496 | "version": "1.0.3", 497 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 498 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 499 | "dev": true, 500 | "dependencies": { 501 | "function-bind": "^1.1.1" 502 | }, 503 | "engines": { 504 | "node": ">= 0.4.0" 505 | } 506 | }, 507 | "node_modules/http-errors": { 508 | "version": "1.8.1", 509 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz", 510 | "integrity": "sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g==", 511 | "dependencies": { 512 | "depd": "~1.1.2", 513 | "inherits": "2.0.4", 514 | "setprototypeof": "1.2.0", 515 | "statuses": ">= 1.5.0 < 2", 516 | "toidentifier": "1.0.1" 517 | }, 518 | "engines": { 519 | "node": ">= 0.6" 520 | } 521 | }, 522 | "node_modules/iconv-lite": { 523 | "version": "0.4.24", 524 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 525 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 526 | "dependencies": { 527 | "safer-buffer": ">= 2.1.2 < 3" 528 | }, 529 | "engines": { 530 | "node": ">=0.10.0" 531 | } 532 | }, 533 | "node_modules/inflight": { 534 | "version": "1.0.6", 535 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 536 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 537 | "dev": true, 538 | "dependencies": { 539 | "once": "^1.3.0", 540 | "wrappy": "1" 541 | } 542 | }, 543 | "node_modules/inherits": { 544 | "version": "2.0.4", 545 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 546 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 547 | }, 548 | "node_modules/ipaddr.js": { 549 | "version": "1.9.1", 550 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 551 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 552 | "engines": { 553 | "node": ">= 0.10" 554 | } 555 | }, 556 | "node_modules/is-binary-path": { 557 | "version": "2.1.0", 558 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 559 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 560 | "dev": true, 561 | "dependencies": { 562 | "binary-extensions": "^2.0.0" 563 | }, 564 | "engines": { 565 | "node": ">=8" 566 | } 567 | }, 568 | "node_modules/is-core-module": { 569 | "version": "2.8.1", 570 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.1.tgz", 571 | "integrity": "sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==", 572 | "dev": true, 573 | "dependencies": { 574 | "has": "^1.0.3" 575 | }, 576 | "funding": { 577 | "url": "https://github.com/sponsors/ljharb" 578 | } 579 | }, 580 | "node_modules/is-extglob": { 581 | "version": "2.1.1", 582 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 583 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 584 | "dev": true, 585 | "engines": { 586 | "node": ">=0.10.0" 587 | } 588 | }, 589 | "node_modules/is-glob": { 590 | "version": "4.0.3", 591 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 592 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 593 | "dev": true, 594 | "dependencies": { 595 | "is-extglob": "^2.1.1" 596 | }, 597 | "engines": { 598 | "node": ">=0.10.0" 599 | } 600 | }, 601 | "node_modules/is-number": { 602 | "version": "7.0.0", 603 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 604 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 605 | "dev": true, 606 | "engines": { 607 | "node": ">=0.12.0" 608 | } 609 | }, 610 | "node_modules/make-error": { 611 | "version": "1.3.6", 612 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 613 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 614 | "dev": true 615 | }, 616 | "node_modules/media-typer": { 617 | "version": "0.3.0", 618 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 619 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=", 620 | "engines": { 621 | "node": ">= 0.6" 622 | } 623 | }, 624 | "node_modules/merge-descriptors": { 625 | "version": "1.0.1", 626 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 627 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 628 | }, 629 | "node_modules/methods": { 630 | "version": "1.1.2", 631 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 632 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", 633 | "engines": { 634 | "node": ">= 0.6" 635 | } 636 | }, 637 | "node_modules/mime": { 638 | "version": "1.6.0", 639 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 640 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 641 | "bin": { 642 | "mime": "cli.js" 643 | }, 644 | "engines": { 645 | "node": ">=4" 646 | } 647 | }, 648 | "node_modules/mime-db": { 649 | "version": "1.52.0", 650 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 651 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 652 | "engines": { 653 | "node": ">= 0.6" 654 | } 655 | }, 656 | "node_modules/mime-types": { 657 | "version": "2.1.35", 658 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 659 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 660 | "dependencies": { 661 | "mime-db": "1.52.0" 662 | }, 663 | "engines": { 664 | "node": ">= 0.6" 665 | } 666 | }, 667 | "node_modules/minimatch": { 668 | "version": "3.1.2", 669 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 670 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 671 | "dev": true, 672 | "dependencies": { 673 | "brace-expansion": "^1.1.7" 674 | }, 675 | "engines": { 676 | "node": "*" 677 | } 678 | }, 679 | "node_modules/minimist": { 680 | "version": "1.2.6", 681 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 682 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 683 | "dev": true 684 | }, 685 | "node_modules/mkdirp": { 686 | "version": "1.0.4", 687 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 688 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 689 | "dev": true, 690 | "bin": { 691 | "mkdirp": "bin/cmd.js" 692 | }, 693 | "engines": { 694 | "node": ">=10" 695 | } 696 | }, 697 | "node_modules/ms": { 698 | "version": "2.0.0", 699 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 700 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 701 | }, 702 | "node_modules/negotiator": { 703 | "version": "0.6.3", 704 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 705 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 706 | "engines": { 707 | "node": ">= 0.6" 708 | } 709 | }, 710 | "node_modules/normalize-path": { 711 | "version": "3.0.0", 712 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 713 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 714 | "dev": true, 715 | "engines": { 716 | "node": ">=0.10.0" 717 | } 718 | }, 719 | "node_modules/on-finished": { 720 | "version": "2.3.0", 721 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 722 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 723 | "dependencies": { 724 | "ee-first": "1.1.1" 725 | }, 726 | "engines": { 727 | "node": ">= 0.8" 728 | } 729 | }, 730 | "node_modules/once": { 731 | "version": "1.4.0", 732 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 733 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 734 | "dev": true, 735 | "dependencies": { 736 | "wrappy": "1" 737 | } 738 | }, 739 | "node_modules/parseurl": { 740 | "version": "1.3.3", 741 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 742 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 743 | "engines": { 744 | "node": ">= 0.8" 745 | } 746 | }, 747 | "node_modules/path-is-absolute": { 748 | "version": "1.0.1", 749 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 750 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 751 | "dev": true, 752 | "engines": { 753 | "node": ">=0.10.0" 754 | } 755 | }, 756 | "node_modules/path-parse": { 757 | "version": "1.0.7", 758 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 759 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 760 | "dev": true 761 | }, 762 | "node_modules/path-to-regexp": { 763 | "version": "0.1.7", 764 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 765 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 766 | }, 767 | "node_modules/picomatch": { 768 | "version": "2.3.1", 769 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 770 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 771 | "dev": true, 772 | "engines": { 773 | "node": ">=8.6" 774 | }, 775 | "funding": { 776 | "url": "https://github.com/sponsors/jonschlinkert" 777 | } 778 | }, 779 | "node_modules/proxy-addr": { 780 | "version": "2.0.7", 781 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 782 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 783 | "dependencies": { 784 | "forwarded": "0.2.0", 785 | "ipaddr.js": "1.9.1" 786 | }, 787 | "engines": { 788 | "node": ">= 0.10" 789 | } 790 | }, 791 | "node_modules/qs": { 792 | "version": "6.9.7", 793 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.9.7.tgz", 794 | "integrity": "sha512-IhMFgUmuNpyRfxA90umL7ByLlgRXu6tIfKPpF5TmcfRLlLCckfP/g3IQmju6jjpu+Hh8rA+2p6A27ZSPOOHdKw==", 795 | "engines": { 796 | "node": ">=0.6" 797 | }, 798 | "funding": { 799 | "url": "https://github.com/sponsors/ljharb" 800 | } 801 | }, 802 | "node_modules/range-parser": { 803 | "version": "1.2.1", 804 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 805 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 806 | "engines": { 807 | "node": ">= 0.6" 808 | } 809 | }, 810 | "node_modules/raw-body": { 811 | "version": "2.4.3", 812 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.3.tgz", 813 | "integrity": "sha512-UlTNLIcu0uzb4D2f4WltY6cVjLi+/jEN4lgEUj3E04tpMDpUlkBo/eSn6zou9hum2VMNpCCUone0O0WeJim07g==", 814 | "dependencies": { 815 | "bytes": "3.1.2", 816 | "http-errors": "1.8.1", 817 | "iconv-lite": "0.4.24", 818 | "unpipe": "1.0.0" 819 | }, 820 | "engines": { 821 | "node": ">= 0.8" 822 | } 823 | }, 824 | "node_modules/readdirp": { 825 | "version": "3.6.0", 826 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 827 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 828 | "dev": true, 829 | "dependencies": { 830 | "picomatch": "^2.2.1" 831 | }, 832 | "engines": { 833 | "node": ">=8.10.0" 834 | } 835 | }, 836 | "node_modules/resolve": { 837 | "version": "1.22.0", 838 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz", 839 | "integrity": "sha512-Hhtrw0nLeSrFQ7phPp4OOcVjLPIeMnRlr5mcnVuMe7M/7eBn98A3hmFRLoFo3DLZkivSYwhRUJTyPyWAk56WLw==", 840 | "dev": true, 841 | "dependencies": { 842 | "is-core-module": "^2.8.1", 843 | "path-parse": "^1.0.7", 844 | "supports-preserve-symlinks-flag": "^1.0.0" 845 | }, 846 | "bin": { 847 | "resolve": "bin/resolve" 848 | }, 849 | "funding": { 850 | "url": "https://github.com/sponsors/ljharb" 851 | } 852 | }, 853 | "node_modules/rimraf": { 854 | "version": "2.7.1", 855 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 856 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 857 | "dev": true, 858 | "dependencies": { 859 | "glob": "^7.1.3" 860 | }, 861 | "bin": { 862 | "rimraf": "bin.js" 863 | } 864 | }, 865 | "node_modules/safe-buffer": { 866 | "version": "5.2.1", 867 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 868 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 869 | "funding": [ 870 | { 871 | "type": "github", 872 | "url": "https://github.com/sponsors/feross" 873 | }, 874 | { 875 | "type": "patreon", 876 | "url": "https://www.patreon.com/feross" 877 | }, 878 | { 879 | "type": "consulting", 880 | "url": "https://feross.org/support" 881 | } 882 | ] 883 | }, 884 | "node_modules/safer-buffer": { 885 | "version": "2.1.2", 886 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 887 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 888 | }, 889 | "node_modules/send": { 890 | "version": "0.17.2", 891 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.2.tgz", 892 | "integrity": "sha512-UJYB6wFSJE3G00nEivR5rgWp8c2xXvJ3OPWPhmuteU0IKj8nKbG3DrjiOmLwpnHGYWAVwA69zmTm++YG0Hmwww==", 893 | "dependencies": { 894 | "debug": "2.6.9", 895 | "depd": "~1.1.2", 896 | "destroy": "~1.0.4", 897 | "encodeurl": "~1.0.2", 898 | "escape-html": "~1.0.3", 899 | "etag": "~1.8.1", 900 | "fresh": "0.5.2", 901 | "http-errors": "1.8.1", 902 | "mime": "1.6.0", 903 | "ms": "2.1.3", 904 | "on-finished": "~2.3.0", 905 | "range-parser": "~1.2.1", 906 | "statuses": "~1.5.0" 907 | }, 908 | "engines": { 909 | "node": ">= 0.8.0" 910 | } 911 | }, 912 | "node_modules/send/node_modules/ms": { 913 | "version": "2.1.3", 914 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 915 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 916 | }, 917 | "node_modules/serve-static": { 918 | "version": "1.14.2", 919 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.2.tgz", 920 | "integrity": "sha512-+TMNA9AFxUEGuC0z2mevogSnn9MXKb4fa7ngeRMJaaGv8vTwnIEkKi+QGvPt33HSnf8pRS+WGM0EbMtCJLKMBQ==", 921 | "dependencies": { 922 | "encodeurl": "~1.0.2", 923 | "escape-html": "~1.0.3", 924 | "parseurl": "~1.3.3", 925 | "send": "0.17.2" 926 | }, 927 | "engines": { 928 | "node": ">= 0.8.0" 929 | } 930 | }, 931 | "node_modules/setprototypeof": { 932 | "version": "1.2.0", 933 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 934 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 935 | }, 936 | "node_modules/source-map": { 937 | "version": "0.6.1", 938 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 939 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 940 | "dev": true, 941 | "engines": { 942 | "node": ">=0.10.0" 943 | } 944 | }, 945 | "node_modules/source-map-support": { 946 | "version": "0.5.21", 947 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 948 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 949 | "dev": true, 950 | "dependencies": { 951 | "buffer-from": "^1.0.0", 952 | "source-map": "^0.6.0" 953 | } 954 | }, 955 | "node_modules/statuses": { 956 | "version": "1.5.0", 957 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 958 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 959 | "engines": { 960 | "node": ">= 0.6" 961 | } 962 | }, 963 | "node_modules/strip-bom": { 964 | "version": "3.0.0", 965 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 966 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 967 | "dev": true, 968 | "engines": { 969 | "node": ">=4" 970 | } 971 | }, 972 | "node_modules/strip-json-comments": { 973 | "version": "2.0.1", 974 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 975 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 976 | "dev": true, 977 | "engines": { 978 | "node": ">=0.10.0" 979 | } 980 | }, 981 | "node_modules/supports-preserve-symlinks-flag": { 982 | "version": "1.0.0", 983 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 984 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 985 | "dev": true, 986 | "engines": { 987 | "node": ">= 0.4" 988 | }, 989 | "funding": { 990 | "url": "https://github.com/sponsors/ljharb" 991 | } 992 | }, 993 | "node_modules/to-regex-range": { 994 | "version": "5.0.1", 995 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 996 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 997 | "dev": true, 998 | "dependencies": { 999 | "is-number": "^7.0.0" 1000 | }, 1001 | "engines": { 1002 | "node": ">=8.0" 1003 | } 1004 | }, 1005 | "node_modules/toidentifier": { 1006 | "version": "1.0.1", 1007 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1008 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1009 | "engines": { 1010 | "node": ">=0.6" 1011 | } 1012 | }, 1013 | "node_modules/tree-kill": { 1014 | "version": "1.2.2", 1015 | "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", 1016 | "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==", 1017 | "dev": true, 1018 | "bin": { 1019 | "tree-kill": "cli.js" 1020 | } 1021 | }, 1022 | "node_modules/ts-node": { 1023 | "version": "9.1.1", 1024 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-9.1.1.tgz", 1025 | "integrity": "sha512-hPlt7ZACERQGf03M253ytLY3dHbGNGrAq9qIHWUY9XHYl1z7wYngSr3OQ5xmui8o2AaxsONxIzjafLUiWBo1Fg==", 1026 | "dev": true, 1027 | "dependencies": { 1028 | "arg": "^4.1.0", 1029 | "create-require": "^1.1.0", 1030 | "diff": "^4.0.1", 1031 | "make-error": "^1.1.1", 1032 | "source-map-support": "^0.5.17", 1033 | "yn": "3.1.1" 1034 | }, 1035 | "bin": { 1036 | "ts-node": "dist/bin.js", 1037 | "ts-node-script": "dist/bin-script.js", 1038 | "ts-node-transpile-only": "dist/bin-transpile.js", 1039 | "ts-script": "dist/bin-script-deprecated.js" 1040 | }, 1041 | "engines": { 1042 | "node": ">=10.0.0" 1043 | }, 1044 | "peerDependencies": { 1045 | "typescript": ">=2.7" 1046 | } 1047 | }, 1048 | "node_modules/ts-node-dev": { 1049 | "version": "1.1.8", 1050 | "resolved": "https://registry.npmjs.org/ts-node-dev/-/ts-node-dev-1.1.8.tgz", 1051 | "integrity": "sha512-Q/m3vEwzYwLZKmV6/0VlFxcZzVV/xcgOt+Tx/VjaaRHyiBcFlV0541yrT09QjzzCxlDZ34OzKjrFAynlmtflEg==", 1052 | "dev": true, 1053 | "dependencies": { 1054 | "chokidar": "^3.5.1", 1055 | "dynamic-dedupe": "^0.3.0", 1056 | "minimist": "^1.2.5", 1057 | "mkdirp": "^1.0.4", 1058 | "resolve": "^1.0.0", 1059 | "rimraf": "^2.6.1", 1060 | "source-map-support": "^0.5.12", 1061 | "tree-kill": "^1.2.2", 1062 | "ts-node": "^9.0.0", 1063 | "tsconfig": "^7.0.0" 1064 | }, 1065 | "bin": { 1066 | "ts-node-dev": "lib/bin.js", 1067 | "tsnd": "lib/bin.js" 1068 | }, 1069 | "engines": { 1070 | "node": ">=0.8.0" 1071 | }, 1072 | "peerDependencies": { 1073 | "node-notifier": "*", 1074 | "typescript": "*" 1075 | }, 1076 | "peerDependenciesMeta": { 1077 | "node-notifier": { 1078 | "optional": true 1079 | } 1080 | } 1081 | }, 1082 | "node_modules/tsconfig": { 1083 | "version": "7.0.0", 1084 | "resolved": "https://registry.npmjs.org/tsconfig/-/tsconfig-7.0.0.tgz", 1085 | "integrity": "sha512-vZXmzPrL+EmC4T/4rVlT2jNVMWCi/O4DIiSj3UHg1OE5kCKbk4mfrXc6dZksLgRM/TZlKnousKH9bbTazUWRRw==", 1086 | "dev": true, 1087 | "dependencies": { 1088 | "@types/strip-bom": "^3.0.0", 1089 | "@types/strip-json-comments": "0.0.30", 1090 | "strip-bom": "^3.0.0", 1091 | "strip-json-comments": "^2.0.0" 1092 | } 1093 | }, 1094 | "node_modules/type-is": { 1095 | "version": "1.6.18", 1096 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1097 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1098 | "dependencies": { 1099 | "media-typer": "0.3.0", 1100 | "mime-types": "~2.1.24" 1101 | }, 1102 | "engines": { 1103 | "node": ">= 0.6" 1104 | } 1105 | }, 1106 | "node_modules/typescript": { 1107 | "version": "4.6.3", 1108 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.6.3.tgz", 1109 | "integrity": "sha512-yNIatDa5iaofVozS/uQJEl3JRWLKKGJKh6Yaiv0GLGSuhpFJe7P3SbHZ8/yjAHRQwKRoA6YZqlfjXWmVzoVSMw==", 1110 | "dev": true, 1111 | "bin": { 1112 | "tsc": "bin/tsc", 1113 | "tsserver": "bin/tsserver" 1114 | }, 1115 | "engines": { 1116 | "node": ">=4.2.0" 1117 | } 1118 | }, 1119 | "node_modules/unpipe": { 1120 | "version": "1.0.0", 1121 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1122 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", 1123 | "engines": { 1124 | "node": ">= 0.8" 1125 | } 1126 | }, 1127 | "node_modules/utils-merge": { 1128 | "version": "1.0.1", 1129 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1130 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 1131 | "engines": { 1132 | "node": ">= 0.4.0" 1133 | } 1134 | }, 1135 | "node_modules/vary": { 1136 | "version": "1.1.2", 1137 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1138 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", 1139 | "engines": { 1140 | "node": ">= 0.8" 1141 | } 1142 | }, 1143 | "node_modules/wrappy": { 1144 | "version": "1.0.2", 1145 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1146 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1147 | "dev": true 1148 | }, 1149 | "node_modules/xtend": { 1150 | "version": "4.0.2", 1151 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 1152 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 1153 | "dev": true, 1154 | "engines": { 1155 | "node": ">=0.4" 1156 | } 1157 | }, 1158 | "node_modules/yn": { 1159 | "version": "3.1.1", 1160 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 1161 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 1162 | "dev": true, 1163 | "engines": { 1164 | "node": ">=6" 1165 | } 1166 | }, 1167 | "node_modules/zod": { 1168 | "version": "3.14.4", 1169 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.14.4.tgz", 1170 | "integrity": "sha512-U9BFLb2GO34Sfo9IUYp0w3wJLlmcyGoMd75qU9yf+DrdGA4kEx6e+l9KOkAlyUO0PSQzZCa3TR4qVlcmwqSDuw==", 1171 | "funding": { 1172 | "url": "https://github.com/sponsors/colinhacks" 1173 | } 1174 | } 1175 | }, 1176 | "dependencies": { 1177 | "@types/body-parser": { 1178 | "version": "1.19.2", 1179 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz", 1180 | "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==", 1181 | "dev": true, 1182 | "requires": { 1183 | "@types/connect": "*", 1184 | "@types/node": "*" 1185 | } 1186 | }, 1187 | "@types/connect": { 1188 | "version": "3.4.35", 1189 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", 1190 | "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", 1191 | "dev": true, 1192 | "requires": { 1193 | "@types/node": "*" 1194 | } 1195 | }, 1196 | "@types/express": { 1197 | "version": "4.17.13", 1198 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz", 1199 | "integrity": "sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA==", 1200 | "dev": true, 1201 | "requires": { 1202 | "@types/body-parser": "*", 1203 | "@types/express-serve-static-core": "^4.17.18", 1204 | "@types/qs": "*", 1205 | "@types/serve-static": "*" 1206 | } 1207 | }, 1208 | "@types/express-serve-static-core": { 1209 | "version": "4.17.28", 1210 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.28.tgz", 1211 | "integrity": "sha512-P1BJAEAW3E2DJUlkgq4tOL3RyMunoWXqbSCygWo5ZIWTjUgN1YnaXWW4VWl/oc8vs/XoYibEGBKP0uZyF4AHig==", 1212 | "dev": true, 1213 | "requires": { 1214 | "@types/node": "*", 1215 | "@types/qs": "*", 1216 | "@types/range-parser": "*" 1217 | } 1218 | }, 1219 | "@types/mime": { 1220 | "version": "1.3.2", 1221 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", 1222 | "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==", 1223 | "dev": true 1224 | }, 1225 | "@types/node": { 1226 | "version": "17.0.24", 1227 | "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.24.tgz", 1228 | "integrity": "sha512-aveCYRQbgTH9Pssp1voEP7HiuWlD2jW2BO56w+bVrJn04i61yh6mRfoKO6hEYQD9vF+W8Chkwc6j1M36uPkx4g==", 1229 | "dev": true 1230 | }, 1231 | "@types/qs": { 1232 | "version": "6.9.7", 1233 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 1234 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==", 1235 | "dev": true 1236 | }, 1237 | "@types/range-parser": { 1238 | "version": "1.2.4", 1239 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", 1240 | "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==", 1241 | "dev": true 1242 | }, 1243 | "@types/serve-static": { 1244 | "version": "1.13.10", 1245 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz", 1246 | "integrity": "sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ==", 1247 | "dev": true, 1248 | "requires": { 1249 | "@types/mime": "^1", 1250 | "@types/node": "*" 1251 | } 1252 | }, 1253 | "@types/strip-bom": { 1254 | "version": "3.0.0", 1255 | "resolved": "https://registry.npmjs.org/@types/strip-bom/-/strip-bom-3.0.0.tgz", 1256 | "integrity": "sha1-FKjsOVbC6B7bdSB5CuzyHCkK69I=", 1257 | "dev": true 1258 | }, 1259 | "@types/strip-json-comments": { 1260 | "version": "0.0.30", 1261 | "resolved": "https://registry.npmjs.org/@types/strip-json-comments/-/strip-json-comments-0.0.30.tgz", 1262 | "integrity": "sha512-7NQmHra/JILCd1QqpSzl8+mJRc8ZHz3uDm8YV1Ks9IhK0epEiTw8aIErbvH9PI+6XbqhyIQy3462nEsn7UVzjQ==", 1263 | "dev": true 1264 | }, 1265 | "accepts": { 1266 | "version": "1.3.8", 1267 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 1268 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 1269 | "requires": { 1270 | "mime-types": "~2.1.34", 1271 | "negotiator": "0.6.3" 1272 | } 1273 | }, 1274 | "anymatch": { 1275 | "version": "3.1.2", 1276 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 1277 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 1278 | "dev": true, 1279 | "requires": { 1280 | "normalize-path": "^3.0.0", 1281 | "picomatch": "^2.0.4" 1282 | } 1283 | }, 1284 | "arg": { 1285 | "version": "4.1.3", 1286 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 1287 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 1288 | "dev": true 1289 | }, 1290 | "array-flatten": { 1291 | "version": "1.1.1", 1292 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 1293 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 1294 | }, 1295 | "balanced-match": { 1296 | "version": "1.0.2", 1297 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1298 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1299 | "dev": true 1300 | }, 1301 | "binary-extensions": { 1302 | "version": "2.2.0", 1303 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 1304 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 1305 | "dev": true 1306 | }, 1307 | "body-parser": { 1308 | "version": "1.19.2", 1309 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.2.tgz", 1310 | "integrity": "sha512-SAAwOxgoCKMGs9uUAUFHygfLAyaniaoun6I8mFY9pRAJL9+Kec34aU+oIjDhTycub1jozEfEwx1W1IuOYxVSFw==", 1311 | "requires": { 1312 | "bytes": "3.1.2", 1313 | "content-type": "~1.0.4", 1314 | "debug": "2.6.9", 1315 | "depd": "~1.1.2", 1316 | "http-errors": "1.8.1", 1317 | "iconv-lite": "0.4.24", 1318 | "on-finished": "~2.3.0", 1319 | "qs": "6.9.7", 1320 | "raw-body": "2.4.3", 1321 | "type-is": "~1.6.18" 1322 | } 1323 | }, 1324 | "brace-expansion": { 1325 | "version": "1.1.11", 1326 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1327 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1328 | "dev": true, 1329 | "requires": { 1330 | "balanced-match": "^1.0.0", 1331 | "concat-map": "0.0.1" 1332 | } 1333 | }, 1334 | "braces": { 1335 | "version": "3.0.2", 1336 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1337 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1338 | "dev": true, 1339 | "requires": { 1340 | "fill-range": "^7.0.1" 1341 | } 1342 | }, 1343 | "buffer-from": { 1344 | "version": "1.1.2", 1345 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 1346 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 1347 | "dev": true 1348 | }, 1349 | "bytes": { 1350 | "version": "3.1.2", 1351 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 1352 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==" 1353 | }, 1354 | "chokidar": { 1355 | "version": "3.5.3", 1356 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 1357 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 1358 | "dev": true, 1359 | "requires": { 1360 | "anymatch": "~3.1.2", 1361 | "braces": "~3.0.2", 1362 | "fsevents": "~2.3.2", 1363 | "glob-parent": "~5.1.2", 1364 | "is-binary-path": "~2.1.0", 1365 | "is-glob": "~4.0.1", 1366 | "normalize-path": "~3.0.0", 1367 | "readdirp": "~3.6.0" 1368 | } 1369 | }, 1370 | "concat-map": { 1371 | "version": "0.0.1", 1372 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1373 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 1374 | "dev": true 1375 | }, 1376 | "content-disposition": { 1377 | "version": "0.5.4", 1378 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 1379 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 1380 | "requires": { 1381 | "safe-buffer": "5.2.1" 1382 | } 1383 | }, 1384 | "content-type": { 1385 | "version": "1.0.4", 1386 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 1387 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 1388 | }, 1389 | "cookie": { 1390 | "version": "0.4.2", 1391 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz", 1392 | "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==" 1393 | }, 1394 | "cookie-signature": { 1395 | "version": "1.0.6", 1396 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 1397 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 1398 | }, 1399 | "create-require": { 1400 | "version": "1.1.1", 1401 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 1402 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 1403 | "dev": true 1404 | }, 1405 | "debug": { 1406 | "version": "2.6.9", 1407 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1408 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1409 | "requires": { 1410 | "ms": "2.0.0" 1411 | } 1412 | }, 1413 | "depd": { 1414 | "version": "1.1.2", 1415 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 1416 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 1417 | }, 1418 | "destroy": { 1419 | "version": "1.0.4", 1420 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 1421 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 1422 | }, 1423 | "diff": { 1424 | "version": "4.0.2", 1425 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 1426 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 1427 | "dev": true 1428 | }, 1429 | "dynamic-dedupe": { 1430 | "version": "0.3.0", 1431 | "resolved": "https://registry.npmjs.org/dynamic-dedupe/-/dynamic-dedupe-0.3.0.tgz", 1432 | "integrity": "sha1-BuRMIj9eTpTXjvnbI6ZRXOL5YqE=", 1433 | "dev": true, 1434 | "requires": { 1435 | "xtend": "^4.0.0" 1436 | } 1437 | }, 1438 | "ee-first": { 1439 | "version": "1.1.1", 1440 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 1441 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 1442 | }, 1443 | "encodeurl": { 1444 | "version": "1.0.2", 1445 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 1446 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 1447 | }, 1448 | "escape-html": { 1449 | "version": "1.0.3", 1450 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 1451 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 1452 | }, 1453 | "etag": { 1454 | "version": "1.8.1", 1455 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 1456 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 1457 | }, 1458 | "express": { 1459 | "version": "4.17.3", 1460 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.3.tgz", 1461 | "integrity": "sha512-yuSQpz5I+Ch7gFrPCk4/c+dIBKlQUxtgwqzph132bsT6qhuzss6I8cLJQz7B3rFblzd6wtcI0ZbGltH/C4LjUg==", 1462 | "requires": { 1463 | "accepts": "~1.3.8", 1464 | "array-flatten": "1.1.1", 1465 | "body-parser": "1.19.2", 1466 | "content-disposition": "0.5.4", 1467 | "content-type": "~1.0.4", 1468 | "cookie": "0.4.2", 1469 | "cookie-signature": "1.0.6", 1470 | "debug": "2.6.9", 1471 | "depd": "~1.1.2", 1472 | "encodeurl": "~1.0.2", 1473 | "escape-html": "~1.0.3", 1474 | "etag": "~1.8.1", 1475 | "finalhandler": "~1.1.2", 1476 | "fresh": "0.5.2", 1477 | "merge-descriptors": "1.0.1", 1478 | "methods": "~1.1.2", 1479 | "on-finished": "~2.3.0", 1480 | "parseurl": "~1.3.3", 1481 | "path-to-regexp": "0.1.7", 1482 | "proxy-addr": "~2.0.7", 1483 | "qs": "6.9.7", 1484 | "range-parser": "~1.2.1", 1485 | "safe-buffer": "5.2.1", 1486 | "send": "0.17.2", 1487 | "serve-static": "1.14.2", 1488 | "setprototypeof": "1.2.0", 1489 | "statuses": "~1.5.0", 1490 | "type-is": "~1.6.18", 1491 | "utils-merge": "1.0.1", 1492 | "vary": "~1.1.2" 1493 | } 1494 | }, 1495 | "fill-range": { 1496 | "version": "7.0.1", 1497 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1498 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1499 | "dev": true, 1500 | "requires": { 1501 | "to-regex-range": "^5.0.1" 1502 | } 1503 | }, 1504 | "finalhandler": { 1505 | "version": "1.1.2", 1506 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 1507 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 1508 | "requires": { 1509 | "debug": "2.6.9", 1510 | "encodeurl": "~1.0.2", 1511 | "escape-html": "~1.0.3", 1512 | "on-finished": "~2.3.0", 1513 | "parseurl": "~1.3.3", 1514 | "statuses": "~1.5.0", 1515 | "unpipe": "~1.0.0" 1516 | } 1517 | }, 1518 | "forwarded": { 1519 | "version": "0.2.0", 1520 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 1521 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 1522 | }, 1523 | "fresh": { 1524 | "version": "0.5.2", 1525 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 1526 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 1527 | }, 1528 | "fs.realpath": { 1529 | "version": "1.0.0", 1530 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1531 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1532 | "dev": true 1533 | }, 1534 | "fsevents": { 1535 | "version": "2.3.2", 1536 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1537 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1538 | "dev": true, 1539 | "optional": true 1540 | }, 1541 | "function-bind": { 1542 | "version": "1.1.1", 1543 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1544 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1545 | "dev": true 1546 | }, 1547 | "glob": { 1548 | "version": "7.2.0", 1549 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 1550 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 1551 | "dev": true, 1552 | "requires": { 1553 | "fs.realpath": "^1.0.0", 1554 | "inflight": "^1.0.4", 1555 | "inherits": "2", 1556 | "minimatch": "^3.0.4", 1557 | "once": "^1.3.0", 1558 | "path-is-absolute": "^1.0.0" 1559 | } 1560 | }, 1561 | "glob-parent": { 1562 | "version": "5.1.2", 1563 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1564 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1565 | "dev": true, 1566 | "requires": { 1567 | "is-glob": "^4.0.1" 1568 | } 1569 | }, 1570 | "has": { 1571 | "version": "1.0.3", 1572 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1573 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1574 | "dev": true, 1575 | "requires": { 1576 | "function-bind": "^1.1.1" 1577 | } 1578 | }, 1579 | "http-errors": { 1580 | "version": "1.8.1", 1581 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz", 1582 | "integrity": "sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g==", 1583 | "requires": { 1584 | "depd": "~1.1.2", 1585 | "inherits": "2.0.4", 1586 | "setprototypeof": "1.2.0", 1587 | "statuses": ">= 1.5.0 < 2", 1588 | "toidentifier": "1.0.1" 1589 | } 1590 | }, 1591 | "iconv-lite": { 1592 | "version": "0.4.24", 1593 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1594 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1595 | "requires": { 1596 | "safer-buffer": ">= 2.1.2 < 3" 1597 | } 1598 | }, 1599 | "inflight": { 1600 | "version": "1.0.6", 1601 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1602 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1603 | "dev": true, 1604 | "requires": { 1605 | "once": "^1.3.0", 1606 | "wrappy": "1" 1607 | } 1608 | }, 1609 | "inherits": { 1610 | "version": "2.0.4", 1611 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1612 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1613 | }, 1614 | "ipaddr.js": { 1615 | "version": "1.9.1", 1616 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 1617 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 1618 | }, 1619 | "is-binary-path": { 1620 | "version": "2.1.0", 1621 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1622 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1623 | "dev": true, 1624 | "requires": { 1625 | "binary-extensions": "^2.0.0" 1626 | } 1627 | }, 1628 | "is-core-module": { 1629 | "version": "2.8.1", 1630 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.1.tgz", 1631 | "integrity": "sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==", 1632 | "dev": true, 1633 | "requires": { 1634 | "has": "^1.0.3" 1635 | } 1636 | }, 1637 | "is-extglob": { 1638 | "version": "2.1.1", 1639 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1640 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1641 | "dev": true 1642 | }, 1643 | "is-glob": { 1644 | "version": "4.0.3", 1645 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1646 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1647 | "dev": true, 1648 | "requires": { 1649 | "is-extglob": "^2.1.1" 1650 | } 1651 | }, 1652 | "is-number": { 1653 | "version": "7.0.0", 1654 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1655 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1656 | "dev": true 1657 | }, 1658 | "make-error": { 1659 | "version": "1.3.6", 1660 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1661 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 1662 | "dev": true 1663 | }, 1664 | "media-typer": { 1665 | "version": "0.3.0", 1666 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1667 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1668 | }, 1669 | "merge-descriptors": { 1670 | "version": "1.0.1", 1671 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1672 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1673 | }, 1674 | "methods": { 1675 | "version": "1.1.2", 1676 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1677 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1678 | }, 1679 | "mime": { 1680 | "version": "1.6.0", 1681 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1682 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 1683 | }, 1684 | "mime-db": { 1685 | "version": "1.52.0", 1686 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1687 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" 1688 | }, 1689 | "mime-types": { 1690 | "version": "2.1.35", 1691 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1692 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1693 | "requires": { 1694 | "mime-db": "1.52.0" 1695 | } 1696 | }, 1697 | "minimatch": { 1698 | "version": "3.1.2", 1699 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1700 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1701 | "dev": true, 1702 | "requires": { 1703 | "brace-expansion": "^1.1.7" 1704 | } 1705 | }, 1706 | "minimist": { 1707 | "version": "1.2.6", 1708 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 1709 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 1710 | "dev": true 1711 | }, 1712 | "mkdirp": { 1713 | "version": "1.0.4", 1714 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 1715 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 1716 | "dev": true 1717 | }, 1718 | "ms": { 1719 | "version": "2.0.0", 1720 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1721 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1722 | }, 1723 | "negotiator": { 1724 | "version": "0.6.3", 1725 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1726 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==" 1727 | }, 1728 | "normalize-path": { 1729 | "version": "3.0.0", 1730 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1731 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1732 | "dev": true 1733 | }, 1734 | "on-finished": { 1735 | "version": "2.3.0", 1736 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1737 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1738 | "requires": { 1739 | "ee-first": "1.1.1" 1740 | } 1741 | }, 1742 | "once": { 1743 | "version": "1.4.0", 1744 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1745 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1746 | "dev": true, 1747 | "requires": { 1748 | "wrappy": "1" 1749 | } 1750 | }, 1751 | "parseurl": { 1752 | "version": "1.3.3", 1753 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1754 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 1755 | }, 1756 | "path-is-absolute": { 1757 | "version": "1.0.1", 1758 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1759 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1760 | "dev": true 1761 | }, 1762 | "path-parse": { 1763 | "version": "1.0.7", 1764 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1765 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1766 | "dev": true 1767 | }, 1768 | "path-to-regexp": { 1769 | "version": "0.1.7", 1770 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1771 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1772 | }, 1773 | "picomatch": { 1774 | "version": "2.3.1", 1775 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1776 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1777 | "dev": true 1778 | }, 1779 | "proxy-addr": { 1780 | "version": "2.0.7", 1781 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1782 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1783 | "requires": { 1784 | "forwarded": "0.2.0", 1785 | "ipaddr.js": "1.9.1" 1786 | } 1787 | }, 1788 | "qs": { 1789 | "version": "6.9.7", 1790 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.9.7.tgz", 1791 | "integrity": "sha512-IhMFgUmuNpyRfxA90umL7ByLlgRXu6tIfKPpF5TmcfRLlLCckfP/g3IQmju6jjpu+Hh8rA+2p6A27ZSPOOHdKw==" 1792 | }, 1793 | "range-parser": { 1794 | "version": "1.2.1", 1795 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1796 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 1797 | }, 1798 | "raw-body": { 1799 | "version": "2.4.3", 1800 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.3.tgz", 1801 | "integrity": "sha512-UlTNLIcu0uzb4D2f4WltY6cVjLi+/jEN4lgEUj3E04tpMDpUlkBo/eSn6zou9hum2VMNpCCUone0O0WeJim07g==", 1802 | "requires": { 1803 | "bytes": "3.1.2", 1804 | "http-errors": "1.8.1", 1805 | "iconv-lite": "0.4.24", 1806 | "unpipe": "1.0.0" 1807 | } 1808 | }, 1809 | "readdirp": { 1810 | "version": "3.6.0", 1811 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1812 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1813 | "dev": true, 1814 | "requires": { 1815 | "picomatch": "^2.2.1" 1816 | } 1817 | }, 1818 | "resolve": { 1819 | "version": "1.22.0", 1820 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz", 1821 | "integrity": "sha512-Hhtrw0nLeSrFQ7phPp4OOcVjLPIeMnRlr5mcnVuMe7M/7eBn98A3hmFRLoFo3DLZkivSYwhRUJTyPyWAk56WLw==", 1822 | "dev": true, 1823 | "requires": { 1824 | "is-core-module": "^2.8.1", 1825 | "path-parse": "^1.0.7", 1826 | "supports-preserve-symlinks-flag": "^1.0.0" 1827 | } 1828 | }, 1829 | "rimraf": { 1830 | "version": "2.7.1", 1831 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1832 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1833 | "dev": true, 1834 | "requires": { 1835 | "glob": "^7.1.3" 1836 | } 1837 | }, 1838 | "safe-buffer": { 1839 | "version": "5.2.1", 1840 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1841 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 1842 | }, 1843 | "safer-buffer": { 1844 | "version": "2.1.2", 1845 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1846 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1847 | }, 1848 | "send": { 1849 | "version": "0.17.2", 1850 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.2.tgz", 1851 | "integrity": "sha512-UJYB6wFSJE3G00nEivR5rgWp8c2xXvJ3OPWPhmuteU0IKj8nKbG3DrjiOmLwpnHGYWAVwA69zmTm++YG0Hmwww==", 1852 | "requires": { 1853 | "debug": "2.6.9", 1854 | "depd": "~1.1.2", 1855 | "destroy": "~1.0.4", 1856 | "encodeurl": "~1.0.2", 1857 | "escape-html": "~1.0.3", 1858 | "etag": "~1.8.1", 1859 | "fresh": "0.5.2", 1860 | "http-errors": "1.8.1", 1861 | "mime": "1.6.0", 1862 | "ms": "2.1.3", 1863 | "on-finished": "~2.3.0", 1864 | "range-parser": "~1.2.1", 1865 | "statuses": "~1.5.0" 1866 | }, 1867 | "dependencies": { 1868 | "ms": { 1869 | "version": "2.1.3", 1870 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1871 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1872 | } 1873 | } 1874 | }, 1875 | "serve-static": { 1876 | "version": "1.14.2", 1877 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.2.tgz", 1878 | "integrity": "sha512-+TMNA9AFxUEGuC0z2mevogSnn9MXKb4fa7ngeRMJaaGv8vTwnIEkKi+QGvPt33HSnf8pRS+WGM0EbMtCJLKMBQ==", 1879 | "requires": { 1880 | "encodeurl": "~1.0.2", 1881 | "escape-html": "~1.0.3", 1882 | "parseurl": "~1.3.3", 1883 | "send": "0.17.2" 1884 | } 1885 | }, 1886 | "setprototypeof": { 1887 | "version": "1.2.0", 1888 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1889 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1890 | }, 1891 | "source-map": { 1892 | "version": "0.6.1", 1893 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1894 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1895 | "dev": true 1896 | }, 1897 | "source-map-support": { 1898 | "version": "0.5.21", 1899 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 1900 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 1901 | "dev": true, 1902 | "requires": { 1903 | "buffer-from": "^1.0.0", 1904 | "source-map": "^0.6.0" 1905 | } 1906 | }, 1907 | "statuses": { 1908 | "version": "1.5.0", 1909 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1910 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 1911 | }, 1912 | "strip-bom": { 1913 | "version": "3.0.0", 1914 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1915 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1916 | "dev": true 1917 | }, 1918 | "strip-json-comments": { 1919 | "version": "2.0.1", 1920 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1921 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1922 | "dev": true 1923 | }, 1924 | "supports-preserve-symlinks-flag": { 1925 | "version": "1.0.0", 1926 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1927 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1928 | "dev": true 1929 | }, 1930 | "to-regex-range": { 1931 | "version": "5.0.1", 1932 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1933 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1934 | "dev": true, 1935 | "requires": { 1936 | "is-number": "^7.0.0" 1937 | } 1938 | }, 1939 | "toidentifier": { 1940 | "version": "1.0.1", 1941 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1942 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==" 1943 | }, 1944 | "tree-kill": { 1945 | "version": "1.2.2", 1946 | "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", 1947 | "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==", 1948 | "dev": true 1949 | }, 1950 | "ts-node": { 1951 | "version": "9.1.1", 1952 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-9.1.1.tgz", 1953 | "integrity": "sha512-hPlt7ZACERQGf03M253ytLY3dHbGNGrAq9qIHWUY9XHYl1z7wYngSr3OQ5xmui8o2AaxsONxIzjafLUiWBo1Fg==", 1954 | "dev": true, 1955 | "requires": { 1956 | "arg": "^4.1.0", 1957 | "create-require": "^1.1.0", 1958 | "diff": "^4.0.1", 1959 | "make-error": "^1.1.1", 1960 | "source-map-support": "^0.5.17", 1961 | "yn": "3.1.1" 1962 | } 1963 | }, 1964 | "ts-node-dev": { 1965 | "version": "1.1.8", 1966 | "resolved": "https://registry.npmjs.org/ts-node-dev/-/ts-node-dev-1.1.8.tgz", 1967 | "integrity": "sha512-Q/m3vEwzYwLZKmV6/0VlFxcZzVV/xcgOt+Tx/VjaaRHyiBcFlV0541yrT09QjzzCxlDZ34OzKjrFAynlmtflEg==", 1968 | "dev": true, 1969 | "requires": { 1970 | "chokidar": "^3.5.1", 1971 | "dynamic-dedupe": "^0.3.0", 1972 | "minimist": "^1.2.5", 1973 | "mkdirp": "^1.0.4", 1974 | "resolve": "^1.0.0", 1975 | "rimraf": "^2.6.1", 1976 | "source-map-support": "^0.5.12", 1977 | "tree-kill": "^1.2.2", 1978 | "ts-node": "^9.0.0", 1979 | "tsconfig": "^7.0.0" 1980 | } 1981 | }, 1982 | "tsconfig": { 1983 | "version": "7.0.0", 1984 | "resolved": "https://registry.npmjs.org/tsconfig/-/tsconfig-7.0.0.tgz", 1985 | "integrity": "sha512-vZXmzPrL+EmC4T/4rVlT2jNVMWCi/O4DIiSj3UHg1OE5kCKbk4mfrXc6dZksLgRM/TZlKnousKH9bbTazUWRRw==", 1986 | "dev": true, 1987 | "requires": { 1988 | "@types/strip-bom": "^3.0.0", 1989 | "@types/strip-json-comments": "0.0.30", 1990 | "strip-bom": "^3.0.0", 1991 | "strip-json-comments": "^2.0.0" 1992 | } 1993 | }, 1994 | "type-is": { 1995 | "version": "1.6.18", 1996 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1997 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1998 | "requires": { 1999 | "media-typer": "0.3.0", 2000 | "mime-types": "~2.1.24" 2001 | } 2002 | }, 2003 | "typescript": { 2004 | "version": "4.6.3", 2005 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.6.3.tgz", 2006 | "integrity": "sha512-yNIatDa5iaofVozS/uQJEl3JRWLKKGJKh6Yaiv0GLGSuhpFJe7P3SbHZ8/yjAHRQwKRoA6YZqlfjXWmVzoVSMw==", 2007 | "dev": true 2008 | }, 2009 | "unpipe": { 2010 | "version": "1.0.0", 2011 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2012 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 2013 | }, 2014 | "utils-merge": { 2015 | "version": "1.0.1", 2016 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2017 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 2018 | }, 2019 | "vary": { 2020 | "version": "1.1.2", 2021 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2022 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 2023 | }, 2024 | "wrappy": { 2025 | "version": "1.0.2", 2026 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2027 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2028 | "dev": true 2029 | }, 2030 | "xtend": { 2031 | "version": "4.0.2", 2032 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 2033 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 2034 | "dev": true 2035 | }, 2036 | "yn": { 2037 | "version": "3.1.1", 2038 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 2039 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 2040 | "dev": true 2041 | }, 2042 | "zod": { 2043 | "version": "3.14.4", 2044 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.14.4.tgz", 2045 | "integrity": "sha512-U9BFLb2GO34Sfo9IUYp0w3wJLlmcyGoMd75qU9yf+DrdGA4kEx6e+l9KOkAlyUO0PSQzZCa3TR4qVlcmwqSDuw==" 2046 | } 2047 | } 2048 | } 2049 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "zod-restapi-tutorial", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "dev": "ts-node-dev --respawn src/index.ts" 8 | }, 9 | "keywords": [], 10 | "author": "", 11 | "license": "ISC", 12 | "dependencies": { 13 | "express": "^4.17.3", 14 | "zod": "^3.14.4" 15 | }, 16 | "devDependencies": { 17 | "@types/express": "^4.17.13", 18 | "ts-node-dev": "^1.1.8", 19 | "typescript": "^4.6.3" 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /src/controllers/auth.controller.ts: -------------------------------------------------------------------------------- 1 | import { Request, Response } from "express"; 2 | 3 | export const login = (req: Request, res: Response) => { 4 | try { 5 | console.log(req.body); 6 | res.send("login"); 7 | } catch (error) { 8 | return res.status(500).json({ message: "Internal server error" }); 9 | } 10 | }; 11 | -------------------------------------------------------------------------------- /src/controllers/products.controller.ts: -------------------------------------------------------------------------------- 1 | import { Request, Response } from "express"; 2 | import { 3 | CreateProductType, 4 | UpdateProductBodyType, 5 | UpdateProductParamsType, 6 | UpdateProductQueryType, 7 | } from "../schemas/product.schema"; 8 | 9 | export const createProduct = ( 10 | req: Request, 11 | res: Response 12 | ) => { 13 | const { name, price } = req.body; 14 | res.send("creating product"); 15 | }; 16 | 17 | export const updateProduct = ( 18 | req: Request< 19 | UpdateProductParamsType, 20 | unknown, 21 | UpdateProductBodyType, 22 | UpdateProductQueryType 23 | >, 24 | res: Response 25 | ) => { 26 | const { id } = req.params; 27 | const { name, price } = req.body; 28 | const { title } = req.query; 29 | 30 | console.log(id, name, price, title); 31 | res.send("updating product"); 32 | }; 33 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | import express from "express"; 2 | import authRoutes from './routes/auth.routes' 3 | import productRoutes from './routes/products.routes' 4 | 5 | const app = express(); 6 | 7 | app.use(express.json()); 8 | 9 | app.use(authRoutes) 10 | app.use(productRoutes) 11 | 12 | app.listen(3000); 13 | console.log("Server on port", 3000); 14 | -------------------------------------------------------------------------------- /src/middlewares/schemaValidator.middleware.ts: -------------------------------------------------------------------------------- 1 | import { NextFunction, Request, Response } from "express"; 2 | import { AnyZodObject, ZodError } from "zod"; 3 | 4 | export const schemaValition = 5 | (schema: AnyZodObject) => 6 | (req: Request, res: Response, next: NextFunction) => { 7 | try { 8 | schema.parse({ 9 | body: req.body, 10 | params: req.params, 11 | query: req.query, 12 | }); 13 | next(); 14 | } catch (error) { 15 | console.log(error); 16 | if (error instanceof ZodError) { 17 | return res.status(400).json( 18 | error.issues.map((issue) => ({ 19 | path: issue.path, 20 | message: issue.message, 21 | })) 22 | ); 23 | } 24 | return res.status(400).json({ message: "internal server error" }); 25 | } 26 | }; 27 | -------------------------------------------------------------------------------- /src/routes/auth.routes.ts: -------------------------------------------------------------------------------- 1 | import { Router } from "express"; 2 | import { login } from "../controllers/auth.controller"; 3 | import { schemaValition } from "../middlewares/schemaValidator.middleware"; 4 | import {loginSchema} from '../schemas/auth.schema' 5 | 6 | const router = Router(); 7 | 8 | router.post("/login", schemaValition(loginSchema), login); 9 | 10 | export default router; 11 | -------------------------------------------------------------------------------- /src/routes/products.routes.ts: -------------------------------------------------------------------------------- 1 | import { Router } from "express"; 2 | import { 3 | createProduct, 4 | updateProduct, 5 | } from "../controllers/products.controller"; 6 | import { schemaValition } from "../middlewares/schemaValidator.middleware"; 7 | import { 8 | CreateProductSchema, 9 | UpdateProductSchema, 10 | } from "../schemas/product.schema"; 11 | 12 | const router = Router(); 13 | 14 | router.post("/products", schemaValition(CreateProductSchema), createProduct); 15 | router.put("/products/:id", schemaValition(UpdateProductSchema), updateProduct); 16 | 17 | export default router; 18 | -------------------------------------------------------------------------------- /src/schemas/auth.schema.ts: -------------------------------------------------------------------------------- 1 | import { z } from "zod"; 2 | 3 | export const loginSchema = z.object({ 4 | body: z.object({ 5 | email: z.string().nonempty("Email is required").email({ 6 | message: "Write a correct email", 7 | }), 8 | password: z 9 | .string() 10 | .nonempty("Password is required") 11 | .min(6, "Password too short"), 12 | }), 13 | }); 14 | -------------------------------------------------------------------------------- /src/schemas/product.schema.ts: -------------------------------------------------------------------------------- 1 | import { z } from "zod"; 2 | 3 | export const CreateProductSchema = z.object({ 4 | body: z.object({ 5 | name: z.string().nonempty(), 6 | price: z.number().nonnegative(), 7 | }), 8 | }); 9 | 10 | export const UpdateProductSchema = z.object({ 11 | body: z.object({ 12 | name: z.string().optional(), 13 | price: z.number().nonnegative().optional(), 14 | }), 15 | params: z.object({ 16 | id: z.string().min(3), 17 | }), 18 | query: z.object({ 19 | title: z.string(), 20 | }), 21 | }); 22 | 23 | export type CreateProductType = z.infer["body"]; 24 | 25 | export type UpdateProductBodyType = z.infer["body"]; 26 | export type UpdateProductParamsType = z.infer< 27 | typeof UpdateProductSchema 28 | >["params"]; 29 | export type UpdateProductQueryType = z.infer< 30 | typeof UpdateProductSchema 31 | >["query"]; 32 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | /* Visit https://aka.ms/tsconfig.json to read more about this file */ 4 | 5 | /* Projects */ 6 | // "incremental": true, /* Enable incremental compilation */ 7 | // "composite": true, /* Enable constraints that allow a TypeScript project to be used with project references. */ 8 | // "tsBuildInfoFile": "./", /* Specify the folder for .tsbuildinfo incremental compilation files. */ 9 | // "disableSourceOfProjectReferenceRedirect": true, /* Disable preferring source files instead of declaration files when referencing composite projects */ 10 | // "disableSolutionSearching": true, /* Opt a project out of multi-project reference checking when editing. */ 11 | // "disableReferencedProjectLoad": true, /* Reduce the number of projects loaded automatically by TypeScript. */ 12 | 13 | /* Language and Environment */ 14 | "target": "es2016", /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */ 15 | // "lib": [], /* Specify a set of bundled library declaration files that describe the target runtime environment. */ 16 | // "jsx": "preserve", /* Specify what JSX code is generated. */ 17 | // "experimentalDecorators": true, /* Enable experimental support for TC39 stage 2 draft decorators. */ 18 | // "emitDecoratorMetadata": true, /* Emit design-type metadata for decorated declarations in source files. */ 19 | // "jsxFactory": "", /* Specify the JSX factory function used when targeting React JSX emit, e.g. 'React.createElement' or 'h' */ 20 | // "jsxFragmentFactory": "", /* Specify the JSX Fragment reference used for fragments when targeting React JSX emit e.g. 'React.Fragment' or 'Fragment'. */ 21 | // "jsxImportSource": "", /* Specify module specifier used to import the JSX factory functions when using `jsx: react-jsx*`.` */ 22 | // "reactNamespace": "", /* Specify the object invoked for `createElement`. This only applies when targeting `react` JSX emit. */ 23 | // "noLib": true, /* Disable including any library files, including the default lib.d.ts. */ 24 | // "useDefineForClassFields": true, /* Emit ECMAScript-standard-compliant class fields. */ 25 | 26 | /* Modules */ 27 | "module": "commonjs", /* Specify what module code is generated. */ 28 | "rootDir": "./src", /* Specify the root folder within your source files. */ 29 | // "moduleResolution": "node", /* Specify how TypeScript looks up a file from a given module specifier. */ 30 | // "baseUrl": "./", /* Specify the base directory to resolve non-relative module names. */ 31 | // "paths": {}, /* Specify a set of entries that re-map imports to additional lookup locations. */ 32 | // "rootDirs": [], /* Allow multiple folders to be treated as one when resolving modules. */ 33 | // "typeRoots": [], /* Specify multiple folders that act like `./node_modules/@types`. */ 34 | // "types": [], /* Specify type package names to be included without being referenced in a source file. */ 35 | // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ 36 | // "resolveJsonModule": true, /* Enable importing .json files */ 37 | // "noResolve": true, /* Disallow `import`s, `require`s or ``s from expanding the number of files TypeScript should add to a project. */ 38 | 39 | /* JavaScript Support */ 40 | // "allowJs": true, /* Allow JavaScript files to be a part of your program. Use the `checkJS` option to get errors from these files. */ 41 | // "checkJs": true, /* Enable error reporting in type-checked JavaScript files. */ 42 | // "maxNodeModuleJsDepth": 1, /* Specify the maximum folder depth used for checking JavaScript files from `node_modules`. Only applicable with `allowJs`. */ 43 | 44 | /* Emit */ 45 | // "declaration": true, /* Generate .d.ts files from TypeScript and JavaScript files in your project. */ 46 | // "declarationMap": true, /* Create sourcemaps for d.ts files. */ 47 | // "emitDeclarationOnly": true, /* Only output d.ts files and not JavaScript files. */ 48 | // "sourceMap": true, /* Create source map files for emitted JavaScript files. */ 49 | // "outFile": "./", /* Specify a file that bundles all outputs into one JavaScript file. If `declaration` is true, also designates a file that bundles all .d.ts output. */ 50 | "outDir": "./dist", /* Specify an output folder for all emitted files. */ 51 | // "removeComments": true, /* Disable emitting comments. */ 52 | // "noEmit": true, /* Disable emitting files from a compilation. */ 53 | // "importHelpers": true, /* Allow importing helper functions from tslib once per project, instead of including them per-file. */ 54 | // "importsNotUsedAsValues": "remove", /* Specify emit/checking behavior for imports that are only used for types */ 55 | // "downlevelIteration": true, /* Emit more compliant, but verbose and less performant JavaScript for iteration. */ 56 | // "sourceRoot": "", /* Specify the root path for debuggers to find the reference source code. */ 57 | // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ 58 | // "inlineSourceMap": true, /* Include sourcemap files inside the emitted JavaScript. */ 59 | // "inlineSources": true, /* Include source code in the sourcemaps inside the emitted JavaScript. */ 60 | // "emitBOM": true, /* Emit a UTF-8 Byte Order Mark (BOM) in the beginning of output files. */ 61 | // "newLine": "crlf", /* Set the newline character for emitting files. */ 62 | // "stripInternal": true, /* Disable emitting declarations that have `@internal` in their JSDoc comments. */ 63 | // "noEmitHelpers": true, /* Disable generating custom helper functions like `__extends` in compiled output. */ 64 | // "noEmitOnError": true, /* Disable emitting files if any type checking errors are reported. */ 65 | // "preserveConstEnums": true, /* Disable erasing `const enum` declarations in generated code. */ 66 | // "declarationDir": "./", /* Specify the output directory for generated declaration files. */ 67 | // "preserveValueImports": true, /* Preserve unused imported values in the JavaScript output that would otherwise be removed. */ 68 | 69 | /* Interop Constraints */ 70 | // "isolatedModules": true, /* Ensure that each file can be safely transpiled without relying on other imports. */ 71 | // "allowSyntheticDefaultImports": true, /* Allow 'import x from y' when a module doesn't have a default export. */ 72 | "esModuleInterop": true, /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables `allowSyntheticDefaultImports` for type compatibility. */ 73 | // "preserveSymlinks": true, /* Disable resolving symlinks to their realpath. This correlates to the same flag in node. */ 74 | "forceConsistentCasingInFileNames": true, /* Ensure that casing is correct in imports. */ 75 | 76 | /* Type Checking */ 77 | "strict": true, /* Enable all strict type-checking options. */ 78 | // "noImplicitAny": true, /* Enable error reporting for expressions and declarations with an implied `any` type.. */ 79 | // "strictNullChecks": true, /* When type checking, take into account `null` and `undefined`. */ 80 | // "strictFunctionTypes": true, /* When assigning functions, check to ensure parameters and the return values are subtype-compatible. */ 81 | // "strictBindCallApply": true, /* Check that the arguments for `bind`, `call`, and `apply` methods match the original function. */ 82 | // "strictPropertyInitialization": true, /* Check for class properties that are declared but not set in the constructor. */ 83 | // "noImplicitThis": true, /* Enable error reporting when `this` is given the type `any`. */ 84 | // "useUnknownInCatchVariables": true, /* Type catch clause variables as 'unknown' instead of 'any'. */ 85 | // "alwaysStrict": true, /* Ensure 'use strict' is always emitted. */ 86 | // "noUnusedLocals": true, /* Enable error reporting when a local variables aren't read. */ 87 | // "noUnusedParameters": true, /* Raise an error when a function parameter isn't read */ 88 | // "exactOptionalPropertyTypes": true, /* Interpret optional property types as written, rather than adding 'undefined'. */ 89 | // "noImplicitReturns": true, /* Enable error reporting for codepaths that do not explicitly return in a function. */ 90 | // "noFallthroughCasesInSwitch": true, /* Enable error reporting for fallthrough cases in switch statements. */ 91 | // "noUncheckedIndexedAccess": true, /* Include 'undefined' in index signature results */ 92 | // "noImplicitOverride": true, /* Ensure overriding members in derived classes are marked with an override modifier. */ 93 | // "noPropertyAccessFromIndexSignature": true, /* Enforces using indexed accessors for keys declared using an indexed type */ 94 | // "allowUnusedLabels": true, /* Disable error reporting for unused labels. */ 95 | // "allowUnreachableCode": true, /* Disable error reporting for unreachable code. */ 96 | 97 | /* Completeness */ 98 | // "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */ 99 | "skipLibCheck": true /* Skip type checking all .d.ts files. */ 100 | } 101 | } 102 | --------------------------------------------------------------------------------