├── .gitignore ├── README.md ├── package-lock.json ├── package.json ├── sql ├── cache.sql ├── match_prompts_cosine.sql └── match_prompts_cosine_auth.sql ├── src ├── .DS_Store ├── api │ ├── cache │ │ ├── get.ts │ │ ├── post.ts │ │ └── router.ts │ └── router.ts ├── common │ └── errors │ │ ├── api_error.ts │ │ └── base_error.ts ├── config │ └── environment_config.ts ├── helpers │ └── embedding_helper.ts ├── index.ts ├── lib │ ├── openai.ts │ └── supabase.ts ├── middlewares │ ├── auth_middleware.ts │ └── error_middleware.ts └── utils │ ├── datetime_util.ts │ ├── misc_util.ts │ └── serialization_util.ts ├── tsconfig.json └── tslint.json /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | dist 3 | *.env -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | Magic cache is a key value store much like Redis. But it allows your keys (your prompts) to be a lot fuzzier. 2 | 3 | E.g. a prompt of “Capital of USA” and “What is the capital of the United States?” should probably be the same key. So if you already know that “Capital Of USA” should have the completion “Washington DC”, then you could also return that from the cache for the prompt “What is the capital of the United States?” 4 | 5 | You can customise the similarity threshold from 0 and 1 to find how exact you want matches to be. 6 | 7 | # Quick start 8 | 9 | ## Sign in to Magic Cache 10 | 11 | Go to [magiccache](https://cache.scalingdevtools.com/) & signup/login 12 | 13 | ## Copy your server API key and app ID 14 | 15 | You should see a long API key like the below: 16 | 17 | ```jsx 18 | 25a52459-ggda-04d3-a3e8-160b23902b5z4 19 | ``` 20 | 21 | ### Post a completion 22 | 23 | ``` 24 | curl --location --request POST 'https://magic-cache.herokuapp.com/cache/' \ 25 | --header 'Authorization: Bearer *API_KEY*' \ 26 | --header 'Content-Type: application/json' \ 27 | --data-raw '{ 28 | "prompt": "Tell me a joke", 29 | "completion":"Sure, here'\''s a joke for you: Why don'\''t scientists trust atoms? Because they make up everything!" 30 | }' 31 | ``` 32 | 33 | Example Response 34 | 35 | ``` 36 | { 37 | "success": true 38 | } 39 | ``` 40 | ### Search for matching completions 41 | 42 | ``` 43 | curl --location --request GET 'https://magic-cache.herokuapp.com/cache/' \ 44 | --header 'Authorization: Bearer *API_KEY*' \ 45 | --header 'Content-Type: application/json' \ 46 | --data-raw '{ 47 | "prompt": "Joke please", 48 | "similarity_threshold":"0.5" 49 | }' 50 | ``` 51 | Example Response: 52 | ``` 53 | [ 54 | { 55 | "id": 13, 56 | "prompt": "Tell me a joke", 57 | "completion": "Sure, here's a joke for you: Why don't scientists trust atoms? Because they make up everything!", 58 | "similarity": 0.880884534086156 59 | } 60 | ] 61 | ``` 62 | 63 | ### Self hosting 64 | 65 | You can alternatively self host this yourself 66 | 67 | Use the below variables 68 | ``` 69 | PORT= 70 | OPENAI_API_KEY= 71 | SUPABASE_URL= 72 | SUPABASE_SERVICE_KEY= 73 | ``` -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "magic-cache", 3 | "version": "0.0.1", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "magic-cache", 9 | "version": "0.0.1", 10 | "license": "UNLICENSED", 11 | "dependencies": { 12 | "@grpc/grpc-js": "^1.8.0", 13 | "@supabase/supabase-js": "^2.21.0", 14 | "@types/express-jwt": "^6.0.4", 15 | "@types/jsonwebtoken": "^9.0.0", 16 | "@types/mime-types": "^2.1.1", 17 | "@types/uuid": "^9.0.1", 18 | "cookie-parser": "^1.4.6", 19 | "cors": "^2.8.5", 20 | "dotenv": "^16.0.3", 21 | "express": "^5.0.0-alpha.8", 22 | "mime-types": "^2.1.35", 23 | "node-fetch": "^2.6.1", 24 | "openai": "^3.2.1", 25 | "slugify": "^1.6.5", 26 | "ts-node": "^10.9.1", 27 | "uuid": "^9.0.0", 28 | "zod": "^3.20.2" 29 | }, 30 | "devDependencies": { 31 | "@types/cookie-parser": "^1.4.3", 32 | "@types/cors": "^2.8.13", 33 | "@types/dotenv": "^8.2.0", 34 | "@types/express": "^4.17.15", 35 | "@types/helmet": "^4.0.0", 36 | "@types/multer": "^1.4.7", 37 | "@types/node": "^18.11.18", 38 | "@types/node-fetch": "^2.6.2", 39 | "ts-node-dev": "^2.0.0", 40 | "tslint": "^6.1.3", 41 | "typescript": "^4.9.5" 42 | }, 43 | "engines": { 44 | "node": "<=16.17.0" 45 | } 46 | }, 47 | "node_modules/@babel/code-frame": { 48 | "version": "7.21.4", 49 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.21.4.tgz", 50 | "integrity": "sha512-LYvhNKfwWSPpocw8GI7gpK2nq3HSDuEPC/uSYaALSJu9xjsalaaYFOq0Pwt5KmVqwEbZlDu81aLXwBOmD/Fv9g==", 51 | "dev": true, 52 | "dependencies": { 53 | "@babel/highlight": "^7.18.6" 54 | }, 55 | "engines": { 56 | "node": ">=6.9.0" 57 | } 58 | }, 59 | "node_modules/@babel/helper-validator-identifier": { 60 | "version": "7.19.1", 61 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", 62 | "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==", 63 | "dev": true, 64 | "engines": { 65 | "node": ">=6.9.0" 66 | } 67 | }, 68 | "node_modules/@babel/highlight": { 69 | "version": "7.18.6", 70 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", 71 | "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", 72 | "dev": true, 73 | "dependencies": { 74 | "@babel/helper-validator-identifier": "^7.18.6", 75 | "chalk": "^2.0.0", 76 | "js-tokens": "^4.0.0" 77 | }, 78 | "engines": { 79 | "node": ">=6.9.0" 80 | } 81 | }, 82 | "node_modules/@cspotcode/source-map-support": { 83 | "version": "0.8.1", 84 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 85 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 86 | "dependencies": { 87 | "@jridgewell/trace-mapping": "0.3.9" 88 | }, 89 | "engines": { 90 | "node": ">=12" 91 | } 92 | }, 93 | "node_modules/@grpc/grpc-js": { 94 | "version": "1.8.13", 95 | "resolved": "https://registry.npmjs.org/@grpc/grpc-js/-/grpc-js-1.8.13.tgz", 96 | "integrity": "sha512-iY3jsdfbc0ARoCLFvbvUB8optgyb0r1XLPb142u+QtgBcKJYkCIFt3Fd/881KqjLYWjsBJF57N3b8Eop9NDfUA==", 97 | "dependencies": { 98 | "@grpc/proto-loader": "^0.7.0", 99 | "@types/node": ">=12.12.47" 100 | }, 101 | "engines": { 102 | "node": "^8.13.0 || >=10.10.0" 103 | } 104 | }, 105 | "node_modules/@grpc/proto-loader": { 106 | "version": "0.7.6", 107 | "resolved": "https://registry.npmjs.org/@grpc/proto-loader/-/proto-loader-0.7.6.tgz", 108 | "integrity": "sha512-QyAXR8Hyh7uMDmveWxDSUcJr9NAWaZ2I6IXgAYvQmfflwouTM+rArE2eEaCtLlRqO81j7pRLCt81IefUei6Zbw==", 109 | "dependencies": { 110 | "@types/long": "^4.0.1", 111 | "lodash.camelcase": "^4.3.0", 112 | "long": "^4.0.0", 113 | "protobufjs": "^7.0.0", 114 | "yargs": "^16.2.0" 115 | }, 116 | "bin": { 117 | "proto-loader-gen-types": "build/bin/proto-loader-gen-types.js" 118 | }, 119 | "engines": { 120 | "node": ">=6" 121 | } 122 | }, 123 | "node_modules/@jridgewell/resolve-uri": { 124 | "version": "3.1.1", 125 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz", 126 | "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==", 127 | "engines": { 128 | "node": ">=6.0.0" 129 | } 130 | }, 131 | "node_modules/@jridgewell/sourcemap-codec": { 132 | "version": "1.4.15", 133 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 134 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==" 135 | }, 136 | "node_modules/@jridgewell/trace-mapping": { 137 | "version": "0.3.9", 138 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 139 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 140 | "dependencies": { 141 | "@jridgewell/resolve-uri": "^3.0.3", 142 | "@jridgewell/sourcemap-codec": "^1.4.10" 143 | } 144 | }, 145 | "node_modules/@protobufjs/aspromise": { 146 | "version": "1.1.2", 147 | "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", 148 | "integrity": "sha512-j+gKExEuLmKwvz3OgROXtrJ2UG2x8Ch2YZUxahh+s1F2HZ+wAceUNLkvy6zKCPVRkU++ZWQrdxsUeQXmcg4uoQ==" 149 | }, 150 | "node_modules/@protobufjs/base64": { 151 | "version": "1.1.2", 152 | "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", 153 | "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==" 154 | }, 155 | "node_modules/@protobufjs/codegen": { 156 | "version": "2.0.4", 157 | "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", 158 | "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==" 159 | }, 160 | "node_modules/@protobufjs/eventemitter": { 161 | "version": "1.1.0", 162 | "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", 163 | "integrity": "sha512-j9ednRT81vYJ9OfVuXG6ERSTdEL1xVsNgqpkxMsbIabzSo3goCjDIveeGv5d03om39ML71RdmrGNjG5SReBP/Q==" 164 | }, 165 | "node_modules/@protobufjs/fetch": { 166 | "version": "1.1.0", 167 | "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", 168 | "integrity": "sha512-lljVXpqXebpsijW71PZaCYeIcE5on1w5DlQy5WH6GLbFryLUrBD4932W/E2BSpfRJWseIL4v/KPgBFxDOIdKpQ==", 169 | "dependencies": { 170 | "@protobufjs/aspromise": "^1.1.1", 171 | "@protobufjs/inquire": "^1.1.0" 172 | } 173 | }, 174 | "node_modules/@protobufjs/float": { 175 | "version": "1.0.2", 176 | "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", 177 | "integrity": "sha512-Ddb+kVXlXst9d+R9PfTIxh1EdNkgoRe5tOX6t01f1lYWOvJnSPDBlG241QLzcyPdoNTsblLUdujGSE4RzrTZGQ==" 178 | }, 179 | "node_modules/@protobufjs/inquire": { 180 | "version": "1.1.0", 181 | "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", 182 | "integrity": "sha512-kdSefcPdruJiFMVSbn801t4vFK7KB/5gd2fYvrxhuJYg8ILrmn9SKSX2tZdV6V+ksulWqS7aXjBcRXl3wHoD9Q==" 183 | }, 184 | "node_modules/@protobufjs/path": { 185 | "version": "1.1.2", 186 | "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", 187 | "integrity": "sha512-6JOcJ5Tm08dOHAbdR3GrvP+yUUfkjG5ePsHYczMFLq3ZmMkAD98cDgcT2iA1lJ9NVwFd4tH/iSSoe44YWkltEA==" 188 | }, 189 | "node_modules/@protobufjs/pool": { 190 | "version": "1.1.0", 191 | "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", 192 | "integrity": "sha512-0kELaGSIDBKvcgS4zkjz1PeddatrjYcmMWOlAuAPwAeccUrPHdUqo/J6LiymHHEiJT5NrF1UVwxY14f+fy4WQw==" 193 | }, 194 | "node_modules/@protobufjs/utf8": { 195 | "version": "1.1.0", 196 | "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", 197 | "integrity": "sha512-Vvn3zZrhQZkkBE8LSuW3em98c0FwgO4nxzv6OdSxPKJIEKY2bGbHn+mhGIPerzI4twdxaP8/0+06HBpwf345Lw==" 198 | }, 199 | "node_modules/@supabase/functions-js": { 200 | "version": "2.1.1", 201 | "resolved": "https://registry.npmjs.org/@supabase/functions-js/-/functions-js-2.1.1.tgz", 202 | "integrity": "sha512-bIR1Puae6W+1/MzPfYBWOG/SCWGo4B5CB7c0ZZksvliNEAzhxNBJ0UFKYINcGdGtxG8ZC+1xr3utWpNZNwnoRw==", 203 | "dependencies": { 204 | "cross-fetch": "^3.1.5" 205 | } 206 | }, 207 | "node_modules/@supabase/gotrue-js": { 208 | "version": "2.24.0", 209 | "resolved": "https://registry.npmjs.org/@supabase/gotrue-js/-/gotrue-js-2.24.0.tgz", 210 | "integrity": "sha512-ZsH4K5cbMTjfMytXaDYVYs9l9igmlZFxiwXn7J2IP/CklWR5qmLCma+dvat5rccPLITVkN6oAZbKxDzW+pEgCg==", 211 | "dependencies": { 212 | "cross-fetch": "^3.1.5" 213 | } 214 | }, 215 | "node_modules/@supabase/postgrest-js": { 216 | "version": "1.6.0", 217 | "resolved": "https://registry.npmjs.org/@supabase/postgrest-js/-/postgrest-js-1.6.0.tgz", 218 | "integrity": "sha512-HCphMC6KjtoaGcowSlkKRVKBOlNpmKWE2CwoumMwwsfhnRxplIy1zBiIYIL3zIYo/Bm20H/1C6enqjBeTvSwXg==", 219 | "dependencies": { 220 | "cross-fetch": "^3.1.5" 221 | } 222 | }, 223 | "node_modules/@supabase/realtime-js": { 224 | "version": "2.7.2", 225 | "resolved": "https://registry.npmjs.org/@supabase/realtime-js/-/realtime-js-2.7.2.tgz", 226 | "integrity": "sha512-Fi6xAl5PUkqnjl3wo4rdcQIbMG3+yTRX1aUZe/yfvTG84RMvmCXJ1yN6MmafVLeZpU1xkaz5Vx4L0tnHcLiy6w==", 227 | "dependencies": { 228 | "@types/phoenix": "^1.5.4", 229 | "@types/websocket": "^1.0.3", 230 | "websocket": "^1.0.34" 231 | } 232 | }, 233 | "node_modules/@supabase/storage-js": { 234 | "version": "2.5.1", 235 | "resolved": "https://registry.npmjs.org/@supabase/storage-js/-/storage-js-2.5.1.tgz", 236 | "integrity": "sha512-nkR0fQA9ScAtIKA3vNoPEqbZv1k5B5HVRYEvRWdlP6mUpFphM9TwPL2jZ/ztNGMTG5xT6SrHr+H7Ykz8qzbhjw==", 237 | "dependencies": { 238 | "cross-fetch": "^3.1.5" 239 | } 240 | }, 241 | "node_modules/@supabase/supabase-js": { 242 | "version": "2.21.0", 243 | "resolved": "https://registry.npmjs.org/@supabase/supabase-js/-/supabase-js-2.21.0.tgz", 244 | "integrity": "sha512-FW3ZzBoc4orSgfX0dXrmJoXAcI/hiekmqXTkN64vjtUF2Urp3UjyAf71UTtV9Jl6ejHoe3K++e0+Rg9zKUJh5w==", 245 | "dependencies": { 246 | "@supabase/functions-js": "^2.1.0", 247 | "@supabase/gotrue-js": "^2.23.0", 248 | "@supabase/postgrest-js": "^1.1.1", 249 | "@supabase/realtime-js": "^2.7.2", 250 | "@supabase/storage-js": "^2.5.1", 251 | "cross-fetch": "^3.1.5" 252 | } 253 | }, 254 | "node_modules/@tsconfig/node10": { 255 | "version": "1.0.9", 256 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz", 257 | "integrity": "sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA==" 258 | }, 259 | "node_modules/@tsconfig/node12": { 260 | "version": "1.0.11", 261 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz", 262 | "integrity": "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==" 263 | }, 264 | "node_modules/@tsconfig/node14": { 265 | "version": "1.0.3", 266 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz", 267 | "integrity": "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==" 268 | }, 269 | "node_modules/@tsconfig/node16": { 270 | "version": "1.0.3", 271 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.3.tgz", 272 | "integrity": "sha512-yOlFc+7UtL/89t2ZhjPvvB/DeAr3r+Dq58IgzsFkOAvVC6NMJXmCGjbptdXdR9qsX7pKcTL+s87FtYREi2dEEQ==" 273 | }, 274 | "node_modules/@types/body-parser": { 275 | "version": "1.19.2", 276 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz", 277 | "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==", 278 | "dependencies": { 279 | "@types/connect": "*", 280 | "@types/node": "*" 281 | } 282 | }, 283 | "node_modules/@types/connect": { 284 | "version": "3.4.35", 285 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", 286 | "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", 287 | "dependencies": { 288 | "@types/node": "*" 289 | } 290 | }, 291 | "node_modules/@types/cookie-parser": { 292 | "version": "1.4.3", 293 | "resolved": "https://registry.npmjs.org/@types/cookie-parser/-/cookie-parser-1.4.3.tgz", 294 | "integrity": "sha512-CqSKwFwefj4PzZ5n/iwad/bow2hTCh0FlNAeWLtQM3JA/NX/iYagIpWG2cf1bQKQ2c9gU2log5VUCrn7LDOs0w==", 295 | "dev": true, 296 | "dependencies": { 297 | "@types/express": "*" 298 | } 299 | }, 300 | "node_modules/@types/cors": { 301 | "version": "2.8.13", 302 | "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.13.tgz", 303 | "integrity": "sha512-RG8AStHlUiV5ysZQKq97copd2UmVYw3/pRMLefISZ3S1hK104Cwm7iLQ3fTKx+lsUH2CE8FlLaYeEA2LSeqYUA==", 304 | "dev": true, 305 | "dependencies": { 306 | "@types/node": "*" 307 | } 308 | }, 309 | "node_modules/@types/dotenv": { 310 | "version": "8.2.0", 311 | "resolved": "https://registry.npmjs.org/@types/dotenv/-/dotenv-8.2.0.tgz", 312 | "integrity": "sha512-ylSC9GhfRH7m1EUXBXofhgx4lUWmFeQDINW5oLuS+gxWdfUeW4zJdeVTYVkexEW+e2VUvlZR2kGnGGipAWR7kw==", 313 | "deprecated": "This is a stub types definition. dotenv provides its own type definitions, so you do not need this installed.", 314 | "dev": true, 315 | "dependencies": { 316 | "dotenv": "*" 317 | } 318 | }, 319 | "node_modules/@types/express": { 320 | "version": "4.17.17", 321 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.17.tgz", 322 | "integrity": "sha512-Q4FmmuLGBG58btUnfS1c1r/NQdlp3DMfGDGig8WhfpA2YRUtEkxAjkZb0yvplJGYdF1fsQ81iMDcH24sSCNC/Q==", 323 | "dependencies": { 324 | "@types/body-parser": "*", 325 | "@types/express-serve-static-core": "^4.17.33", 326 | "@types/qs": "*", 327 | "@types/serve-static": "*" 328 | } 329 | }, 330 | "node_modules/@types/express-jwt": { 331 | "version": "6.0.4", 332 | "resolved": "https://registry.npmjs.org/@types/express-jwt/-/express-jwt-6.0.4.tgz", 333 | "integrity": "sha512-I53KRQ9D0eTA6hVCN9S73iOeprKS3JNWK+Cp2mDPB6uOIkTVpkgSkX394kHQzb5cd0U02I0adRmsMxHk+zX8tA==", 334 | "dependencies": { 335 | "@types/express": "*", 336 | "@types/express-unless": "*" 337 | } 338 | }, 339 | "node_modules/@types/express-serve-static-core": { 340 | "version": "4.17.33", 341 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.33.tgz", 342 | "integrity": "sha512-TPBqmR/HRYI3eC2E5hmiivIzv+bidAfXofM+sbonAGvyDhySGw9/PQZFt2BLOrjUUR++4eJVpx6KnLQK1Fk9tA==", 343 | "dependencies": { 344 | "@types/node": "*", 345 | "@types/qs": "*", 346 | "@types/range-parser": "*" 347 | } 348 | }, 349 | "node_modules/@types/express-unless": { 350 | "version": "2.0.1", 351 | "resolved": "https://registry.npmjs.org/@types/express-unless/-/express-unless-2.0.1.tgz", 352 | "integrity": "sha512-PJLiNw03EjkWDkQbhNjIXXDLObC3eMQhFASDV+WakFbT8eL7YdjlbV6MXd3Av5Lejq499d6pFuV1jyK+EHyG3Q==", 353 | "deprecated": "This is a stub types definition. express-unless provides its own type definitions, so you do not need this installed.", 354 | "dependencies": { 355 | "express-unless": "*" 356 | } 357 | }, 358 | "node_modules/@types/helmet": { 359 | "version": "4.0.0", 360 | "resolved": "https://registry.npmjs.org/@types/helmet/-/helmet-4.0.0.tgz", 361 | "integrity": "sha512-ONIn/nSNQA57yRge3oaMQESef/6QhoeX7llWeDli0UZIfz8TQMkfNPTXA8VnnyeA1WUjG2pGqdjEIueYonMdfQ==", 362 | "deprecated": "This is a stub types definition. helmet provides its own type definitions, so you do not need this installed.", 363 | "dev": true, 364 | "dependencies": { 365 | "helmet": "*" 366 | } 367 | }, 368 | "node_modules/@types/jsonwebtoken": { 369 | "version": "9.0.1", 370 | "resolved": "https://registry.npmjs.org/@types/jsonwebtoken/-/jsonwebtoken-9.0.1.tgz", 371 | "integrity": "sha512-c5ltxazpWabia/4UzhIoaDcIza4KViOQhdbjRlfcIGVnsE3c3brkz9Z+F/EeJIECOQP7W7US2hNE930cWWkPiw==", 372 | "dependencies": { 373 | "@types/node": "*" 374 | } 375 | }, 376 | "node_modules/@types/long": { 377 | "version": "4.0.2", 378 | "resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.2.tgz", 379 | "integrity": "sha512-MqTGEo5bj5t157U6fA/BiDynNkn0YknVdh48CMPkTSpFTVmvao5UQmm7uEF6xBEo7qIMAlY/JSleYaE6VOdpaA==" 380 | }, 381 | "node_modules/@types/mime": { 382 | "version": "3.0.1", 383 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-3.0.1.tgz", 384 | "integrity": "sha512-Y4XFY5VJAuw0FgAqPNd6NNoV44jbq9Bz2L7Rh/J6jLTiHBSBJa9fxqQIvkIld4GsoDOcCbvzOUAbLPsSKKg+uA==" 385 | }, 386 | "node_modules/@types/mime-types": { 387 | "version": "2.1.1", 388 | "resolved": "https://registry.npmjs.org/@types/mime-types/-/mime-types-2.1.1.tgz", 389 | "integrity": "sha512-vXOTGVSLR2jMw440moWTC7H19iUyLtP3Z1YTj7cSsubOICinjMxFeb/V57v9QdyyPGbbWolUFSSmSiRSn94tFw==" 390 | }, 391 | "node_modules/@types/multer": { 392 | "version": "1.4.7", 393 | "resolved": "https://registry.npmjs.org/@types/multer/-/multer-1.4.7.tgz", 394 | "integrity": "sha512-/SNsDidUFCvqqcWDwxv2feww/yqhNeTRL5CVoL3jU4Goc4kKEL10T7Eye65ZqPNi4HRx8sAEX59pV1aEH7drNA==", 395 | "dev": true, 396 | "dependencies": { 397 | "@types/express": "*" 398 | } 399 | }, 400 | "node_modules/@types/node": { 401 | "version": "18.15.11", 402 | "resolved": "https://registry.npmjs.org/@types/node/-/node-18.15.11.tgz", 403 | "integrity": "sha512-E5Kwq2n4SbMzQOn6wnmBjuK9ouqlURrcZDVfbo9ftDDTFt3nk7ZKK4GMOzoYgnpQJKcxwQw+lGaBvvlMo0qN/Q==" 404 | }, 405 | "node_modules/@types/node-fetch": { 406 | "version": "2.6.3", 407 | "resolved": "https://registry.npmjs.org/@types/node-fetch/-/node-fetch-2.6.3.tgz", 408 | "integrity": "sha512-ETTL1mOEdq/sxUtgtOhKjyB2Irra4cjxksvcMUR5Zr4n+PxVhsCD9WS46oPbHL3et9Zde7CNRr+WUNlcHvsX+w==", 409 | "dev": true, 410 | "dependencies": { 411 | "@types/node": "*", 412 | "form-data": "^3.0.0" 413 | } 414 | }, 415 | "node_modules/@types/phoenix": { 416 | "version": "1.5.6", 417 | "resolved": "https://registry.npmjs.org/@types/phoenix/-/phoenix-1.5.6.tgz", 418 | "integrity": "sha512-e7jZ6I9uyRGsg7MNwQcarmBvRlbGb9DibbocE9crVnxqsy6C23RMxLWbJ2CQ3vgCW7taoL1L+F02EcjA6ld7XA==" 419 | }, 420 | "node_modules/@types/qs": { 421 | "version": "6.9.7", 422 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 423 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==" 424 | }, 425 | "node_modules/@types/range-parser": { 426 | "version": "1.2.4", 427 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", 428 | "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==" 429 | }, 430 | "node_modules/@types/serve-static": { 431 | "version": "1.15.1", 432 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.15.1.tgz", 433 | "integrity": "sha512-NUo5XNiAdULrJENtJXZZ3fHtfMolzZwczzBbnAeBbqBwG+LaG6YaJtuwzwGSQZ2wsCrxjEhNNjAkKigy3n8teQ==", 434 | "dependencies": { 435 | "@types/mime": "*", 436 | "@types/node": "*" 437 | } 438 | }, 439 | "node_modules/@types/strip-bom": { 440 | "version": "3.0.0", 441 | "resolved": "https://registry.npmjs.org/@types/strip-bom/-/strip-bom-3.0.0.tgz", 442 | "integrity": "sha512-xevGOReSYGM7g/kUBZzPqCrR/KYAo+F0yiPc85WFTJa0MSLtyFTVTU6cJu/aV4mid7IffDIWqo69THF2o4JiEQ==", 443 | "dev": true 444 | }, 445 | "node_modules/@types/strip-json-comments": { 446 | "version": "0.0.30", 447 | "resolved": "https://registry.npmjs.org/@types/strip-json-comments/-/strip-json-comments-0.0.30.tgz", 448 | "integrity": "sha512-7NQmHra/JILCd1QqpSzl8+mJRc8ZHz3uDm8YV1Ks9IhK0epEiTw8aIErbvH9PI+6XbqhyIQy3462nEsn7UVzjQ==", 449 | "dev": true 450 | }, 451 | "node_modules/@types/uuid": { 452 | "version": "9.0.1", 453 | "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-9.0.1.tgz", 454 | "integrity": "sha512-rFT3ak0/2trgvp4yYZo5iKFEPsET7vKydKF+VRCxlQ9bpheehyAJH89dAkaLEq/j/RZXJIqcgsmPJKUP1Z28HA==" 455 | }, 456 | "node_modules/@types/websocket": { 457 | "version": "1.0.5", 458 | "resolved": "https://registry.npmjs.org/@types/websocket/-/websocket-1.0.5.tgz", 459 | "integrity": "sha512-NbsqiNX9CnEfC1Z0Vf4mE1SgAJ07JnRYcNex7AJ9zAVzmiGHmjKFEk7O4TJIsgv2B1sLEb6owKFZrACwdYngsQ==", 460 | "dependencies": { 461 | "@types/node": "*" 462 | } 463 | }, 464 | "node_modules/accepts": { 465 | "version": "1.3.8", 466 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 467 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 468 | "dependencies": { 469 | "mime-types": "~2.1.34", 470 | "negotiator": "0.6.3" 471 | }, 472 | "engines": { 473 | "node": ">= 0.6" 474 | } 475 | }, 476 | "node_modules/acorn": { 477 | "version": "8.8.2", 478 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.2.tgz", 479 | "integrity": "sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw==", 480 | "bin": { 481 | "acorn": "bin/acorn" 482 | }, 483 | "engines": { 484 | "node": ">=0.4.0" 485 | } 486 | }, 487 | "node_modules/acorn-walk": { 488 | "version": "8.2.0", 489 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 490 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 491 | "engines": { 492 | "node": ">=0.4.0" 493 | } 494 | }, 495 | "node_modules/ansi-regex": { 496 | "version": "5.0.1", 497 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 498 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 499 | "engines": { 500 | "node": ">=8" 501 | } 502 | }, 503 | "node_modules/ansi-styles": { 504 | "version": "3.2.1", 505 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 506 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 507 | "dev": true, 508 | "dependencies": { 509 | "color-convert": "^1.9.0" 510 | }, 511 | "engines": { 512 | "node": ">=4" 513 | } 514 | }, 515 | "node_modules/anymatch": { 516 | "version": "3.1.3", 517 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 518 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 519 | "dev": true, 520 | "dependencies": { 521 | "normalize-path": "^3.0.0", 522 | "picomatch": "^2.0.4" 523 | }, 524 | "engines": { 525 | "node": ">= 8" 526 | } 527 | }, 528 | "node_modules/arg": { 529 | "version": "4.1.3", 530 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 531 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==" 532 | }, 533 | "node_modules/argparse": { 534 | "version": "1.0.10", 535 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 536 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 537 | "dev": true, 538 | "dependencies": { 539 | "sprintf-js": "~1.0.2" 540 | } 541 | }, 542 | "node_modules/array-flatten": { 543 | "version": "3.0.0", 544 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-3.0.0.tgz", 545 | "integrity": "sha512-zPMVc3ZYlGLNk4mpK1NzP2wg0ml9t7fUgDsayR5Y5rSzxQilzR9FGu/EH2jQOcKSAeAfWeylyW8juy3OkWRvNA==" 546 | }, 547 | "node_modules/asynckit": { 548 | "version": "0.4.0", 549 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 550 | "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" 551 | }, 552 | "node_modules/axios": { 553 | "version": "0.26.1", 554 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.26.1.tgz", 555 | "integrity": "sha512-fPwcX4EvnSHuInCMItEhAGnaSEXRBjtzh9fOtsE6E1G6p7vl7edEeZe11QHf18+6+9gR5PbKV/sGKNaD8YaMeA==", 556 | "dependencies": { 557 | "follow-redirects": "^1.14.8" 558 | } 559 | }, 560 | "node_modules/balanced-match": { 561 | "version": "1.0.2", 562 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 563 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 564 | "dev": true 565 | }, 566 | "node_modules/binary-extensions": { 567 | "version": "2.2.0", 568 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 569 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 570 | "dev": true, 571 | "engines": { 572 | "node": ">=8" 573 | } 574 | }, 575 | "node_modules/body-parser": { 576 | "version": "2.0.0-beta.1", 577 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-2.0.0-beta.1.tgz", 578 | "integrity": "sha512-I1v2bt2OdYqtmk8nEFZuEf+9Opb30DphYwTPDbgg/OorSAoJOuTpWyDrZaSWQw7FdoevbBRCP2+9z/halXSWcA==", 579 | "dependencies": { 580 | "bytes": "3.1.1", 581 | "content-type": "~1.0.4", 582 | "debug": "2.6.9", 583 | "depd": "~1.1.2", 584 | "http-errors": "1.8.1", 585 | "iconv-lite": "0.4.24", 586 | "on-finished": "~2.3.0", 587 | "qs": "6.9.6", 588 | "raw-body": "2.4.2", 589 | "type-is": "~1.6.18" 590 | }, 591 | "engines": { 592 | "node": ">= 0.10" 593 | } 594 | }, 595 | "node_modules/body-parser/node_modules/debug": { 596 | "version": "2.6.9", 597 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 598 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 599 | "dependencies": { 600 | "ms": "2.0.0" 601 | } 602 | }, 603 | "node_modules/body-parser/node_modules/iconv-lite": { 604 | "version": "0.4.24", 605 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 606 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 607 | "dependencies": { 608 | "safer-buffer": ">= 2.1.2 < 3" 609 | }, 610 | "engines": { 611 | "node": ">=0.10.0" 612 | } 613 | }, 614 | "node_modules/brace-expansion": { 615 | "version": "1.1.11", 616 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 617 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 618 | "dev": true, 619 | "dependencies": { 620 | "balanced-match": "^1.0.0", 621 | "concat-map": "0.0.1" 622 | } 623 | }, 624 | "node_modules/braces": { 625 | "version": "3.0.2", 626 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 627 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 628 | "dev": true, 629 | "dependencies": { 630 | "fill-range": "^7.0.1" 631 | }, 632 | "engines": { 633 | "node": ">=8" 634 | } 635 | }, 636 | "node_modules/buffer-from": { 637 | "version": "1.1.2", 638 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 639 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 640 | "dev": true 641 | }, 642 | "node_modules/bufferutil": { 643 | "version": "4.0.7", 644 | "resolved": "https://registry.npmjs.org/bufferutil/-/bufferutil-4.0.7.tgz", 645 | "integrity": "sha512-kukuqc39WOHtdxtw4UScxF/WVnMFVSQVKhtx3AjZJzhd0RGZZldcrfSEbVsWWe6KNH253574cq5F+wpv0G9pJw==", 646 | "hasInstallScript": true, 647 | "dependencies": { 648 | "node-gyp-build": "^4.3.0" 649 | }, 650 | "engines": { 651 | "node": ">=6.14.2" 652 | } 653 | }, 654 | "node_modules/builtin-modules": { 655 | "version": "1.1.1", 656 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 657 | "integrity": "sha512-wxXCdllwGhI2kCC0MnvTGYTMvnVZTvqgypkiTI8Pa5tcz2i6VqsqwYGgqwXji+4RgCzms6EajE4IxiUH6HH8nQ==", 658 | "dev": true, 659 | "engines": { 660 | "node": ">=0.10.0" 661 | } 662 | }, 663 | "node_modules/bytes": { 664 | "version": "3.1.1", 665 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.1.tgz", 666 | "integrity": "sha512-dWe4nWO/ruEOY7HkUJ5gFt1DCFV9zPRoJr8pV0/ASQermOZjtq8jMjOprC0Kd10GLN+l7xaUPvxzJFWtxGu8Fg==", 667 | "engines": { 668 | "node": ">= 0.8" 669 | } 670 | }, 671 | "node_modules/chalk": { 672 | "version": "2.4.2", 673 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 674 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 675 | "dev": true, 676 | "dependencies": { 677 | "ansi-styles": "^3.2.1", 678 | "escape-string-regexp": "^1.0.5", 679 | "supports-color": "^5.3.0" 680 | }, 681 | "engines": { 682 | "node": ">=4" 683 | } 684 | }, 685 | "node_modules/chokidar": { 686 | "version": "3.5.3", 687 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 688 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 689 | "dev": true, 690 | "funding": [ 691 | { 692 | "type": "individual", 693 | "url": "https://paulmillr.com/funding/" 694 | } 695 | ], 696 | "dependencies": { 697 | "anymatch": "~3.1.2", 698 | "braces": "~3.0.2", 699 | "glob-parent": "~5.1.2", 700 | "is-binary-path": "~2.1.0", 701 | "is-glob": "~4.0.1", 702 | "normalize-path": "~3.0.0", 703 | "readdirp": "~3.6.0" 704 | }, 705 | "engines": { 706 | "node": ">= 8.10.0" 707 | }, 708 | "optionalDependencies": { 709 | "fsevents": "~2.3.2" 710 | } 711 | }, 712 | "node_modules/cliui": { 713 | "version": "7.0.4", 714 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 715 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 716 | "dependencies": { 717 | "string-width": "^4.2.0", 718 | "strip-ansi": "^6.0.0", 719 | "wrap-ansi": "^7.0.0" 720 | } 721 | }, 722 | "node_modules/color-convert": { 723 | "version": "1.9.3", 724 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 725 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 726 | "dev": true, 727 | "dependencies": { 728 | "color-name": "1.1.3" 729 | } 730 | }, 731 | "node_modules/color-name": { 732 | "version": "1.1.3", 733 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 734 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 735 | "dev": true 736 | }, 737 | "node_modules/combined-stream": { 738 | "version": "1.0.8", 739 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 740 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 741 | "dependencies": { 742 | "delayed-stream": "~1.0.0" 743 | }, 744 | "engines": { 745 | "node": ">= 0.8" 746 | } 747 | }, 748 | "node_modules/concat-map": { 749 | "version": "0.0.1", 750 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 751 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 752 | "dev": true 753 | }, 754 | "node_modules/content-disposition": { 755 | "version": "0.5.4", 756 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 757 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 758 | "dependencies": { 759 | "safe-buffer": "5.2.1" 760 | }, 761 | "engines": { 762 | "node": ">= 0.6" 763 | } 764 | }, 765 | "node_modules/content-type": { 766 | "version": "1.0.5", 767 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 768 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 769 | "engines": { 770 | "node": ">= 0.6" 771 | } 772 | }, 773 | "node_modules/cookie": { 774 | "version": "0.4.1", 775 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz", 776 | "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA==", 777 | "engines": { 778 | "node": ">= 0.6" 779 | } 780 | }, 781 | "node_modules/cookie-parser": { 782 | "version": "1.4.6", 783 | "resolved": "https://registry.npmjs.org/cookie-parser/-/cookie-parser-1.4.6.tgz", 784 | "integrity": "sha512-z3IzaNjdwUC2olLIB5/ITd0/setiaFMLYiZJle7xg5Fe9KWAceil7xszYfHHBtDFYLSgJduS2Ty0P1uJdPDJeA==", 785 | "dependencies": { 786 | "cookie": "0.4.1", 787 | "cookie-signature": "1.0.6" 788 | }, 789 | "engines": { 790 | "node": ">= 0.8.0" 791 | } 792 | }, 793 | "node_modules/cookie-signature": { 794 | "version": "1.0.6", 795 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 796 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 797 | }, 798 | "node_modules/cors": { 799 | "version": "2.8.5", 800 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 801 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 802 | "dependencies": { 803 | "object-assign": "^4", 804 | "vary": "^1" 805 | }, 806 | "engines": { 807 | "node": ">= 0.10" 808 | } 809 | }, 810 | "node_modules/create-require": { 811 | "version": "1.1.1", 812 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 813 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==" 814 | }, 815 | "node_modules/cross-fetch": { 816 | "version": "3.1.5", 817 | "resolved": "https://registry.npmjs.org/cross-fetch/-/cross-fetch-3.1.5.tgz", 818 | "integrity": "sha512-lvb1SBsI0Z7GDwmuid+mU3kWVBwTVUbe7S0H52yaaAdQOXq2YktTCZdlAcNKFzE6QtRz0snpw9bNiPeOIkkQvw==", 819 | "dependencies": { 820 | "node-fetch": "2.6.7" 821 | } 822 | }, 823 | "node_modules/cross-fetch/node_modules/node-fetch": { 824 | "version": "2.6.7", 825 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.7.tgz", 826 | "integrity": "sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==", 827 | "dependencies": { 828 | "whatwg-url": "^5.0.0" 829 | }, 830 | "engines": { 831 | "node": "4.x || >=6.0.0" 832 | }, 833 | "peerDependencies": { 834 | "encoding": "^0.1.0" 835 | }, 836 | "peerDependenciesMeta": { 837 | "encoding": { 838 | "optional": true 839 | } 840 | } 841 | }, 842 | "node_modules/cross-fetch/node_modules/tr46": { 843 | "version": "0.0.3", 844 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 845 | "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" 846 | }, 847 | "node_modules/cross-fetch/node_modules/webidl-conversions": { 848 | "version": "3.0.1", 849 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 850 | "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" 851 | }, 852 | "node_modules/cross-fetch/node_modules/whatwg-url": { 853 | "version": "5.0.0", 854 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 855 | "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", 856 | "dependencies": { 857 | "tr46": "~0.0.3", 858 | "webidl-conversions": "^3.0.0" 859 | } 860 | }, 861 | "node_modules/d": { 862 | "version": "1.0.1", 863 | "resolved": "https://registry.npmjs.org/d/-/d-1.0.1.tgz", 864 | "integrity": "sha512-m62ShEObQ39CfralilEQRjH6oAMtNCV1xJyEx5LpRYUVN+EviphDgUc/F3hnYbADmkiNs67Y+3ylmlG7Lnu+FA==", 865 | "dependencies": { 866 | "es5-ext": "^0.10.50", 867 | "type": "^1.0.1" 868 | } 869 | }, 870 | "node_modules/debug": { 871 | "version": "3.1.0", 872 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 873 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 874 | "dependencies": { 875 | "ms": "2.0.0" 876 | } 877 | }, 878 | "node_modules/delayed-stream": { 879 | "version": "1.0.0", 880 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 881 | "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", 882 | "engines": { 883 | "node": ">=0.4.0" 884 | } 885 | }, 886 | "node_modules/depd": { 887 | "version": "1.1.2", 888 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 889 | "integrity": "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==", 890 | "engines": { 891 | "node": ">= 0.6" 892 | } 893 | }, 894 | "node_modules/destroy": { 895 | "version": "1.0.4", 896 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 897 | "integrity": "sha512-3NdhDuEXnfun/z7x9GOElY49LoqVHoGScmOKwmxhsS8N5Y+Z8KyPPDnaSzqWgYt/ji4mqwfTS34Htrk0zPIXVg==" 898 | }, 899 | "node_modules/diff": { 900 | "version": "4.0.2", 901 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 902 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 903 | "engines": { 904 | "node": ">=0.3.1" 905 | } 906 | }, 907 | "node_modules/dotenv": { 908 | "version": "16.0.3", 909 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.3.tgz", 910 | "integrity": "sha512-7GO6HghkA5fYG9TYnNxi14/7K9f5occMlp3zXAuSxn7CKCxt9xbNWG7yF8hTCSUchlfWSe3uLmlPfigevRItzQ==", 911 | "engines": { 912 | "node": ">=12" 913 | } 914 | }, 915 | "node_modules/dynamic-dedupe": { 916 | "version": "0.3.0", 917 | "resolved": "https://registry.npmjs.org/dynamic-dedupe/-/dynamic-dedupe-0.3.0.tgz", 918 | "integrity": "sha512-ssuANeD+z97meYOqd50e04Ze5qp4bPqo8cCkI4TRjZkzAUgIDTrXV1R8QCdINpiI+hw14+rYazvTRdQrz0/rFQ==", 919 | "dev": true, 920 | "dependencies": { 921 | "xtend": "^4.0.0" 922 | } 923 | }, 924 | "node_modules/ee-first": { 925 | "version": "1.1.1", 926 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 927 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 928 | }, 929 | "node_modules/emoji-regex": { 930 | "version": "8.0.0", 931 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 932 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 933 | }, 934 | "node_modules/encodeurl": { 935 | "version": "1.0.2", 936 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 937 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 938 | "engines": { 939 | "node": ">= 0.8" 940 | } 941 | }, 942 | "node_modules/es5-ext": { 943 | "version": "0.10.62", 944 | "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.62.tgz", 945 | "integrity": "sha512-BHLqn0klhEpnOKSrzn/Xsz2UIW8j+cGmo9JLzr8BiUapV8hPL9+FliFqjwr9ngW7jWdnxv6eO+/LqyhJVqgrjA==", 946 | "hasInstallScript": true, 947 | "dependencies": { 948 | "es6-iterator": "^2.0.3", 949 | "es6-symbol": "^3.1.3", 950 | "next-tick": "^1.1.0" 951 | }, 952 | "engines": { 953 | "node": ">=0.10" 954 | } 955 | }, 956 | "node_modules/es6-iterator": { 957 | "version": "2.0.3", 958 | "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.3.tgz", 959 | "integrity": "sha512-zw4SRzoUkd+cl+ZoE15A9o1oQd920Bb0iOJMQkQhl3jNc03YqVjAhG7scf9C5KWRU/R13Orf588uCC6525o02g==", 960 | "dependencies": { 961 | "d": "1", 962 | "es5-ext": "^0.10.35", 963 | "es6-symbol": "^3.1.1" 964 | } 965 | }, 966 | "node_modules/es6-symbol": { 967 | "version": "3.1.3", 968 | "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.3.tgz", 969 | "integrity": "sha512-NJ6Yn3FuDinBaBRWl/q5X/s4koRHBrgKAu+yGI6JCBeiu3qrcbJhwT2GeR/EXVfylRk8dpQVJoLEFhK+Mu31NA==", 970 | "dependencies": { 971 | "d": "^1.0.1", 972 | "ext": "^1.1.2" 973 | } 974 | }, 975 | "node_modules/escalade": { 976 | "version": "3.1.1", 977 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 978 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 979 | "engines": { 980 | "node": ">=6" 981 | } 982 | }, 983 | "node_modules/escape-html": { 984 | "version": "1.0.3", 985 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 986 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 987 | }, 988 | "node_modules/escape-string-regexp": { 989 | "version": "1.0.5", 990 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 991 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 992 | "dev": true, 993 | "engines": { 994 | "node": ">=0.8.0" 995 | } 996 | }, 997 | "node_modules/esprima": { 998 | "version": "4.0.1", 999 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1000 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1001 | "dev": true, 1002 | "bin": { 1003 | "esparse": "bin/esparse.js", 1004 | "esvalidate": "bin/esvalidate.js" 1005 | }, 1006 | "engines": { 1007 | "node": ">=4" 1008 | } 1009 | }, 1010 | "node_modules/etag": { 1011 | "version": "1.8.1", 1012 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 1013 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 1014 | "engines": { 1015 | "node": ">= 0.6" 1016 | } 1017 | }, 1018 | "node_modules/express": { 1019 | "version": "5.0.0-beta.1", 1020 | "resolved": "https://registry.npmjs.org/express/-/express-5.0.0-beta.1.tgz", 1021 | "integrity": "sha512-KPtBrlZoQu2Ps0Ce/Imqtq73AB0KBJ8Gx59yZQ3pmDJU2/LhcoZETo03oSgtTQufbcLXt/WBITk/jMjl/WMyrQ==", 1022 | "dependencies": { 1023 | "accepts": "~1.3.7", 1024 | "array-flatten": "3.0.0", 1025 | "body-parser": "2.0.0-beta.1", 1026 | "content-disposition": "0.5.4", 1027 | "content-type": "~1.0.4", 1028 | "cookie": "0.4.1", 1029 | "cookie-signature": "1.0.6", 1030 | "debug": "3.1.0", 1031 | "depd": "~1.1.2", 1032 | "encodeurl": "~1.0.2", 1033 | "escape-html": "~1.0.3", 1034 | "etag": "~1.8.1", 1035 | "finalhandler": "~1.1.2", 1036 | "fresh": "0.5.2", 1037 | "merge-descriptors": "1.0.1", 1038 | "methods": "~1.1.2", 1039 | "mime-types": "~2.1.34", 1040 | "on-finished": "~2.3.0", 1041 | "parseurl": "~1.3.3", 1042 | "path-is-absolute": "1.0.1", 1043 | "proxy-addr": "~2.0.7", 1044 | "qs": "6.9.6", 1045 | "range-parser": "~1.2.1", 1046 | "router": "2.0.0-beta.1", 1047 | "safe-buffer": "5.2.1", 1048 | "send": "1.0.0-beta.1", 1049 | "serve-static": "2.0.0-beta.1", 1050 | "setprototypeof": "1.2.0", 1051 | "statuses": "~1.5.0", 1052 | "type-is": "~1.6.18", 1053 | "utils-merge": "1.0.1", 1054 | "vary": "~1.1.2" 1055 | }, 1056 | "engines": { 1057 | "node": ">= 4" 1058 | } 1059 | }, 1060 | "node_modules/express-unless": { 1061 | "version": "2.1.3", 1062 | "resolved": "https://registry.npmjs.org/express-unless/-/express-unless-2.1.3.tgz", 1063 | "integrity": "sha512-wj4tLMyCVYuIIKHGt0FhCtIViBcwzWejX0EjNxveAa6dG+0XBCQhMbx+PnkLkFCxLC69qoFrxds4pIyL88inaQ==" 1064 | }, 1065 | "node_modules/ext": { 1066 | "version": "1.7.0", 1067 | "resolved": "https://registry.npmjs.org/ext/-/ext-1.7.0.tgz", 1068 | "integrity": "sha512-6hxeJYaL110a9b5TEJSj0gojyHQAmA2ch5Os+ySCiA1QGdS697XWY1pzsrSjqA9LDEEgdB/KypIlR59RcLuHYw==", 1069 | "dependencies": { 1070 | "type": "^2.7.2" 1071 | } 1072 | }, 1073 | "node_modules/ext/node_modules/type": { 1074 | "version": "2.7.2", 1075 | "resolved": "https://registry.npmjs.org/type/-/type-2.7.2.tgz", 1076 | "integrity": "sha512-dzlvlNlt6AXU7EBSfpAscydQ7gXB+pPGsPnfJnZpiNJBDj7IaJzQlBZYGdEi4R9HmPdBv2XmWJ6YUtoTa7lmCw==" 1077 | }, 1078 | "node_modules/fill-range": { 1079 | "version": "7.0.1", 1080 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1081 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1082 | "dev": true, 1083 | "dependencies": { 1084 | "to-regex-range": "^5.0.1" 1085 | }, 1086 | "engines": { 1087 | "node": ">=8" 1088 | } 1089 | }, 1090 | "node_modules/finalhandler": { 1091 | "version": "1.1.2", 1092 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 1093 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 1094 | "dependencies": { 1095 | "debug": "2.6.9", 1096 | "encodeurl": "~1.0.2", 1097 | "escape-html": "~1.0.3", 1098 | "on-finished": "~2.3.0", 1099 | "parseurl": "~1.3.3", 1100 | "statuses": "~1.5.0", 1101 | "unpipe": "~1.0.0" 1102 | }, 1103 | "engines": { 1104 | "node": ">= 0.8" 1105 | } 1106 | }, 1107 | "node_modules/finalhandler/node_modules/debug": { 1108 | "version": "2.6.9", 1109 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1110 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1111 | "dependencies": { 1112 | "ms": "2.0.0" 1113 | } 1114 | }, 1115 | "node_modules/follow-redirects": { 1116 | "version": "1.15.2", 1117 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.2.tgz", 1118 | "integrity": "sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA==", 1119 | "funding": [ 1120 | { 1121 | "type": "individual", 1122 | "url": "https://github.com/sponsors/RubenVerborgh" 1123 | } 1124 | ], 1125 | "engines": { 1126 | "node": ">=4.0" 1127 | }, 1128 | "peerDependenciesMeta": { 1129 | "debug": { 1130 | "optional": true 1131 | } 1132 | } 1133 | }, 1134 | "node_modules/form-data": { 1135 | "version": "3.0.1", 1136 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", 1137 | "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", 1138 | "dev": true, 1139 | "dependencies": { 1140 | "asynckit": "^0.4.0", 1141 | "combined-stream": "^1.0.8", 1142 | "mime-types": "^2.1.12" 1143 | }, 1144 | "engines": { 1145 | "node": ">= 6" 1146 | } 1147 | }, 1148 | "node_modules/forwarded": { 1149 | "version": "0.2.0", 1150 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 1151 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 1152 | "engines": { 1153 | "node": ">= 0.6" 1154 | } 1155 | }, 1156 | "node_modules/fresh": { 1157 | "version": "0.5.2", 1158 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 1159 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 1160 | "engines": { 1161 | "node": ">= 0.6" 1162 | } 1163 | }, 1164 | "node_modules/fs.realpath": { 1165 | "version": "1.0.0", 1166 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1167 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1168 | "dev": true 1169 | }, 1170 | "node_modules/fsevents": { 1171 | "version": "2.3.2", 1172 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1173 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1174 | "dev": true, 1175 | "hasInstallScript": true, 1176 | "optional": true, 1177 | "os": [ 1178 | "darwin" 1179 | ], 1180 | "engines": { 1181 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1182 | } 1183 | }, 1184 | "node_modules/function-bind": { 1185 | "version": "1.1.1", 1186 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1187 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1188 | "dev": true 1189 | }, 1190 | "node_modules/get-caller-file": { 1191 | "version": "2.0.5", 1192 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1193 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1194 | "engines": { 1195 | "node": "6.* || 8.* || >= 10.*" 1196 | } 1197 | }, 1198 | "node_modules/glob": { 1199 | "version": "7.2.3", 1200 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1201 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1202 | "dev": true, 1203 | "dependencies": { 1204 | "fs.realpath": "^1.0.0", 1205 | "inflight": "^1.0.4", 1206 | "inherits": "2", 1207 | "minimatch": "^3.1.1", 1208 | "once": "^1.3.0", 1209 | "path-is-absolute": "^1.0.0" 1210 | }, 1211 | "engines": { 1212 | "node": "*" 1213 | }, 1214 | "funding": { 1215 | "url": "https://github.com/sponsors/isaacs" 1216 | } 1217 | }, 1218 | "node_modules/glob-parent": { 1219 | "version": "5.1.2", 1220 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1221 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1222 | "dev": true, 1223 | "dependencies": { 1224 | "is-glob": "^4.0.1" 1225 | }, 1226 | "engines": { 1227 | "node": ">= 6" 1228 | } 1229 | }, 1230 | "node_modules/has": { 1231 | "version": "1.0.3", 1232 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1233 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1234 | "dev": true, 1235 | "dependencies": { 1236 | "function-bind": "^1.1.1" 1237 | }, 1238 | "engines": { 1239 | "node": ">= 0.4.0" 1240 | } 1241 | }, 1242 | "node_modules/has-flag": { 1243 | "version": "3.0.0", 1244 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1245 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 1246 | "dev": true, 1247 | "engines": { 1248 | "node": ">=4" 1249 | } 1250 | }, 1251 | "node_modules/helmet": { 1252 | "version": "6.0.1", 1253 | "resolved": "https://registry.npmjs.org/helmet/-/helmet-6.0.1.tgz", 1254 | "integrity": "sha512-8wo+VdQhTMVBMCITYZaGTbE4lvlthelPYSvoyNvk4RECTmrVjMerp9RfUOQXZWLvCcAn1pKj7ZRxK4lI9Alrcw==", 1255 | "dev": true, 1256 | "engines": { 1257 | "node": ">=14.0.0" 1258 | } 1259 | }, 1260 | "node_modules/http-errors": { 1261 | "version": "1.8.1", 1262 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz", 1263 | "integrity": "sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g==", 1264 | "dependencies": { 1265 | "depd": "~1.1.2", 1266 | "inherits": "2.0.4", 1267 | "setprototypeof": "1.2.0", 1268 | "statuses": ">= 1.5.0 < 2", 1269 | "toidentifier": "1.0.1" 1270 | }, 1271 | "engines": { 1272 | "node": ">= 0.6" 1273 | } 1274 | }, 1275 | "node_modules/inflight": { 1276 | "version": "1.0.6", 1277 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1278 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1279 | "dev": true, 1280 | "dependencies": { 1281 | "once": "^1.3.0", 1282 | "wrappy": "1" 1283 | } 1284 | }, 1285 | "node_modules/inherits": { 1286 | "version": "2.0.4", 1287 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1288 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1289 | }, 1290 | "node_modules/ipaddr.js": { 1291 | "version": "1.9.1", 1292 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 1293 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 1294 | "engines": { 1295 | "node": ">= 0.10" 1296 | } 1297 | }, 1298 | "node_modules/is-binary-path": { 1299 | "version": "2.1.0", 1300 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1301 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1302 | "dev": true, 1303 | "dependencies": { 1304 | "binary-extensions": "^2.0.0" 1305 | }, 1306 | "engines": { 1307 | "node": ">=8" 1308 | } 1309 | }, 1310 | "node_modules/is-core-module": { 1311 | "version": "2.11.0", 1312 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.11.0.tgz", 1313 | "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==", 1314 | "dev": true, 1315 | "dependencies": { 1316 | "has": "^1.0.3" 1317 | }, 1318 | "funding": { 1319 | "url": "https://github.com/sponsors/ljharb" 1320 | } 1321 | }, 1322 | "node_modules/is-extglob": { 1323 | "version": "2.1.1", 1324 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1325 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1326 | "dev": true, 1327 | "engines": { 1328 | "node": ">=0.10.0" 1329 | } 1330 | }, 1331 | "node_modules/is-fullwidth-code-point": { 1332 | "version": "3.0.0", 1333 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1334 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1335 | "engines": { 1336 | "node": ">=8" 1337 | } 1338 | }, 1339 | "node_modules/is-glob": { 1340 | "version": "4.0.3", 1341 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1342 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1343 | "dev": true, 1344 | "dependencies": { 1345 | "is-extglob": "^2.1.1" 1346 | }, 1347 | "engines": { 1348 | "node": ">=0.10.0" 1349 | } 1350 | }, 1351 | "node_modules/is-number": { 1352 | "version": "7.0.0", 1353 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1354 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1355 | "dev": true, 1356 | "engines": { 1357 | "node": ">=0.12.0" 1358 | } 1359 | }, 1360 | "node_modules/is-typedarray": { 1361 | "version": "1.0.0", 1362 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1363 | "integrity": "sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA==" 1364 | }, 1365 | "node_modules/js-tokens": { 1366 | "version": "4.0.0", 1367 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1368 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1369 | "dev": true 1370 | }, 1371 | "node_modules/js-yaml": { 1372 | "version": "3.14.1", 1373 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 1374 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 1375 | "dev": true, 1376 | "dependencies": { 1377 | "argparse": "^1.0.7", 1378 | "esprima": "^4.0.0" 1379 | }, 1380 | "bin": { 1381 | "js-yaml": "bin/js-yaml.js" 1382 | } 1383 | }, 1384 | "node_modules/lodash.camelcase": { 1385 | "version": "4.3.0", 1386 | "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", 1387 | "integrity": "sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA==" 1388 | }, 1389 | "node_modules/long": { 1390 | "version": "4.0.0", 1391 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 1392 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 1393 | }, 1394 | "node_modules/make-error": { 1395 | "version": "1.3.6", 1396 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1397 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==" 1398 | }, 1399 | "node_modules/media-typer": { 1400 | "version": "0.3.0", 1401 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1402 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 1403 | "engines": { 1404 | "node": ">= 0.6" 1405 | } 1406 | }, 1407 | "node_modules/merge-descriptors": { 1408 | "version": "1.0.1", 1409 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1410 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 1411 | }, 1412 | "node_modules/methods": { 1413 | "version": "1.1.2", 1414 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1415 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", 1416 | "engines": { 1417 | "node": ">= 0.6" 1418 | } 1419 | }, 1420 | "node_modules/mime-db": { 1421 | "version": "1.52.0", 1422 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1423 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 1424 | "engines": { 1425 | "node": ">= 0.6" 1426 | } 1427 | }, 1428 | "node_modules/mime-types": { 1429 | "version": "2.1.35", 1430 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1431 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1432 | "dependencies": { 1433 | "mime-db": "1.52.0" 1434 | }, 1435 | "engines": { 1436 | "node": ">= 0.6" 1437 | } 1438 | }, 1439 | "node_modules/minimatch": { 1440 | "version": "3.1.2", 1441 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1442 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1443 | "dev": true, 1444 | "dependencies": { 1445 | "brace-expansion": "^1.1.7" 1446 | }, 1447 | "engines": { 1448 | "node": "*" 1449 | } 1450 | }, 1451 | "node_modules/minimist": { 1452 | "version": "1.2.8", 1453 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 1454 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 1455 | "dev": true, 1456 | "funding": { 1457 | "url": "https://github.com/sponsors/ljharb" 1458 | } 1459 | }, 1460 | "node_modules/mkdirp": { 1461 | "version": "0.5.6", 1462 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 1463 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 1464 | "dev": true, 1465 | "dependencies": { 1466 | "minimist": "^1.2.6" 1467 | }, 1468 | "bin": { 1469 | "mkdirp": "bin/cmd.js" 1470 | } 1471 | }, 1472 | "node_modules/ms": { 1473 | "version": "2.0.0", 1474 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1475 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 1476 | }, 1477 | "node_modules/negotiator": { 1478 | "version": "0.6.3", 1479 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1480 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 1481 | "engines": { 1482 | "node": ">= 0.6" 1483 | } 1484 | }, 1485 | "node_modules/next-tick": { 1486 | "version": "1.1.0", 1487 | "resolved": "https://registry.npmjs.org/next-tick/-/next-tick-1.1.0.tgz", 1488 | "integrity": "sha512-CXdUiJembsNjuToQvxayPZF9Vqht7hewsvy2sOWafLvi2awflj9mOC6bHIg50orX8IJvWKY9wYQ/zB2kogPslQ==" 1489 | }, 1490 | "node_modules/node-fetch": { 1491 | "version": "2.6.9", 1492 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.9.tgz", 1493 | "integrity": "sha512-DJm/CJkZkRjKKj4Zi4BsKVZh3ValV5IR5s7LVZnW+6YMh0W1BfNA8XSs6DLMGYlId5F3KnA70uu2qepcR08Qqg==", 1494 | "dependencies": { 1495 | "whatwg-url": "^5.0.0" 1496 | }, 1497 | "engines": { 1498 | "node": "4.x || >=6.0.0" 1499 | }, 1500 | "peerDependencies": { 1501 | "encoding": "^0.1.0" 1502 | }, 1503 | "peerDependenciesMeta": { 1504 | "encoding": { 1505 | "optional": true 1506 | } 1507 | } 1508 | }, 1509 | "node_modules/node-fetch/node_modules/tr46": { 1510 | "version": "0.0.3", 1511 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 1512 | "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" 1513 | }, 1514 | "node_modules/node-fetch/node_modules/webidl-conversions": { 1515 | "version": "3.0.1", 1516 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 1517 | "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" 1518 | }, 1519 | "node_modules/node-fetch/node_modules/whatwg-url": { 1520 | "version": "5.0.0", 1521 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 1522 | "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", 1523 | "dependencies": { 1524 | "tr46": "~0.0.3", 1525 | "webidl-conversions": "^3.0.0" 1526 | } 1527 | }, 1528 | "node_modules/node-gyp-build": { 1529 | "version": "4.6.0", 1530 | "resolved": "https://registry.npmjs.org/node-gyp-build/-/node-gyp-build-4.6.0.tgz", 1531 | "integrity": "sha512-NTZVKn9IylLwUzaKjkas1e4u2DLNcV4rdYagA4PWdPwW87Bi7z+BznyKSRwS/761tV/lzCGXplWsiaMjLqP2zQ==", 1532 | "bin": { 1533 | "node-gyp-build": "bin.js", 1534 | "node-gyp-build-optional": "optional.js", 1535 | "node-gyp-build-test": "build-test.js" 1536 | } 1537 | }, 1538 | "node_modules/normalize-path": { 1539 | "version": "3.0.0", 1540 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1541 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1542 | "dev": true, 1543 | "engines": { 1544 | "node": ">=0.10.0" 1545 | } 1546 | }, 1547 | "node_modules/object-assign": { 1548 | "version": "4.1.1", 1549 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1550 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 1551 | "engines": { 1552 | "node": ">=0.10.0" 1553 | } 1554 | }, 1555 | "node_modules/on-finished": { 1556 | "version": "2.3.0", 1557 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1558 | "integrity": "sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww==", 1559 | "dependencies": { 1560 | "ee-first": "1.1.1" 1561 | }, 1562 | "engines": { 1563 | "node": ">= 0.8" 1564 | } 1565 | }, 1566 | "node_modules/once": { 1567 | "version": "1.4.0", 1568 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1569 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1570 | "dev": true, 1571 | "dependencies": { 1572 | "wrappy": "1" 1573 | } 1574 | }, 1575 | "node_modules/openai": { 1576 | "version": "3.2.1", 1577 | "resolved": "https://registry.npmjs.org/openai/-/openai-3.2.1.tgz", 1578 | "integrity": "sha512-762C9BNlJPbjjlWZi4WYK9iM2tAVAv0uUp1UmI34vb0CN5T2mjB/qM6RYBmNKMh/dN9fC+bxqPwWJZUTWW052A==", 1579 | "dependencies": { 1580 | "axios": "^0.26.0", 1581 | "form-data": "^4.0.0" 1582 | } 1583 | }, 1584 | "node_modules/openai/node_modules/form-data": { 1585 | "version": "4.0.0", 1586 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", 1587 | "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", 1588 | "dependencies": { 1589 | "asynckit": "^0.4.0", 1590 | "combined-stream": "^1.0.8", 1591 | "mime-types": "^2.1.12" 1592 | }, 1593 | "engines": { 1594 | "node": ">= 6" 1595 | } 1596 | }, 1597 | "node_modules/parseurl": { 1598 | "version": "1.3.3", 1599 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1600 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1601 | "engines": { 1602 | "node": ">= 0.8" 1603 | } 1604 | }, 1605 | "node_modules/path-is-absolute": { 1606 | "version": "1.0.1", 1607 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1608 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1609 | "engines": { 1610 | "node": ">=0.10.0" 1611 | } 1612 | }, 1613 | "node_modules/path-parse": { 1614 | "version": "1.0.7", 1615 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1616 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1617 | "dev": true 1618 | }, 1619 | "node_modules/path-to-regexp": { 1620 | "version": "3.2.0", 1621 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-3.2.0.tgz", 1622 | "integrity": "sha512-jczvQbCUS7XmS7o+y1aEO9OBVFeZBQ1MDSEqmO7xSoPgOPoowY/SxLpZ6Vh97/8qHZOteiCKb7gkG9gA2ZUxJA==" 1623 | }, 1624 | "node_modules/picomatch": { 1625 | "version": "2.3.1", 1626 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1627 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1628 | "dev": true, 1629 | "engines": { 1630 | "node": ">=8.6" 1631 | }, 1632 | "funding": { 1633 | "url": "https://github.com/sponsors/jonschlinkert" 1634 | } 1635 | }, 1636 | "node_modules/protobufjs": { 1637 | "version": "7.2.3", 1638 | "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-7.2.3.tgz", 1639 | "integrity": "sha512-TtpvOqwB5Gdz/PQmOjgsrGH1nHjAQVCN7JG4A6r1sXRWESL5rNMAiRcBQlCAdKxZcAbstExQePYG8xof/JVRgg==", 1640 | "hasInstallScript": true, 1641 | "dependencies": { 1642 | "@protobufjs/aspromise": "^1.1.2", 1643 | "@protobufjs/base64": "^1.1.2", 1644 | "@protobufjs/codegen": "^2.0.4", 1645 | "@protobufjs/eventemitter": "^1.1.0", 1646 | "@protobufjs/fetch": "^1.1.0", 1647 | "@protobufjs/float": "^1.0.2", 1648 | "@protobufjs/inquire": "^1.1.0", 1649 | "@protobufjs/path": "^1.1.2", 1650 | "@protobufjs/pool": "^1.1.0", 1651 | "@protobufjs/utf8": "^1.1.0", 1652 | "@types/node": ">=13.7.0", 1653 | "long": "^5.0.0" 1654 | }, 1655 | "engines": { 1656 | "node": ">=12.0.0" 1657 | } 1658 | }, 1659 | "node_modules/protobufjs/node_modules/long": { 1660 | "version": "5.2.1", 1661 | "resolved": "https://registry.npmjs.org/long/-/long-5.2.1.tgz", 1662 | "integrity": "sha512-GKSNGeNAtw8IryjjkhZxuKB3JzlcLTwjtiQCHKvqQet81I93kXslhDQruGI/QsddO83mcDToBVy7GqGS/zYf/A==" 1663 | }, 1664 | "node_modules/proxy-addr": { 1665 | "version": "2.0.7", 1666 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1667 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1668 | "dependencies": { 1669 | "forwarded": "0.2.0", 1670 | "ipaddr.js": "1.9.1" 1671 | }, 1672 | "engines": { 1673 | "node": ">= 0.10" 1674 | } 1675 | }, 1676 | "node_modules/qs": { 1677 | "version": "6.9.6", 1678 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.9.6.tgz", 1679 | "integrity": "sha512-TIRk4aqYLNoJUbd+g2lEdz5kLWIuTMRagAXxl78Q0RiVjAOugHmeKNGdd3cwo/ktpf9aL9epCfFqWDEKysUlLQ==", 1680 | "engines": { 1681 | "node": ">=0.6" 1682 | }, 1683 | "funding": { 1684 | "url": "https://github.com/sponsors/ljharb" 1685 | } 1686 | }, 1687 | "node_modules/range-parser": { 1688 | "version": "1.2.1", 1689 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1690 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1691 | "engines": { 1692 | "node": ">= 0.6" 1693 | } 1694 | }, 1695 | "node_modules/raw-body": { 1696 | "version": "2.4.2", 1697 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.2.tgz", 1698 | "integrity": "sha512-RPMAFUJP19WIet/99ngh6Iv8fzAbqum4Li7AD6DtGaW2RpMB/11xDoalPiJMTbu6I3hkbMVkATvZrqb9EEqeeQ==", 1699 | "dependencies": { 1700 | "bytes": "3.1.1", 1701 | "http-errors": "1.8.1", 1702 | "iconv-lite": "0.4.24", 1703 | "unpipe": "1.0.0" 1704 | }, 1705 | "engines": { 1706 | "node": ">= 0.8" 1707 | } 1708 | }, 1709 | "node_modules/raw-body/node_modules/iconv-lite": { 1710 | "version": "0.4.24", 1711 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1712 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1713 | "dependencies": { 1714 | "safer-buffer": ">= 2.1.2 < 3" 1715 | }, 1716 | "engines": { 1717 | "node": ">=0.10.0" 1718 | } 1719 | }, 1720 | "node_modules/readdirp": { 1721 | "version": "3.6.0", 1722 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1723 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1724 | "dev": true, 1725 | "dependencies": { 1726 | "picomatch": "^2.2.1" 1727 | }, 1728 | "engines": { 1729 | "node": ">=8.10.0" 1730 | } 1731 | }, 1732 | "node_modules/require-directory": { 1733 | "version": "2.1.1", 1734 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1735 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 1736 | "engines": { 1737 | "node": ">=0.10.0" 1738 | } 1739 | }, 1740 | "node_modules/resolve": { 1741 | "version": "1.22.2", 1742 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.2.tgz", 1743 | "integrity": "sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==", 1744 | "dev": true, 1745 | "dependencies": { 1746 | "is-core-module": "^2.11.0", 1747 | "path-parse": "^1.0.7", 1748 | "supports-preserve-symlinks-flag": "^1.0.0" 1749 | }, 1750 | "bin": { 1751 | "resolve": "bin/resolve" 1752 | }, 1753 | "funding": { 1754 | "url": "https://github.com/sponsors/ljharb" 1755 | } 1756 | }, 1757 | "node_modules/rimraf": { 1758 | "version": "2.7.1", 1759 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1760 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1761 | "dev": true, 1762 | "dependencies": { 1763 | "glob": "^7.1.3" 1764 | }, 1765 | "bin": { 1766 | "rimraf": "bin.js" 1767 | } 1768 | }, 1769 | "node_modules/router": { 1770 | "version": "2.0.0-beta.1", 1771 | "resolved": "https://registry.npmjs.org/router/-/router-2.0.0-beta.1.tgz", 1772 | "integrity": "sha512-GLoYgkhAGAiwVda5nt6Qd4+5RAPuQ4WIYLlZ+mxfYICI+22gnIB3eCfmhgV8+uJNPS1/39DOYi/vdrrz0/ouKA==", 1773 | "dependencies": { 1774 | "array-flatten": "3.0.0", 1775 | "methods": "~1.1.2", 1776 | "parseurl": "~1.3.3", 1777 | "path-to-regexp": "3.2.0", 1778 | "setprototypeof": "1.2.0", 1779 | "utils-merge": "1.0.1" 1780 | }, 1781 | "engines": { 1782 | "node": ">= 0.10" 1783 | } 1784 | }, 1785 | "node_modules/safe-buffer": { 1786 | "version": "5.2.1", 1787 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1788 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1789 | "funding": [ 1790 | { 1791 | "type": "github", 1792 | "url": "https://github.com/sponsors/feross" 1793 | }, 1794 | { 1795 | "type": "patreon", 1796 | "url": "https://www.patreon.com/feross" 1797 | }, 1798 | { 1799 | "type": "consulting", 1800 | "url": "https://feross.org/support" 1801 | } 1802 | ] 1803 | }, 1804 | "node_modules/safer-buffer": { 1805 | "version": "2.1.2", 1806 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1807 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1808 | }, 1809 | "node_modules/semver": { 1810 | "version": "5.7.1", 1811 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1812 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1813 | "dev": true, 1814 | "bin": { 1815 | "semver": "bin/semver" 1816 | } 1817 | }, 1818 | "node_modules/send": { 1819 | "version": "1.0.0-beta.1", 1820 | "resolved": "https://registry.npmjs.org/send/-/send-1.0.0-beta.1.tgz", 1821 | "integrity": "sha512-OKTRokcl/oo34O8+6aUpj8Jf2Bjw2D0tZzmX0/RvyfVC9ZOZW+HPAWAlhS817IsRaCnzYX1z++h2kHFr2/KNRg==", 1822 | "dependencies": { 1823 | "debug": "3.1.0", 1824 | "destroy": "~1.0.4", 1825 | "encodeurl": "~1.0.2", 1826 | "escape-html": "~1.0.3", 1827 | "etag": "~1.8.1", 1828 | "fresh": "0.5.2", 1829 | "http-errors": "1.8.1", 1830 | "mime-types": "~2.1.34", 1831 | "ms": "2.1.3", 1832 | "on-finished": "~2.3.0", 1833 | "range-parser": "~1.2.1", 1834 | "statuses": "~1.5.0" 1835 | }, 1836 | "engines": { 1837 | "node": ">= 0.10" 1838 | } 1839 | }, 1840 | "node_modules/send/node_modules/ms": { 1841 | "version": "2.1.3", 1842 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1843 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1844 | }, 1845 | "node_modules/serve-static": { 1846 | "version": "2.0.0-beta.1", 1847 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-2.0.0-beta.1.tgz", 1848 | "integrity": "sha512-DEJ9on/tQeFO2Omj7ovT02lCp1YgP4Kb8W2lv2o/4keTFAbgc8HtH3yPd47++2wv9lvQeqiA7FHFDe5+8c4XpA==", 1849 | "dependencies": { 1850 | "encodeurl": "~1.0.2", 1851 | "escape-html": "~1.0.3", 1852 | "parseurl": "~1.3.3", 1853 | "send": "1.0.0-beta.1" 1854 | }, 1855 | "engines": { 1856 | "node": ">= 0.10" 1857 | } 1858 | }, 1859 | "node_modules/setprototypeof": { 1860 | "version": "1.2.0", 1861 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1862 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1863 | }, 1864 | "node_modules/slugify": { 1865 | "version": "1.6.6", 1866 | "resolved": "https://registry.npmjs.org/slugify/-/slugify-1.6.6.tgz", 1867 | "integrity": "sha512-h+z7HKHYXj6wJU+AnS/+IH8Uh9fdcX1Lrhg1/VMdf9PwoBQXFcXiAdsy2tSK0P6gKwJLXp02r90ahUCqHk9rrw==", 1868 | "engines": { 1869 | "node": ">=8.0.0" 1870 | } 1871 | }, 1872 | "node_modules/source-map": { 1873 | "version": "0.6.1", 1874 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1875 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1876 | "dev": true, 1877 | "engines": { 1878 | "node": ">=0.10.0" 1879 | } 1880 | }, 1881 | "node_modules/source-map-support": { 1882 | "version": "0.5.21", 1883 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 1884 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 1885 | "dev": true, 1886 | "dependencies": { 1887 | "buffer-from": "^1.0.0", 1888 | "source-map": "^0.6.0" 1889 | } 1890 | }, 1891 | "node_modules/sprintf-js": { 1892 | "version": "1.0.3", 1893 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1894 | "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", 1895 | "dev": true 1896 | }, 1897 | "node_modules/statuses": { 1898 | "version": "1.5.0", 1899 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1900 | "integrity": "sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==", 1901 | "engines": { 1902 | "node": ">= 0.6" 1903 | } 1904 | }, 1905 | "node_modules/string-width": { 1906 | "version": "4.2.3", 1907 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1908 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1909 | "dependencies": { 1910 | "emoji-regex": "^8.0.0", 1911 | "is-fullwidth-code-point": "^3.0.0", 1912 | "strip-ansi": "^6.0.1" 1913 | }, 1914 | "engines": { 1915 | "node": ">=8" 1916 | } 1917 | }, 1918 | "node_modules/strip-ansi": { 1919 | "version": "6.0.1", 1920 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1921 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1922 | "dependencies": { 1923 | "ansi-regex": "^5.0.1" 1924 | }, 1925 | "engines": { 1926 | "node": ">=8" 1927 | } 1928 | }, 1929 | "node_modules/strip-bom": { 1930 | "version": "3.0.0", 1931 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1932 | "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", 1933 | "dev": true, 1934 | "engines": { 1935 | "node": ">=4" 1936 | } 1937 | }, 1938 | "node_modules/strip-json-comments": { 1939 | "version": "2.0.1", 1940 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1941 | "integrity": "sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ==", 1942 | "dev": true, 1943 | "engines": { 1944 | "node": ">=0.10.0" 1945 | } 1946 | }, 1947 | "node_modules/supports-color": { 1948 | "version": "5.5.0", 1949 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1950 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1951 | "dev": true, 1952 | "dependencies": { 1953 | "has-flag": "^3.0.0" 1954 | }, 1955 | "engines": { 1956 | "node": ">=4" 1957 | } 1958 | }, 1959 | "node_modules/supports-preserve-symlinks-flag": { 1960 | "version": "1.0.0", 1961 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1962 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1963 | "dev": true, 1964 | "engines": { 1965 | "node": ">= 0.4" 1966 | }, 1967 | "funding": { 1968 | "url": "https://github.com/sponsors/ljharb" 1969 | } 1970 | }, 1971 | "node_modules/to-regex-range": { 1972 | "version": "5.0.1", 1973 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1974 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1975 | "dev": true, 1976 | "dependencies": { 1977 | "is-number": "^7.0.0" 1978 | }, 1979 | "engines": { 1980 | "node": ">=8.0" 1981 | } 1982 | }, 1983 | "node_modules/toidentifier": { 1984 | "version": "1.0.1", 1985 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1986 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1987 | "engines": { 1988 | "node": ">=0.6" 1989 | } 1990 | }, 1991 | "node_modules/tree-kill": { 1992 | "version": "1.2.2", 1993 | "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", 1994 | "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==", 1995 | "dev": true, 1996 | "bin": { 1997 | "tree-kill": "cli.js" 1998 | } 1999 | }, 2000 | "node_modules/ts-node": { 2001 | "version": "10.9.1", 2002 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.1.tgz", 2003 | "integrity": "sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw==", 2004 | "dependencies": { 2005 | "@cspotcode/source-map-support": "^0.8.0", 2006 | "@tsconfig/node10": "^1.0.7", 2007 | "@tsconfig/node12": "^1.0.7", 2008 | "@tsconfig/node14": "^1.0.0", 2009 | "@tsconfig/node16": "^1.0.2", 2010 | "acorn": "^8.4.1", 2011 | "acorn-walk": "^8.1.1", 2012 | "arg": "^4.1.0", 2013 | "create-require": "^1.1.0", 2014 | "diff": "^4.0.1", 2015 | "make-error": "^1.1.1", 2016 | "v8-compile-cache-lib": "^3.0.1", 2017 | "yn": "3.1.1" 2018 | }, 2019 | "bin": { 2020 | "ts-node": "dist/bin.js", 2021 | "ts-node-cwd": "dist/bin-cwd.js", 2022 | "ts-node-esm": "dist/bin-esm.js", 2023 | "ts-node-script": "dist/bin-script.js", 2024 | "ts-node-transpile-only": "dist/bin-transpile.js", 2025 | "ts-script": "dist/bin-script-deprecated.js" 2026 | }, 2027 | "peerDependencies": { 2028 | "@swc/core": ">=1.2.50", 2029 | "@swc/wasm": ">=1.2.50", 2030 | "@types/node": "*", 2031 | "typescript": ">=2.7" 2032 | }, 2033 | "peerDependenciesMeta": { 2034 | "@swc/core": { 2035 | "optional": true 2036 | }, 2037 | "@swc/wasm": { 2038 | "optional": true 2039 | } 2040 | } 2041 | }, 2042 | "node_modules/ts-node-dev": { 2043 | "version": "2.0.0", 2044 | "resolved": "https://registry.npmjs.org/ts-node-dev/-/ts-node-dev-2.0.0.tgz", 2045 | "integrity": "sha512-ywMrhCfH6M75yftYvrvNarLEY+SUXtUvU8/0Z6llrHQVBx12GiFk5sStF8UdfE/yfzk9IAq7O5EEbTQsxlBI8w==", 2046 | "dev": true, 2047 | "dependencies": { 2048 | "chokidar": "^3.5.1", 2049 | "dynamic-dedupe": "^0.3.0", 2050 | "minimist": "^1.2.6", 2051 | "mkdirp": "^1.0.4", 2052 | "resolve": "^1.0.0", 2053 | "rimraf": "^2.6.1", 2054 | "source-map-support": "^0.5.12", 2055 | "tree-kill": "^1.2.2", 2056 | "ts-node": "^10.4.0", 2057 | "tsconfig": "^7.0.0" 2058 | }, 2059 | "bin": { 2060 | "ts-node-dev": "lib/bin.js", 2061 | "tsnd": "lib/bin.js" 2062 | }, 2063 | "engines": { 2064 | "node": ">=0.8.0" 2065 | }, 2066 | "peerDependencies": { 2067 | "node-notifier": "*", 2068 | "typescript": "*" 2069 | }, 2070 | "peerDependenciesMeta": { 2071 | "node-notifier": { 2072 | "optional": true 2073 | } 2074 | } 2075 | }, 2076 | "node_modules/ts-node-dev/node_modules/mkdirp": { 2077 | "version": "1.0.4", 2078 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 2079 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 2080 | "dev": true, 2081 | "bin": { 2082 | "mkdirp": "bin/cmd.js" 2083 | }, 2084 | "engines": { 2085 | "node": ">=10" 2086 | } 2087 | }, 2088 | "node_modules/tsconfig": { 2089 | "version": "7.0.0", 2090 | "resolved": "https://registry.npmjs.org/tsconfig/-/tsconfig-7.0.0.tgz", 2091 | "integrity": "sha512-vZXmzPrL+EmC4T/4rVlT2jNVMWCi/O4DIiSj3UHg1OE5kCKbk4mfrXc6dZksLgRM/TZlKnousKH9bbTazUWRRw==", 2092 | "dev": true, 2093 | "dependencies": { 2094 | "@types/strip-bom": "^3.0.0", 2095 | "@types/strip-json-comments": "0.0.30", 2096 | "strip-bom": "^3.0.0", 2097 | "strip-json-comments": "^2.0.0" 2098 | } 2099 | }, 2100 | "node_modules/tslib": { 2101 | "version": "1.14.1", 2102 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 2103 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 2104 | "dev": true 2105 | }, 2106 | "node_modules/tslint": { 2107 | "version": "6.1.3", 2108 | "resolved": "https://registry.npmjs.org/tslint/-/tslint-6.1.3.tgz", 2109 | "integrity": "sha512-IbR4nkT96EQOvKE2PW/djGz8iGNeJ4rF2mBfiYaR/nvUWYKJhLwimoJKgjIFEIDibBtOevj7BqCRL4oHeWWUCg==", 2110 | "deprecated": "TSLint has been deprecated in favor of ESLint. Please see https://github.com/palantir/tslint/issues/4534 for more information.", 2111 | "dev": true, 2112 | "dependencies": { 2113 | "@babel/code-frame": "^7.0.0", 2114 | "builtin-modules": "^1.1.1", 2115 | "chalk": "^2.3.0", 2116 | "commander": "^2.12.1", 2117 | "diff": "^4.0.1", 2118 | "glob": "^7.1.1", 2119 | "js-yaml": "^3.13.1", 2120 | "minimatch": "^3.0.4", 2121 | "mkdirp": "^0.5.3", 2122 | "resolve": "^1.3.2", 2123 | "semver": "^5.3.0", 2124 | "tslib": "^1.13.0", 2125 | "tsutils": "^2.29.0" 2126 | }, 2127 | "bin": { 2128 | "tslint": "bin/tslint" 2129 | }, 2130 | "engines": { 2131 | "node": ">=4.8.0" 2132 | }, 2133 | "peerDependencies": { 2134 | "typescript": ">=2.3.0-dev || >=2.4.0-dev || >=2.5.0-dev || >=2.6.0-dev || >=2.7.0-dev || >=2.8.0-dev || >=2.9.0-dev || >=3.0.0-dev || >= 3.1.0-dev || >= 3.2.0-dev || >= 4.0.0-dev" 2135 | } 2136 | }, 2137 | "node_modules/tslint/node_modules/commander": { 2138 | "version": "2.20.3", 2139 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 2140 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 2141 | "dev": true 2142 | }, 2143 | "node_modules/tsutils": { 2144 | "version": "2.29.0", 2145 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-2.29.0.tgz", 2146 | "integrity": "sha512-g5JVHCIJwzfISaXpXE1qvNalca5Jwob6FjI4AoPlqMusJ6ftFE7IkkFoMhVLRgK+4Kx3gkzb8UZK5t5yTTvEmA==", 2147 | "dev": true, 2148 | "dependencies": { 2149 | "tslib": "^1.8.1" 2150 | }, 2151 | "peerDependencies": { 2152 | "typescript": ">=2.1.0 || >=2.1.0-dev || >=2.2.0-dev || >=2.3.0-dev || >=2.4.0-dev || >=2.5.0-dev || >=2.6.0-dev || >=2.7.0-dev || >=2.8.0-dev || >=2.9.0-dev || >= 3.0.0-dev || >= 3.1.0-dev" 2153 | } 2154 | }, 2155 | "node_modules/type": { 2156 | "version": "1.2.0", 2157 | "resolved": "https://registry.npmjs.org/type/-/type-1.2.0.tgz", 2158 | "integrity": "sha512-+5nt5AAniqsCnu2cEQQdpzCAh33kVx8n0VoFidKpB1dVVLAN/F+bgVOqOJqOnEnrhp222clB5p3vUlD+1QAnfg==" 2159 | }, 2160 | "node_modules/type-is": { 2161 | "version": "1.6.18", 2162 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2163 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2164 | "dependencies": { 2165 | "media-typer": "0.3.0", 2166 | "mime-types": "~2.1.24" 2167 | }, 2168 | "engines": { 2169 | "node": ">= 0.6" 2170 | } 2171 | }, 2172 | "node_modules/typedarray-to-buffer": { 2173 | "version": "3.1.5", 2174 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 2175 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 2176 | "dependencies": { 2177 | "is-typedarray": "^1.0.0" 2178 | } 2179 | }, 2180 | "node_modules/typescript": { 2181 | "version": "4.9.5", 2182 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.5.tgz", 2183 | "integrity": "sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g==", 2184 | "bin": { 2185 | "tsc": "bin/tsc", 2186 | "tsserver": "bin/tsserver" 2187 | }, 2188 | "engines": { 2189 | "node": ">=4.2.0" 2190 | } 2191 | }, 2192 | "node_modules/unpipe": { 2193 | "version": "1.0.0", 2194 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2195 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 2196 | "engines": { 2197 | "node": ">= 0.8" 2198 | } 2199 | }, 2200 | "node_modules/utf-8-validate": { 2201 | "version": "5.0.10", 2202 | "resolved": "https://registry.npmjs.org/utf-8-validate/-/utf-8-validate-5.0.10.tgz", 2203 | "integrity": "sha512-Z6czzLq4u8fPOyx7TU6X3dvUZVvoJmxSQ+IcrlmagKhilxlhZgxPK6C5Jqbkw1IDUmFTM+cz9QDnnLTwDz/2gQ==", 2204 | "hasInstallScript": true, 2205 | "dependencies": { 2206 | "node-gyp-build": "^4.3.0" 2207 | }, 2208 | "engines": { 2209 | "node": ">=6.14.2" 2210 | } 2211 | }, 2212 | "node_modules/utils-merge": { 2213 | "version": "1.0.1", 2214 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2215 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", 2216 | "engines": { 2217 | "node": ">= 0.4.0" 2218 | } 2219 | }, 2220 | "node_modules/uuid": { 2221 | "version": "9.0.0", 2222 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-9.0.0.tgz", 2223 | "integrity": "sha512-MXcSTerfPa4uqyzStbRoTgt5XIe3x5+42+q1sDuy3R5MDk66URdLMOZe5aPX/SQd+kuYAh0FdP/pO28IkQyTeg==", 2224 | "bin": { 2225 | "uuid": "dist/bin/uuid" 2226 | } 2227 | }, 2228 | "node_modules/v8-compile-cache-lib": { 2229 | "version": "3.0.1", 2230 | "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz", 2231 | "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==" 2232 | }, 2233 | "node_modules/vary": { 2234 | "version": "1.1.2", 2235 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2236 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", 2237 | "engines": { 2238 | "node": ">= 0.8" 2239 | } 2240 | }, 2241 | "node_modules/websocket": { 2242 | "version": "1.0.34", 2243 | "resolved": "https://registry.npmjs.org/websocket/-/websocket-1.0.34.tgz", 2244 | "integrity": "sha512-PRDso2sGwF6kM75QykIesBijKSVceR6jL2G8NGYyq2XrItNC2P5/qL5XeR056GhA+Ly7JMFvJb9I312mJfmqnQ==", 2245 | "dependencies": { 2246 | "bufferutil": "^4.0.1", 2247 | "debug": "^2.2.0", 2248 | "es5-ext": "^0.10.50", 2249 | "typedarray-to-buffer": "^3.1.5", 2250 | "utf-8-validate": "^5.0.2", 2251 | "yaeti": "^0.0.6" 2252 | }, 2253 | "engines": { 2254 | "node": ">=4.0.0" 2255 | } 2256 | }, 2257 | "node_modules/websocket/node_modules/debug": { 2258 | "version": "2.6.9", 2259 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2260 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2261 | "dependencies": { 2262 | "ms": "2.0.0" 2263 | } 2264 | }, 2265 | "node_modules/wrap-ansi": { 2266 | "version": "7.0.0", 2267 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2268 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2269 | "dependencies": { 2270 | "ansi-styles": "^4.0.0", 2271 | "string-width": "^4.1.0", 2272 | "strip-ansi": "^6.0.0" 2273 | }, 2274 | "engines": { 2275 | "node": ">=10" 2276 | }, 2277 | "funding": { 2278 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2279 | } 2280 | }, 2281 | "node_modules/wrap-ansi/node_modules/ansi-styles": { 2282 | "version": "4.3.0", 2283 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2284 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2285 | "dependencies": { 2286 | "color-convert": "^2.0.1" 2287 | }, 2288 | "engines": { 2289 | "node": ">=8" 2290 | }, 2291 | "funding": { 2292 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2293 | } 2294 | }, 2295 | "node_modules/wrap-ansi/node_modules/color-convert": { 2296 | "version": "2.0.1", 2297 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2298 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2299 | "dependencies": { 2300 | "color-name": "~1.1.4" 2301 | }, 2302 | "engines": { 2303 | "node": ">=7.0.0" 2304 | } 2305 | }, 2306 | "node_modules/wrap-ansi/node_modules/color-name": { 2307 | "version": "1.1.4", 2308 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2309 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 2310 | }, 2311 | "node_modules/wrappy": { 2312 | "version": "1.0.2", 2313 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2314 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 2315 | "dev": true 2316 | }, 2317 | "node_modules/xtend": { 2318 | "version": "4.0.2", 2319 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 2320 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 2321 | "dev": true, 2322 | "engines": { 2323 | "node": ">=0.4" 2324 | } 2325 | }, 2326 | "node_modules/y18n": { 2327 | "version": "5.0.8", 2328 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 2329 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 2330 | "engines": { 2331 | "node": ">=10" 2332 | } 2333 | }, 2334 | "node_modules/yaeti": { 2335 | "version": "0.0.6", 2336 | "resolved": "https://registry.npmjs.org/yaeti/-/yaeti-0.0.6.tgz", 2337 | "integrity": "sha512-MvQa//+KcZCUkBTIC9blM+CU9J2GzuTytsOUwf2lidtvkx/6gnEp1QvJv34t9vdjhFmha/mUiNDbN0D0mJWdug==", 2338 | "engines": { 2339 | "node": ">=0.10.32" 2340 | } 2341 | }, 2342 | "node_modules/yargs": { 2343 | "version": "16.2.0", 2344 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 2345 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 2346 | "dependencies": { 2347 | "cliui": "^7.0.2", 2348 | "escalade": "^3.1.1", 2349 | "get-caller-file": "^2.0.5", 2350 | "require-directory": "^2.1.1", 2351 | "string-width": "^4.2.0", 2352 | "y18n": "^5.0.5", 2353 | "yargs-parser": "^20.2.2" 2354 | }, 2355 | "engines": { 2356 | "node": ">=10" 2357 | } 2358 | }, 2359 | "node_modules/yargs-parser": { 2360 | "version": "20.2.9", 2361 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 2362 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 2363 | "engines": { 2364 | "node": ">=10" 2365 | } 2366 | }, 2367 | "node_modules/yn": { 2368 | "version": "3.1.1", 2369 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 2370 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 2371 | "engines": { 2372 | "node": ">=6" 2373 | } 2374 | }, 2375 | "node_modules/zod": { 2376 | "version": "3.21.4", 2377 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.21.4.tgz", 2378 | "integrity": "sha512-m46AKbrzKVzOzs/DZgVnG5H55N1sv1M8qZU3A8RIKbs3mrACDNeIOeilDymVb2HdmP8uwshOCF4uJ8uM9rCqJw==", 2379 | "funding": { 2380 | "url": "https://github.com/sponsors/colinhacks" 2381 | } 2382 | } 2383 | } 2384 | } 2385 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "magic-cache", 3 | "version": "0.0.1", 4 | "description": "Magic Cache", 5 | "main": "dist/index", 6 | "scripts": { 7 | "build": "tsc", 8 | "deploy": "yarn build && (yarn deploy:app)", 9 | "start": "node ./dist/index", 10 | "test": "echo \"Error: no test specified\" && exit 1", 11 | "dev": "ts-node-dev --respawn --pretty --transpile-only src/index.ts" 12 | }, 13 | "engines": { 14 | "node": "<=16.17.0" 15 | }, 16 | "private": true, 17 | "repository": { 18 | "type": "git", 19 | "url": "git+https://github.com/jackbridger/magic-cache.git" 20 | }, 21 | "author": "tzvc", 22 | "license": "UNLICENSED", 23 | "bugs": { 24 | "url": "https://github.com/jackbridger/magic-cache/issues" 25 | }, 26 | "homepage": "https://github.com/jackbridger/magic-cache#readme", 27 | "devDependencies": { 28 | "@types/cookie-parser": "^1.4.3", 29 | "@types/cors": "^2.8.13", 30 | "@types/dotenv": "^8.2.0", 31 | "@types/express": "^4.17.15", 32 | "@types/helmet": "^4.0.0", 33 | "@types/multer": "^1.4.7", 34 | "@types/node": "^18.11.18", 35 | "@types/node-fetch": "^2.6.2", 36 | "ts-node-dev": "^2.0.0", 37 | "tslint": "^6.1.3", 38 | "typescript": "^4.9.5" 39 | }, 40 | "dependencies": { 41 | "@grpc/grpc-js": "^1.8.0", 42 | "@supabase/supabase-js": "^2.21.0", 43 | "@types/express-jwt": "^6.0.4", 44 | "@types/jsonwebtoken": "^9.0.0", 45 | "@types/mime-types": "^2.1.1", 46 | "@types/uuid": "^9.0.1", 47 | "cookie-parser": "^1.4.6", 48 | "cors": "^2.8.5", 49 | "dotenv": "^16.0.3", 50 | "express": "^5.0.0-alpha.8", 51 | "mime-types": "^2.1.35", 52 | "node-fetch": "^2.6.1", 53 | "openai": "^3.2.1", 54 | "slugify": "^1.6.5", 55 | "ts-node": "^10.9.1", 56 | "uuid": "^9.0.0", 57 | "zod": "^3.20.2" 58 | } 59 | } 60 | -------------------------------------------------------------------------------- /sql/cache.sql: -------------------------------------------------------------------------------- 1 | create table 2 | public.cache_entries ( 3 | id integer not null default nextval('cache_entries_id_seq'::regclass), 4 | prompt text not null, 5 | completion text null, 6 | prompt_embedding public.vector null, 7 | user_id uuid not null, 8 | constraint cache_entries_pkey primary key (id) 9 | ) tablespace pg_default; -------------------------------------------------------------------------------- /sql/match_prompts_cosine.sql: -------------------------------------------------------------------------------- 1 | create or replace function match_prompts_cosine ( 2 | query_embedding vector(1536), 3 | match_threshold float, 4 | match_count int 5 | ) 6 | returns table ( 7 | id bigint, 8 | prompt text, 9 | completion text, 10 | similarity float 11 | ) 12 | language sql stable 13 | as $$ 14 | select 15 | cache_entries.id, 16 | cache_entries.prompt, 17 | cache_entries.completion, 18 | 1 - (cache_entries.prompt_embedding <=> query_embedding) as similarity 19 | from cache_entries 20 | where 1 - (cache_entries.prompt_embedding <=> query_embedding) > match_threshold 21 | order by similarity desc 22 | limit match_count; 23 | $$; -------------------------------------------------------------------------------- /sql/match_prompts_cosine_auth.sql: -------------------------------------------------------------------------------- 1 | create or replace function match_prompts_cosine_auth ( 2 | query_embedding vector(1536), 3 | match_threshold float, 4 | match_count int, 5 | auth_user_id uuid 6 | ) 7 | returns table ( 8 | id bigint, 9 | prompt text, 10 | completion text, 11 | similarity float 12 | ) 13 | language sql stable 14 | as $$ 15 | select 16 | cache_entries.id, 17 | cache_entries.prompt, 18 | cache_entries.completion, 19 | 1 - (cache_entries.prompt_embedding <=> query_embedding) as similarity 20 | from cache_entries 21 | where 1 - (cache_entries.prompt_embedding <=> query_embedding) > match_threshold and cache_entries.user_id = auth_user_id 22 | order by similarity desc 23 | limit match_count; 24 | $$; -------------------------------------------------------------------------------- /src/.DS_Store: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/bitreach/magic-cache/1acb7576f08af4269f75e23c1c1901b8bd27c247/src/.DS_Store -------------------------------------------------------------------------------- /src/api/cache/get.ts: -------------------------------------------------------------------------------- 1 | import * as dotenv from "dotenv"; // see https://github.com/motdotla/dotenv#how-do-i-use-dotenv-with-import 2 | import express from "express"; 3 | import { z } from "zod"; 4 | 5 | import { 6 | APIError, 7 | BadRequestError, 8 | InternalError, 9 | NotFoundError, 10 | UnauthenticatedError, 11 | } from "../../common/errors/api_error"; 12 | import { EmbeddingHelper } from "../../helpers/embedding_helper"; 13 | import { getUserFromJWT, supabaseClient, isValidAPIKey } from "../../lib/supabase"; 14 | 15 | dotenv.config(); 16 | 17 | const payloadSchema = z.object({ 18 | prompt: z.string().nonempty(), 19 | // parse string into number 20 | similarity_threshold: z.preprocess( 21 | (a) => parseFloat(z.string().parse(a)), 22 | z.number().positive().max(1) 23 | ), 24 | }); 25 | 26 | // extract the inferred type 27 | type Payload = z.infer; 28 | 29 | export default async (req: express.Request, res: express.Response) => { 30 | try { 31 | if (!req || !req.headers || !req.headers.authorization) { 32 | return res.status(401).json({error:"Failed to authenticate"}) 33 | } 34 | const receivedAPIKey = req.headers.authorization.split(' ')[1] 35 | const userID = await isValidAPIKey(receivedAPIKey) 36 | if (!userID){ 37 | throw new UnauthenticatedError("Invalid API Key"); 38 | } 39 | // const user = await getUserFromJWT(req.headers.authorization as string); 40 | // if (!user) 41 | // throw new UnauthenticatedError( 42 | // "Expecting a valid JWT token in the Authorization header." 43 | // ); 44 | 45 | const zodRes = payloadSchema.safeParse(req.body); 46 | if (!zodRes.success) 47 | throw new BadRequestError( 48 | zodRes.error.errors 49 | .map((error: any) => `${error.code} ${error.path} ${error.message}`) 50 | .join(",") 51 | ); 52 | 53 | const payload: Payload = zodRes.data; 54 | 55 | console.log(payload); 56 | 57 | const promptEmbedding = await EmbeddingHelper.computeEmbedding( 58 | payload.prompt 59 | ); 60 | 61 | console.log(promptEmbedding); 62 | 63 | const { data: documents } = await supabaseClient.rpc( 64 | "match_prompts_cosine_auth", 65 | { 66 | query_embedding: promptEmbedding, 67 | match_threshold: payload.similarity_threshold, // Similarity threshold 68 | match_count: 10, // Number of match 69 | auth_user_id: userID 70 | } 71 | ); 72 | 73 | if (!documents || documents.length === 0) 74 | throw new NotFoundError("No documents found"); 75 | 76 | return res.json(documents); 77 | } catch (e) { 78 | console.error(e); 79 | if (e instanceof APIError) throw e; 80 | throw new InternalError((e as Error).message); 81 | } 82 | }; 83 | -------------------------------------------------------------------------------- /src/api/cache/post.ts: -------------------------------------------------------------------------------- 1 | import * as dotenv from "dotenv"; // see https://github.com/motdotla/dotenv#how-do-i-use-dotenv-with-import 2 | import express from "express"; 3 | import { z } from "zod"; 4 | import { 5 | APIError, 6 | BadRequestError, 7 | InternalError, 8 | UnauthenticatedError, 9 | } from "../../common/errors/api_error"; 10 | import { getUserFromJWT, supabaseClient, isValidAPIKey } from "../../lib/supabase"; 11 | import { EmbeddingHelper } from "../../helpers/embedding_helper"; 12 | dotenv.config(); 13 | 14 | const payloadSchema = z.object({ 15 | prompt: z.string().nonempty(), 16 | completion: z.string(), 17 | }); 18 | 19 | // extract the inferred type 20 | type Payload = z.infer; 21 | 22 | export default async (req: express.Request, res: express.Response) => { 23 | try { 24 | if (!req || !req.headers || !req.headers.authorization) { 25 | console.log(req.headers) 26 | return res.status(401).json({error:"Failed to authenticate"}) 27 | } 28 | const receivedAPIKey = req.headers.authorization.split(' ')[1] 29 | const userID = await isValidAPIKey(receivedAPIKey) 30 | if (!userID){ 31 | throw new UnauthenticatedError("Invalid API Key"); 32 | } 33 | 34 | // need to get the user id from the api key 35 | // const user = await getUserFromJWT(req.headers.authorization as string); 36 | // if (!user) 37 | // throw new UnauthenticatedError( 38 | // "Expecting a valid JWT token in the Authorization header." 39 | // ); 40 | 41 | const zodRes = payloadSchema.safeParse(req.body); 42 | if (!zodRes.success) 43 | throw new BadRequestError( 44 | zodRes.error.errors 45 | .map((error: any) => `${error.code} ${error.path} ${error.message}`) 46 | .join(",") 47 | ); 48 | 49 | const payload: Payload = zodRes.data; 50 | 51 | const promptEmbedding = await EmbeddingHelper.computeEmbedding( 52 | payload.prompt 53 | ); 54 | 55 | // Store the vector in Postgres 56 | const { data, error } = await supabaseClient.from("cache_entries").insert({ 57 | prompt: payload.prompt, 58 | completion: payload.completion, 59 | prompt_embedding: promptEmbedding, 60 | user_id: userID, 61 | }); 62 | 63 | if (error) throw new InternalError(error.message); 64 | 65 | return res.json({ success: true }); 66 | } catch (e) { 67 | console.error(e); 68 | if (e instanceof APIError) throw e; 69 | throw new InternalError((e as Error).message); 70 | } 71 | }; 72 | -------------------------------------------------------------------------------- /src/api/cache/router.ts: -------------------------------------------------------------------------------- 1 | import { Router } from "express"; 2 | import post from "./post"; 3 | import get from "./get"; 4 | 5 | export const apiCacheRouter = Router({ mergeParams: true }); // inherit params from parents 6 | 7 | apiCacheRouter.post("/", post); 8 | apiCacheRouter.get("/", get); 9 | -------------------------------------------------------------------------------- /src/api/router.ts: -------------------------------------------------------------------------------- 1 | import express from "express"; 2 | import { apiCacheRouter } from "./cache/router"; 3 | 4 | const router = express.Router(); 5 | 6 | router.use("/cache", apiCacheRouter); 7 | 8 | export const apiRouter = router; 9 | -------------------------------------------------------------------------------- /src/common/errors/api_error.ts: -------------------------------------------------------------------------------- 1 | import { BaseError } from "./base_error"; 2 | 3 | export enum HttpStatusCode { 4 | OK = 200, 5 | BAD_REQUEST = 400, 6 | UNAUTHENTICATED = 401, 7 | PAYMENT_REQUIRED = 402, 8 | UNAUTHORIZED = 403, 9 | NOT_FOUND = 404, 10 | CONFLICT = 409, 11 | TOO_MANY_REQUESTS = 429, 12 | INTERNAL_SERVER = 500, 13 | } 14 | 15 | export class APIError extends BaseError { 16 | public readonly httpCode: HttpStatusCode; 17 | 18 | constructor( 19 | name: string, 20 | httpCode = HttpStatusCode.INTERNAL_SERVER, 21 | description = "internal server error" 22 | ) { 23 | super(name, true, description); 24 | this.httpCode = httpCode; 25 | } 26 | } 27 | 28 | export class InternalError extends APIError { 29 | constructor(description = "internal") { 30 | super("internal", HttpStatusCode.INTERNAL_SERVER, description); 31 | } 32 | } 33 | 34 | export class NotFoundError extends APIError { 35 | constructor(description = "not found") { 36 | super("not-found", HttpStatusCode.NOT_FOUND, description); 37 | } 38 | } 39 | 40 | export class BadRequestError extends APIError { 41 | constructor(description = "bad request") { 42 | super("bad-request", HttpStatusCode.BAD_REQUEST, description); 43 | } 44 | } 45 | 46 | export class ConflictError extends APIError { 47 | constructor(description = "conflict") { 48 | super("conflict", HttpStatusCode.CONFLICT, description); 49 | } 50 | } 51 | 52 | export class UnauthenticatedError extends APIError { 53 | constructor(description = "unauthenticated") { 54 | super("unauthenticated", HttpStatusCode.UNAUTHENTICATED, description); 55 | } 56 | } 57 | 58 | export class UnauthorizedError extends APIError { 59 | constructor(description = "unauthorized") { 60 | super("unauthorized", HttpStatusCode.UNAUTHORIZED, description); 61 | } 62 | } 63 | 64 | export class PaymentRequiredError extends APIError { 65 | constructor(description = "payment-required") { 66 | super("payment-required", HttpStatusCode.PAYMENT_REQUIRED, description); 67 | } 68 | } 69 | 70 | export class TooManyRequestsError extends APIError { 71 | constructor(description = "too-many-requests") { 72 | super("too-many-requests", HttpStatusCode.TOO_MANY_REQUESTS, description); 73 | } 74 | } 75 | -------------------------------------------------------------------------------- /src/common/errors/base_error.ts: -------------------------------------------------------------------------------- 1 | export class BaseError extends Error { 2 | public readonly name: string; 3 | public readonly isOperational: boolean; 4 | 5 | constructor(name: string, isOperational: boolean, description: string) { 6 | super(description); 7 | Object.setPrototypeOf(this, new.target.prototype); 8 | 9 | this.name = name; 10 | this.isOperational = isOperational; 11 | 12 | Error.captureStackTrace(this); 13 | } 14 | } 15 | -------------------------------------------------------------------------------- /src/config/environment_config.ts: -------------------------------------------------------------------------------- 1 | import * as dotenv from "dotenv"; 2 | console.debug("Loaded env variables..."); 3 | const config = dotenv.config(); 4 | process.env = { ...process.env, ...config.parsed }; 5 | -------------------------------------------------------------------------------- /src/helpers/embedding_helper.ts: -------------------------------------------------------------------------------- 1 | import { openaiClient } from "../lib/openai"; 2 | 3 | export class EmbeddingHelper { 4 | static async computeEmbedding(text: string) { 5 | // OpenAI recommends replacing newlines with spaces for best results 6 | const sanitizedPrompt = text.replace(/\n/g, " "); 7 | 8 | // Generate a vector embedding using OpenAI 9 | const embeddingResponse = await openaiClient.createEmbedding({ 10 | model: "text-embedding-ada-002", 11 | input: sanitizedPrompt, 12 | }); 13 | 14 | const [{ embedding }] = embeddingResponse.data.data; 15 | 16 | return embedding; 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * Required External Modules 3 | */ 4 | 5 | import "./config/environment_config"; 6 | import cookieParser from "cookie-parser"; 7 | import cors from "cors"; 8 | import "dotenv/config"; 9 | import express from "express"; 10 | import { apiRouter } from "./api/router"; 11 | import handleErrors from "./middlewares/error_middleware"; 12 | /** 13 | * App Variables 14 | */ 15 | if (!process.env.PORT) { 16 | console.error("No PORT variable found in env. exiting..."); 17 | process.exit(1); 18 | } 19 | 20 | const PORT: number = parseInt(process.env.PORT as string, 10); 21 | 22 | const app = express(); 23 | 24 | /** 25 | * App Configuration 26 | */ 27 | app.use(cors()); 28 | app.use(cookieParser()); 29 | app.use(express.json()); 30 | 31 | // API router 32 | app.use("/", apiRouter); 33 | // Custom error handling 34 | app.use(handleErrors); 35 | 36 | /** 37 | * Server Activation 38 | */ 39 | app.listen(PORT); 40 | console.debug(`Listening on port ${PORT}`); 41 | 42 | process.on("exit", function (code) { 43 | console.log(`About to exit with code ${code}`); 44 | }); 45 | -------------------------------------------------------------------------------- /src/lib/openai.ts: -------------------------------------------------------------------------------- 1 | import { Configuration, OpenAIApi } from "openai"; 2 | 3 | const configuration = new Configuration({ 4 | apiKey: process.env.OPENAI_API_KEY, 5 | }); 6 | export const openaiClient = new OpenAIApi(configuration); 7 | -------------------------------------------------------------------------------- /src/lib/supabase.ts: -------------------------------------------------------------------------------- 1 | import "dotenv/config"; 2 | import { createClient } from "@supabase/supabase-js"; 3 | 4 | // Create a single supabase client for interacting with your database 5 | export const supabaseClient = createClient( 6 | process.env.SUPABASE_URL as string, 7 | process.env.SUPABASE_SERVICE_KEY as string 8 | ); 9 | 10 | export const getUserFromJWT = async (token: string) => { 11 | if (!token) return null; 12 | const res = await supabaseClient.auth.getUser(token.replace("Bearer ", "")); 13 | return res.data.user; 14 | }; 15 | 16 | export const isValidAPIKey = async function (receivedAPIKey:string) { 17 | try{ 18 | const { data, error } = await supabaseClient 19 | .from('api_keys') 20 | .select(`api_key, api_key_developer (developer_id)`) 21 | .eq('api_key', receivedAPIKey) 22 | if (error){ 23 | console.log(error) 24 | return false 25 | } 26 | else{ 27 | if (data.length === 0 ) { 28 | return false 29 | } 30 | const isAuthenticated = data[0].api_key === receivedAPIKey 31 | if (!isAuthenticated) { 32 | return false 33 | } 34 | let developerID; 35 | if (Array.isArray(data[0].api_key_developer)) { 36 | developerID = data[0].api_key_developer[0]?.developer_id 37 | } else { 38 | developerID = data[0].api_key_developer?.developer_id 39 | } 40 | return developerID 41 | } 42 | }catch(err){ 43 | return false 44 | } 45 | } -------------------------------------------------------------------------------- /src/middlewares/auth_middleware.ts: -------------------------------------------------------------------------------- 1 | // import express from "express"; 2 | // import jwt from "jsonwebtoken"; 3 | // import { ACCESS_TOKEN_COOKIE_NAME } from "../api/auth/signin/post"; 4 | // import { 5 | // UnauthenticatedError, 6 | // UnauthorizedError, 7 | // } from "../common/errors/api_error"; 8 | 9 | // export async function attachSession( 10 | // req: express.Request, 11 | // _: express.Response, 12 | // next: express.NextFunction 13 | // ) { 14 | // const headerToken = req.headers.authorization; 15 | // const cookieToken = req.cookies[ACCESS_TOKEN_COOKIE_NAME]; 16 | 17 | // if (!cookieToken && !headerToken) { 18 | // req.session = null; 19 | // next(); 20 | // return; 21 | // } 22 | // const token = cookieToken ? cookieToken : headerToken!.split("Bearer ")[1]; 23 | // try { 24 | // const decoded = jwt.verify( 25 | // token, 26 | // process.env.JWT_SECRET as string 27 | // ) as jwt.JwtPayload; 28 | // console.log(decoded); 29 | // req.session = { userId: decoded["user_id"] }; 30 | // analyticsService.identify(req.session.userId, {}); 31 | // } catch (err) { 32 | // // @ts-ignore 33 | // throw new UnauthorizedError(`Unauthorized. Reason: ${err.message}`); 34 | // } 35 | 36 | // next(); 37 | // } 38 | 39 | // export async function requireSession( 40 | // req: express.Request, 41 | // _: express.Response, 42 | // next: express.NextFunction 43 | // ) { 44 | // if (req.session == null || req.session.userId == null) 45 | // throw new UnauthenticatedError("Authentication token required."); 46 | 47 | // next(); 48 | // } 49 | 50 | // // export async function authenticateWithApiKey( 51 | // // req: express.Request, 52 | // // _: express.Response, 53 | // // next: express.NextFunction, 54 | // // ) { 55 | // // const rawToken = req.headers.authorization; 56 | 57 | // // if (!rawToken || !rawToken.startsWith('ApiKey ')) 58 | // // throw new UnauthenticatedError('Missing Api Key.'); 59 | 60 | // // const apiKey = rawToken.split('ApiKey ')[1]; 61 | 62 | // // if (apiKey !== process.env.ZIGG_API_KEY) 63 | // // throw new UnauthenticatedError('Invalid API key.'); 64 | // // req.session = 'admin'; 65 | 66 | // // next(); 67 | // // } 68 | -------------------------------------------------------------------------------- /src/middlewares/error_middleware.ts: -------------------------------------------------------------------------------- 1 | import express from "express"; 2 | import { APIError, InternalError } from "../common/errors/api_error"; 3 | import { BaseError } from "../common/errors/base_error"; 4 | 5 | export default function handleErrors( 6 | error: Error, 7 | req: express.Request, 8 | res: express.Response, 9 | _: express.NextFunction 10 | ) { 11 | if (!(error instanceof BaseError) || !error.isOperational) { 12 | // shit went south, log error somewhere I can look at it 13 | } 14 | 15 | if (!(error instanceof APIError) || error instanceof InternalError) { 16 | console.error(error, { 17 | url: req.originalUrl, 18 | }); 19 | return res.status(500).send({ 20 | name: "internal", 21 | message: "Internal server error, please try again later.", 22 | }); 23 | } 24 | 25 | return res 26 | .status(error.httpCode) 27 | .send({ name: error.name, message: error.message }); 28 | } 29 | -------------------------------------------------------------------------------- /src/utils/datetime_util.ts: -------------------------------------------------------------------------------- 1 | export class DateTimeUtil { 2 | static dateWithAddedDays(date: Date, days: number) { 3 | var d = new Date(); 4 | d.setDate(date.getDate() + days); 5 | return d; 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /src/utils/misc_util.ts: -------------------------------------------------------------------------------- 1 | export function chunkArray(arr: T[], size: number): T[][] { 2 | const chunkedArray: T[][] = []; 3 | 4 | for (let i = 0; i < arr.length; i += size) { 5 | const chunk = arr.slice(i, i + size); 6 | chunkedArray.push(chunk); 7 | } 8 | 9 | return chunkedArray; 10 | } 11 | 12 | // random in array 13 | export function randomInArray(arr: T[]): T { 14 | return arr[Math.floor(Math.random() * arr.length)]; 15 | } 16 | -------------------------------------------------------------------------------- /src/utils/serialization_util.ts: -------------------------------------------------------------------------------- 1 | const LONG_TYPE = 'type.googleapis.com/google.protobuf.Int64Value'; 2 | const UNSIGNED_LONG_TYPE = 'type.googleapis.com/google.protobuf.UInt64Value'; 3 | 4 | function mapValues( 5 | // { [k: string]: unknown } is no longer a wildcard assignment target after typescript 3.5 6 | // eslint-disable-next-line @typescript-eslint/no-explicit-any 7 | o: { [key: string]: any }, 8 | f: (arg0: unknown) => unknown, 9 | ): object { 10 | const result: { [key: string]: unknown } = {}; 11 | for (const key in o) { 12 | if (o.hasOwnProperty(key)) { 13 | result[key] = f(o[key]); 14 | } 15 | } 16 | return result; 17 | } 18 | 19 | /** 20 | * Takes data and encodes it in a JSON-friendly way, such that types such as 21 | * Date are preserved. 22 | * @internal 23 | * @param data - Data to encode. 24 | */ 25 | export function encode(data: unknown): unknown { 26 | if (data == null) { 27 | return null; 28 | } 29 | if (data instanceof Number) { 30 | data = data.valueOf(); 31 | } 32 | if (typeof data === 'number' && isFinite(data)) { 33 | // Any number in JS is safe to put directly in JSON and parse as a double 34 | // without any loss of precision. 35 | return data; 36 | } 37 | if (data === true || data === false) { 38 | return data; 39 | } 40 | if (Object.prototype.toString.call(data) === '[object String]') { 41 | return data; 42 | } 43 | if (data instanceof Date) { 44 | return data.toISOString(); 45 | } 46 | if (Array.isArray(data)) { 47 | return data.map(x => encode(x)); 48 | } 49 | if (typeof data === 'function' || typeof data === 'object') { 50 | return mapValues(data!, x => encode(x)); 51 | } 52 | // If we got this far, the data is not encodable. 53 | throw new Error('Data cannot be encoded in JSON: ' + data); 54 | } 55 | 56 | /** 57 | * Takes data that's been encoded in a JSON-friendly form and returns a form 58 | * with richer datatypes, such as Dates, etc. 59 | * @internal 60 | * @param json - JSON to convert. 61 | */ 62 | export function decode(json: unknown): unknown { 63 | if (json == null) { 64 | return json; 65 | } 66 | if ((json as { [key: string]: unknown })['@type']) { 67 | switch ((json as { [key: string]: unknown })['@type']) { 68 | case LONG_TYPE: 69 | // Fall through and handle this the same as unsigned. 70 | case UNSIGNED_LONG_TYPE: { 71 | // Technically, this could work return a valid number for malformed 72 | // data if there was a number followed by garbage. But it's just not 73 | // worth all the extra code to detect that case. 74 | const value = Number((json as { [key: string]: unknown })['value']); 75 | if (isNaN(value)) { 76 | throw new Error('Data cannot be decoded from JSON: ' + json); 77 | } 78 | return value; 79 | } 80 | default: { 81 | throw new Error('Data cannot be decoded from JSON: ' + json); 82 | } 83 | } 84 | } 85 | if (Array.isArray(json)) { 86 | return json.map(x => decode(x)); 87 | } 88 | if (typeof json === 'function' || typeof json === 'object') { 89 | return mapValues(json!, x => decode(x)); 90 | } 91 | // Anything else is safe to return. 92 | return json; 93 | } 94 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "strict": true, 4 | "esModuleInterop": true, 5 | "target": "es2021", 6 | "module": "nodenext", 7 | "moduleResolution": "nodenext", 8 | "sourceMap": true, 9 | "outDir": "dist", 10 | // required for fireORM 11 | // "experimentalDecorators": true 12 | "allowSyntheticDefaultImports": true 13 | }, 14 | "ts-node": { 15 | // Tell ts-node CLI to install the --loader automatically 16 | "esm": true 17 | }, 18 | "lib": ["es2021"] 19 | } 20 | -------------------------------------------------------------------------------- /tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "defaultSeverity": "error", 3 | "extends": ["tslint:recommended"], 4 | "jsRules": {}, 5 | "rules": {}, 6 | "rulesDirectory": [] 7 | } 8 | --------------------------------------------------------------------------------