├── .github └── dependabot.yml ├── .gitignore ├── LICENSE ├── README.md ├── example ├── .gitignore ├── index.ts ├── package-lock.json ├── package.json └── prisma │ └── schema.prisma ├── package-lock.json ├── package.json ├── src ├── index.ts └── types.ts ├── test ├── main.test.ts └── prisma │ └── schema.prisma └── tsconfig.json /.github/dependabot.yml: -------------------------------------------------------------------------------- 1 | version: 2 2 | updates: 3 | - package-ecosystem: "npm" 4 | directory: "/" 5 | schedule: 6 | interval: "weekly" 7 | time: "04:00" 8 | commit-message: 9 | prefix: "deps" 10 | open-pull-requests-limit: 10 11 | labels: 12 | - "dependencies" 13 | - "automated" 14 | groups: 15 | all-dependencies: 16 | patterns: 17 | - "*" # This groups all dependencies into one PR 18 | # reviewers: 19 | # - "your-github-username" 20 | # assignees: 21 | # - "your-github-username" 22 | # ignore: 23 | # - dependency-name: "example-package" 24 | # versions: ["1.x"] 25 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Dependency directories 2 | node_modules/ 3 | 4 | dist/ 5 | var/ 6 | 7 | # dotenv environment variable files 8 | .env 9 | 10 | *.tgz 11 | dev.db* 12 | .DS_Store 13 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2023 Roberto Sero 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # prisma-extension-cache-manager 2 | 3 | A caching extension for [Prisma](https://www.prisma.io/), compatible with [cache-manager](https://www.npmjs.com/package/cache-manager). 4 | 5 | ## Features 6 | 7 | - [cache-manager](https://www.npmjs.com/package/cache-manager) v6 compatibility 8 | - Only model queries can be cacheable (no $query or $queryRaw) 9 | - Uses [object-code](https://www.npmjs.com/package/object-code) as default key generator, but you can pass a custom one 10 | 11 | Because `cache-manager` needs a `keyv` compatible store, string serialization is mandatory. 12 | `v8` object serialization is good enough to serialize JavaScript native types like `BigInt` or `Date`, 13 | but be aware that it cannot serialize Prisma's `Decimal` type for example. 14 | 15 | ## Installation 16 | 17 | Install: 18 | 19 | ``` 20 | npm i prisma-extension-cache-manager cache-manager cacheable keyv 21 | ``` 22 | 23 | ## Usage 24 | 25 | ```typescript 26 | import v8 from 'node:v8'; 27 | import { PrismaClient } from '@prisma/client'; 28 | import { KeyvCacheableMemory } from 'cacheable'; 29 | import Keyv from 'keyv'; 30 | import * as cm from 'cache-manager'; 31 | import cacheExtension from 'prisma-extension-cache-manager'; 32 | 33 | async function main() { 34 | const cache = cm.createCache({ 35 | ttl: defaultTtl, 36 | stores: [ 37 | new Keyv({ 38 | store: new KeyvCacheableMemory({ ttl: defaultTtl }), 39 | serialize: (x) => v8.serialize(x).toString('base64'), 40 | deserialize: (s) => v8.deserialize(Buffer.from(s, 'base64')), 41 | }), 42 | ], 43 | }); 44 | const prisma = new PrismaClient().$extends(cacheExtension({ cache })); 45 | await prisma.user.findUniqueOrThrow({ 46 | where: { 47 | email: user.email, 48 | }, 49 | cache: true, // using cache default settings 50 | }); 51 | await prisma.user.findMany({ 52 | cache: 5000, // setting ttl in milliseconds 53 | }); 54 | await prisma.user.count({ 55 | cache: { 56 | ttl: 2000, 57 | key: 'user_count', // custom cache key 58 | }, 59 | }); 60 | } 61 | 62 | main().catch(console.error); 63 | ``` 64 | 65 | ## Learn more 66 | 67 | - [Docs — Client extensions](https://www.prisma.io/docs/concepts/components/prisma-client/client-extensions) 68 | - [Docs — Shared extensions](https://www.prisma.io/docs/concepts/components/prisma-client/client-extensions/shared-extensions) 69 | - [Examples](https://github.com/prisma/prisma-client-extensions/tree/main) 70 | - [Preview announcement blog post](https://www.prisma.io/blog/client-extensions-preview-8t3w27xkrxxn#introduction) 71 | -------------------------------------------------------------------------------- /example/.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | # Keep environment variables out of version control 3 | .env 4 | -------------------------------------------------------------------------------- /example/index.ts: -------------------------------------------------------------------------------- 1 | import { PrismaClient } from '@prisma/client'; 2 | import * as cm from 'cache-manager'; 3 | import assert from 'node:assert'; 4 | import cacheExtension from '../dist'; 5 | 6 | async function main() { 7 | const cache = await cm.caching('memory', { 8 | ttl: 1000, 9 | max: 200, 10 | }); 11 | const ext = cacheExtension({ cache }); 12 | const prisma = new PrismaClient().$extends(ext); 13 | assert(prisma.$cache === cache); 14 | await prisma.user.findMany({ 15 | take: 20, 16 | cache: true, 17 | }); 18 | await prisma.user.findUnique({ 19 | where: { 20 | id: 1, 21 | }, 22 | cache: 10 * 1000, 23 | }); 24 | await prisma.user.count({ 25 | where: { 26 | id: { 27 | gt: 0, 28 | }, 29 | }, 30 | cache: { 31 | ttl: 30 * 1000, 32 | key: `user_count_gt_0`, 33 | }, 34 | }); 35 | } 36 | 37 | main().catch(console.error); 38 | -------------------------------------------------------------------------------- /example/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "example", 3 | "lockfileVersion": 3, 4 | "requires": true, 5 | "packages": { 6 | "": { 7 | "name": "example", 8 | "dependencies": { 9 | "@prisma/client": "^5.3.1", 10 | "cache-manager": "^5.2.3" 11 | }, 12 | "devDependencies": { 13 | "@types/node": "^18.18.0", 14 | "npm-run-all": "^4.1.5", 15 | "prisma": "^5.3.1", 16 | "ts-node": "^10.9.1", 17 | "typescript": "^5.2.2" 18 | } 19 | }, 20 | "node_modules/@cspotcode/source-map-support": { 21 | "version": "0.8.1", 22 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 23 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 24 | "dev": true, 25 | "dependencies": { 26 | "@jridgewell/trace-mapping": "0.3.9" 27 | }, 28 | "engines": { 29 | "node": ">=12" 30 | } 31 | }, 32 | "node_modules/@jridgewell/resolve-uri": { 33 | "version": "3.1.1", 34 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz", 35 | "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==", 36 | "dev": true, 37 | "engines": { 38 | "node": ">=6.0.0" 39 | } 40 | }, 41 | "node_modules/@jridgewell/sourcemap-codec": { 42 | "version": "1.4.15", 43 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 44 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 45 | "dev": true 46 | }, 47 | "node_modules/@jridgewell/trace-mapping": { 48 | "version": "0.3.9", 49 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 50 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 51 | "dev": true, 52 | "dependencies": { 53 | "@jridgewell/resolve-uri": "^3.0.3", 54 | "@jridgewell/sourcemap-codec": "^1.4.10" 55 | } 56 | }, 57 | "node_modules/@prisma/client": { 58 | "version": "5.3.1", 59 | "resolved": "https://registry.npmjs.org/@prisma/client/-/client-5.3.1.tgz", 60 | "integrity": "sha512-ArOKjHwdFZIe1cGU56oIfy7wRuTn0FfZjGuU/AjgEBOQh+4rDkB6nF+AGHP8KaVpkBIiHGPQh3IpwQ3xDMdO0Q==", 61 | "hasInstallScript": true, 62 | "dependencies": { 63 | "@prisma/engines-version": "5.3.1-2.61e140623197a131c2a6189271ffee05a7aa9a59" 64 | }, 65 | "engines": { 66 | "node": ">=16.13" 67 | }, 68 | "peerDependencies": { 69 | "prisma": "*" 70 | }, 71 | "peerDependenciesMeta": { 72 | "prisma": { 73 | "optional": true 74 | } 75 | } 76 | }, 77 | "node_modules/@prisma/engines": { 78 | "version": "5.3.1", 79 | "resolved": "https://registry.npmjs.org/@prisma/engines/-/engines-5.3.1.tgz", 80 | "integrity": "sha512-6QkILNyfeeN67BNEPEtkgh3Xo2tm6D7V+UhrkBbRHqKw9CTaz/vvTP/ROwYSP/3JT2MtIutZm/EnhxUiuOPVDA==", 81 | "devOptional": true, 82 | "hasInstallScript": true 83 | }, 84 | "node_modules/@prisma/engines-version": { 85 | "version": "5.3.1-2.61e140623197a131c2a6189271ffee05a7aa9a59", 86 | "resolved": "https://registry.npmjs.org/@prisma/engines-version/-/engines-version-5.3.1-2.61e140623197a131c2a6189271ffee05a7aa9a59.tgz", 87 | "integrity": "sha512-y5qbUi3ql2Xg7XraqcXEdMHh0MocBfnBzDn5GbV1xk23S3Mq8MGs+VjacTNiBh3dtEdUERCrUUG7Z3QaJ+h79w==" 88 | }, 89 | "node_modules/@tsconfig/node10": { 90 | "version": "1.0.9", 91 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz", 92 | "integrity": "sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA==", 93 | "dev": true 94 | }, 95 | "node_modules/@tsconfig/node12": { 96 | "version": "1.0.11", 97 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz", 98 | "integrity": "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==", 99 | "dev": true 100 | }, 101 | "node_modules/@tsconfig/node14": { 102 | "version": "1.0.3", 103 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz", 104 | "integrity": "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==", 105 | "dev": true 106 | }, 107 | "node_modules/@tsconfig/node16": { 108 | "version": "1.0.4", 109 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.4.tgz", 110 | "integrity": "sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA==", 111 | "dev": true 112 | }, 113 | "node_modules/@types/node": { 114 | "version": "18.18.0", 115 | "resolved": "https://registry.npmjs.org/@types/node/-/node-18.18.0.tgz", 116 | "integrity": "sha512-3xA4X31gHT1F1l38ATDIL9GpRLdwVhnEFC8Uikv5ZLlXATwrCYyPq7ZWHxzxc3J/30SUiwiYT+bQe0/XvKlWbw==", 117 | "dev": true 118 | }, 119 | "node_modules/acorn": { 120 | "version": "8.10.0", 121 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz", 122 | "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==", 123 | "dev": true, 124 | "bin": { 125 | "acorn": "bin/acorn" 126 | }, 127 | "engines": { 128 | "node": ">=0.4.0" 129 | } 130 | }, 131 | "node_modules/acorn-walk": { 132 | "version": "8.2.0", 133 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 134 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 135 | "dev": true, 136 | "engines": { 137 | "node": ">=0.4.0" 138 | } 139 | }, 140 | "node_modules/ansi-styles": { 141 | "version": "3.2.1", 142 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 143 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 144 | "dev": true, 145 | "dependencies": { 146 | "color-convert": "^1.9.0" 147 | }, 148 | "engines": { 149 | "node": ">=4" 150 | } 151 | }, 152 | "node_modules/arg": { 153 | "version": "4.1.3", 154 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 155 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 156 | "dev": true 157 | }, 158 | "node_modules/array-buffer-byte-length": { 159 | "version": "1.0.0", 160 | "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz", 161 | "integrity": "sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==", 162 | "dev": true, 163 | "dependencies": { 164 | "call-bind": "^1.0.2", 165 | "is-array-buffer": "^3.0.1" 166 | }, 167 | "funding": { 168 | "url": "https://github.com/sponsors/ljharb" 169 | } 170 | }, 171 | "node_modules/arraybuffer.prototype.slice": { 172 | "version": "1.0.2", 173 | "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.2.tgz", 174 | "integrity": "sha512-yMBKppFur/fbHu9/6USUe03bZ4knMYiwFBcyiaXB8Go0qNehwX6inYPzK9U0NeQvGxKthcmHcaR8P5MStSRBAw==", 175 | "dev": true, 176 | "dependencies": { 177 | "array-buffer-byte-length": "^1.0.0", 178 | "call-bind": "^1.0.2", 179 | "define-properties": "^1.2.0", 180 | "es-abstract": "^1.22.1", 181 | "get-intrinsic": "^1.2.1", 182 | "is-array-buffer": "^3.0.2", 183 | "is-shared-array-buffer": "^1.0.2" 184 | }, 185 | "engines": { 186 | "node": ">= 0.4" 187 | }, 188 | "funding": { 189 | "url": "https://github.com/sponsors/ljharb" 190 | } 191 | }, 192 | "node_modules/available-typed-arrays": { 193 | "version": "1.0.5", 194 | "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz", 195 | "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==", 196 | "dev": true, 197 | "engines": { 198 | "node": ">= 0.4" 199 | }, 200 | "funding": { 201 | "url": "https://github.com/sponsors/ljharb" 202 | } 203 | }, 204 | "node_modules/balanced-match": { 205 | "version": "1.0.2", 206 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 207 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 208 | "dev": true 209 | }, 210 | "node_modules/brace-expansion": { 211 | "version": "1.1.11", 212 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 213 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 214 | "dev": true, 215 | "dependencies": { 216 | "balanced-match": "^1.0.0", 217 | "concat-map": "0.0.1" 218 | } 219 | }, 220 | "node_modules/cache-manager": { 221 | "version": "5.2.3", 222 | "resolved": "https://registry.npmjs.org/cache-manager/-/cache-manager-5.2.3.tgz", 223 | "integrity": "sha512-9OErI8fksFkxAMJ8Mco0aiZSdphyd90HcKiOMJQncSlU1yq/9lHHxrT8PDayxrmr9IIIZPOAEfXuGSD7g29uog==", 224 | "dependencies": { 225 | "lodash.clonedeep": "^4.5.0", 226 | "lru-cache": "^9.1.2" 227 | } 228 | }, 229 | "node_modules/call-bind": { 230 | "version": "1.0.2", 231 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 232 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 233 | "dev": true, 234 | "dependencies": { 235 | "function-bind": "^1.1.1", 236 | "get-intrinsic": "^1.0.2" 237 | }, 238 | "funding": { 239 | "url": "https://github.com/sponsors/ljharb" 240 | } 241 | }, 242 | "node_modules/chalk": { 243 | "version": "2.4.2", 244 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 245 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 246 | "dev": true, 247 | "dependencies": { 248 | "ansi-styles": "^3.2.1", 249 | "escape-string-regexp": "^1.0.5", 250 | "supports-color": "^5.3.0" 251 | }, 252 | "engines": { 253 | "node": ">=4" 254 | } 255 | }, 256 | "node_modules/color-convert": { 257 | "version": "1.9.3", 258 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 259 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 260 | "dev": true, 261 | "dependencies": { 262 | "color-name": "1.1.3" 263 | } 264 | }, 265 | "node_modules/color-name": { 266 | "version": "1.1.3", 267 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 268 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 269 | "dev": true 270 | }, 271 | "node_modules/concat-map": { 272 | "version": "0.0.1", 273 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 274 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 275 | "dev": true 276 | }, 277 | "node_modules/create-require": { 278 | "version": "1.1.1", 279 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 280 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 281 | "dev": true 282 | }, 283 | "node_modules/cross-spawn": { 284 | "version": "6.0.5", 285 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 286 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 287 | "dev": true, 288 | "dependencies": { 289 | "nice-try": "^1.0.4", 290 | "path-key": "^2.0.1", 291 | "semver": "^5.5.0", 292 | "shebang-command": "^1.2.0", 293 | "which": "^1.2.9" 294 | }, 295 | "engines": { 296 | "node": ">=4.8" 297 | } 298 | }, 299 | "node_modules/define-data-property": { 300 | "version": "1.1.0", 301 | "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.0.tgz", 302 | "integrity": "sha512-UzGwzcjyv3OtAvolTj1GoyNYzfFR+iqbGjcnBEENZVCpM4/Ng1yhGNvS3lR/xDS74Tb2wGG9WzNSNIOS9UVb2g==", 303 | "dev": true, 304 | "dependencies": { 305 | "get-intrinsic": "^1.2.1", 306 | "gopd": "^1.0.1", 307 | "has-property-descriptors": "^1.0.0" 308 | }, 309 | "engines": { 310 | "node": ">= 0.4" 311 | } 312 | }, 313 | "node_modules/define-properties": { 314 | "version": "1.2.1", 315 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", 316 | "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", 317 | "dev": true, 318 | "dependencies": { 319 | "define-data-property": "^1.0.1", 320 | "has-property-descriptors": "^1.0.0", 321 | "object-keys": "^1.1.1" 322 | }, 323 | "engines": { 324 | "node": ">= 0.4" 325 | }, 326 | "funding": { 327 | "url": "https://github.com/sponsors/ljharb" 328 | } 329 | }, 330 | "node_modules/diff": { 331 | "version": "4.0.2", 332 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 333 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 334 | "dev": true, 335 | "engines": { 336 | "node": ">=0.3.1" 337 | } 338 | }, 339 | "node_modules/error-ex": { 340 | "version": "1.3.2", 341 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 342 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 343 | "dev": true, 344 | "dependencies": { 345 | "is-arrayish": "^0.2.1" 346 | } 347 | }, 348 | "node_modules/es-abstract": { 349 | "version": "1.22.2", 350 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.2.tgz", 351 | "integrity": "sha512-YoxfFcDmhjOgWPWsV13+2RNjq1F6UQnfs+8TftwNqtzlmFzEXvlUwdrNrYeaizfjQzRMxkZ6ElWMOJIFKdVqwA==", 352 | "dev": true, 353 | "dependencies": { 354 | "array-buffer-byte-length": "^1.0.0", 355 | "arraybuffer.prototype.slice": "^1.0.2", 356 | "available-typed-arrays": "^1.0.5", 357 | "call-bind": "^1.0.2", 358 | "es-set-tostringtag": "^2.0.1", 359 | "es-to-primitive": "^1.2.1", 360 | "function.prototype.name": "^1.1.6", 361 | "get-intrinsic": "^1.2.1", 362 | "get-symbol-description": "^1.0.0", 363 | "globalthis": "^1.0.3", 364 | "gopd": "^1.0.1", 365 | "has": "^1.0.3", 366 | "has-property-descriptors": "^1.0.0", 367 | "has-proto": "^1.0.1", 368 | "has-symbols": "^1.0.3", 369 | "internal-slot": "^1.0.5", 370 | "is-array-buffer": "^3.0.2", 371 | "is-callable": "^1.2.7", 372 | "is-negative-zero": "^2.0.2", 373 | "is-regex": "^1.1.4", 374 | "is-shared-array-buffer": "^1.0.2", 375 | "is-string": "^1.0.7", 376 | "is-typed-array": "^1.1.12", 377 | "is-weakref": "^1.0.2", 378 | "object-inspect": "^1.12.3", 379 | "object-keys": "^1.1.1", 380 | "object.assign": "^4.1.4", 381 | "regexp.prototype.flags": "^1.5.1", 382 | "safe-array-concat": "^1.0.1", 383 | "safe-regex-test": "^1.0.0", 384 | "string.prototype.trim": "^1.2.8", 385 | "string.prototype.trimend": "^1.0.7", 386 | "string.prototype.trimstart": "^1.0.7", 387 | "typed-array-buffer": "^1.0.0", 388 | "typed-array-byte-length": "^1.0.0", 389 | "typed-array-byte-offset": "^1.0.0", 390 | "typed-array-length": "^1.0.4", 391 | "unbox-primitive": "^1.0.2", 392 | "which-typed-array": "^1.1.11" 393 | }, 394 | "engines": { 395 | "node": ">= 0.4" 396 | }, 397 | "funding": { 398 | "url": "https://github.com/sponsors/ljharb" 399 | } 400 | }, 401 | "node_modules/es-set-tostringtag": { 402 | "version": "2.0.1", 403 | "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.1.tgz", 404 | "integrity": "sha512-g3OMbtlwY3QewlqAiMLI47KywjWZoEytKr8pf6iTC8uJq5bIAH52Z9pnQ8pVL6whrCto53JZDuUIsifGeLorTg==", 405 | "dev": true, 406 | "dependencies": { 407 | "get-intrinsic": "^1.1.3", 408 | "has": "^1.0.3", 409 | "has-tostringtag": "^1.0.0" 410 | }, 411 | "engines": { 412 | "node": ">= 0.4" 413 | } 414 | }, 415 | "node_modules/es-to-primitive": { 416 | "version": "1.2.1", 417 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 418 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 419 | "dev": true, 420 | "dependencies": { 421 | "is-callable": "^1.1.4", 422 | "is-date-object": "^1.0.1", 423 | "is-symbol": "^1.0.2" 424 | }, 425 | "engines": { 426 | "node": ">= 0.4" 427 | }, 428 | "funding": { 429 | "url": "https://github.com/sponsors/ljharb" 430 | } 431 | }, 432 | "node_modules/escape-string-regexp": { 433 | "version": "1.0.5", 434 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 435 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 436 | "dev": true, 437 | "engines": { 438 | "node": ">=0.8.0" 439 | } 440 | }, 441 | "node_modules/for-each": { 442 | "version": "0.3.3", 443 | "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", 444 | "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", 445 | "dev": true, 446 | "dependencies": { 447 | "is-callable": "^1.1.3" 448 | } 449 | }, 450 | "node_modules/function-bind": { 451 | "version": "1.1.1", 452 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 453 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 454 | "dev": true 455 | }, 456 | "node_modules/function.prototype.name": { 457 | "version": "1.1.6", 458 | "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", 459 | "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", 460 | "dev": true, 461 | "dependencies": { 462 | "call-bind": "^1.0.2", 463 | "define-properties": "^1.2.0", 464 | "es-abstract": "^1.22.1", 465 | "functions-have-names": "^1.2.3" 466 | }, 467 | "engines": { 468 | "node": ">= 0.4" 469 | }, 470 | "funding": { 471 | "url": "https://github.com/sponsors/ljharb" 472 | } 473 | }, 474 | "node_modules/functions-have-names": { 475 | "version": "1.2.3", 476 | "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", 477 | "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", 478 | "dev": true, 479 | "funding": { 480 | "url": "https://github.com/sponsors/ljharb" 481 | } 482 | }, 483 | "node_modules/get-intrinsic": { 484 | "version": "1.2.1", 485 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", 486 | "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", 487 | "dev": true, 488 | "dependencies": { 489 | "function-bind": "^1.1.1", 490 | "has": "^1.0.3", 491 | "has-proto": "^1.0.1", 492 | "has-symbols": "^1.0.3" 493 | }, 494 | "funding": { 495 | "url": "https://github.com/sponsors/ljharb" 496 | } 497 | }, 498 | "node_modules/get-symbol-description": { 499 | "version": "1.0.0", 500 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", 501 | "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", 502 | "dev": true, 503 | "dependencies": { 504 | "call-bind": "^1.0.2", 505 | "get-intrinsic": "^1.1.1" 506 | }, 507 | "engines": { 508 | "node": ">= 0.4" 509 | }, 510 | "funding": { 511 | "url": "https://github.com/sponsors/ljharb" 512 | } 513 | }, 514 | "node_modules/globalthis": { 515 | "version": "1.0.3", 516 | "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", 517 | "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", 518 | "dev": true, 519 | "dependencies": { 520 | "define-properties": "^1.1.3" 521 | }, 522 | "engines": { 523 | "node": ">= 0.4" 524 | }, 525 | "funding": { 526 | "url": "https://github.com/sponsors/ljharb" 527 | } 528 | }, 529 | "node_modules/gopd": { 530 | "version": "1.0.1", 531 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", 532 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", 533 | "dev": true, 534 | "dependencies": { 535 | "get-intrinsic": "^1.1.3" 536 | }, 537 | "funding": { 538 | "url": "https://github.com/sponsors/ljharb" 539 | } 540 | }, 541 | "node_modules/graceful-fs": { 542 | "version": "4.2.11", 543 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 544 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", 545 | "dev": true 546 | }, 547 | "node_modules/has": { 548 | "version": "1.0.3", 549 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 550 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 551 | "dev": true, 552 | "dependencies": { 553 | "function-bind": "^1.1.1" 554 | }, 555 | "engines": { 556 | "node": ">= 0.4.0" 557 | } 558 | }, 559 | "node_modules/has-bigints": { 560 | "version": "1.0.2", 561 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", 562 | "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", 563 | "dev": true, 564 | "funding": { 565 | "url": "https://github.com/sponsors/ljharb" 566 | } 567 | }, 568 | "node_modules/has-flag": { 569 | "version": "3.0.0", 570 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 571 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 572 | "dev": true, 573 | "engines": { 574 | "node": ">=4" 575 | } 576 | }, 577 | "node_modules/has-property-descriptors": { 578 | "version": "1.0.0", 579 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz", 580 | "integrity": "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==", 581 | "dev": true, 582 | "dependencies": { 583 | "get-intrinsic": "^1.1.1" 584 | }, 585 | "funding": { 586 | "url": "https://github.com/sponsors/ljharb" 587 | } 588 | }, 589 | "node_modules/has-proto": { 590 | "version": "1.0.1", 591 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", 592 | "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", 593 | "dev": true, 594 | "engines": { 595 | "node": ">= 0.4" 596 | }, 597 | "funding": { 598 | "url": "https://github.com/sponsors/ljharb" 599 | } 600 | }, 601 | "node_modules/has-symbols": { 602 | "version": "1.0.3", 603 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 604 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 605 | "dev": true, 606 | "engines": { 607 | "node": ">= 0.4" 608 | }, 609 | "funding": { 610 | "url": "https://github.com/sponsors/ljharb" 611 | } 612 | }, 613 | "node_modules/has-tostringtag": { 614 | "version": "1.0.0", 615 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", 616 | "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", 617 | "dev": true, 618 | "dependencies": { 619 | "has-symbols": "^1.0.2" 620 | }, 621 | "engines": { 622 | "node": ">= 0.4" 623 | }, 624 | "funding": { 625 | "url": "https://github.com/sponsors/ljharb" 626 | } 627 | }, 628 | "node_modules/hosted-git-info": { 629 | "version": "2.8.9", 630 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", 631 | "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==", 632 | "dev": true 633 | }, 634 | "node_modules/internal-slot": { 635 | "version": "1.0.5", 636 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.5.tgz", 637 | "integrity": "sha512-Y+R5hJrzs52QCG2laLn4udYVnxsfny9CpOhNhUvk/SSSVyF6T27FzRbF0sroPidSu3X8oEAkOn2K804mjpt6UQ==", 638 | "dev": true, 639 | "dependencies": { 640 | "get-intrinsic": "^1.2.0", 641 | "has": "^1.0.3", 642 | "side-channel": "^1.0.4" 643 | }, 644 | "engines": { 645 | "node": ">= 0.4" 646 | } 647 | }, 648 | "node_modules/is-array-buffer": { 649 | "version": "3.0.2", 650 | "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.2.tgz", 651 | "integrity": "sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==", 652 | "dev": true, 653 | "dependencies": { 654 | "call-bind": "^1.0.2", 655 | "get-intrinsic": "^1.2.0", 656 | "is-typed-array": "^1.1.10" 657 | }, 658 | "funding": { 659 | "url": "https://github.com/sponsors/ljharb" 660 | } 661 | }, 662 | "node_modules/is-arrayish": { 663 | "version": "0.2.1", 664 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 665 | "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", 666 | "dev": true 667 | }, 668 | "node_modules/is-bigint": { 669 | "version": "1.0.4", 670 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 671 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 672 | "dev": true, 673 | "dependencies": { 674 | "has-bigints": "^1.0.1" 675 | }, 676 | "funding": { 677 | "url": "https://github.com/sponsors/ljharb" 678 | } 679 | }, 680 | "node_modules/is-boolean-object": { 681 | "version": "1.1.2", 682 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 683 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 684 | "dev": true, 685 | "dependencies": { 686 | "call-bind": "^1.0.2", 687 | "has-tostringtag": "^1.0.0" 688 | }, 689 | "engines": { 690 | "node": ">= 0.4" 691 | }, 692 | "funding": { 693 | "url": "https://github.com/sponsors/ljharb" 694 | } 695 | }, 696 | "node_modules/is-callable": { 697 | "version": "1.2.7", 698 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", 699 | "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", 700 | "dev": true, 701 | "engines": { 702 | "node": ">= 0.4" 703 | }, 704 | "funding": { 705 | "url": "https://github.com/sponsors/ljharb" 706 | } 707 | }, 708 | "node_modules/is-core-module": { 709 | "version": "2.13.0", 710 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.0.tgz", 711 | "integrity": "sha512-Z7dk6Qo8pOCp3l4tsX2C5ZVas4V+UxwQodwZhLopL91TX8UyyHEXafPcyoeeWuLrwzHcr3igO78wNLwHJHsMCQ==", 712 | "dev": true, 713 | "dependencies": { 714 | "has": "^1.0.3" 715 | }, 716 | "funding": { 717 | "url": "https://github.com/sponsors/ljharb" 718 | } 719 | }, 720 | "node_modules/is-date-object": { 721 | "version": "1.0.5", 722 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 723 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 724 | "dev": true, 725 | "dependencies": { 726 | "has-tostringtag": "^1.0.0" 727 | }, 728 | "engines": { 729 | "node": ">= 0.4" 730 | }, 731 | "funding": { 732 | "url": "https://github.com/sponsors/ljharb" 733 | } 734 | }, 735 | "node_modules/is-negative-zero": { 736 | "version": "2.0.2", 737 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", 738 | "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", 739 | "dev": true, 740 | "engines": { 741 | "node": ">= 0.4" 742 | }, 743 | "funding": { 744 | "url": "https://github.com/sponsors/ljharb" 745 | } 746 | }, 747 | "node_modules/is-number-object": { 748 | "version": "1.0.7", 749 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", 750 | "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", 751 | "dev": true, 752 | "dependencies": { 753 | "has-tostringtag": "^1.0.0" 754 | }, 755 | "engines": { 756 | "node": ">= 0.4" 757 | }, 758 | "funding": { 759 | "url": "https://github.com/sponsors/ljharb" 760 | } 761 | }, 762 | "node_modules/is-regex": { 763 | "version": "1.1.4", 764 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 765 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 766 | "dev": true, 767 | "dependencies": { 768 | "call-bind": "^1.0.2", 769 | "has-tostringtag": "^1.0.0" 770 | }, 771 | "engines": { 772 | "node": ">= 0.4" 773 | }, 774 | "funding": { 775 | "url": "https://github.com/sponsors/ljharb" 776 | } 777 | }, 778 | "node_modules/is-shared-array-buffer": { 779 | "version": "1.0.2", 780 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz", 781 | "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==", 782 | "dev": true, 783 | "dependencies": { 784 | "call-bind": "^1.0.2" 785 | }, 786 | "funding": { 787 | "url": "https://github.com/sponsors/ljharb" 788 | } 789 | }, 790 | "node_modules/is-string": { 791 | "version": "1.0.7", 792 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 793 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 794 | "dev": true, 795 | "dependencies": { 796 | "has-tostringtag": "^1.0.0" 797 | }, 798 | "engines": { 799 | "node": ">= 0.4" 800 | }, 801 | "funding": { 802 | "url": "https://github.com/sponsors/ljharb" 803 | } 804 | }, 805 | "node_modules/is-symbol": { 806 | "version": "1.0.4", 807 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 808 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 809 | "dev": true, 810 | "dependencies": { 811 | "has-symbols": "^1.0.2" 812 | }, 813 | "engines": { 814 | "node": ">= 0.4" 815 | }, 816 | "funding": { 817 | "url": "https://github.com/sponsors/ljharb" 818 | } 819 | }, 820 | "node_modules/is-typed-array": { 821 | "version": "1.1.12", 822 | "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.12.tgz", 823 | "integrity": "sha512-Z14TF2JNG8Lss5/HMqt0//T9JeHXttXy5pH/DBU4vi98ozO2btxzq9MwYDZYnKwU8nRsz/+GVFVRDq3DkVuSPg==", 824 | "dev": true, 825 | "dependencies": { 826 | "which-typed-array": "^1.1.11" 827 | }, 828 | "engines": { 829 | "node": ">= 0.4" 830 | }, 831 | "funding": { 832 | "url": "https://github.com/sponsors/ljharb" 833 | } 834 | }, 835 | "node_modules/is-weakref": { 836 | "version": "1.0.2", 837 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", 838 | "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", 839 | "dev": true, 840 | "dependencies": { 841 | "call-bind": "^1.0.2" 842 | }, 843 | "funding": { 844 | "url": "https://github.com/sponsors/ljharb" 845 | } 846 | }, 847 | "node_modules/isarray": { 848 | "version": "2.0.5", 849 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", 850 | "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", 851 | "dev": true 852 | }, 853 | "node_modules/isexe": { 854 | "version": "2.0.0", 855 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 856 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 857 | "dev": true 858 | }, 859 | "node_modules/json-parse-better-errors": { 860 | "version": "1.0.2", 861 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 862 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 863 | "dev": true 864 | }, 865 | "node_modules/load-json-file": { 866 | "version": "4.0.0", 867 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 868 | "integrity": "sha512-Kx8hMakjX03tiGTLAIdJ+lL0htKnXjEZN6hk/tozf/WOuYGdZBJrZ+rCJRbVCugsjB3jMLn9746NsQIf5VjBMw==", 869 | "dev": true, 870 | "dependencies": { 871 | "graceful-fs": "^4.1.2", 872 | "parse-json": "^4.0.0", 873 | "pify": "^3.0.0", 874 | "strip-bom": "^3.0.0" 875 | }, 876 | "engines": { 877 | "node": ">=4" 878 | } 879 | }, 880 | "node_modules/lodash.clonedeep": { 881 | "version": "4.5.0", 882 | "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", 883 | "integrity": "sha512-H5ZhCF25riFd9uB5UCkVKo61m3S/xZk1x4wA6yp/L3RFP6Z/eHH1ymQcGLo7J3GMPfm0V/7m1tryHuGVxpqEBQ==" 884 | }, 885 | "node_modules/lru-cache": { 886 | "version": "9.1.2", 887 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-9.1.2.tgz", 888 | "integrity": "sha512-ERJq3FOzJTxBbFjZ7iDs+NiK4VI9Wz+RdrrAB8dio1oV+YvdPzUEE4QNiT2VD51DkIbCYRUUzCRkssXCHqSnKQ==", 889 | "engines": { 890 | "node": "14 || >=16.14" 891 | } 892 | }, 893 | "node_modules/make-error": { 894 | "version": "1.3.6", 895 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 896 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 897 | "dev": true 898 | }, 899 | "node_modules/memorystream": { 900 | "version": "0.3.1", 901 | "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", 902 | "integrity": "sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw==", 903 | "dev": true, 904 | "engines": { 905 | "node": ">= 0.10.0" 906 | } 907 | }, 908 | "node_modules/minimatch": { 909 | "version": "3.1.2", 910 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 911 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 912 | "dev": true, 913 | "dependencies": { 914 | "brace-expansion": "^1.1.7" 915 | }, 916 | "engines": { 917 | "node": "*" 918 | } 919 | }, 920 | "node_modules/nice-try": { 921 | "version": "1.0.5", 922 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 923 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 924 | "dev": true 925 | }, 926 | "node_modules/normalize-package-data": { 927 | "version": "2.5.0", 928 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 929 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 930 | "dev": true, 931 | "dependencies": { 932 | "hosted-git-info": "^2.1.4", 933 | "resolve": "^1.10.0", 934 | "semver": "2 || 3 || 4 || 5", 935 | "validate-npm-package-license": "^3.0.1" 936 | } 937 | }, 938 | "node_modules/npm-run-all": { 939 | "version": "4.1.5", 940 | "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", 941 | "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", 942 | "dev": true, 943 | "dependencies": { 944 | "ansi-styles": "^3.2.1", 945 | "chalk": "^2.4.1", 946 | "cross-spawn": "^6.0.5", 947 | "memorystream": "^0.3.1", 948 | "minimatch": "^3.0.4", 949 | "pidtree": "^0.3.0", 950 | "read-pkg": "^3.0.0", 951 | "shell-quote": "^1.6.1", 952 | "string.prototype.padend": "^3.0.0" 953 | }, 954 | "bin": { 955 | "npm-run-all": "bin/npm-run-all/index.js", 956 | "run-p": "bin/run-p/index.js", 957 | "run-s": "bin/run-s/index.js" 958 | }, 959 | "engines": { 960 | "node": ">= 4" 961 | } 962 | }, 963 | "node_modules/object-inspect": { 964 | "version": "1.12.3", 965 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 966 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==", 967 | "dev": true, 968 | "funding": { 969 | "url": "https://github.com/sponsors/ljharb" 970 | } 971 | }, 972 | "node_modules/object-keys": { 973 | "version": "1.1.1", 974 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 975 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 976 | "dev": true, 977 | "engines": { 978 | "node": ">= 0.4" 979 | } 980 | }, 981 | "node_modules/object.assign": { 982 | "version": "4.1.4", 983 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.4.tgz", 984 | "integrity": "sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ==", 985 | "dev": true, 986 | "dependencies": { 987 | "call-bind": "^1.0.2", 988 | "define-properties": "^1.1.4", 989 | "has-symbols": "^1.0.3", 990 | "object-keys": "^1.1.1" 991 | }, 992 | "engines": { 993 | "node": ">= 0.4" 994 | }, 995 | "funding": { 996 | "url": "https://github.com/sponsors/ljharb" 997 | } 998 | }, 999 | "node_modules/parse-json": { 1000 | "version": "4.0.0", 1001 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 1002 | "integrity": "sha512-aOIos8bujGN93/8Ox/jPLh7RwVnPEysynVFE+fQZyg6jKELEHwzgKdLRFHUgXJL6kylijVSBC4BvN9OmsB48Rw==", 1003 | "dev": true, 1004 | "dependencies": { 1005 | "error-ex": "^1.3.1", 1006 | "json-parse-better-errors": "^1.0.1" 1007 | }, 1008 | "engines": { 1009 | "node": ">=4" 1010 | } 1011 | }, 1012 | "node_modules/path-key": { 1013 | "version": "2.0.1", 1014 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1015 | "integrity": "sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw==", 1016 | "dev": true, 1017 | "engines": { 1018 | "node": ">=4" 1019 | } 1020 | }, 1021 | "node_modules/path-parse": { 1022 | "version": "1.0.7", 1023 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1024 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1025 | "dev": true 1026 | }, 1027 | "node_modules/path-type": { 1028 | "version": "3.0.0", 1029 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", 1030 | "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", 1031 | "dev": true, 1032 | "dependencies": { 1033 | "pify": "^3.0.0" 1034 | }, 1035 | "engines": { 1036 | "node": ">=4" 1037 | } 1038 | }, 1039 | "node_modules/pidtree": { 1040 | "version": "0.3.1", 1041 | "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.1.tgz", 1042 | "integrity": "sha512-qQbW94hLHEqCg7nhby4yRC7G2+jYHY4Rguc2bjw7Uug4GIJuu1tvf2uHaZv5Q8zdt+WKJ6qK1FOI6amaWUo5FA==", 1043 | "dev": true, 1044 | "bin": { 1045 | "pidtree": "bin/pidtree.js" 1046 | }, 1047 | "engines": { 1048 | "node": ">=0.10" 1049 | } 1050 | }, 1051 | "node_modules/pify": { 1052 | "version": "3.0.0", 1053 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 1054 | "integrity": "sha512-C3FsVNH1udSEX48gGX1xfvwTWfsYWj5U+8/uK15BGzIGrKoUpghX8hWZwa/OFnakBiiVNmBvemTJR5mcy7iPcg==", 1055 | "dev": true, 1056 | "engines": { 1057 | "node": ">=4" 1058 | } 1059 | }, 1060 | "node_modules/prisma": { 1061 | "version": "5.3.1", 1062 | "resolved": "https://registry.npmjs.org/prisma/-/prisma-5.3.1.tgz", 1063 | "integrity": "sha512-Wp2msQIlMPHe+5k5Od6xnsI/WNG7UJGgFUJgqv/ygc7kOECZapcSz/iU4NIEzISs3H1W9sFLjAPbg/gOqqtB7A==", 1064 | "devOptional": true, 1065 | "hasInstallScript": true, 1066 | "dependencies": { 1067 | "@prisma/engines": "5.3.1" 1068 | }, 1069 | "bin": { 1070 | "prisma": "build/index.js" 1071 | }, 1072 | "engines": { 1073 | "node": ">=16.13" 1074 | } 1075 | }, 1076 | "node_modules/read-pkg": { 1077 | "version": "3.0.0", 1078 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", 1079 | "integrity": "sha512-BLq/cCO9two+lBgiTYNqD6GdtK8s4NpaWrl6/rCO9w0TUS8oJl7cmToOZfRYllKTISY6nt1U7jQ53brmKqY6BA==", 1080 | "dev": true, 1081 | "dependencies": { 1082 | "load-json-file": "^4.0.0", 1083 | "normalize-package-data": "^2.3.2", 1084 | "path-type": "^3.0.0" 1085 | }, 1086 | "engines": { 1087 | "node": ">=4" 1088 | } 1089 | }, 1090 | "node_modules/regexp.prototype.flags": { 1091 | "version": "1.5.1", 1092 | "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz", 1093 | "integrity": "sha512-sy6TXMN+hnP/wMy+ISxg3krXx7BAtWVO4UouuCN/ziM9UEne0euamVNafDfvC83bRNr95y0V5iijeDQFUNpvrg==", 1094 | "dev": true, 1095 | "dependencies": { 1096 | "call-bind": "^1.0.2", 1097 | "define-properties": "^1.2.0", 1098 | "set-function-name": "^2.0.0" 1099 | }, 1100 | "engines": { 1101 | "node": ">= 0.4" 1102 | }, 1103 | "funding": { 1104 | "url": "https://github.com/sponsors/ljharb" 1105 | } 1106 | }, 1107 | "node_modules/resolve": { 1108 | "version": "1.22.6", 1109 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.6.tgz", 1110 | "integrity": "sha512-njhxM7mV12JfufShqGy3Rz8j11RPdLy4xi15UurGJeoHLfJpVXKdh3ueuOqbYUcDZnffr6X739JBo5LzyahEsw==", 1111 | "dev": true, 1112 | "dependencies": { 1113 | "is-core-module": "^2.13.0", 1114 | "path-parse": "^1.0.7", 1115 | "supports-preserve-symlinks-flag": "^1.0.0" 1116 | }, 1117 | "bin": { 1118 | "resolve": "bin/resolve" 1119 | }, 1120 | "funding": { 1121 | "url": "https://github.com/sponsors/ljharb" 1122 | } 1123 | }, 1124 | "node_modules/safe-array-concat": { 1125 | "version": "1.0.1", 1126 | "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.0.1.tgz", 1127 | "integrity": "sha512-6XbUAseYE2KtOuGueyeobCySj9L4+66Tn6KQMOPQJrAJEowYKW/YR/MGJZl7FdydUdaFu4LYyDZjxf4/Nmo23Q==", 1128 | "dev": true, 1129 | "dependencies": { 1130 | "call-bind": "^1.0.2", 1131 | "get-intrinsic": "^1.2.1", 1132 | "has-symbols": "^1.0.3", 1133 | "isarray": "^2.0.5" 1134 | }, 1135 | "engines": { 1136 | "node": ">=0.4" 1137 | }, 1138 | "funding": { 1139 | "url": "https://github.com/sponsors/ljharb" 1140 | } 1141 | }, 1142 | "node_modules/safe-regex-test": { 1143 | "version": "1.0.0", 1144 | "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.0.tgz", 1145 | "integrity": "sha512-JBUUzyOgEwXQY1NuPtvcj/qcBDbDmEvWufhlnXZIm75DEHp+afM1r1ujJpJsV/gSM4t59tpDyPi1sd6ZaPFfsA==", 1146 | "dev": true, 1147 | "dependencies": { 1148 | "call-bind": "^1.0.2", 1149 | "get-intrinsic": "^1.1.3", 1150 | "is-regex": "^1.1.4" 1151 | }, 1152 | "funding": { 1153 | "url": "https://github.com/sponsors/ljharb" 1154 | } 1155 | }, 1156 | "node_modules/semver": { 1157 | "version": "5.7.2", 1158 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", 1159 | "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", 1160 | "dev": true, 1161 | "bin": { 1162 | "semver": "bin/semver" 1163 | } 1164 | }, 1165 | "node_modules/set-function-name": { 1166 | "version": "2.0.1", 1167 | "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.1.tgz", 1168 | "integrity": "sha512-tMNCiqYVkXIZgc2Hnoy2IvC/f8ezc5koaRFkCjrpWzGpCd3qbZXPzVy9MAZzK1ch/X0jvSkojys3oqJN0qCmdA==", 1169 | "dev": true, 1170 | "dependencies": { 1171 | "define-data-property": "^1.0.1", 1172 | "functions-have-names": "^1.2.3", 1173 | "has-property-descriptors": "^1.0.0" 1174 | }, 1175 | "engines": { 1176 | "node": ">= 0.4" 1177 | } 1178 | }, 1179 | "node_modules/shebang-command": { 1180 | "version": "1.2.0", 1181 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1182 | "integrity": "sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg==", 1183 | "dev": true, 1184 | "dependencies": { 1185 | "shebang-regex": "^1.0.0" 1186 | }, 1187 | "engines": { 1188 | "node": ">=0.10.0" 1189 | } 1190 | }, 1191 | "node_modules/shebang-regex": { 1192 | "version": "1.0.0", 1193 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1194 | "integrity": "sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ==", 1195 | "dev": true, 1196 | "engines": { 1197 | "node": ">=0.10.0" 1198 | } 1199 | }, 1200 | "node_modules/shell-quote": { 1201 | "version": "1.8.1", 1202 | "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.8.1.tgz", 1203 | "integrity": "sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==", 1204 | "dev": true, 1205 | "funding": { 1206 | "url": "https://github.com/sponsors/ljharb" 1207 | } 1208 | }, 1209 | "node_modules/side-channel": { 1210 | "version": "1.0.4", 1211 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1212 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1213 | "dev": true, 1214 | "dependencies": { 1215 | "call-bind": "^1.0.0", 1216 | "get-intrinsic": "^1.0.2", 1217 | "object-inspect": "^1.9.0" 1218 | }, 1219 | "funding": { 1220 | "url": "https://github.com/sponsors/ljharb" 1221 | } 1222 | }, 1223 | "node_modules/spdx-correct": { 1224 | "version": "3.2.0", 1225 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz", 1226 | "integrity": "sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==", 1227 | "dev": true, 1228 | "dependencies": { 1229 | "spdx-expression-parse": "^3.0.0", 1230 | "spdx-license-ids": "^3.0.0" 1231 | } 1232 | }, 1233 | "node_modules/spdx-exceptions": { 1234 | "version": "2.3.0", 1235 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 1236 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", 1237 | "dev": true 1238 | }, 1239 | "node_modules/spdx-expression-parse": { 1240 | "version": "3.0.1", 1241 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 1242 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 1243 | "dev": true, 1244 | "dependencies": { 1245 | "spdx-exceptions": "^2.1.0", 1246 | "spdx-license-ids": "^3.0.0" 1247 | } 1248 | }, 1249 | "node_modules/spdx-license-ids": { 1250 | "version": "3.0.15", 1251 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.15.tgz", 1252 | "integrity": "sha512-lpT8hSQp9jAKp9mhtBU4Xjon8LPGBvLIuBiSVhMEtmLecTh2mO0tlqrAMp47tBXzMr13NJMQ2lf7RpQGLJ3HsQ==", 1253 | "dev": true 1254 | }, 1255 | "node_modules/string.prototype.padend": { 1256 | "version": "3.1.5", 1257 | "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.5.tgz", 1258 | "integrity": "sha512-DOB27b/2UTTD+4myKUFh+/fXWcu/UDyASIXfg+7VzoCNNGOfWvoyU/x5pvVHr++ztyt/oSYI1BcWBBG/hmlNjA==", 1259 | "dev": true, 1260 | "dependencies": { 1261 | "call-bind": "^1.0.2", 1262 | "define-properties": "^1.2.0", 1263 | "es-abstract": "^1.22.1" 1264 | }, 1265 | "engines": { 1266 | "node": ">= 0.4" 1267 | }, 1268 | "funding": { 1269 | "url": "https://github.com/sponsors/ljharb" 1270 | } 1271 | }, 1272 | "node_modules/string.prototype.trim": { 1273 | "version": "1.2.8", 1274 | "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz", 1275 | "integrity": "sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==", 1276 | "dev": true, 1277 | "dependencies": { 1278 | "call-bind": "^1.0.2", 1279 | "define-properties": "^1.2.0", 1280 | "es-abstract": "^1.22.1" 1281 | }, 1282 | "engines": { 1283 | "node": ">= 0.4" 1284 | }, 1285 | "funding": { 1286 | "url": "https://github.com/sponsors/ljharb" 1287 | } 1288 | }, 1289 | "node_modules/string.prototype.trimend": { 1290 | "version": "1.0.7", 1291 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz", 1292 | "integrity": "sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==", 1293 | "dev": true, 1294 | "dependencies": { 1295 | "call-bind": "^1.0.2", 1296 | "define-properties": "^1.2.0", 1297 | "es-abstract": "^1.22.1" 1298 | }, 1299 | "funding": { 1300 | "url": "https://github.com/sponsors/ljharb" 1301 | } 1302 | }, 1303 | "node_modules/string.prototype.trimstart": { 1304 | "version": "1.0.7", 1305 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz", 1306 | "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==", 1307 | "dev": true, 1308 | "dependencies": { 1309 | "call-bind": "^1.0.2", 1310 | "define-properties": "^1.2.0", 1311 | "es-abstract": "^1.22.1" 1312 | }, 1313 | "funding": { 1314 | "url": "https://github.com/sponsors/ljharb" 1315 | } 1316 | }, 1317 | "node_modules/strip-bom": { 1318 | "version": "3.0.0", 1319 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1320 | "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", 1321 | "dev": true, 1322 | "engines": { 1323 | "node": ">=4" 1324 | } 1325 | }, 1326 | "node_modules/supports-color": { 1327 | "version": "5.5.0", 1328 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1329 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1330 | "dev": true, 1331 | "dependencies": { 1332 | "has-flag": "^3.0.0" 1333 | }, 1334 | "engines": { 1335 | "node": ">=4" 1336 | } 1337 | }, 1338 | "node_modules/supports-preserve-symlinks-flag": { 1339 | "version": "1.0.0", 1340 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1341 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1342 | "dev": true, 1343 | "engines": { 1344 | "node": ">= 0.4" 1345 | }, 1346 | "funding": { 1347 | "url": "https://github.com/sponsors/ljharb" 1348 | } 1349 | }, 1350 | "node_modules/ts-node": { 1351 | "version": "10.9.1", 1352 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.1.tgz", 1353 | "integrity": "sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw==", 1354 | "dev": true, 1355 | "dependencies": { 1356 | "@cspotcode/source-map-support": "^0.8.0", 1357 | "@tsconfig/node10": "^1.0.7", 1358 | "@tsconfig/node12": "^1.0.7", 1359 | "@tsconfig/node14": "^1.0.0", 1360 | "@tsconfig/node16": "^1.0.2", 1361 | "acorn": "^8.4.1", 1362 | "acorn-walk": "^8.1.1", 1363 | "arg": "^4.1.0", 1364 | "create-require": "^1.1.0", 1365 | "diff": "^4.0.1", 1366 | "make-error": "^1.1.1", 1367 | "v8-compile-cache-lib": "^3.0.1", 1368 | "yn": "3.1.1" 1369 | }, 1370 | "bin": { 1371 | "ts-node": "dist/bin.js", 1372 | "ts-node-cwd": "dist/bin-cwd.js", 1373 | "ts-node-esm": "dist/bin-esm.js", 1374 | "ts-node-script": "dist/bin-script.js", 1375 | "ts-node-transpile-only": "dist/bin-transpile.js", 1376 | "ts-script": "dist/bin-script-deprecated.js" 1377 | }, 1378 | "peerDependencies": { 1379 | "@swc/core": ">=1.2.50", 1380 | "@swc/wasm": ">=1.2.50", 1381 | "@types/node": "*", 1382 | "typescript": ">=2.7" 1383 | }, 1384 | "peerDependenciesMeta": { 1385 | "@swc/core": { 1386 | "optional": true 1387 | }, 1388 | "@swc/wasm": { 1389 | "optional": true 1390 | } 1391 | } 1392 | }, 1393 | "node_modules/typed-array-buffer": { 1394 | "version": "1.0.0", 1395 | "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.0.tgz", 1396 | "integrity": "sha512-Y8KTSIglk9OZEr8zywiIHG/kmQ7KWyjseXs1CbSo8vC42w7hg2HgYTxSWwP0+is7bWDc1H+Fo026CpHFwm8tkw==", 1397 | "dev": true, 1398 | "dependencies": { 1399 | "call-bind": "^1.0.2", 1400 | "get-intrinsic": "^1.2.1", 1401 | "is-typed-array": "^1.1.10" 1402 | }, 1403 | "engines": { 1404 | "node": ">= 0.4" 1405 | } 1406 | }, 1407 | "node_modules/typed-array-byte-length": { 1408 | "version": "1.0.0", 1409 | "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz", 1410 | "integrity": "sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA==", 1411 | "dev": true, 1412 | "dependencies": { 1413 | "call-bind": "^1.0.2", 1414 | "for-each": "^0.3.3", 1415 | "has-proto": "^1.0.1", 1416 | "is-typed-array": "^1.1.10" 1417 | }, 1418 | "engines": { 1419 | "node": ">= 0.4" 1420 | }, 1421 | "funding": { 1422 | "url": "https://github.com/sponsors/ljharb" 1423 | } 1424 | }, 1425 | "node_modules/typed-array-byte-offset": { 1426 | "version": "1.0.0", 1427 | "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz", 1428 | "integrity": "sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg==", 1429 | "dev": true, 1430 | "dependencies": { 1431 | "available-typed-arrays": "^1.0.5", 1432 | "call-bind": "^1.0.2", 1433 | "for-each": "^0.3.3", 1434 | "has-proto": "^1.0.1", 1435 | "is-typed-array": "^1.1.10" 1436 | }, 1437 | "engines": { 1438 | "node": ">= 0.4" 1439 | }, 1440 | "funding": { 1441 | "url": "https://github.com/sponsors/ljharb" 1442 | } 1443 | }, 1444 | "node_modules/typed-array-length": { 1445 | "version": "1.0.4", 1446 | "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.4.tgz", 1447 | "integrity": "sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==", 1448 | "dev": true, 1449 | "dependencies": { 1450 | "call-bind": "^1.0.2", 1451 | "for-each": "^0.3.3", 1452 | "is-typed-array": "^1.1.9" 1453 | }, 1454 | "funding": { 1455 | "url": "https://github.com/sponsors/ljharb" 1456 | } 1457 | }, 1458 | "node_modules/typescript": { 1459 | "version": "5.2.2", 1460 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.2.2.tgz", 1461 | "integrity": "sha512-mI4WrpHsbCIcwT9cF4FZvr80QUeKvsUsUvKDoR+X/7XHQH98xYD8YHZg7ANtz2GtZt/CBq2QJ0thkGJMHfqc1w==", 1462 | "dev": true, 1463 | "bin": { 1464 | "tsc": "bin/tsc", 1465 | "tsserver": "bin/tsserver" 1466 | }, 1467 | "engines": { 1468 | "node": ">=14.17" 1469 | } 1470 | }, 1471 | "node_modules/unbox-primitive": { 1472 | "version": "1.0.2", 1473 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", 1474 | "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", 1475 | "dev": true, 1476 | "dependencies": { 1477 | "call-bind": "^1.0.2", 1478 | "has-bigints": "^1.0.2", 1479 | "has-symbols": "^1.0.3", 1480 | "which-boxed-primitive": "^1.0.2" 1481 | }, 1482 | "funding": { 1483 | "url": "https://github.com/sponsors/ljharb" 1484 | } 1485 | }, 1486 | "node_modules/v8-compile-cache-lib": { 1487 | "version": "3.0.1", 1488 | "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz", 1489 | "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==", 1490 | "dev": true 1491 | }, 1492 | "node_modules/validate-npm-package-license": { 1493 | "version": "3.0.4", 1494 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 1495 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 1496 | "dev": true, 1497 | "dependencies": { 1498 | "spdx-correct": "^3.0.0", 1499 | "spdx-expression-parse": "^3.0.0" 1500 | } 1501 | }, 1502 | "node_modules/which": { 1503 | "version": "1.3.1", 1504 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1505 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1506 | "dev": true, 1507 | "dependencies": { 1508 | "isexe": "^2.0.0" 1509 | }, 1510 | "bin": { 1511 | "which": "bin/which" 1512 | } 1513 | }, 1514 | "node_modules/which-boxed-primitive": { 1515 | "version": "1.0.2", 1516 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 1517 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 1518 | "dev": true, 1519 | "dependencies": { 1520 | "is-bigint": "^1.0.1", 1521 | "is-boolean-object": "^1.1.0", 1522 | "is-number-object": "^1.0.4", 1523 | "is-string": "^1.0.5", 1524 | "is-symbol": "^1.0.3" 1525 | }, 1526 | "funding": { 1527 | "url": "https://github.com/sponsors/ljharb" 1528 | } 1529 | }, 1530 | "node_modules/which-typed-array": { 1531 | "version": "1.1.11", 1532 | "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.11.tgz", 1533 | "integrity": "sha512-qe9UWWpkeG5yzZ0tNYxDmd7vo58HDBc39mZ0xWWpolAGADdFOzkfamWLDxkOWcvHQKVmdTyQdLD4NOfjLWTKew==", 1534 | "dev": true, 1535 | "dependencies": { 1536 | "available-typed-arrays": "^1.0.5", 1537 | "call-bind": "^1.0.2", 1538 | "for-each": "^0.3.3", 1539 | "gopd": "^1.0.1", 1540 | "has-tostringtag": "^1.0.0" 1541 | }, 1542 | "engines": { 1543 | "node": ">= 0.4" 1544 | }, 1545 | "funding": { 1546 | "url": "https://github.com/sponsors/ljharb" 1547 | } 1548 | }, 1549 | "node_modules/yn": { 1550 | "version": "3.1.1", 1551 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 1552 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 1553 | "dev": true, 1554 | "engines": { 1555 | "node": ">=6" 1556 | } 1557 | } 1558 | } 1559 | } 1560 | -------------------------------------------------------------------------------- /example/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "example", 3 | "scripts": { 4 | "dev": "ts-node index.ts" 5 | }, 6 | "dependencies": { 7 | "@prisma/client": "^5.3.1", 8 | "cache-manager": "^5.2.3" 9 | }, 10 | "devDependencies": { 11 | "@types/node": "^18.18.0", 12 | "npm-run-all": "^4.1.5", 13 | "prisma": "^5.3.1", 14 | "ts-node": "^10.9.1", 15 | "typescript": "^5.2.2" 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /example/prisma/schema.prisma: -------------------------------------------------------------------------------- 1 | // This is your Prisma schema file, 2 | // learn more about it in the docs: https://pris.ly/d/prisma-schema 3 | 4 | generator client { 5 | provider = "prisma-client-js" 6 | previewFeatures = ["metrics"] 7 | } 8 | 9 | datasource db { 10 | provider = "sqlite" 11 | url = "file:./dev.db" 12 | } 13 | 14 | model User { 15 | id Int @id @default(autoincrement()) 16 | string String? 17 | decimal Decimal? 18 | bigint BigInt? 19 | float Float? 20 | timestamp DateTime? 21 | bytes Bytes? 22 | } 23 | 24 | // model Post { 25 | // id Int @id @default(autoincrement()) 26 | // text String? 27 | 28 | // } 29 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "prisma-extension-cache-manager", 3 | "version": "1.1.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "prisma-extension-cache-manager", 9 | "version": "1.1.0", 10 | "license": "MIT", 11 | "dependencies": { 12 | "object-code": "^1.3.3" 13 | }, 14 | "devDependencies": { 15 | "@prisma/client": "^6.3.1", 16 | "cache-manager": "^6.4.0", 17 | "cacheable": "^1.8.8", 18 | "keyv": "^5.2.3", 19 | "npm-run-all": "^4.1.5", 20 | "prisma": "^6.3.1", 21 | "rimraf": "^6.0.1", 22 | "ts-node": "^10.9.2", 23 | "typescript": "^5.7.3" 24 | }, 25 | "engines": { 26 | "node": ">=18.18" 27 | }, 28 | "peerDependencies": { 29 | "@prisma/client": "^6.0.1" 30 | } 31 | }, 32 | "node_modules/@cspotcode/source-map-support": { 33 | "version": "0.8.1", 34 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 35 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 36 | "dev": true, 37 | "dependencies": { 38 | "@jridgewell/trace-mapping": "0.3.9" 39 | }, 40 | "engines": { 41 | "node": ">=12" 42 | } 43 | }, 44 | "node_modules/@esbuild/aix-ppc64": { 45 | "version": "0.25.2", 46 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.25.2.tgz", 47 | "integrity": "sha512-wCIboOL2yXZym2cgm6mlA742s9QeJ8DjGVaL39dLN4rRwrOgOyYSnOaFPhKZGLb2ngj4EyfAFjsNJwPXZvseag==", 48 | "cpu": [ 49 | "ppc64" 50 | ], 51 | "dev": true, 52 | "license": "MIT", 53 | "optional": true, 54 | "os": [ 55 | "aix" 56 | ], 57 | "engines": { 58 | "node": ">=18" 59 | } 60 | }, 61 | "node_modules/@esbuild/android-arm": { 62 | "version": "0.25.2", 63 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.25.2.tgz", 64 | "integrity": "sha512-NQhH7jFstVY5x8CKbcfa166GoV0EFkaPkCKBQkdPJFvo5u+nGXLEH/ooniLb3QI8Fk58YAx7nsPLozUWfCBOJA==", 65 | "cpu": [ 66 | "arm" 67 | ], 68 | "dev": true, 69 | "license": "MIT", 70 | "optional": true, 71 | "os": [ 72 | "android" 73 | ], 74 | "engines": { 75 | "node": ">=18" 76 | } 77 | }, 78 | "node_modules/@esbuild/android-arm64": { 79 | "version": "0.25.2", 80 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.25.2.tgz", 81 | "integrity": "sha512-5ZAX5xOmTligeBaeNEPnPaeEuah53Id2tX4c2CVP3JaROTH+j4fnfHCkr1PjXMd78hMst+TlkfKcW/DlTq0i4w==", 82 | "cpu": [ 83 | "arm64" 84 | ], 85 | "dev": true, 86 | "license": "MIT", 87 | "optional": true, 88 | "os": [ 89 | "android" 90 | ], 91 | "engines": { 92 | "node": ">=18" 93 | } 94 | }, 95 | "node_modules/@esbuild/android-x64": { 96 | "version": "0.25.2", 97 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.25.2.tgz", 98 | "integrity": "sha512-Ffcx+nnma8Sge4jzddPHCZVRvIfQ0kMsUsCMcJRHkGJ1cDmhe4SsrYIjLUKn1xpHZybmOqCWwB0zQvsjdEHtkg==", 99 | "cpu": [ 100 | "x64" 101 | ], 102 | "dev": true, 103 | "license": "MIT", 104 | "optional": true, 105 | "os": [ 106 | "android" 107 | ], 108 | "engines": { 109 | "node": ">=18" 110 | } 111 | }, 112 | "node_modules/@esbuild/darwin-arm64": { 113 | "version": "0.25.2", 114 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.25.2.tgz", 115 | "integrity": "sha512-MpM6LUVTXAzOvN4KbjzU/q5smzryuoNjlriAIx+06RpecwCkL9JpenNzpKd2YMzLJFOdPqBpuub6eVRP5IgiSA==", 116 | "cpu": [ 117 | "arm64" 118 | ], 119 | "dev": true, 120 | "license": "MIT", 121 | "optional": true, 122 | "os": [ 123 | "darwin" 124 | ], 125 | "engines": { 126 | "node": ">=18" 127 | } 128 | }, 129 | "node_modules/@esbuild/darwin-x64": { 130 | "version": "0.25.2", 131 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.25.2.tgz", 132 | "integrity": "sha512-5eRPrTX7wFyuWe8FqEFPG2cU0+butQQVNcT4sVipqjLYQjjh8a8+vUTfgBKM88ObB85ahsnTwF7PSIt6PG+QkA==", 133 | "cpu": [ 134 | "x64" 135 | ], 136 | "dev": true, 137 | "license": "MIT", 138 | "optional": true, 139 | "os": [ 140 | "darwin" 141 | ], 142 | "engines": { 143 | "node": ">=18" 144 | } 145 | }, 146 | "node_modules/@esbuild/freebsd-arm64": { 147 | "version": "0.25.2", 148 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.25.2.tgz", 149 | "integrity": "sha512-mLwm4vXKiQ2UTSX4+ImyiPdiHjiZhIaE9QvC7sw0tZ6HoNMjYAqQpGyui5VRIi5sGd+uWq940gdCbY3VLvsO1w==", 150 | "cpu": [ 151 | "arm64" 152 | ], 153 | "dev": true, 154 | "license": "MIT", 155 | "optional": true, 156 | "os": [ 157 | "freebsd" 158 | ], 159 | "engines": { 160 | "node": ">=18" 161 | } 162 | }, 163 | "node_modules/@esbuild/freebsd-x64": { 164 | "version": "0.25.2", 165 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.25.2.tgz", 166 | "integrity": "sha512-6qyyn6TjayJSwGpm8J9QYYGQcRgc90nmfdUb0O7pp1s4lTY+9D0H9O02v5JqGApUyiHOtkz6+1hZNvNtEhbwRQ==", 167 | "cpu": [ 168 | "x64" 169 | ], 170 | "dev": true, 171 | "license": "MIT", 172 | "optional": true, 173 | "os": [ 174 | "freebsd" 175 | ], 176 | "engines": { 177 | "node": ">=18" 178 | } 179 | }, 180 | "node_modules/@esbuild/linux-arm": { 181 | "version": "0.25.2", 182 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.25.2.tgz", 183 | "integrity": "sha512-UHBRgJcmjJv5oeQF8EpTRZs/1knq6loLxTsjc3nxO9eXAPDLcWW55flrMVc97qFPbmZP31ta1AZVUKQzKTzb0g==", 184 | "cpu": [ 185 | "arm" 186 | ], 187 | "dev": true, 188 | "license": "MIT", 189 | "optional": true, 190 | "os": [ 191 | "linux" 192 | ], 193 | "engines": { 194 | "node": ">=18" 195 | } 196 | }, 197 | "node_modules/@esbuild/linux-arm64": { 198 | "version": "0.25.2", 199 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.25.2.tgz", 200 | "integrity": "sha512-gq/sjLsOyMT19I8obBISvhoYiZIAaGF8JpeXu1u8yPv8BE5HlWYobmlsfijFIZ9hIVGYkbdFhEqC0NvM4kNO0g==", 201 | "cpu": [ 202 | "arm64" 203 | ], 204 | "dev": true, 205 | "license": "MIT", 206 | "optional": true, 207 | "os": [ 208 | "linux" 209 | ], 210 | "engines": { 211 | "node": ">=18" 212 | } 213 | }, 214 | "node_modules/@esbuild/linux-ia32": { 215 | "version": "0.25.2", 216 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.25.2.tgz", 217 | "integrity": "sha512-bBYCv9obgW2cBP+2ZWfjYTU+f5cxRoGGQ5SeDbYdFCAZpYWrfjjfYwvUpP8MlKbP0nwZ5gyOU/0aUzZ5HWPuvQ==", 218 | "cpu": [ 219 | "ia32" 220 | ], 221 | "dev": true, 222 | "license": "MIT", 223 | "optional": true, 224 | "os": [ 225 | "linux" 226 | ], 227 | "engines": { 228 | "node": ">=18" 229 | } 230 | }, 231 | "node_modules/@esbuild/linux-loong64": { 232 | "version": "0.25.2", 233 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.25.2.tgz", 234 | "integrity": "sha512-SHNGiKtvnU2dBlM5D8CXRFdd+6etgZ9dXfaPCeJtz+37PIUlixvlIhI23L5khKXs3DIzAn9V8v+qb1TRKrgT5w==", 235 | "cpu": [ 236 | "loong64" 237 | ], 238 | "dev": true, 239 | "license": "MIT", 240 | "optional": true, 241 | "os": [ 242 | "linux" 243 | ], 244 | "engines": { 245 | "node": ">=18" 246 | } 247 | }, 248 | "node_modules/@esbuild/linux-mips64el": { 249 | "version": "0.25.2", 250 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.25.2.tgz", 251 | "integrity": "sha512-hDDRlzE6rPeoj+5fsADqdUZl1OzqDYow4TB4Y/3PlKBD0ph1e6uPHzIQcv2Z65u2K0kpeByIyAjCmjn1hJgG0Q==", 252 | "cpu": [ 253 | "mips64el" 254 | ], 255 | "dev": true, 256 | "license": "MIT", 257 | "optional": true, 258 | "os": [ 259 | "linux" 260 | ], 261 | "engines": { 262 | "node": ">=18" 263 | } 264 | }, 265 | "node_modules/@esbuild/linux-ppc64": { 266 | "version": "0.25.2", 267 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.25.2.tgz", 268 | "integrity": "sha512-tsHu2RRSWzipmUi9UBDEzc0nLc4HtpZEI5Ba+Omms5456x5WaNuiG3u7xh5AO6sipnJ9r4cRWQB2tUjPyIkc6g==", 269 | "cpu": [ 270 | "ppc64" 271 | ], 272 | "dev": true, 273 | "license": "MIT", 274 | "optional": true, 275 | "os": [ 276 | "linux" 277 | ], 278 | "engines": { 279 | "node": ">=18" 280 | } 281 | }, 282 | "node_modules/@esbuild/linux-riscv64": { 283 | "version": "0.25.2", 284 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.25.2.tgz", 285 | "integrity": "sha512-k4LtpgV7NJQOml/10uPU0s4SAXGnowi5qBSjaLWMojNCUICNu7TshqHLAEbkBdAszL5TabfvQ48kK84hyFzjnw==", 286 | "cpu": [ 287 | "riscv64" 288 | ], 289 | "dev": true, 290 | "license": "MIT", 291 | "optional": true, 292 | "os": [ 293 | "linux" 294 | ], 295 | "engines": { 296 | "node": ">=18" 297 | } 298 | }, 299 | "node_modules/@esbuild/linux-s390x": { 300 | "version": "0.25.2", 301 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.25.2.tgz", 302 | "integrity": "sha512-GRa4IshOdvKY7M/rDpRR3gkiTNp34M0eLTaC1a08gNrh4u488aPhuZOCpkF6+2wl3zAN7L7XIpOFBhnaE3/Q8Q==", 303 | "cpu": [ 304 | "s390x" 305 | ], 306 | "dev": true, 307 | "license": "MIT", 308 | "optional": true, 309 | "os": [ 310 | "linux" 311 | ], 312 | "engines": { 313 | "node": ">=18" 314 | } 315 | }, 316 | "node_modules/@esbuild/linux-x64": { 317 | "version": "0.25.2", 318 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.25.2.tgz", 319 | "integrity": "sha512-QInHERlqpTTZ4FRB0fROQWXcYRD64lAoiegezDunLpalZMjcUcld3YzZmVJ2H/Cp0wJRZ8Xtjtj0cEHhYc/uUg==", 320 | "cpu": [ 321 | "x64" 322 | ], 323 | "dev": true, 324 | "license": "MIT", 325 | "optional": true, 326 | "os": [ 327 | "linux" 328 | ], 329 | "engines": { 330 | "node": ">=18" 331 | } 332 | }, 333 | "node_modules/@esbuild/netbsd-arm64": { 334 | "version": "0.25.2", 335 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-arm64/-/netbsd-arm64-0.25.2.tgz", 336 | "integrity": "sha512-talAIBoY5M8vHc6EeI2WW9d/CkiO9MQJ0IOWX8hrLhxGbro/vBXJvaQXefW2cP0z0nQVTdQ/eNyGFV1GSKrxfw==", 337 | "cpu": [ 338 | "arm64" 339 | ], 340 | "dev": true, 341 | "license": "MIT", 342 | "optional": true, 343 | "os": [ 344 | "netbsd" 345 | ], 346 | "engines": { 347 | "node": ">=18" 348 | } 349 | }, 350 | "node_modules/@esbuild/netbsd-x64": { 351 | "version": "0.25.2", 352 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.25.2.tgz", 353 | "integrity": "sha512-voZT9Z+tpOxrvfKFyfDYPc4DO4rk06qamv1a/fkuzHpiVBMOhpjK+vBmWM8J1eiB3OLSMFYNaOaBNLXGChf5tg==", 354 | "cpu": [ 355 | "x64" 356 | ], 357 | "dev": true, 358 | "license": "MIT", 359 | "optional": true, 360 | "os": [ 361 | "netbsd" 362 | ], 363 | "engines": { 364 | "node": ">=18" 365 | } 366 | }, 367 | "node_modules/@esbuild/openbsd-arm64": { 368 | "version": "0.25.2", 369 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-arm64/-/openbsd-arm64-0.25.2.tgz", 370 | "integrity": "sha512-dcXYOC6NXOqcykeDlwId9kB6OkPUxOEqU+rkrYVqJbK2hagWOMrsTGsMr8+rW02M+d5Op5NNlgMmjzecaRf7Tg==", 371 | "cpu": [ 372 | "arm64" 373 | ], 374 | "dev": true, 375 | "license": "MIT", 376 | "optional": true, 377 | "os": [ 378 | "openbsd" 379 | ], 380 | "engines": { 381 | "node": ">=18" 382 | } 383 | }, 384 | "node_modules/@esbuild/openbsd-x64": { 385 | "version": "0.25.2", 386 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.25.2.tgz", 387 | "integrity": "sha512-t/TkWwahkH0Tsgoq1Ju7QfgGhArkGLkF1uYz8nQS/PPFlXbP5YgRpqQR3ARRiC2iXoLTWFxc6DJMSK10dVXluw==", 388 | "cpu": [ 389 | "x64" 390 | ], 391 | "dev": true, 392 | "license": "MIT", 393 | "optional": true, 394 | "os": [ 395 | "openbsd" 396 | ], 397 | "engines": { 398 | "node": ">=18" 399 | } 400 | }, 401 | "node_modules/@esbuild/sunos-x64": { 402 | "version": "0.25.2", 403 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.25.2.tgz", 404 | "integrity": "sha512-cfZH1co2+imVdWCjd+D1gf9NjkchVhhdpgb1q5y6Hcv9TP6Zi9ZG/beI3ig8TvwT9lH9dlxLq5MQBBgwuj4xvA==", 405 | "cpu": [ 406 | "x64" 407 | ], 408 | "dev": true, 409 | "license": "MIT", 410 | "optional": true, 411 | "os": [ 412 | "sunos" 413 | ], 414 | "engines": { 415 | "node": ">=18" 416 | } 417 | }, 418 | "node_modules/@esbuild/win32-arm64": { 419 | "version": "0.25.2", 420 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.25.2.tgz", 421 | "integrity": "sha512-7Loyjh+D/Nx/sOTzV8vfbB3GJuHdOQyrOryFdZvPHLf42Tk9ivBU5Aedi7iyX+x6rbn2Mh68T4qq1SDqJBQO5Q==", 422 | "cpu": [ 423 | "arm64" 424 | ], 425 | "dev": true, 426 | "license": "MIT", 427 | "optional": true, 428 | "os": [ 429 | "win32" 430 | ], 431 | "engines": { 432 | "node": ">=18" 433 | } 434 | }, 435 | "node_modules/@esbuild/win32-ia32": { 436 | "version": "0.25.2", 437 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.25.2.tgz", 438 | "integrity": "sha512-WRJgsz9un0nqZJ4MfhabxaD9Ft8KioqU3JMinOTvobbX6MOSUigSBlogP8QB3uxpJDsFS6yN+3FDBdqE5lg9kg==", 439 | "cpu": [ 440 | "ia32" 441 | ], 442 | "dev": true, 443 | "license": "MIT", 444 | "optional": true, 445 | "os": [ 446 | "win32" 447 | ], 448 | "engines": { 449 | "node": ">=18" 450 | } 451 | }, 452 | "node_modules/@esbuild/win32-x64": { 453 | "version": "0.25.2", 454 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.25.2.tgz", 455 | "integrity": "sha512-kM3HKb16VIXZyIeVrM1ygYmZBKybX8N4p754bw390wGO3Tf2j4L2/WYL+4suWujpgf6GBYs3jv7TyUivdd05JA==", 456 | "cpu": [ 457 | "x64" 458 | ], 459 | "dev": true, 460 | "license": "MIT", 461 | "optional": true, 462 | "os": [ 463 | "win32" 464 | ], 465 | "engines": { 466 | "node": ">=18" 467 | } 468 | }, 469 | "node_modules/@isaacs/cliui": { 470 | "version": "8.0.2", 471 | "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", 472 | "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", 473 | "dev": true, 474 | "license": "ISC", 475 | "dependencies": { 476 | "string-width": "^5.1.2", 477 | "string-width-cjs": "npm:string-width@^4.2.0", 478 | "strip-ansi": "^7.0.1", 479 | "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", 480 | "wrap-ansi": "^8.1.0", 481 | "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" 482 | }, 483 | "engines": { 484 | "node": ">=12" 485 | } 486 | }, 487 | "node_modules/@jridgewell/resolve-uri": { 488 | "version": "3.1.1", 489 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz", 490 | "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==", 491 | "dev": true, 492 | "engines": { 493 | "node": ">=6.0.0" 494 | } 495 | }, 496 | "node_modules/@jridgewell/sourcemap-codec": { 497 | "version": "1.4.15", 498 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 499 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 500 | "dev": true 501 | }, 502 | "node_modules/@jridgewell/trace-mapping": { 503 | "version": "0.3.9", 504 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 505 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 506 | "dev": true, 507 | "dependencies": { 508 | "@jridgewell/resolve-uri": "^3.0.3", 509 | "@jridgewell/sourcemap-codec": "^1.4.10" 510 | } 511 | }, 512 | "node_modules/@keyv/serialize": { 513 | "version": "1.0.3", 514 | "resolved": "https://registry.npmjs.org/@keyv/serialize/-/serialize-1.0.3.tgz", 515 | "integrity": "sha512-qnEovoOp5Np2JDGonIDL6Ayihw0RhnRh6vxPuHo4RDn1UOzwEo4AeIfpL6UGIrsceWrCMiVPgwRjbHu4vYFc3g==", 516 | "dev": true, 517 | "license": "MIT", 518 | "dependencies": { 519 | "buffer": "^6.0.3" 520 | } 521 | }, 522 | "node_modules/@prisma/client": { 523 | "version": "6.6.0", 524 | "resolved": "https://registry.npmjs.org/@prisma/client/-/client-6.6.0.tgz", 525 | "integrity": "sha512-vfp73YT/BHsWWOAuthKQ/1lBgESSqYqAWZEYyTdGXyFAHpmewwWL2Iz6ErIzkj4aHbuc6/cGSsE6ZY+pBO04Cg==", 526 | "dev": true, 527 | "hasInstallScript": true, 528 | "license": "Apache-2.0", 529 | "engines": { 530 | "node": ">=18.18" 531 | }, 532 | "peerDependencies": { 533 | "prisma": "*", 534 | "typescript": ">=5.1.0" 535 | }, 536 | "peerDependenciesMeta": { 537 | "prisma": { 538 | "optional": true 539 | }, 540 | "typescript": { 541 | "optional": true 542 | } 543 | } 544 | }, 545 | "node_modules/@prisma/config": { 546 | "version": "6.6.0", 547 | "resolved": "https://registry.npmjs.org/@prisma/config/-/config-6.6.0.tgz", 548 | "integrity": "sha512-d8FlXRHsx72RbN8nA2QCRORNv5AcUnPXgtPvwhXmYkQSMF/j9cKaJg+9VcUzBRXGy9QBckNzEQDEJZdEOZ+ubA==", 549 | "dev": true, 550 | "license": "Apache-2.0", 551 | "dependencies": { 552 | "esbuild": ">=0.12 <1", 553 | "esbuild-register": "3.6.0" 554 | } 555 | }, 556 | "node_modules/@prisma/debug": { 557 | "version": "6.6.0", 558 | "resolved": "https://registry.npmjs.org/@prisma/debug/-/debug-6.6.0.tgz", 559 | "integrity": "sha512-DL6n4IKlW5k2LEXzpN60SQ1kP/F6fqaCgU/McgaYsxSf43GZ8lwtmXLke9efS+L1uGmrhtBUP4npV/QKF8s2ZQ==", 560 | "dev": true, 561 | "license": "Apache-2.0" 562 | }, 563 | "node_modules/@prisma/engines": { 564 | "version": "6.6.0", 565 | "resolved": "https://registry.npmjs.org/@prisma/engines/-/engines-6.6.0.tgz", 566 | "integrity": "sha512-nC0IV4NHh7500cozD1fBoTwTD1ydJERndreIjpZr/S3mno3P6tm8qnXmIND5SwUkibNeSJMpgl4gAnlqJ/gVlg==", 567 | "dev": true, 568 | "hasInstallScript": true, 569 | "license": "Apache-2.0", 570 | "dependencies": { 571 | "@prisma/debug": "6.6.0", 572 | "@prisma/engines-version": "6.6.0-53.f676762280b54cd07c770017ed3711ddde35f37a", 573 | "@prisma/fetch-engine": "6.6.0", 574 | "@prisma/get-platform": "6.6.0" 575 | } 576 | }, 577 | "node_modules/@prisma/engines-version": { 578 | "version": "6.6.0-53.f676762280b54cd07c770017ed3711ddde35f37a", 579 | "resolved": "https://registry.npmjs.org/@prisma/engines-version/-/engines-version-6.6.0-53.f676762280b54cd07c770017ed3711ddde35f37a.tgz", 580 | "integrity": "sha512-JzRaQ5Em1fuEcbR3nUsMNYaIYrOT1iMheenjCvzZblJcjv/3JIuxXN7RCNT5i6lRkLodW5ojCGhR7n5yvnNKrw==", 581 | "dev": true, 582 | "license": "Apache-2.0" 583 | }, 584 | "node_modules/@prisma/fetch-engine": { 585 | "version": "6.6.0", 586 | "resolved": "https://registry.npmjs.org/@prisma/fetch-engine/-/fetch-engine-6.6.0.tgz", 587 | "integrity": "sha512-Ohfo8gKp05LFLZaBlPUApM0M7k43a0jmo86YY35u1/4t+vuQH9mRGU7jGwVzGFY3v+9edeb/cowb1oG4buM1yw==", 588 | "dev": true, 589 | "license": "Apache-2.0", 590 | "dependencies": { 591 | "@prisma/debug": "6.6.0", 592 | "@prisma/engines-version": "6.6.0-53.f676762280b54cd07c770017ed3711ddde35f37a", 593 | "@prisma/get-platform": "6.6.0" 594 | } 595 | }, 596 | "node_modules/@prisma/get-platform": { 597 | "version": "6.6.0", 598 | "resolved": "https://registry.npmjs.org/@prisma/get-platform/-/get-platform-6.6.0.tgz", 599 | "integrity": "sha512-3qCwmnT4Jh5WCGUrkWcc6VZaw0JY7eWN175/pcb5Z6FiLZZ3ygY93UX0WuV41bG51a6JN/oBH0uywJ90Y+V5eA==", 600 | "dev": true, 601 | "license": "Apache-2.0", 602 | "dependencies": { 603 | "@prisma/debug": "6.6.0" 604 | } 605 | }, 606 | "node_modules/@tsconfig/node10": { 607 | "version": "1.0.9", 608 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz", 609 | "integrity": "sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA==", 610 | "dev": true 611 | }, 612 | "node_modules/@tsconfig/node12": { 613 | "version": "1.0.11", 614 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz", 615 | "integrity": "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==", 616 | "dev": true 617 | }, 618 | "node_modules/@tsconfig/node14": { 619 | "version": "1.0.3", 620 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz", 621 | "integrity": "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==", 622 | "dev": true 623 | }, 624 | "node_modules/@tsconfig/node16": { 625 | "version": "1.0.4", 626 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.4.tgz", 627 | "integrity": "sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA==", 628 | "dev": true 629 | }, 630 | "node_modules/@types/node": { 631 | "version": "20.8.2", 632 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.8.2.tgz", 633 | "integrity": "sha512-Vvycsc9FQdwhxE3y3DzeIxuEJbWGDsnrxvMADzTDF/lcdR9/K+AQIeAghTQsHtotg/q0j3WEOYS/jQgSdWue3w==", 634 | "dev": true, 635 | "peer": true 636 | }, 637 | "node_modules/acorn": { 638 | "version": "8.10.0", 639 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz", 640 | "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==", 641 | "dev": true, 642 | "bin": { 643 | "acorn": "bin/acorn" 644 | }, 645 | "engines": { 646 | "node": ">=0.4.0" 647 | } 648 | }, 649 | "node_modules/acorn-walk": { 650 | "version": "8.2.0", 651 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 652 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 653 | "dev": true, 654 | "engines": { 655 | "node": ">=0.4.0" 656 | } 657 | }, 658 | "node_modules/ansi-regex": { 659 | "version": "6.1.0", 660 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", 661 | "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", 662 | "dev": true, 663 | "license": "MIT", 664 | "engines": { 665 | "node": ">=12" 666 | }, 667 | "funding": { 668 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 669 | } 670 | }, 671 | "node_modules/ansi-styles": { 672 | "version": "3.2.1", 673 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 674 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 675 | "dev": true, 676 | "dependencies": { 677 | "color-convert": "^1.9.0" 678 | }, 679 | "engines": { 680 | "node": ">=4" 681 | } 682 | }, 683 | "node_modules/arg": { 684 | "version": "4.1.3", 685 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 686 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 687 | "dev": true 688 | }, 689 | "node_modules/array-buffer-byte-length": { 690 | "version": "1.0.0", 691 | "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz", 692 | "integrity": "sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==", 693 | "dev": true, 694 | "dependencies": { 695 | "call-bind": "^1.0.2", 696 | "is-array-buffer": "^3.0.1" 697 | }, 698 | "funding": { 699 | "url": "https://github.com/sponsors/ljharb" 700 | } 701 | }, 702 | "node_modules/arraybuffer.prototype.slice": { 703 | "version": "1.0.2", 704 | "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.2.tgz", 705 | "integrity": "sha512-yMBKppFur/fbHu9/6USUe03bZ4knMYiwFBcyiaXB8Go0qNehwX6inYPzK9U0NeQvGxKthcmHcaR8P5MStSRBAw==", 706 | "dev": true, 707 | "dependencies": { 708 | "array-buffer-byte-length": "^1.0.0", 709 | "call-bind": "^1.0.2", 710 | "define-properties": "^1.2.0", 711 | "es-abstract": "^1.22.1", 712 | "get-intrinsic": "^1.2.1", 713 | "is-array-buffer": "^3.0.2", 714 | "is-shared-array-buffer": "^1.0.2" 715 | }, 716 | "engines": { 717 | "node": ">= 0.4" 718 | }, 719 | "funding": { 720 | "url": "https://github.com/sponsors/ljharb" 721 | } 722 | }, 723 | "node_modules/available-typed-arrays": { 724 | "version": "1.0.5", 725 | "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz", 726 | "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==", 727 | "dev": true, 728 | "engines": { 729 | "node": ">= 0.4" 730 | }, 731 | "funding": { 732 | "url": "https://github.com/sponsors/ljharb" 733 | } 734 | }, 735 | "node_modules/balanced-match": { 736 | "version": "1.0.2", 737 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 738 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 739 | "dev": true 740 | }, 741 | "node_modules/base64-js": { 742 | "version": "1.5.1", 743 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 744 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 745 | "dev": true, 746 | "funding": [ 747 | { 748 | "type": "github", 749 | "url": "https://github.com/sponsors/feross" 750 | }, 751 | { 752 | "type": "patreon", 753 | "url": "https://www.patreon.com/feross" 754 | }, 755 | { 756 | "type": "consulting", 757 | "url": "https://feross.org/support" 758 | } 759 | ], 760 | "license": "MIT" 761 | }, 762 | "node_modules/brace-expansion": { 763 | "version": "1.1.11", 764 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 765 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 766 | "dev": true, 767 | "dependencies": { 768 | "balanced-match": "^1.0.0", 769 | "concat-map": "0.0.1" 770 | } 771 | }, 772 | "node_modules/buffer": { 773 | "version": "6.0.3", 774 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz", 775 | "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==", 776 | "dev": true, 777 | "funding": [ 778 | { 779 | "type": "github", 780 | "url": "https://github.com/sponsors/feross" 781 | }, 782 | { 783 | "type": "patreon", 784 | "url": "https://www.patreon.com/feross" 785 | }, 786 | { 787 | "type": "consulting", 788 | "url": "https://feross.org/support" 789 | } 790 | ], 791 | "license": "MIT", 792 | "dependencies": { 793 | "base64-js": "^1.3.1", 794 | "ieee754": "^1.2.1" 795 | } 796 | }, 797 | "node_modules/cache-manager": { 798 | "version": "6.4.2", 799 | "resolved": "https://registry.npmjs.org/cache-manager/-/cache-manager-6.4.2.tgz", 800 | "integrity": "sha512-oT0d1cGWZAlqEGDPjOfhmldTS767jT6kBT3KIdn7MX5OevlRVYqJT+LxRv5WY4xW9heJtYxeRRXaoKlEW+Biew==", 801 | "dev": true, 802 | "license": "MIT", 803 | "dependencies": { 804 | "keyv": "^5.3.2" 805 | } 806 | }, 807 | "node_modules/cacheable": { 808 | "version": "1.8.10", 809 | "resolved": "https://registry.npmjs.org/cacheable/-/cacheable-1.8.10.tgz", 810 | "integrity": "sha512-0ZnbicB/N2R6uziva8l6O6BieBklArWyiGx4GkwAhLKhSHyQtRfM9T1nx7HHuHDKkYB/efJQhz3QJ6x/YqoZzA==", 811 | "dev": true, 812 | "license": "MIT", 813 | "dependencies": { 814 | "hookified": "^1.8.1", 815 | "keyv": "^5.3.2" 816 | } 817 | }, 818 | "node_modules/call-bind": { 819 | "version": "1.0.2", 820 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 821 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 822 | "dev": true, 823 | "dependencies": { 824 | "function-bind": "^1.1.1", 825 | "get-intrinsic": "^1.0.2" 826 | }, 827 | "funding": { 828 | "url": "https://github.com/sponsors/ljharb" 829 | } 830 | }, 831 | "node_modules/chalk": { 832 | "version": "2.4.2", 833 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 834 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 835 | "dev": true, 836 | "dependencies": { 837 | "ansi-styles": "^3.2.1", 838 | "escape-string-regexp": "^1.0.5", 839 | "supports-color": "^5.3.0" 840 | }, 841 | "engines": { 842 | "node": ">=4" 843 | } 844 | }, 845 | "node_modules/color-convert": { 846 | "version": "1.9.3", 847 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 848 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 849 | "dev": true, 850 | "dependencies": { 851 | "color-name": "1.1.3" 852 | } 853 | }, 854 | "node_modules/color-name": { 855 | "version": "1.1.3", 856 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 857 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 858 | "dev": true 859 | }, 860 | "node_modules/concat-map": { 861 | "version": "0.0.1", 862 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 863 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 864 | "dev": true 865 | }, 866 | "node_modules/create-require": { 867 | "version": "1.1.1", 868 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 869 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 870 | "dev": true 871 | }, 872 | "node_modules/cross-spawn": { 873 | "version": "6.0.6", 874 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.6.tgz", 875 | "integrity": "sha512-VqCUuhcd1iB+dsv8gxPttb5iZh/D0iubSP21g36KXdEuf6I5JiioesUVjpCdHV9MZRUfVFlvwtIUyPfxo5trtw==", 876 | "dev": true, 877 | "license": "MIT", 878 | "dependencies": { 879 | "nice-try": "^1.0.4", 880 | "path-key": "^2.0.1", 881 | "semver": "^5.5.0", 882 | "shebang-command": "^1.2.0", 883 | "which": "^1.2.9" 884 | }, 885 | "engines": { 886 | "node": ">=4.8" 887 | } 888 | }, 889 | "node_modules/debug": { 890 | "version": "4.4.0", 891 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", 892 | "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", 893 | "dev": true, 894 | "license": "MIT", 895 | "dependencies": { 896 | "ms": "^2.1.3" 897 | }, 898 | "engines": { 899 | "node": ">=6.0" 900 | }, 901 | "peerDependenciesMeta": { 902 | "supports-color": { 903 | "optional": true 904 | } 905 | } 906 | }, 907 | "node_modules/define-data-property": { 908 | "version": "1.1.0", 909 | "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.0.tgz", 910 | "integrity": "sha512-UzGwzcjyv3OtAvolTj1GoyNYzfFR+iqbGjcnBEENZVCpM4/Ng1yhGNvS3lR/xDS74Tb2wGG9WzNSNIOS9UVb2g==", 911 | "dev": true, 912 | "dependencies": { 913 | "get-intrinsic": "^1.2.1", 914 | "gopd": "^1.0.1", 915 | "has-property-descriptors": "^1.0.0" 916 | }, 917 | "engines": { 918 | "node": ">= 0.4" 919 | } 920 | }, 921 | "node_modules/define-properties": { 922 | "version": "1.2.1", 923 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", 924 | "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", 925 | "dev": true, 926 | "dependencies": { 927 | "define-data-property": "^1.0.1", 928 | "has-property-descriptors": "^1.0.0", 929 | "object-keys": "^1.1.1" 930 | }, 931 | "engines": { 932 | "node": ">= 0.4" 933 | }, 934 | "funding": { 935 | "url": "https://github.com/sponsors/ljharb" 936 | } 937 | }, 938 | "node_modules/diff": { 939 | "version": "4.0.2", 940 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 941 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 942 | "dev": true, 943 | "engines": { 944 | "node": ">=0.3.1" 945 | } 946 | }, 947 | "node_modules/eastasianwidth": { 948 | "version": "0.2.0", 949 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 950 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 951 | "dev": true, 952 | "license": "MIT" 953 | }, 954 | "node_modules/emoji-regex": { 955 | "version": "9.2.2", 956 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 957 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", 958 | "dev": true, 959 | "license": "MIT" 960 | }, 961 | "node_modules/error-ex": { 962 | "version": "1.3.2", 963 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 964 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 965 | "dev": true, 966 | "dependencies": { 967 | "is-arrayish": "^0.2.1" 968 | } 969 | }, 970 | "node_modules/es-abstract": { 971 | "version": "1.22.2", 972 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.2.tgz", 973 | "integrity": "sha512-YoxfFcDmhjOgWPWsV13+2RNjq1F6UQnfs+8TftwNqtzlmFzEXvlUwdrNrYeaizfjQzRMxkZ6ElWMOJIFKdVqwA==", 974 | "dev": true, 975 | "dependencies": { 976 | "array-buffer-byte-length": "^1.0.0", 977 | "arraybuffer.prototype.slice": "^1.0.2", 978 | "available-typed-arrays": "^1.0.5", 979 | "call-bind": "^1.0.2", 980 | "es-set-tostringtag": "^2.0.1", 981 | "es-to-primitive": "^1.2.1", 982 | "function.prototype.name": "^1.1.6", 983 | "get-intrinsic": "^1.2.1", 984 | "get-symbol-description": "^1.0.0", 985 | "globalthis": "^1.0.3", 986 | "gopd": "^1.0.1", 987 | "has": "^1.0.3", 988 | "has-property-descriptors": "^1.0.0", 989 | "has-proto": "^1.0.1", 990 | "has-symbols": "^1.0.3", 991 | "internal-slot": "^1.0.5", 992 | "is-array-buffer": "^3.0.2", 993 | "is-callable": "^1.2.7", 994 | "is-negative-zero": "^2.0.2", 995 | "is-regex": "^1.1.4", 996 | "is-shared-array-buffer": "^1.0.2", 997 | "is-string": "^1.0.7", 998 | "is-typed-array": "^1.1.12", 999 | "is-weakref": "^1.0.2", 1000 | "object-inspect": "^1.12.3", 1001 | "object-keys": "^1.1.1", 1002 | "object.assign": "^4.1.4", 1003 | "regexp.prototype.flags": "^1.5.1", 1004 | "safe-array-concat": "^1.0.1", 1005 | "safe-regex-test": "^1.0.0", 1006 | "string.prototype.trim": "^1.2.8", 1007 | "string.prototype.trimend": "^1.0.7", 1008 | "string.prototype.trimstart": "^1.0.7", 1009 | "typed-array-buffer": "^1.0.0", 1010 | "typed-array-byte-length": "^1.0.0", 1011 | "typed-array-byte-offset": "^1.0.0", 1012 | "typed-array-length": "^1.0.4", 1013 | "unbox-primitive": "^1.0.2", 1014 | "which-typed-array": "^1.1.11" 1015 | }, 1016 | "engines": { 1017 | "node": ">= 0.4" 1018 | }, 1019 | "funding": { 1020 | "url": "https://github.com/sponsors/ljharb" 1021 | } 1022 | }, 1023 | "node_modules/es-set-tostringtag": { 1024 | "version": "2.0.1", 1025 | "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.1.tgz", 1026 | "integrity": "sha512-g3OMbtlwY3QewlqAiMLI47KywjWZoEytKr8pf6iTC8uJq5bIAH52Z9pnQ8pVL6whrCto53JZDuUIsifGeLorTg==", 1027 | "dev": true, 1028 | "dependencies": { 1029 | "get-intrinsic": "^1.1.3", 1030 | "has": "^1.0.3", 1031 | "has-tostringtag": "^1.0.0" 1032 | }, 1033 | "engines": { 1034 | "node": ">= 0.4" 1035 | } 1036 | }, 1037 | "node_modules/es-to-primitive": { 1038 | "version": "1.2.1", 1039 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 1040 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 1041 | "dev": true, 1042 | "dependencies": { 1043 | "is-callable": "^1.1.4", 1044 | "is-date-object": "^1.0.1", 1045 | "is-symbol": "^1.0.2" 1046 | }, 1047 | "engines": { 1048 | "node": ">= 0.4" 1049 | }, 1050 | "funding": { 1051 | "url": "https://github.com/sponsors/ljharb" 1052 | } 1053 | }, 1054 | "node_modules/esbuild": { 1055 | "version": "0.25.2", 1056 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.25.2.tgz", 1057 | "integrity": "sha512-16854zccKPnC+toMywC+uKNeYSv+/eXkevRAfwRD/G9Cleq66m8XFIrigkbvauLLlCfDL45Q2cWegSg53gGBnQ==", 1058 | "dev": true, 1059 | "hasInstallScript": true, 1060 | "license": "MIT", 1061 | "bin": { 1062 | "esbuild": "bin/esbuild" 1063 | }, 1064 | "engines": { 1065 | "node": ">=18" 1066 | }, 1067 | "optionalDependencies": { 1068 | "@esbuild/aix-ppc64": "0.25.2", 1069 | "@esbuild/android-arm": "0.25.2", 1070 | "@esbuild/android-arm64": "0.25.2", 1071 | "@esbuild/android-x64": "0.25.2", 1072 | "@esbuild/darwin-arm64": "0.25.2", 1073 | "@esbuild/darwin-x64": "0.25.2", 1074 | "@esbuild/freebsd-arm64": "0.25.2", 1075 | "@esbuild/freebsd-x64": "0.25.2", 1076 | "@esbuild/linux-arm": "0.25.2", 1077 | "@esbuild/linux-arm64": "0.25.2", 1078 | "@esbuild/linux-ia32": "0.25.2", 1079 | "@esbuild/linux-loong64": "0.25.2", 1080 | "@esbuild/linux-mips64el": "0.25.2", 1081 | "@esbuild/linux-ppc64": "0.25.2", 1082 | "@esbuild/linux-riscv64": "0.25.2", 1083 | "@esbuild/linux-s390x": "0.25.2", 1084 | "@esbuild/linux-x64": "0.25.2", 1085 | "@esbuild/netbsd-arm64": "0.25.2", 1086 | "@esbuild/netbsd-x64": "0.25.2", 1087 | "@esbuild/openbsd-arm64": "0.25.2", 1088 | "@esbuild/openbsd-x64": "0.25.2", 1089 | "@esbuild/sunos-x64": "0.25.2", 1090 | "@esbuild/win32-arm64": "0.25.2", 1091 | "@esbuild/win32-ia32": "0.25.2", 1092 | "@esbuild/win32-x64": "0.25.2" 1093 | } 1094 | }, 1095 | "node_modules/esbuild-register": { 1096 | "version": "3.6.0", 1097 | "resolved": "https://registry.npmjs.org/esbuild-register/-/esbuild-register-3.6.0.tgz", 1098 | "integrity": "sha512-H2/S7Pm8a9CL1uhp9OvjwrBh5Pvx0H8qVOxNu8Wed9Y7qv56MPtq+GGM8RJpq6glYJn9Wspr8uw7l55uyinNeg==", 1099 | "dev": true, 1100 | "license": "MIT", 1101 | "dependencies": { 1102 | "debug": "^4.3.4" 1103 | }, 1104 | "peerDependencies": { 1105 | "esbuild": ">=0.12 <1" 1106 | } 1107 | }, 1108 | "node_modules/escape-string-regexp": { 1109 | "version": "1.0.5", 1110 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1111 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 1112 | "dev": true, 1113 | "engines": { 1114 | "node": ">=0.8.0" 1115 | } 1116 | }, 1117 | "node_modules/for-each": { 1118 | "version": "0.3.3", 1119 | "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", 1120 | "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", 1121 | "dev": true, 1122 | "dependencies": { 1123 | "is-callable": "^1.1.3" 1124 | } 1125 | }, 1126 | "node_modules/foreground-child": { 1127 | "version": "3.3.0", 1128 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.3.0.tgz", 1129 | "integrity": "sha512-Ld2g8rrAyMYFXBhEqMz8ZAHBi4J4uS1i/CxGMDnjyFWddMXLVcDp051DZfu+t7+ab7Wv6SMqpWmyFIj5UbfFvg==", 1130 | "dev": true, 1131 | "license": "ISC", 1132 | "dependencies": { 1133 | "cross-spawn": "^7.0.0", 1134 | "signal-exit": "^4.0.1" 1135 | }, 1136 | "engines": { 1137 | "node": ">=14" 1138 | }, 1139 | "funding": { 1140 | "url": "https://github.com/sponsors/isaacs" 1141 | } 1142 | }, 1143 | "node_modules/foreground-child/node_modules/cross-spawn": { 1144 | "version": "7.0.6", 1145 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", 1146 | "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==", 1147 | "dev": true, 1148 | "license": "MIT", 1149 | "dependencies": { 1150 | "path-key": "^3.1.0", 1151 | "shebang-command": "^2.0.0", 1152 | "which": "^2.0.1" 1153 | }, 1154 | "engines": { 1155 | "node": ">= 8" 1156 | } 1157 | }, 1158 | "node_modules/foreground-child/node_modules/path-key": { 1159 | "version": "3.1.1", 1160 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1161 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1162 | "dev": true, 1163 | "license": "MIT", 1164 | "engines": { 1165 | "node": ">=8" 1166 | } 1167 | }, 1168 | "node_modules/foreground-child/node_modules/shebang-command": { 1169 | "version": "2.0.0", 1170 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1171 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1172 | "dev": true, 1173 | "license": "MIT", 1174 | "dependencies": { 1175 | "shebang-regex": "^3.0.0" 1176 | }, 1177 | "engines": { 1178 | "node": ">=8" 1179 | } 1180 | }, 1181 | "node_modules/foreground-child/node_modules/shebang-regex": { 1182 | "version": "3.0.0", 1183 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1184 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1185 | "dev": true, 1186 | "license": "MIT", 1187 | "engines": { 1188 | "node": ">=8" 1189 | } 1190 | }, 1191 | "node_modules/foreground-child/node_modules/which": { 1192 | "version": "2.0.2", 1193 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1194 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1195 | "dev": true, 1196 | "license": "ISC", 1197 | "dependencies": { 1198 | "isexe": "^2.0.0" 1199 | }, 1200 | "bin": { 1201 | "node-which": "bin/node-which" 1202 | }, 1203 | "engines": { 1204 | "node": ">= 8" 1205 | } 1206 | }, 1207 | "node_modules/fsevents": { 1208 | "version": "2.3.3", 1209 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 1210 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 1211 | "dev": true, 1212 | "hasInstallScript": true, 1213 | "optional": true, 1214 | "os": [ 1215 | "darwin" 1216 | ], 1217 | "engines": { 1218 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1219 | } 1220 | }, 1221 | "node_modules/function-bind": { 1222 | "version": "1.1.1", 1223 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1224 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1225 | "dev": true 1226 | }, 1227 | "node_modules/function.prototype.name": { 1228 | "version": "1.1.6", 1229 | "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", 1230 | "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", 1231 | "dev": true, 1232 | "dependencies": { 1233 | "call-bind": "^1.0.2", 1234 | "define-properties": "^1.2.0", 1235 | "es-abstract": "^1.22.1", 1236 | "functions-have-names": "^1.2.3" 1237 | }, 1238 | "engines": { 1239 | "node": ">= 0.4" 1240 | }, 1241 | "funding": { 1242 | "url": "https://github.com/sponsors/ljharb" 1243 | } 1244 | }, 1245 | "node_modules/functions-have-names": { 1246 | "version": "1.2.3", 1247 | "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", 1248 | "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", 1249 | "dev": true, 1250 | "funding": { 1251 | "url": "https://github.com/sponsors/ljharb" 1252 | } 1253 | }, 1254 | "node_modules/get-intrinsic": { 1255 | "version": "1.2.1", 1256 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", 1257 | "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", 1258 | "dev": true, 1259 | "dependencies": { 1260 | "function-bind": "^1.1.1", 1261 | "has": "^1.0.3", 1262 | "has-proto": "^1.0.1", 1263 | "has-symbols": "^1.0.3" 1264 | }, 1265 | "funding": { 1266 | "url": "https://github.com/sponsors/ljharb" 1267 | } 1268 | }, 1269 | "node_modules/get-symbol-description": { 1270 | "version": "1.0.0", 1271 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", 1272 | "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", 1273 | "dev": true, 1274 | "dependencies": { 1275 | "call-bind": "^1.0.2", 1276 | "get-intrinsic": "^1.1.1" 1277 | }, 1278 | "engines": { 1279 | "node": ">= 0.4" 1280 | }, 1281 | "funding": { 1282 | "url": "https://github.com/sponsors/ljharb" 1283 | } 1284 | }, 1285 | "node_modules/glob": { 1286 | "version": "11.0.1", 1287 | "resolved": "https://registry.npmjs.org/glob/-/glob-11.0.1.tgz", 1288 | "integrity": "sha512-zrQDm8XPnYEKawJScsnM0QzobJxlT/kHOOlRTio8IH/GrmxRE5fjllkzdaHclIuNjUQTJYH2xHNIGfdpJkDJUw==", 1289 | "dev": true, 1290 | "license": "ISC", 1291 | "dependencies": { 1292 | "foreground-child": "^3.1.0", 1293 | "jackspeak": "^4.0.1", 1294 | "minimatch": "^10.0.0", 1295 | "minipass": "^7.1.2", 1296 | "package-json-from-dist": "^1.0.0", 1297 | "path-scurry": "^2.0.0" 1298 | }, 1299 | "bin": { 1300 | "glob": "dist/esm/bin.mjs" 1301 | }, 1302 | "engines": { 1303 | "node": "20 || >=22" 1304 | }, 1305 | "funding": { 1306 | "url": "https://github.com/sponsors/isaacs" 1307 | } 1308 | }, 1309 | "node_modules/glob/node_modules/brace-expansion": { 1310 | "version": "2.0.1", 1311 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1312 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1313 | "dev": true, 1314 | "license": "MIT", 1315 | "dependencies": { 1316 | "balanced-match": "^1.0.0" 1317 | } 1318 | }, 1319 | "node_modules/glob/node_modules/minimatch": { 1320 | "version": "10.0.1", 1321 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-10.0.1.tgz", 1322 | "integrity": "sha512-ethXTt3SGGR+95gudmqJ1eNhRO7eGEGIgYA9vnPatK4/etz2MEVDno5GMCibdMTuBMyElzIlgxMna3K94XDIDQ==", 1323 | "dev": true, 1324 | "license": "ISC", 1325 | "dependencies": { 1326 | "brace-expansion": "^2.0.1" 1327 | }, 1328 | "engines": { 1329 | "node": "20 || >=22" 1330 | }, 1331 | "funding": { 1332 | "url": "https://github.com/sponsors/isaacs" 1333 | } 1334 | }, 1335 | "node_modules/globalthis": { 1336 | "version": "1.0.3", 1337 | "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", 1338 | "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", 1339 | "dev": true, 1340 | "dependencies": { 1341 | "define-properties": "^1.1.3" 1342 | }, 1343 | "engines": { 1344 | "node": ">= 0.4" 1345 | }, 1346 | "funding": { 1347 | "url": "https://github.com/sponsors/ljharb" 1348 | } 1349 | }, 1350 | "node_modules/gopd": { 1351 | "version": "1.0.1", 1352 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", 1353 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", 1354 | "dev": true, 1355 | "dependencies": { 1356 | "get-intrinsic": "^1.1.3" 1357 | }, 1358 | "funding": { 1359 | "url": "https://github.com/sponsors/ljharb" 1360 | } 1361 | }, 1362 | "node_modules/graceful-fs": { 1363 | "version": "4.2.11", 1364 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 1365 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", 1366 | "dev": true 1367 | }, 1368 | "node_modules/has": { 1369 | "version": "1.0.3", 1370 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1371 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1372 | "dev": true, 1373 | "dependencies": { 1374 | "function-bind": "^1.1.1" 1375 | }, 1376 | "engines": { 1377 | "node": ">= 0.4.0" 1378 | } 1379 | }, 1380 | "node_modules/has-bigints": { 1381 | "version": "1.0.2", 1382 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", 1383 | "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", 1384 | "dev": true, 1385 | "funding": { 1386 | "url": "https://github.com/sponsors/ljharb" 1387 | } 1388 | }, 1389 | "node_modules/has-flag": { 1390 | "version": "3.0.0", 1391 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1392 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 1393 | "dev": true, 1394 | "engines": { 1395 | "node": ">=4" 1396 | } 1397 | }, 1398 | "node_modules/has-property-descriptors": { 1399 | "version": "1.0.0", 1400 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz", 1401 | "integrity": "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==", 1402 | "dev": true, 1403 | "dependencies": { 1404 | "get-intrinsic": "^1.1.1" 1405 | }, 1406 | "funding": { 1407 | "url": "https://github.com/sponsors/ljharb" 1408 | } 1409 | }, 1410 | "node_modules/has-proto": { 1411 | "version": "1.0.1", 1412 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", 1413 | "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", 1414 | "dev": true, 1415 | "engines": { 1416 | "node": ">= 0.4" 1417 | }, 1418 | "funding": { 1419 | "url": "https://github.com/sponsors/ljharb" 1420 | } 1421 | }, 1422 | "node_modules/has-symbols": { 1423 | "version": "1.0.3", 1424 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 1425 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 1426 | "dev": true, 1427 | "engines": { 1428 | "node": ">= 0.4" 1429 | }, 1430 | "funding": { 1431 | "url": "https://github.com/sponsors/ljharb" 1432 | } 1433 | }, 1434 | "node_modules/has-tostringtag": { 1435 | "version": "1.0.0", 1436 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", 1437 | "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", 1438 | "dev": true, 1439 | "dependencies": { 1440 | "has-symbols": "^1.0.2" 1441 | }, 1442 | "engines": { 1443 | "node": ">= 0.4" 1444 | }, 1445 | "funding": { 1446 | "url": "https://github.com/sponsors/ljharb" 1447 | } 1448 | }, 1449 | "node_modules/hookified": { 1450 | "version": "1.8.2", 1451 | "resolved": "https://registry.npmjs.org/hookified/-/hookified-1.8.2.tgz", 1452 | "integrity": "sha512-5nZbBNP44sFCDjSoB//0N7m508APCgbQ4mGGo1KJGBYyCKNHfry1Pvd0JVHZIxjdnqn8nFRBAN/eFB6Rk/4w5w==", 1453 | "dev": true, 1454 | "license": "MIT" 1455 | }, 1456 | "node_modules/hosted-git-info": { 1457 | "version": "2.8.9", 1458 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", 1459 | "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==", 1460 | "dev": true 1461 | }, 1462 | "node_modules/ieee754": { 1463 | "version": "1.2.1", 1464 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 1465 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", 1466 | "dev": true, 1467 | "funding": [ 1468 | { 1469 | "type": "github", 1470 | "url": "https://github.com/sponsors/feross" 1471 | }, 1472 | { 1473 | "type": "patreon", 1474 | "url": "https://www.patreon.com/feross" 1475 | }, 1476 | { 1477 | "type": "consulting", 1478 | "url": "https://feross.org/support" 1479 | } 1480 | ], 1481 | "license": "BSD-3-Clause" 1482 | }, 1483 | "node_modules/internal-slot": { 1484 | "version": "1.0.5", 1485 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.5.tgz", 1486 | "integrity": "sha512-Y+R5hJrzs52QCG2laLn4udYVnxsfny9CpOhNhUvk/SSSVyF6T27FzRbF0sroPidSu3X8oEAkOn2K804mjpt6UQ==", 1487 | "dev": true, 1488 | "dependencies": { 1489 | "get-intrinsic": "^1.2.0", 1490 | "has": "^1.0.3", 1491 | "side-channel": "^1.0.4" 1492 | }, 1493 | "engines": { 1494 | "node": ">= 0.4" 1495 | } 1496 | }, 1497 | "node_modules/is-array-buffer": { 1498 | "version": "3.0.2", 1499 | "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.2.tgz", 1500 | "integrity": "sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==", 1501 | "dev": true, 1502 | "dependencies": { 1503 | "call-bind": "^1.0.2", 1504 | "get-intrinsic": "^1.2.0", 1505 | "is-typed-array": "^1.1.10" 1506 | }, 1507 | "funding": { 1508 | "url": "https://github.com/sponsors/ljharb" 1509 | } 1510 | }, 1511 | "node_modules/is-arrayish": { 1512 | "version": "0.2.1", 1513 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1514 | "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", 1515 | "dev": true 1516 | }, 1517 | "node_modules/is-bigint": { 1518 | "version": "1.0.4", 1519 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 1520 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 1521 | "dev": true, 1522 | "dependencies": { 1523 | "has-bigints": "^1.0.1" 1524 | }, 1525 | "funding": { 1526 | "url": "https://github.com/sponsors/ljharb" 1527 | } 1528 | }, 1529 | "node_modules/is-boolean-object": { 1530 | "version": "1.1.2", 1531 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 1532 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 1533 | "dev": true, 1534 | "dependencies": { 1535 | "call-bind": "^1.0.2", 1536 | "has-tostringtag": "^1.0.0" 1537 | }, 1538 | "engines": { 1539 | "node": ">= 0.4" 1540 | }, 1541 | "funding": { 1542 | "url": "https://github.com/sponsors/ljharb" 1543 | } 1544 | }, 1545 | "node_modules/is-callable": { 1546 | "version": "1.2.7", 1547 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", 1548 | "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", 1549 | "dev": true, 1550 | "engines": { 1551 | "node": ">= 0.4" 1552 | }, 1553 | "funding": { 1554 | "url": "https://github.com/sponsors/ljharb" 1555 | } 1556 | }, 1557 | "node_modules/is-core-module": { 1558 | "version": "2.13.0", 1559 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.0.tgz", 1560 | "integrity": "sha512-Z7dk6Qo8pOCp3l4tsX2C5ZVas4V+UxwQodwZhLopL91TX8UyyHEXafPcyoeeWuLrwzHcr3igO78wNLwHJHsMCQ==", 1561 | "dev": true, 1562 | "dependencies": { 1563 | "has": "^1.0.3" 1564 | }, 1565 | "funding": { 1566 | "url": "https://github.com/sponsors/ljharb" 1567 | } 1568 | }, 1569 | "node_modules/is-date-object": { 1570 | "version": "1.0.5", 1571 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 1572 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 1573 | "dev": true, 1574 | "dependencies": { 1575 | "has-tostringtag": "^1.0.0" 1576 | }, 1577 | "engines": { 1578 | "node": ">= 0.4" 1579 | }, 1580 | "funding": { 1581 | "url": "https://github.com/sponsors/ljharb" 1582 | } 1583 | }, 1584 | "node_modules/is-fullwidth-code-point": { 1585 | "version": "3.0.0", 1586 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1587 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1588 | "dev": true, 1589 | "license": "MIT", 1590 | "engines": { 1591 | "node": ">=8" 1592 | } 1593 | }, 1594 | "node_modules/is-negative-zero": { 1595 | "version": "2.0.2", 1596 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", 1597 | "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", 1598 | "dev": true, 1599 | "engines": { 1600 | "node": ">= 0.4" 1601 | }, 1602 | "funding": { 1603 | "url": "https://github.com/sponsors/ljharb" 1604 | } 1605 | }, 1606 | "node_modules/is-number-object": { 1607 | "version": "1.0.7", 1608 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", 1609 | "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", 1610 | "dev": true, 1611 | "dependencies": { 1612 | "has-tostringtag": "^1.0.0" 1613 | }, 1614 | "engines": { 1615 | "node": ">= 0.4" 1616 | }, 1617 | "funding": { 1618 | "url": "https://github.com/sponsors/ljharb" 1619 | } 1620 | }, 1621 | "node_modules/is-regex": { 1622 | "version": "1.1.4", 1623 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 1624 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 1625 | "dev": true, 1626 | "dependencies": { 1627 | "call-bind": "^1.0.2", 1628 | "has-tostringtag": "^1.0.0" 1629 | }, 1630 | "engines": { 1631 | "node": ">= 0.4" 1632 | }, 1633 | "funding": { 1634 | "url": "https://github.com/sponsors/ljharb" 1635 | } 1636 | }, 1637 | "node_modules/is-shared-array-buffer": { 1638 | "version": "1.0.2", 1639 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz", 1640 | "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==", 1641 | "dev": true, 1642 | "dependencies": { 1643 | "call-bind": "^1.0.2" 1644 | }, 1645 | "funding": { 1646 | "url": "https://github.com/sponsors/ljharb" 1647 | } 1648 | }, 1649 | "node_modules/is-string": { 1650 | "version": "1.0.7", 1651 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 1652 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 1653 | "dev": true, 1654 | "dependencies": { 1655 | "has-tostringtag": "^1.0.0" 1656 | }, 1657 | "engines": { 1658 | "node": ">= 0.4" 1659 | }, 1660 | "funding": { 1661 | "url": "https://github.com/sponsors/ljharb" 1662 | } 1663 | }, 1664 | "node_modules/is-symbol": { 1665 | "version": "1.0.4", 1666 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 1667 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 1668 | "dev": true, 1669 | "dependencies": { 1670 | "has-symbols": "^1.0.2" 1671 | }, 1672 | "engines": { 1673 | "node": ">= 0.4" 1674 | }, 1675 | "funding": { 1676 | "url": "https://github.com/sponsors/ljharb" 1677 | } 1678 | }, 1679 | "node_modules/is-typed-array": { 1680 | "version": "1.1.12", 1681 | "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.12.tgz", 1682 | "integrity": "sha512-Z14TF2JNG8Lss5/HMqt0//T9JeHXttXy5pH/DBU4vi98ozO2btxzq9MwYDZYnKwU8nRsz/+GVFVRDq3DkVuSPg==", 1683 | "dev": true, 1684 | "dependencies": { 1685 | "which-typed-array": "^1.1.11" 1686 | }, 1687 | "engines": { 1688 | "node": ">= 0.4" 1689 | }, 1690 | "funding": { 1691 | "url": "https://github.com/sponsors/ljharb" 1692 | } 1693 | }, 1694 | "node_modules/is-weakref": { 1695 | "version": "1.0.2", 1696 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", 1697 | "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", 1698 | "dev": true, 1699 | "dependencies": { 1700 | "call-bind": "^1.0.2" 1701 | }, 1702 | "funding": { 1703 | "url": "https://github.com/sponsors/ljharb" 1704 | } 1705 | }, 1706 | "node_modules/isarray": { 1707 | "version": "2.0.5", 1708 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", 1709 | "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", 1710 | "dev": true 1711 | }, 1712 | "node_modules/isexe": { 1713 | "version": "2.0.0", 1714 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1715 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1716 | "dev": true 1717 | }, 1718 | "node_modules/jackspeak": { 1719 | "version": "4.0.3", 1720 | "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-4.0.3.tgz", 1721 | "integrity": "sha512-oSwM7q8PTHQWuZAlp995iPpPJ4Vkl7qT0ZRD+9duL9j2oBy6KcTfyxc8mEuHJYC+z/kbps80aJLkaNzTOrf/kw==", 1722 | "dev": true, 1723 | "license": "BlueOak-1.0.0", 1724 | "dependencies": { 1725 | "@isaacs/cliui": "^8.0.2" 1726 | }, 1727 | "engines": { 1728 | "node": "20 || >=22" 1729 | }, 1730 | "funding": { 1731 | "url": "https://github.com/sponsors/isaacs" 1732 | } 1733 | }, 1734 | "node_modules/json-parse-better-errors": { 1735 | "version": "1.0.2", 1736 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 1737 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 1738 | "dev": true 1739 | }, 1740 | "node_modules/keyv": { 1741 | "version": "5.3.3", 1742 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-5.3.3.tgz", 1743 | "integrity": "sha512-Rwu4+nXI9fqcxiEHtbkvoes2X+QfkTRo1TMkPfwzipGsJlJO/z69vqB4FNl9xJ3xCpAcbkvmEabZfPzrwN3+gQ==", 1744 | "dev": true, 1745 | "license": "MIT", 1746 | "dependencies": { 1747 | "@keyv/serialize": "^1.0.3" 1748 | } 1749 | }, 1750 | "node_modules/load-json-file": { 1751 | "version": "4.0.0", 1752 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 1753 | "integrity": "sha512-Kx8hMakjX03tiGTLAIdJ+lL0htKnXjEZN6hk/tozf/WOuYGdZBJrZ+rCJRbVCugsjB3jMLn9746NsQIf5VjBMw==", 1754 | "dev": true, 1755 | "dependencies": { 1756 | "graceful-fs": "^4.1.2", 1757 | "parse-json": "^4.0.0", 1758 | "pify": "^3.0.0", 1759 | "strip-bom": "^3.0.0" 1760 | }, 1761 | "engines": { 1762 | "node": ">=4" 1763 | } 1764 | }, 1765 | "node_modules/lru-cache": { 1766 | "version": "11.0.2", 1767 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-11.0.2.tgz", 1768 | "integrity": "sha512-123qHRfJBmo2jXDbo/a5YOQrJoHF/GNQTLzQ5+IdK5pWpceK17yRc6ozlWd25FxvGKQbIUs91fDFkXmDHTKcyA==", 1769 | "dev": true, 1770 | "license": "ISC", 1771 | "engines": { 1772 | "node": "20 || >=22" 1773 | } 1774 | }, 1775 | "node_modules/make-error": { 1776 | "version": "1.3.6", 1777 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1778 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 1779 | "dev": true 1780 | }, 1781 | "node_modules/memorystream": { 1782 | "version": "0.3.1", 1783 | "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", 1784 | "integrity": "sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw==", 1785 | "dev": true, 1786 | "engines": { 1787 | "node": ">= 0.10.0" 1788 | } 1789 | }, 1790 | "node_modules/minimatch": { 1791 | "version": "3.1.2", 1792 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1793 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1794 | "dev": true, 1795 | "dependencies": { 1796 | "brace-expansion": "^1.1.7" 1797 | }, 1798 | "engines": { 1799 | "node": "*" 1800 | } 1801 | }, 1802 | "node_modules/minipass": { 1803 | "version": "7.1.2", 1804 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", 1805 | "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", 1806 | "dev": true, 1807 | "license": "ISC", 1808 | "engines": { 1809 | "node": ">=16 || 14 >=14.17" 1810 | } 1811 | }, 1812 | "node_modules/ms": { 1813 | "version": "2.1.3", 1814 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1815 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1816 | "dev": true, 1817 | "license": "MIT" 1818 | }, 1819 | "node_modules/nice-try": { 1820 | "version": "1.0.5", 1821 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1822 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1823 | "dev": true 1824 | }, 1825 | "node_modules/normalize-package-data": { 1826 | "version": "2.5.0", 1827 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1828 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1829 | "dev": true, 1830 | "dependencies": { 1831 | "hosted-git-info": "^2.1.4", 1832 | "resolve": "^1.10.0", 1833 | "semver": "2 || 3 || 4 || 5", 1834 | "validate-npm-package-license": "^3.0.1" 1835 | } 1836 | }, 1837 | "node_modules/npm-run-all": { 1838 | "version": "4.1.5", 1839 | "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", 1840 | "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", 1841 | "dev": true, 1842 | "dependencies": { 1843 | "ansi-styles": "^3.2.1", 1844 | "chalk": "^2.4.1", 1845 | "cross-spawn": "^6.0.5", 1846 | "memorystream": "^0.3.1", 1847 | "minimatch": "^3.0.4", 1848 | "pidtree": "^0.3.0", 1849 | "read-pkg": "^3.0.0", 1850 | "shell-quote": "^1.6.1", 1851 | "string.prototype.padend": "^3.0.0" 1852 | }, 1853 | "bin": { 1854 | "npm-run-all": "bin/npm-run-all/index.js", 1855 | "run-p": "bin/run-p/index.js", 1856 | "run-s": "bin/run-s/index.js" 1857 | }, 1858 | "engines": { 1859 | "node": ">= 4" 1860 | } 1861 | }, 1862 | "node_modules/object-code": { 1863 | "version": "1.3.3", 1864 | "resolved": "https://registry.npmjs.org/object-code/-/object-code-1.3.3.tgz", 1865 | "integrity": "sha512-/Ds4Xd5xzrtUOJ+xJQ57iAy0BZsZltOHssnDgcZ8DOhgh41q1YJCnTPnWdWSLkNGNnxYzhYChjc5dgC9mEERCA==", 1866 | "license": "MIT" 1867 | }, 1868 | "node_modules/object-inspect": { 1869 | "version": "1.12.3", 1870 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 1871 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==", 1872 | "dev": true, 1873 | "funding": { 1874 | "url": "https://github.com/sponsors/ljharb" 1875 | } 1876 | }, 1877 | "node_modules/object-keys": { 1878 | "version": "1.1.1", 1879 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1880 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1881 | "dev": true, 1882 | "engines": { 1883 | "node": ">= 0.4" 1884 | } 1885 | }, 1886 | "node_modules/object.assign": { 1887 | "version": "4.1.4", 1888 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.4.tgz", 1889 | "integrity": "sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ==", 1890 | "dev": true, 1891 | "dependencies": { 1892 | "call-bind": "^1.0.2", 1893 | "define-properties": "^1.1.4", 1894 | "has-symbols": "^1.0.3", 1895 | "object-keys": "^1.1.1" 1896 | }, 1897 | "engines": { 1898 | "node": ">= 0.4" 1899 | }, 1900 | "funding": { 1901 | "url": "https://github.com/sponsors/ljharb" 1902 | } 1903 | }, 1904 | "node_modules/package-json-from-dist": { 1905 | "version": "1.0.1", 1906 | "resolved": "https://registry.npmjs.org/package-json-from-dist/-/package-json-from-dist-1.0.1.tgz", 1907 | "integrity": "sha512-UEZIS3/by4OC8vL3P2dTXRETpebLI2NiI5vIrjaD/5UtrkFX/tNbwjTSRAGC/+7CAo2pIcBaRgWmcBBHcsaCIw==", 1908 | "dev": true, 1909 | "license": "BlueOak-1.0.0" 1910 | }, 1911 | "node_modules/parse-json": { 1912 | "version": "4.0.0", 1913 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 1914 | "integrity": "sha512-aOIos8bujGN93/8Ox/jPLh7RwVnPEysynVFE+fQZyg6jKELEHwzgKdLRFHUgXJL6kylijVSBC4BvN9OmsB48Rw==", 1915 | "dev": true, 1916 | "dependencies": { 1917 | "error-ex": "^1.3.1", 1918 | "json-parse-better-errors": "^1.0.1" 1919 | }, 1920 | "engines": { 1921 | "node": ">=4" 1922 | } 1923 | }, 1924 | "node_modules/path-key": { 1925 | "version": "2.0.1", 1926 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1927 | "integrity": "sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw==", 1928 | "dev": true, 1929 | "engines": { 1930 | "node": ">=4" 1931 | } 1932 | }, 1933 | "node_modules/path-parse": { 1934 | "version": "1.0.7", 1935 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1936 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1937 | "dev": true 1938 | }, 1939 | "node_modules/path-scurry": { 1940 | "version": "2.0.0", 1941 | "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-2.0.0.tgz", 1942 | "integrity": "sha512-ypGJsmGtdXUOeM5u93TyeIEfEhM6s+ljAhrk5vAvSx8uyY/02OvrZnA0YNGUrPXfpJMgI1ODd3nwz8Npx4O4cg==", 1943 | "dev": true, 1944 | "license": "BlueOak-1.0.0", 1945 | "dependencies": { 1946 | "lru-cache": "^11.0.0", 1947 | "minipass": "^7.1.2" 1948 | }, 1949 | "engines": { 1950 | "node": "20 || >=22" 1951 | }, 1952 | "funding": { 1953 | "url": "https://github.com/sponsors/isaacs" 1954 | } 1955 | }, 1956 | "node_modules/path-type": { 1957 | "version": "3.0.0", 1958 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", 1959 | "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", 1960 | "dev": true, 1961 | "dependencies": { 1962 | "pify": "^3.0.0" 1963 | }, 1964 | "engines": { 1965 | "node": ">=4" 1966 | } 1967 | }, 1968 | "node_modules/pidtree": { 1969 | "version": "0.3.1", 1970 | "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.1.tgz", 1971 | "integrity": "sha512-qQbW94hLHEqCg7nhby4yRC7G2+jYHY4Rguc2bjw7Uug4GIJuu1tvf2uHaZv5Q8zdt+WKJ6qK1FOI6amaWUo5FA==", 1972 | "dev": true, 1973 | "bin": { 1974 | "pidtree": "bin/pidtree.js" 1975 | }, 1976 | "engines": { 1977 | "node": ">=0.10" 1978 | } 1979 | }, 1980 | "node_modules/pify": { 1981 | "version": "3.0.0", 1982 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 1983 | "integrity": "sha512-C3FsVNH1udSEX48gGX1xfvwTWfsYWj5U+8/uK15BGzIGrKoUpghX8hWZwa/OFnakBiiVNmBvemTJR5mcy7iPcg==", 1984 | "dev": true, 1985 | "engines": { 1986 | "node": ">=4" 1987 | } 1988 | }, 1989 | "node_modules/prisma": { 1990 | "version": "6.6.0", 1991 | "resolved": "https://registry.npmjs.org/prisma/-/prisma-6.6.0.tgz", 1992 | "integrity": "sha512-SYCUykz+1cnl6Ugd8VUvtTQq5+j1Q7C0CtzKPjQ8JyA2ALh0EEJkMCS+KgdnvKW1lrxjtjCyJSHOOT236mENYg==", 1993 | "dev": true, 1994 | "hasInstallScript": true, 1995 | "license": "Apache-2.0", 1996 | "dependencies": { 1997 | "@prisma/config": "6.6.0", 1998 | "@prisma/engines": "6.6.0" 1999 | }, 2000 | "bin": { 2001 | "prisma": "build/index.js" 2002 | }, 2003 | "engines": { 2004 | "node": ">=18.18" 2005 | }, 2006 | "optionalDependencies": { 2007 | "fsevents": "2.3.3" 2008 | }, 2009 | "peerDependencies": { 2010 | "typescript": ">=5.1.0" 2011 | }, 2012 | "peerDependenciesMeta": { 2013 | "typescript": { 2014 | "optional": true 2015 | } 2016 | } 2017 | }, 2018 | "node_modules/read-pkg": { 2019 | "version": "3.0.0", 2020 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", 2021 | "integrity": "sha512-BLq/cCO9two+lBgiTYNqD6GdtK8s4NpaWrl6/rCO9w0TUS8oJl7cmToOZfRYllKTISY6nt1U7jQ53brmKqY6BA==", 2022 | "dev": true, 2023 | "dependencies": { 2024 | "load-json-file": "^4.0.0", 2025 | "normalize-package-data": "^2.3.2", 2026 | "path-type": "^3.0.0" 2027 | }, 2028 | "engines": { 2029 | "node": ">=4" 2030 | } 2031 | }, 2032 | "node_modules/regexp.prototype.flags": { 2033 | "version": "1.5.1", 2034 | "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz", 2035 | "integrity": "sha512-sy6TXMN+hnP/wMy+ISxg3krXx7BAtWVO4UouuCN/ziM9UEne0euamVNafDfvC83bRNr95y0V5iijeDQFUNpvrg==", 2036 | "dev": true, 2037 | "dependencies": { 2038 | "call-bind": "^1.0.2", 2039 | "define-properties": "^1.2.0", 2040 | "set-function-name": "^2.0.0" 2041 | }, 2042 | "engines": { 2043 | "node": ">= 0.4" 2044 | }, 2045 | "funding": { 2046 | "url": "https://github.com/sponsors/ljharb" 2047 | } 2048 | }, 2049 | "node_modules/resolve": { 2050 | "version": "1.22.6", 2051 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.6.tgz", 2052 | "integrity": "sha512-njhxM7mV12JfufShqGy3Rz8j11RPdLy4xi15UurGJeoHLfJpVXKdh3ueuOqbYUcDZnffr6X739JBo5LzyahEsw==", 2053 | "dev": true, 2054 | "dependencies": { 2055 | "is-core-module": "^2.13.0", 2056 | "path-parse": "^1.0.7", 2057 | "supports-preserve-symlinks-flag": "^1.0.0" 2058 | }, 2059 | "bin": { 2060 | "resolve": "bin/resolve" 2061 | }, 2062 | "funding": { 2063 | "url": "https://github.com/sponsors/ljharb" 2064 | } 2065 | }, 2066 | "node_modules/rimraf": { 2067 | "version": "6.0.1", 2068 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-6.0.1.tgz", 2069 | "integrity": "sha512-9dkvaxAsk/xNXSJzMgFqqMCuFgt2+KsOFek3TMLfo8NCPfWpBmqwyNn5Y+NX56QUYfCtsyhF3ayiboEoUmJk/A==", 2070 | "dev": true, 2071 | "license": "ISC", 2072 | "dependencies": { 2073 | "glob": "^11.0.0", 2074 | "package-json-from-dist": "^1.0.0" 2075 | }, 2076 | "bin": { 2077 | "rimraf": "dist/esm/bin.mjs" 2078 | }, 2079 | "engines": { 2080 | "node": "20 || >=22" 2081 | }, 2082 | "funding": { 2083 | "url": "https://github.com/sponsors/isaacs" 2084 | } 2085 | }, 2086 | "node_modules/safe-array-concat": { 2087 | "version": "1.0.1", 2088 | "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.0.1.tgz", 2089 | "integrity": "sha512-6XbUAseYE2KtOuGueyeobCySj9L4+66Tn6KQMOPQJrAJEowYKW/YR/MGJZl7FdydUdaFu4LYyDZjxf4/Nmo23Q==", 2090 | "dev": true, 2091 | "dependencies": { 2092 | "call-bind": "^1.0.2", 2093 | "get-intrinsic": "^1.2.1", 2094 | "has-symbols": "^1.0.3", 2095 | "isarray": "^2.0.5" 2096 | }, 2097 | "engines": { 2098 | "node": ">=0.4" 2099 | }, 2100 | "funding": { 2101 | "url": "https://github.com/sponsors/ljharb" 2102 | } 2103 | }, 2104 | "node_modules/safe-regex-test": { 2105 | "version": "1.0.0", 2106 | "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.0.tgz", 2107 | "integrity": "sha512-JBUUzyOgEwXQY1NuPtvcj/qcBDbDmEvWufhlnXZIm75DEHp+afM1r1ujJpJsV/gSM4t59tpDyPi1sd6ZaPFfsA==", 2108 | "dev": true, 2109 | "dependencies": { 2110 | "call-bind": "^1.0.2", 2111 | "get-intrinsic": "^1.1.3", 2112 | "is-regex": "^1.1.4" 2113 | }, 2114 | "funding": { 2115 | "url": "https://github.com/sponsors/ljharb" 2116 | } 2117 | }, 2118 | "node_modules/semver": { 2119 | "version": "5.7.2", 2120 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", 2121 | "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", 2122 | "dev": true, 2123 | "bin": { 2124 | "semver": "bin/semver" 2125 | } 2126 | }, 2127 | "node_modules/set-function-name": { 2128 | "version": "2.0.1", 2129 | "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.1.tgz", 2130 | "integrity": "sha512-tMNCiqYVkXIZgc2Hnoy2IvC/f8ezc5koaRFkCjrpWzGpCd3qbZXPzVy9MAZzK1ch/X0jvSkojys3oqJN0qCmdA==", 2131 | "dev": true, 2132 | "dependencies": { 2133 | "define-data-property": "^1.0.1", 2134 | "functions-have-names": "^1.2.3", 2135 | "has-property-descriptors": "^1.0.0" 2136 | }, 2137 | "engines": { 2138 | "node": ">= 0.4" 2139 | } 2140 | }, 2141 | "node_modules/shebang-command": { 2142 | "version": "1.2.0", 2143 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2144 | "integrity": "sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg==", 2145 | "dev": true, 2146 | "dependencies": { 2147 | "shebang-regex": "^1.0.0" 2148 | }, 2149 | "engines": { 2150 | "node": ">=0.10.0" 2151 | } 2152 | }, 2153 | "node_modules/shebang-regex": { 2154 | "version": "1.0.0", 2155 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2156 | "integrity": "sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ==", 2157 | "dev": true, 2158 | "engines": { 2159 | "node": ">=0.10.0" 2160 | } 2161 | }, 2162 | "node_modules/shell-quote": { 2163 | "version": "1.8.1", 2164 | "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.8.1.tgz", 2165 | "integrity": "sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==", 2166 | "dev": true, 2167 | "funding": { 2168 | "url": "https://github.com/sponsors/ljharb" 2169 | } 2170 | }, 2171 | "node_modules/side-channel": { 2172 | "version": "1.0.4", 2173 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 2174 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 2175 | "dev": true, 2176 | "dependencies": { 2177 | "call-bind": "^1.0.0", 2178 | "get-intrinsic": "^1.0.2", 2179 | "object-inspect": "^1.9.0" 2180 | }, 2181 | "funding": { 2182 | "url": "https://github.com/sponsors/ljharb" 2183 | } 2184 | }, 2185 | "node_modules/signal-exit": { 2186 | "version": "4.1.0", 2187 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", 2188 | "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", 2189 | "dev": true, 2190 | "license": "ISC", 2191 | "engines": { 2192 | "node": ">=14" 2193 | }, 2194 | "funding": { 2195 | "url": "https://github.com/sponsors/isaacs" 2196 | } 2197 | }, 2198 | "node_modules/spdx-correct": { 2199 | "version": "3.2.0", 2200 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz", 2201 | "integrity": "sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==", 2202 | "dev": true, 2203 | "dependencies": { 2204 | "spdx-expression-parse": "^3.0.0", 2205 | "spdx-license-ids": "^3.0.0" 2206 | } 2207 | }, 2208 | "node_modules/spdx-exceptions": { 2209 | "version": "2.3.0", 2210 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 2211 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", 2212 | "dev": true 2213 | }, 2214 | "node_modules/spdx-expression-parse": { 2215 | "version": "3.0.1", 2216 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 2217 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 2218 | "dev": true, 2219 | "dependencies": { 2220 | "spdx-exceptions": "^2.1.0", 2221 | "spdx-license-ids": "^3.0.0" 2222 | } 2223 | }, 2224 | "node_modules/spdx-license-ids": { 2225 | "version": "3.0.15", 2226 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.15.tgz", 2227 | "integrity": "sha512-lpT8hSQp9jAKp9mhtBU4Xjon8LPGBvLIuBiSVhMEtmLecTh2mO0tlqrAMp47tBXzMr13NJMQ2lf7RpQGLJ3HsQ==", 2228 | "dev": true 2229 | }, 2230 | "node_modules/string-width": { 2231 | "version": "5.1.2", 2232 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", 2233 | "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", 2234 | "dev": true, 2235 | "license": "MIT", 2236 | "dependencies": { 2237 | "eastasianwidth": "^0.2.0", 2238 | "emoji-regex": "^9.2.2", 2239 | "strip-ansi": "^7.0.1" 2240 | }, 2241 | "engines": { 2242 | "node": ">=12" 2243 | }, 2244 | "funding": { 2245 | "url": "https://github.com/sponsors/sindresorhus" 2246 | } 2247 | }, 2248 | "node_modules/string-width-cjs": { 2249 | "name": "string-width", 2250 | "version": "4.2.3", 2251 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2252 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2253 | "dev": true, 2254 | "license": "MIT", 2255 | "dependencies": { 2256 | "emoji-regex": "^8.0.0", 2257 | "is-fullwidth-code-point": "^3.0.0", 2258 | "strip-ansi": "^6.0.1" 2259 | }, 2260 | "engines": { 2261 | "node": ">=8" 2262 | } 2263 | }, 2264 | "node_modules/string-width-cjs/node_modules/ansi-regex": { 2265 | "version": "5.0.1", 2266 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2267 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2268 | "dev": true, 2269 | "license": "MIT", 2270 | "engines": { 2271 | "node": ">=8" 2272 | } 2273 | }, 2274 | "node_modules/string-width-cjs/node_modules/emoji-regex": { 2275 | "version": "8.0.0", 2276 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2277 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2278 | "dev": true, 2279 | "license": "MIT" 2280 | }, 2281 | "node_modules/string-width-cjs/node_modules/strip-ansi": { 2282 | "version": "6.0.1", 2283 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2284 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2285 | "dev": true, 2286 | "license": "MIT", 2287 | "dependencies": { 2288 | "ansi-regex": "^5.0.1" 2289 | }, 2290 | "engines": { 2291 | "node": ">=8" 2292 | } 2293 | }, 2294 | "node_modules/string.prototype.padend": { 2295 | "version": "3.1.5", 2296 | "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.5.tgz", 2297 | "integrity": "sha512-DOB27b/2UTTD+4myKUFh+/fXWcu/UDyASIXfg+7VzoCNNGOfWvoyU/x5pvVHr++ztyt/oSYI1BcWBBG/hmlNjA==", 2298 | "dev": true, 2299 | "dependencies": { 2300 | "call-bind": "^1.0.2", 2301 | "define-properties": "^1.2.0", 2302 | "es-abstract": "^1.22.1" 2303 | }, 2304 | "engines": { 2305 | "node": ">= 0.4" 2306 | }, 2307 | "funding": { 2308 | "url": "https://github.com/sponsors/ljharb" 2309 | } 2310 | }, 2311 | "node_modules/string.prototype.trim": { 2312 | "version": "1.2.8", 2313 | "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz", 2314 | "integrity": "sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==", 2315 | "dev": true, 2316 | "dependencies": { 2317 | "call-bind": "^1.0.2", 2318 | "define-properties": "^1.2.0", 2319 | "es-abstract": "^1.22.1" 2320 | }, 2321 | "engines": { 2322 | "node": ">= 0.4" 2323 | }, 2324 | "funding": { 2325 | "url": "https://github.com/sponsors/ljharb" 2326 | } 2327 | }, 2328 | "node_modules/string.prototype.trimend": { 2329 | "version": "1.0.7", 2330 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz", 2331 | "integrity": "sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==", 2332 | "dev": true, 2333 | "dependencies": { 2334 | "call-bind": "^1.0.2", 2335 | "define-properties": "^1.2.0", 2336 | "es-abstract": "^1.22.1" 2337 | }, 2338 | "funding": { 2339 | "url": "https://github.com/sponsors/ljharb" 2340 | } 2341 | }, 2342 | "node_modules/string.prototype.trimstart": { 2343 | "version": "1.0.7", 2344 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz", 2345 | "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==", 2346 | "dev": true, 2347 | "dependencies": { 2348 | "call-bind": "^1.0.2", 2349 | "define-properties": "^1.2.0", 2350 | "es-abstract": "^1.22.1" 2351 | }, 2352 | "funding": { 2353 | "url": "https://github.com/sponsors/ljharb" 2354 | } 2355 | }, 2356 | "node_modules/strip-ansi": { 2357 | "version": "7.1.0", 2358 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 2359 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 2360 | "dev": true, 2361 | "license": "MIT", 2362 | "dependencies": { 2363 | "ansi-regex": "^6.0.1" 2364 | }, 2365 | "engines": { 2366 | "node": ">=12" 2367 | }, 2368 | "funding": { 2369 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 2370 | } 2371 | }, 2372 | "node_modules/strip-ansi-cjs": { 2373 | "name": "strip-ansi", 2374 | "version": "6.0.1", 2375 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2376 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2377 | "dev": true, 2378 | "license": "MIT", 2379 | "dependencies": { 2380 | "ansi-regex": "^5.0.1" 2381 | }, 2382 | "engines": { 2383 | "node": ">=8" 2384 | } 2385 | }, 2386 | "node_modules/strip-ansi-cjs/node_modules/ansi-regex": { 2387 | "version": "5.0.1", 2388 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2389 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2390 | "dev": true, 2391 | "license": "MIT", 2392 | "engines": { 2393 | "node": ">=8" 2394 | } 2395 | }, 2396 | "node_modules/strip-bom": { 2397 | "version": "3.0.0", 2398 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2399 | "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", 2400 | "dev": true, 2401 | "engines": { 2402 | "node": ">=4" 2403 | } 2404 | }, 2405 | "node_modules/supports-color": { 2406 | "version": "5.5.0", 2407 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2408 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2409 | "dev": true, 2410 | "dependencies": { 2411 | "has-flag": "^3.0.0" 2412 | }, 2413 | "engines": { 2414 | "node": ">=4" 2415 | } 2416 | }, 2417 | "node_modules/supports-preserve-symlinks-flag": { 2418 | "version": "1.0.0", 2419 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 2420 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 2421 | "dev": true, 2422 | "engines": { 2423 | "node": ">= 0.4" 2424 | }, 2425 | "funding": { 2426 | "url": "https://github.com/sponsors/ljharb" 2427 | } 2428 | }, 2429 | "node_modules/ts-node": { 2430 | "version": "10.9.2", 2431 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.2.tgz", 2432 | "integrity": "sha512-f0FFpIdcHgn8zcPSbf1dRevwt047YMnaiJM3u2w2RewrB+fob/zePZcrOyQoLMMO7aBIddLcQIEK5dYjkLnGrQ==", 2433 | "dev": true, 2434 | "license": "MIT", 2435 | "dependencies": { 2436 | "@cspotcode/source-map-support": "^0.8.0", 2437 | "@tsconfig/node10": "^1.0.7", 2438 | "@tsconfig/node12": "^1.0.7", 2439 | "@tsconfig/node14": "^1.0.0", 2440 | "@tsconfig/node16": "^1.0.2", 2441 | "acorn": "^8.4.1", 2442 | "acorn-walk": "^8.1.1", 2443 | "arg": "^4.1.0", 2444 | "create-require": "^1.1.0", 2445 | "diff": "^4.0.1", 2446 | "make-error": "^1.1.1", 2447 | "v8-compile-cache-lib": "^3.0.1", 2448 | "yn": "3.1.1" 2449 | }, 2450 | "bin": { 2451 | "ts-node": "dist/bin.js", 2452 | "ts-node-cwd": "dist/bin-cwd.js", 2453 | "ts-node-esm": "dist/bin-esm.js", 2454 | "ts-node-script": "dist/bin-script.js", 2455 | "ts-node-transpile-only": "dist/bin-transpile.js", 2456 | "ts-script": "dist/bin-script-deprecated.js" 2457 | }, 2458 | "peerDependencies": { 2459 | "@swc/core": ">=1.2.50", 2460 | "@swc/wasm": ">=1.2.50", 2461 | "@types/node": "*", 2462 | "typescript": ">=2.7" 2463 | }, 2464 | "peerDependenciesMeta": { 2465 | "@swc/core": { 2466 | "optional": true 2467 | }, 2468 | "@swc/wasm": { 2469 | "optional": true 2470 | } 2471 | } 2472 | }, 2473 | "node_modules/typed-array-buffer": { 2474 | "version": "1.0.0", 2475 | "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.0.tgz", 2476 | "integrity": "sha512-Y8KTSIglk9OZEr8zywiIHG/kmQ7KWyjseXs1CbSo8vC42w7hg2HgYTxSWwP0+is7bWDc1H+Fo026CpHFwm8tkw==", 2477 | "dev": true, 2478 | "dependencies": { 2479 | "call-bind": "^1.0.2", 2480 | "get-intrinsic": "^1.2.1", 2481 | "is-typed-array": "^1.1.10" 2482 | }, 2483 | "engines": { 2484 | "node": ">= 0.4" 2485 | } 2486 | }, 2487 | "node_modules/typed-array-byte-length": { 2488 | "version": "1.0.0", 2489 | "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz", 2490 | "integrity": "sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA==", 2491 | "dev": true, 2492 | "dependencies": { 2493 | "call-bind": "^1.0.2", 2494 | "for-each": "^0.3.3", 2495 | "has-proto": "^1.0.1", 2496 | "is-typed-array": "^1.1.10" 2497 | }, 2498 | "engines": { 2499 | "node": ">= 0.4" 2500 | }, 2501 | "funding": { 2502 | "url": "https://github.com/sponsors/ljharb" 2503 | } 2504 | }, 2505 | "node_modules/typed-array-byte-offset": { 2506 | "version": "1.0.0", 2507 | "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz", 2508 | "integrity": "sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg==", 2509 | "dev": true, 2510 | "dependencies": { 2511 | "available-typed-arrays": "^1.0.5", 2512 | "call-bind": "^1.0.2", 2513 | "for-each": "^0.3.3", 2514 | "has-proto": "^1.0.1", 2515 | "is-typed-array": "^1.1.10" 2516 | }, 2517 | "engines": { 2518 | "node": ">= 0.4" 2519 | }, 2520 | "funding": { 2521 | "url": "https://github.com/sponsors/ljharb" 2522 | } 2523 | }, 2524 | "node_modules/typed-array-length": { 2525 | "version": "1.0.4", 2526 | "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.4.tgz", 2527 | "integrity": "sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==", 2528 | "dev": true, 2529 | "dependencies": { 2530 | "call-bind": "^1.0.2", 2531 | "for-each": "^0.3.3", 2532 | "is-typed-array": "^1.1.9" 2533 | }, 2534 | "funding": { 2535 | "url": "https://github.com/sponsors/ljharb" 2536 | } 2537 | }, 2538 | "node_modules/typescript": { 2539 | "version": "5.8.3", 2540 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.8.3.tgz", 2541 | "integrity": "sha512-p1diW6TqL9L07nNxvRMM7hMMw4c5XOo/1ibL4aAIGmSAt9slTE1Xgw5KWuof2uTOvCg9BY7ZRi+GaF+7sfgPeQ==", 2542 | "dev": true, 2543 | "license": "Apache-2.0", 2544 | "bin": { 2545 | "tsc": "bin/tsc", 2546 | "tsserver": "bin/tsserver" 2547 | }, 2548 | "engines": { 2549 | "node": ">=14.17" 2550 | } 2551 | }, 2552 | "node_modules/unbox-primitive": { 2553 | "version": "1.0.2", 2554 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", 2555 | "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", 2556 | "dev": true, 2557 | "dependencies": { 2558 | "call-bind": "^1.0.2", 2559 | "has-bigints": "^1.0.2", 2560 | "has-symbols": "^1.0.3", 2561 | "which-boxed-primitive": "^1.0.2" 2562 | }, 2563 | "funding": { 2564 | "url": "https://github.com/sponsors/ljharb" 2565 | } 2566 | }, 2567 | "node_modules/v8-compile-cache-lib": { 2568 | "version": "3.0.1", 2569 | "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz", 2570 | "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==", 2571 | "dev": true 2572 | }, 2573 | "node_modules/validate-npm-package-license": { 2574 | "version": "3.0.4", 2575 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 2576 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 2577 | "dev": true, 2578 | "dependencies": { 2579 | "spdx-correct": "^3.0.0", 2580 | "spdx-expression-parse": "^3.0.0" 2581 | } 2582 | }, 2583 | "node_modules/which": { 2584 | "version": "1.3.1", 2585 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2586 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2587 | "dev": true, 2588 | "dependencies": { 2589 | "isexe": "^2.0.0" 2590 | }, 2591 | "bin": { 2592 | "which": "bin/which" 2593 | } 2594 | }, 2595 | "node_modules/which-boxed-primitive": { 2596 | "version": "1.0.2", 2597 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 2598 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 2599 | "dev": true, 2600 | "dependencies": { 2601 | "is-bigint": "^1.0.1", 2602 | "is-boolean-object": "^1.1.0", 2603 | "is-number-object": "^1.0.4", 2604 | "is-string": "^1.0.5", 2605 | "is-symbol": "^1.0.3" 2606 | }, 2607 | "funding": { 2608 | "url": "https://github.com/sponsors/ljharb" 2609 | } 2610 | }, 2611 | "node_modules/which-typed-array": { 2612 | "version": "1.1.11", 2613 | "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.11.tgz", 2614 | "integrity": "sha512-qe9UWWpkeG5yzZ0tNYxDmd7vo58HDBc39mZ0xWWpolAGADdFOzkfamWLDxkOWcvHQKVmdTyQdLD4NOfjLWTKew==", 2615 | "dev": true, 2616 | "dependencies": { 2617 | "available-typed-arrays": "^1.0.5", 2618 | "call-bind": "^1.0.2", 2619 | "for-each": "^0.3.3", 2620 | "gopd": "^1.0.1", 2621 | "has-tostringtag": "^1.0.0" 2622 | }, 2623 | "engines": { 2624 | "node": ">= 0.4" 2625 | }, 2626 | "funding": { 2627 | "url": "https://github.com/sponsors/ljharb" 2628 | } 2629 | }, 2630 | "node_modules/wrap-ansi": { 2631 | "version": "8.1.0", 2632 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", 2633 | "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", 2634 | "dev": true, 2635 | "license": "MIT", 2636 | "dependencies": { 2637 | "ansi-styles": "^6.1.0", 2638 | "string-width": "^5.0.1", 2639 | "strip-ansi": "^7.0.1" 2640 | }, 2641 | "engines": { 2642 | "node": ">=12" 2643 | }, 2644 | "funding": { 2645 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2646 | } 2647 | }, 2648 | "node_modules/wrap-ansi-cjs": { 2649 | "name": "wrap-ansi", 2650 | "version": "7.0.0", 2651 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2652 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2653 | "dev": true, 2654 | "license": "MIT", 2655 | "dependencies": { 2656 | "ansi-styles": "^4.0.0", 2657 | "string-width": "^4.1.0", 2658 | "strip-ansi": "^6.0.0" 2659 | }, 2660 | "engines": { 2661 | "node": ">=10" 2662 | }, 2663 | "funding": { 2664 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2665 | } 2666 | }, 2667 | "node_modules/wrap-ansi-cjs/node_modules/ansi-regex": { 2668 | "version": "5.0.1", 2669 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2670 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2671 | "dev": true, 2672 | "license": "MIT", 2673 | "engines": { 2674 | "node": ">=8" 2675 | } 2676 | }, 2677 | "node_modules/wrap-ansi-cjs/node_modules/ansi-styles": { 2678 | "version": "4.3.0", 2679 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2680 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2681 | "dev": true, 2682 | "license": "MIT", 2683 | "dependencies": { 2684 | "color-convert": "^2.0.1" 2685 | }, 2686 | "engines": { 2687 | "node": ">=8" 2688 | }, 2689 | "funding": { 2690 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2691 | } 2692 | }, 2693 | "node_modules/wrap-ansi-cjs/node_modules/color-convert": { 2694 | "version": "2.0.1", 2695 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2696 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2697 | "dev": true, 2698 | "license": "MIT", 2699 | "dependencies": { 2700 | "color-name": "~1.1.4" 2701 | }, 2702 | "engines": { 2703 | "node": ">=7.0.0" 2704 | } 2705 | }, 2706 | "node_modules/wrap-ansi-cjs/node_modules/color-name": { 2707 | "version": "1.1.4", 2708 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2709 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2710 | "dev": true, 2711 | "license": "MIT" 2712 | }, 2713 | "node_modules/wrap-ansi-cjs/node_modules/emoji-regex": { 2714 | "version": "8.0.0", 2715 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2716 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2717 | "dev": true, 2718 | "license": "MIT" 2719 | }, 2720 | "node_modules/wrap-ansi-cjs/node_modules/string-width": { 2721 | "version": "4.2.3", 2722 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2723 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2724 | "dev": true, 2725 | "license": "MIT", 2726 | "dependencies": { 2727 | "emoji-regex": "^8.0.0", 2728 | "is-fullwidth-code-point": "^3.0.0", 2729 | "strip-ansi": "^6.0.1" 2730 | }, 2731 | "engines": { 2732 | "node": ">=8" 2733 | } 2734 | }, 2735 | "node_modules/wrap-ansi-cjs/node_modules/strip-ansi": { 2736 | "version": "6.0.1", 2737 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2738 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2739 | "dev": true, 2740 | "license": "MIT", 2741 | "dependencies": { 2742 | "ansi-regex": "^5.0.1" 2743 | }, 2744 | "engines": { 2745 | "node": ">=8" 2746 | } 2747 | }, 2748 | "node_modules/wrap-ansi/node_modules/ansi-styles": { 2749 | "version": "6.2.1", 2750 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", 2751 | "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", 2752 | "dev": true, 2753 | "license": "MIT", 2754 | "engines": { 2755 | "node": ">=12" 2756 | }, 2757 | "funding": { 2758 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2759 | } 2760 | }, 2761 | "node_modules/yn": { 2762 | "version": "3.1.1", 2763 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 2764 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 2765 | "dev": true, 2766 | "engines": { 2767 | "node": ">=6" 2768 | } 2769 | } 2770 | } 2771 | } 2772 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "prisma-extension-cache-manager", 3 | "version": "1.1.0", 4 | "license": "MIT", 5 | "author": "Roberto Sero", 6 | "description": "Prisma client extension for caching model queries", 7 | "repository": { 8 | "type": "git", 9 | "url": "https://github.com/random42/prisma-extension-cache-manager.git" 10 | }, 11 | "keywords": [ 12 | "prisma", 13 | "@prisma/client", 14 | "extension", 15 | "cache", 16 | "caching" 17 | ], 18 | "main": "dist/index.js", 19 | "types": "dist/index.d.ts", 20 | "files": [ 21 | "dist/**" 22 | ], 23 | "scripts": { 24 | "prepare": "run-s build", 25 | "build": "tsc", 26 | "prebuild": "rimraf dist", 27 | "prepublishOnly": "run-s test", 28 | "test": "node --test --test-only --require ts-node/register ./test/*.test.ts", 29 | "pretest": "prisma db push --force-reset --accept-data-loss --schema=./test/prisma/schema.prisma" 30 | }, 31 | "engines": { 32 | "node": ">=18.18" 33 | }, 34 | "peerDependencies": { 35 | "@prisma/client": "^6.0.1" 36 | }, 37 | "devDependencies": { 38 | "@prisma/client": "^6.3.1", 39 | "cache-manager": "^6.4.0", 40 | "cacheable": "^1.8.8", 41 | "keyv": "^5.2.3", 42 | "npm-run-all": "^4.1.5", 43 | "prisma": "^6.3.1", 44 | "rimraf": "^6.0.1", 45 | "ts-node": "^10.9.2", 46 | "typescript": "^5.7.3" 47 | }, 48 | "dependencies": { 49 | "object-code": "^1.3.3" 50 | } 51 | } 52 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | import { Prisma } from '@prisma/client/extension'; 2 | import { hash } from 'object-code'; 3 | import { 4 | CACHE_OPERATIONS, 5 | CacheConfig, 6 | CacheOptions, 7 | KeyGenerator, 8 | ModelExtension, 9 | PrismaCacheExtensionConfig, 10 | } from './types'; 11 | 12 | export type { 13 | CacheConfig, 14 | CacheOperation, 15 | CacheOptions, 16 | KeyGenerator, 17 | KeyGeneratorArgs, 18 | PrismaCacheArgs, 19 | PrismaCacheExtensionConfig, 20 | } from './types'; 21 | 22 | export const defaultKeyGenerator: KeyGenerator = (args) => 23 | hash(args).toString(); 24 | 25 | const _parseConfig = (config: CacheConfig): CacheOptions => { 26 | let options: CacheOptions = {}; 27 | if (typeof config === 'object') { 28 | options = config; 29 | } else if (typeof config === 'number') { 30 | options.ttl = config; 31 | } 32 | return options; 33 | }; 34 | 35 | export default (config: PrismaCacheExtensionConfig) => { 36 | const { cache } = config; 37 | const keyGenerator = config.keyGenerator ?? defaultKeyGenerator; 38 | return Prisma.defineExtension({ 39 | name: 'cache', 40 | client: { 41 | $cache: cache, 42 | }, 43 | model: { 44 | $allModels: {} as ModelExtension, 45 | }, 46 | query: { 47 | $allModels: { 48 | async $allOperations({ model, operation, args, query }) { 49 | const useCache = !!( 50 | ['number', 'boolean', 'object'].includes(typeof args.cache) && 51 | args.cache !== null && 52 | (CACHE_OPERATIONS as ReadonlyArray).includes(operation) 53 | ); 54 | if (!useCache) { 55 | return query(args); 56 | } 57 | const queryArgs = { 58 | ...args, 59 | }; 60 | delete queryArgs.cache; 61 | const options = _parseConfig(args.cache as CacheConfig); 62 | const key: string = 63 | options.key ?? 64 | (await keyGenerator({ model, operation, args: queryArgs })); 65 | return cache.wrap(key, () => query(queryArgs), options.ttl); 66 | }, 67 | }, 68 | }, 69 | }); 70 | }; 71 | -------------------------------------------------------------------------------- /src/types.ts: -------------------------------------------------------------------------------- 1 | import { Operation } from '@prisma/client/runtime/library'; 2 | import { Prisma } from '@prisma/client/extension'; 3 | import type { Cache } from 'cache-manager'; 4 | 5 | export const REQUIRED_ARGS_OPERATIONS = [ 6 | 'findUnique', 7 | 'findUniqueOrThrow', 8 | 'groupBy', 9 | 'aggregate', 10 | ] as const satisfies ReadonlyArray; 11 | export const OPTIONAL_ARGS_OPERATIONS = [ 12 | 'findMany', 13 | 'findFirst', 14 | 'findFirstOrThrow', 15 | 'count', 16 | ] as const satisfies ReadonlyArray; 17 | 18 | export const CACHE_OPERATIONS = [ 19 | ...REQUIRED_ARGS_OPERATIONS, 20 | ...OPTIONAL_ARGS_OPERATIONS, 21 | ] as const; 22 | 23 | // const OPERATIONS = ["findMany"] as const satisfies ReadonlyArray; 24 | type RequiredArgsOperation = (typeof REQUIRED_ARGS_OPERATIONS)[number]; 25 | type OptionalArgsOperation = (typeof OPTIONAL_ARGS_OPERATIONS)[number]; 26 | 27 | export type CacheOperation = RequiredArgsOperation | OptionalArgsOperation; 28 | 29 | type RequiredArgsFunction = ( 30 | this: T, 31 | args: Prisma.Exact & PrismaCacheArgs> 32 | ) => Promise>; 33 | 34 | type OptionalArgsFunction = ( 35 | this: T, 36 | args?: Prisma.Exact & PrismaCacheArgs> 37 | ) => Promise>; 38 | 39 | export type ModelExtension = { 40 | [O1 in RequiredArgsOperation]: RequiredArgsFunction; 41 | } & { 42 | [O2 in OptionalArgsOperation]: OptionalArgsFunction; 43 | }; 44 | 45 | export interface CacheOptions { 46 | /** 47 | * Time-to-live in milliseconds 48 | */ 49 | ttl?: number; 50 | /** 51 | * Cache key 52 | */ 53 | key?: string; 54 | } 55 | 56 | export type CacheConfig = true | number | CacheOptions; 57 | 58 | export interface PrismaCacheArgs { 59 | cache?: CacheConfig; 60 | } 61 | 62 | export type KeyGeneratorArgs = { 63 | model: string; 64 | operation: string; 65 | args: unknown; 66 | }; 67 | 68 | export type KeyGenerator = (args: KeyGeneratorArgs) => string | Promise; 69 | 70 | export interface PrismaCacheExtensionConfig { 71 | cache: Cache; 72 | keyGenerator?: KeyGenerator; 73 | } 74 | -------------------------------------------------------------------------------- /test/main.test.ts: -------------------------------------------------------------------------------- 1 | import { Prisma, PrismaClient } from '@prisma/client'; 2 | import { Metrics } from '@prisma/client/runtime/library'; 3 | import * as cm from 'cache-manager'; 4 | import { KeyvCacheableMemory } from 'cacheable'; 5 | import Keyv from 'keyv'; 6 | import assert from 'node:assert'; 7 | import test from 'node:test'; 8 | import v8 from 'node:v8'; 9 | import { hash } from 'object-code'; 10 | import ext from '../src'; 11 | import { CACHE_OPERATIONS } from '../src/types'; 12 | 13 | const sleep = (ms: number) => new Promise((res) => setTimeout(res, ms)); 14 | 15 | test('extension', { only: true }, async (t) => { 16 | const defaultTtl = 100; 17 | const cache = cm.createCache({ 18 | ttl: defaultTtl, 19 | stores: [ 20 | new Keyv({ 21 | store: new KeyvCacheableMemory({ ttl: defaultTtl }), 22 | serialize: (x) => v8.serialize(x).toString('base64'), 23 | deserialize: (s) => v8.deserialize(Buffer.from(s, 'base64')), 24 | }), 25 | ], 26 | }); 27 | 28 | // regenerate client to reset metrics 29 | const getClient = () => new PrismaClient().$extends(ext({ cache })); 30 | const _client = new PrismaClient(); 31 | let prisma = getClient(); 32 | assert(prisma.$cache === cache); 33 | // db queries count 34 | const queries = async (): Promise => 35 | ((await (prisma as any).$metrics.json()) as Metrics).counters.find( 36 | (x: any) => x.key === 'prisma_client_queries_total' 37 | )?.value; 38 | // expected db query count 39 | let q = 0; 40 | 41 | // reset client and cache before each test 42 | t.beforeEach(async () => { 43 | prisma = getClient(); 44 | await cache.clear(); 45 | q = 0; 46 | }); 47 | 48 | const assertDbQueries = async () => { 49 | const qq = await queries(); 50 | assert.strictEqual(qq, q, 'queries mismatch'); 51 | }; 52 | 53 | const assertCacheKeys = async (...keys: string[]) => { 54 | const data = await cache.mget(keys); 55 | assert.strictEqual(data.length, keys.length); 56 | assert.ok(data.every((x) => x)); 57 | }; 58 | 59 | const insert = { 60 | string: 'string', 61 | // decimal: new Prisma.Decimal('10.44'), 62 | float: 321.84784, 63 | timestamp: new Date(), 64 | bigint: BigInt(4784788738318273), 65 | bytes: Buffer.from('o21ijferve9ir3'), 66 | }; 67 | // clear table 68 | await prisma.$executeRaw`delete from "User"`; 69 | const user = await prisma.user.create({ 70 | data: insert, 71 | }); 72 | 73 | const args = { 74 | where: { 75 | OR: [ 76 | { 77 | id: { 78 | gte: 1, 79 | }, 80 | bytes: user.bytes, 81 | }, 82 | { 83 | string: { 84 | not: null, 85 | }, 86 | // decimal: { 87 | // not: new Prisma.Decimal('10.99'), 88 | // }, 89 | }, 90 | ], 91 | }, 92 | orderBy: { 93 | timestamp: 'desc', 94 | }, 95 | } satisfies Prisma.UserFindManyArgs; 96 | 97 | // t.runOnly(true); 98 | 99 | await t.test('every model operation', async (t) => { 100 | const useCache = { cache: true } as const; 101 | await prisma.user.findFirst(useCache); 102 | await prisma.user.findFirst(useCache); 103 | await prisma.user.findFirstOrThrow(useCache); 104 | await prisma.user.findFirstOrThrow(useCache); 105 | const findUniqueArgs = { 106 | where: { 107 | id: user.id, 108 | }, 109 | ...useCache, 110 | } satisfies Prisma.UserFindUniqueArgs; 111 | await prisma.user.findUnique(findUniqueArgs); 112 | await prisma.user.findUnique(findUniqueArgs); 113 | await prisma.user.findUniqueOrThrow(findUniqueArgs); 114 | await prisma.user.findUniqueOrThrow(findUniqueArgs); 115 | const groupByArgs = { 116 | by: 'id', 117 | _sum: { 118 | float: true, 119 | }, 120 | ...useCache, 121 | } as const; 122 | await prisma.user.groupBy(groupByArgs); 123 | await prisma.user.groupBy(groupByArgs); 124 | await prisma.user.findMany(useCache); 125 | await prisma.user.findMany(useCache); 126 | await prisma.user.count(useCache); 127 | await prisma.user.count(useCache); 128 | const agg = { 129 | select: { 130 | _count: true, 131 | }, 132 | ...useCache, 133 | } as const; 134 | await prisma.user.aggregate(agg); 135 | await prisma.user.aggregate(agg); 136 | const expectedOperations = CACHE_OPERATIONS.length; 137 | q += expectedOperations; 138 | await assertDbQueries(); 139 | }); 140 | 141 | await t.test('value matching', async (t) => { 142 | const key = 'key'; 143 | const arg = { 144 | ...args, 145 | cache: { 146 | key, 147 | }, 148 | }; 149 | const d1 = await prisma.user.findMany(arg); 150 | q++; 151 | const d2 = await prisma.user.findMany(arg); // cached 152 | const d3: typeof d2 = (await cache.get(key))!; 153 | await assertDbQueries(); 154 | assert(d3); 155 | assert.deepStrictEqual(d1, d2); 156 | assert.deepStrictEqual(d1, d3); 157 | }); 158 | 159 | await t.test('key generation', async (t) => { 160 | const hashingData = { model: 'User', operation: 'findMany', args }; 161 | await prisma.user.findMany({ ...args, cache: true }); 162 | const key = hash(hashingData).toString(); 163 | assert(await cache.get(key)); 164 | q++; 165 | await assertDbQueries(); 166 | // same arguments but different instantiation 167 | const now = new Date(); 168 | await prisma.user.count({ 169 | where: { 170 | // decimal: new Prisma.Decimal('1.1213'), 171 | bytes: Buffer.from('123'), 172 | timestamp: now, 173 | }, 174 | cache: true, 175 | }); 176 | // hit because object hash is the same 177 | // this may be different using a Decimal field 178 | await prisma.user.count({ 179 | where: { 180 | // decimal: new Prisma.Decimal('1.1213'), 181 | bytes: Buffer.from('123'), 182 | timestamp: now, 183 | }, 184 | cache: true, 185 | }); 186 | q += 1; 187 | await assertDbQueries(); 188 | }); 189 | 190 | await t.test('no cache', async (t) => { 191 | const key = 'key'; 192 | await prisma.user.findMany({ cache: { key } }); 193 | await prisma.user.findMany(); 194 | q += 2; 195 | assertCacheKeys(key); 196 | await assertDbQueries(); 197 | }); 198 | 199 | await t.test( 200 | 'same args different operation should use different key', 201 | async (t) => { 202 | await prisma.user.findMany({ ...args, cache: true }); 203 | await prisma.user.count({ ...args, cache: true }); 204 | q += 2; 205 | await assertDbQueries(); 206 | } 207 | ); 208 | 209 | await t.test('same args different cache options', async (t) => { 210 | // miss 211 | await prisma.user.count({ ...args, cache: true }); 212 | // hit 213 | await prisma.user.count({ 214 | ...args, 215 | cache: { 216 | ttl: 200, 217 | }, 218 | }); 219 | // miss (different key) 220 | await prisma.user.count({ 221 | ...args, 222 | cache: { 223 | ttl: 100, 224 | key: 'key', 225 | }, 226 | }); 227 | q += 2; 228 | await assertCacheKeys('key'); 229 | await assertDbQueries(); 230 | }); 231 | 232 | await t.test('default ttl', async (t) => { 233 | await prisma.user.findFirst({ 234 | cache: true, 235 | }); 236 | q++; 237 | await sleep(defaultTtl + 10); 238 | // cache miss 239 | await prisma.user.findFirst({ 240 | cache: true, 241 | }); 242 | q++; 243 | await assertDbQueries(); 244 | }); 245 | 246 | await t.test('custom ttl', async (t) => { 247 | const ttl = 200; 248 | await prisma.user.count({ 249 | cache: ttl, 250 | }); 251 | q++; 252 | await sleep(ttl + 10); 253 | await prisma.user.count({ 254 | cache: ttl, 255 | }); 256 | q++; 257 | await assertDbQueries(); 258 | }); 259 | 260 | await t.test('shortened ttl should still use cache', async (t) => { 261 | const ttl = 400; 262 | await prisma.user.count({ 263 | cache: ttl, 264 | }); 265 | q++; 266 | await sleep(ttl / 2); 267 | await prisma.user.count({ 268 | cache: ttl / 4, 269 | }); 270 | await assertDbQueries(); 271 | }); 272 | }); 273 | -------------------------------------------------------------------------------- /test/prisma/schema.prisma: -------------------------------------------------------------------------------- 1 | // This is your Prisma schema file, 2 | // learn more about it in the docs: https://pris.ly/d/prisma-schema 3 | 4 | generator client { 5 | provider = "prisma-client-js" 6 | previewFeatures = ["metrics"] 7 | } 8 | 9 | datasource db { 10 | provider = "sqlite" 11 | url = "file:./dev.db" 12 | } 13 | 14 | model User { 15 | id Int @id @default(autoincrement()) 16 | string String? 17 | // decimal Decimal? this is not supported by v8 serialization 18 | bigint BigInt? 19 | float Float? 20 | timestamp DateTime? 21 | bytes Bytes? 22 | } 23 | 24 | // model Post { 25 | // id Int @id @default(autoincrement()) 26 | // text String? 27 | // } 28 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es2016", 4 | "lib": ["ES2016"], 5 | "module": "CommonJS", 6 | "moduleResolution": "node", 7 | "esModuleInterop": true, 8 | "forceConsistentCasingInFileNames": true, 9 | "strict": true, 10 | "skipDefaultLibCheck": true, 11 | "skipLibCheck": false, 12 | "declaration": true, 13 | "outDir": "./dist" 14 | }, 15 | "include": ["src/**/*.ts"] 16 | } --------------------------------------------------------------------------------