├── .github └── workflows │ └── test.yaml ├── .gitignore ├── LICENSE ├── README.md ├── package-lock.json ├── package.json ├── prisma ├── factories.ts ├── index.ts ├── migrations │ ├── 20230512232905_ │ │ └── migration.sql │ └── migration_lock.toml └── schema.prisma ├── src └── index.ts ├── tests ├── fields.test.ts ├── instance.test.ts ├── setup-tests.ts └── vitest.config.ts └── tsconfig.json /.github/workflows/test.yaml: -------------------------------------------------------------------------------- 1 | name: Test 2 | 3 | on: 4 | push: 5 | branches: 6 | - main 7 | pull_request: 8 | 9 | jobs: 10 | test: 11 | name: Test 12 | runs-on: ubuntu-latest 13 | services: 14 | postgres: 15 | image: postgres 16 | env: 17 | POSTGRES_PASSWORD: prisma 18 | # set health checks to wait until postgres has started 19 | options: >- 20 | --health-cmd pg_isready 21 | --health-interval 10s 22 | --health-timeout 5s 23 | --health-retries 5 24 | ports: 25 | - 5435:5432 26 | steps: 27 | - name: Checkout 28 | uses: actions/checkout@v3 29 | - name: Setup Node 30 | uses: actions/setup-node@v3 31 | - name: Install dependencies 32 | run: npm install --dev 33 | - name: Run migrations 34 | run: npm run migrate 35 | - name: Run tests 36 | run: npm run test 37 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | lerna-debug.log* 8 | .pnpm-debug.log* 9 | 10 | # Diagnostic reports (https://nodejs.org/api/report.html) 11 | report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json 12 | 13 | # Runtime data 14 | pids 15 | *.pid 16 | *.seed 17 | *.pid.lock 18 | 19 | # Directory for instrumented libs generated by jscoverage/JSCover 20 | lib-cov 21 | 22 | # Coverage directory used by tools like istanbul 23 | coverage 24 | *.lcov 25 | 26 | # nyc test coverage 27 | .nyc_output 28 | 29 | # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) 30 | .grunt 31 | 32 | # Bower dependency directory (https://bower.io/) 33 | bower_components 34 | 35 | # node-waf configuration 36 | .lock-wscript 37 | 38 | # Compiled binary addons (https://nodejs.org/api/addons.html) 39 | build/Release 40 | 41 | # Dependency directories 42 | node_modules/ 43 | jspm_packages/ 44 | 45 | # Snowpack dependency directory (https://snowpack.dev/) 46 | web_modules/ 47 | 48 | # TypeScript cache 49 | *.tsbuildinfo 50 | 51 | # Optional npm cache directory 52 | .npm 53 | 54 | # Optional eslint cache 55 | .eslintcache 56 | 57 | # Optional stylelint cache 58 | .stylelintcache 59 | 60 | # Microbundle cache 61 | .rpt2_cache/ 62 | .rts2_cache_cjs/ 63 | .rts2_cache_es/ 64 | .rts2_cache_umd/ 65 | 66 | # Optional REPL history 67 | .node_repl_history 68 | 69 | # Output of 'npm pack' 70 | *.tgz 71 | 72 | # Yarn Integrity file 73 | .yarn-integrity 74 | 75 | # dotenv environment variable files 76 | .env 77 | .env.development.local 78 | .env.test.local 79 | .env.production.local 80 | .env.local 81 | 82 | # parcel-bundler cache (https://parceljs.org/) 83 | .cache 84 | .parcel-cache 85 | 86 | # Next.js build output 87 | .next 88 | out 89 | 90 | # Nuxt.js build / generate output 91 | .nuxt 92 | dist 93 | 94 | # Gatsby files 95 | .cache/ 96 | # Comment in the public line in if your project uses Gatsby and not Next.js 97 | # https://nextjs.org/blog/next-9-1#public-directory-support 98 | # public 99 | 100 | # vuepress build output 101 | .vuepress/dist 102 | 103 | # vuepress v2.x temp and cache directory 104 | .temp 105 | .cache 106 | 107 | # Docusaurus cache and generated files 108 | .docusaurus 109 | 110 | # Serverless directories 111 | .serverless/ 112 | 113 | # FuseBox cache 114 | .fusebox/ 115 | 116 | # DynamoDB Local files 117 | .dynamodb/ 118 | 119 | # TernJS port file 120 | .tern-port 121 | 122 | # Stores VSCode versions used for testing VSCode extensions 123 | .vscode-test 124 | 125 | # yarn v2 126 | .yarn/cache 127 | .yarn/unplugged 128 | .yarn/build-state.yml 129 | .yarn/install-state.gz 130 | .pnp.* 131 | 132 | # IDE 133 | .idea -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2023 Ahmed Al-Jawahiry 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. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # factory-prisma 2 | 3 | [![Test](https://github.com/ahmedaljawahiry/factory-prisma/actions/workflows/test.yaml/badge.svg?branch=main)](https://github.com/ahmedaljawahiry/factory-prisma/actions/workflows/test.yaml) 4 | [![Coverage](https://img.shields.io/badge/coverage%20-100%25-brightgreen.svg)](https://github.com/ahmedaljawahiry/factory-prisma/actions/workflows/test.yaml) 5 | [![npm version](https://img.shields.io/npm/v/factory-prisma.svg)](https://www.npmjs.com/package/factory-prisma) 6 | [![npm license](https://img.shields.io/npm/l/factory-prisma.svg)](https://www.npmjs.com/package/factory-prisma/blob/main/LICENSE) 7 | 8 | Create factories, that create objects with [Prisma](https://github.com/prisma/prisma). 9 | 10 | Inspired by Python's [factory_boy](https://github.com/FactoryBoy/factory_boy), 11 | which is inspired by Ruby's [factory_bot](https://github.com/thoughtbot/factory_bot). 12 | 13 | ### Usage 14 | 15 | Install `factory-prisma` as a dev dependency, then use it to define 16 | factories for your Prisma models. 17 | 18 | ```typescript 19 | import db from 'wherever/your/prisma/client/is' 20 | import { factory, random } from 'factory-prisma' 21 | 22 | export const TeamFactory = factory(db.team, () => ({ 23 | name: random.string(), // use faker if you want to 24 | key: random.string(), 25 | type: TeamType.CLUB, 26 | website: random.url(), 27 | })); 28 | 29 | export const SquadFactory = factory(db.squad, () => ({ 30 | team: { create: TeamFactory.fields() }, 31 | type: SquadType.SENIOR_MEN, 32 | })); 33 | 34 | export const PlayerFactory = factory(db.player, () => ({ 35 | key: random.string(), 36 | name: random.string(), 37 | dob: random.date(), 38 | position: PlayerPosition.CM, 39 | })); 40 | ``` 41 | 42 | Then, use the factories in your tests: 43 | 44 | ```typescript 45 | test("no relations", async () => { 46 | await TeamFactory.instance(); 47 | 48 | expect(await db.team.count()).toBe(1); 49 | }); 50 | 51 | test("with relations", async () => { 52 | await SquadFactory.instance(); 53 | 54 | const team = await db.team.findFirstOrThrow(); 55 | const squad = await db.squad.findFirstOrThrow(); 56 | 57 | expect(await db.team.count()).toBe(1); 58 | expect(await db.squad.count()).toBe(1); 59 | expect(team.id).toBe(squad.teamId); 60 | }); 61 | 62 | test("connect", async () => { 63 | const { id } = await TeamFactory.instance(); 64 | await SquadFactory.instance({ team: { connect: { id } } }); 65 | 66 | const team = await db.team.findFirstOrThrow(); 67 | const squad = await db.squad.findFirstOrThrow(); 68 | 69 | expect(await db.team.count()).toBe(1); 70 | expect(await db.squad.count()).toBe(1); 71 | expect(team.id).toBe(squad.teamId); 72 | }); 73 | ``` 74 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "factory-prisma", 3 | "version": "0.0.2", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "factory-prisma", 9 | "version": "0.0.2", 10 | "license": "MIT", 11 | "devDependencies": { 12 | "@prisma/client": "^4.14.0", 13 | "@vitest/coverage-c8": "^0.31.0", 14 | "prettier": "^2.8.8", 15 | "prisma": "^4.14.0", 16 | "typescript": "^5.0.4", 17 | "vitest": "^0.31.0" 18 | } 19 | }, 20 | "node_modules/@ampproject/remapping": { 21 | "version": "2.2.1", 22 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", 23 | "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", 24 | "dev": true, 25 | "dependencies": { 26 | "@jridgewell/gen-mapping": "^0.3.0", 27 | "@jridgewell/trace-mapping": "^0.3.9" 28 | }, 29 | "engines": { 30 | "node": ">=6.0.0" 31 | } 32 | }, 33 | "node_modules/@bcoe/v8-coverage": { 34 | "version": "0.2.3", 35 | "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", 36 | "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", 37 | "dev": true 38 | }, 39 | "node_modules/@esbuild/android-arm": { 40 | "version": "0.17.18", 41 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.18.tgz", 42 | "integrity": "sha512-EmwL+vUBZJ7mhFCs5lA4ZimpUH3WMAoqvOIYhVQwdIgSpHC8ImHdsRyhHAVxpDYUSm0lWvd63z0XH1IlImS2Qw==", 43 | "cpu": [ 44 | "arm" 45 | ], 46 | "dev": true, 47 | "optional": true, 48 | "os": [ 49 | "android" 50 | ], 51 | "engines": { 52 | "node": ">=12" 53 | } 54 | }, 55 | "node_modules/@esbuild/android-arm64": { 56 | "version": "0.17.18", 57 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.18.tgz", 58 | "integrity": "sha512-/iq0aK0eeHgSC3z55ucMAHO05OIqmQehiGay8eP5l/5l+iEr4EIbh4/MI8xD9qRFjqzgkc0JkX0LculNC9mXBw==", 59 | "cpu": [ 60 | "arm64" 61 | ], 62 | "dev": true, 63 | "optional": true, 64 | "os": [ 65 | "android" 66 | ], 67 | "engines": { 68 | "node": ">=12" 69 | } 70 | }, 71 | "node_modules/@esbuild/android-x64": { 72 | "version": "0.17.18", 73 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.18.tgz", 74 | "integrity": "sha512-x+0efYNBF3NPW2Xc5bFOSFW7tTXdAcpfEg2nXmxegm4mJuVeS+i109m/7HMiOQ6M12aVGGFlqJX3RhNdYM2lWg==", 75 | "cpu": [ 76 | "x64" 77 | ], 78 | "dev": true, 79 | "optional": true, 80 | "os": [ 81 | "android" 82 | ], 83 | "engines": { 84 | "node": ">=12" 85 | } 86 | }, 87 | "node_modules/@esbuild/darwin-arm64": { 88 | "version": "0.17.18", 89 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.18.tgz", 90 | "integrity": "sha512-6tY+djEAdF48M1ONWnQb1C+6LiXrKjmqjzPNPWXhu/GzOHTHX2nh8Mo2ZAmBFg0kIodHhciEgUBtcYCAIjGbjQ==", 91 | "cpu": [ 92 | "arm64" 93 | ], 94 | "dev": true, 95 | "optional": true, 96 | "os": [ 97 | "darwin" 98 | ], 99 | "engines": { 100 | "node": ">=12" 101 | } 102 | }, 103 | "node_modules/@esbuild/darwin-x64": { 104 | "version": "0.17.18", 105 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.18.tgz", 106 | "integrity": "sha512-Qq84ykvLvya3dO49wVC9FFCNUfSrQJLbxhoQk/TE1r6MjHo3sFF2tlJCwMjhkBVq3/ahUisj7+EpRSz0/+8+9A==", 107 | "cpu": [ 108 | "x64" 109 | ], 110 | "dev": true, 111 | "optional": true, 112 | "os": [ 113 | "darwin" 114 | ], 115 | "engines": { 116 | "node": ">=12" 117 | } 118 | }, 119 | "node_modules/@esbuild/freebsd-arm64": { 120 | "version": "0.17.18", 121 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.18.tgz", 122 | "integrity": "sha512-fw/ZfxfAzuHfaQeMDhbzxp9mc+mHn1Y94VDHFHjGvt2Uxl10mT4CDavHm+/L9KG441t1QdABqkVYwakMUeyLRA==", 123 | "cpu": [ 124 | "arm64" 125 | ], 126 | "dev": true, 127 | "optional": true, 128 | "os": [ 129 | "freebsd" 130 | ], 131 | "engines": { 132 | "node": ">=12" 133 | } 134 | }, 135 | "node_modules/@esbuild/freebsd-x64": { 136 | "version": "0.17.18", 137 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.18.tgz", 138 | "integrity": "sha512-FQFbRtTaEi8ZBi/A6kxOC0V0E9B/97vPdYjY9NdawyLd4Qk5VD5g2pbWN2VR1c0xhzcJm74HWpObPszWC+qTew==", 139 | "cpu": [ 140 | "x64" 141 | ], 142 | "dev": true, 143 | "optional": true, 144 | "os": [ 145 | "freebsd" 146 | ], 147 | "engines": { 148 | "node": ">=12" 149 | } 150 | }, 151 | "node_modules/@esbuild/linux-arm": { 152 | "version": "0.17.18", 153 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.18.tgz", 154 | "integrity": "sha512-jW+UCM40LzHcouIaqv3e/oRs0JM76JfhHjCavPxMUti7VAPh8CaGSlS7cmyrdpzSk7A+8f0hiedHqr/LMnfijg==", 155 | "cpu": [ 156 | "arm" 157 | ], 158 | "dev": true, 159 | "optional": true, 160 | "os": [ 161 | "linux" 162 | ], 163 | "engines": { 164 | "node": ">=12" 165 | } 166 | }, 167 | "node_modules/@esbuild/linux-arm64": { 168 | "version": "0.17.18", 169 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.18.tgz", 170 | "integrity": "sha512-R7pZvQZFOY2sxUG8P6A21eq6q+eBv7JPQYIybHVf1XkQYC+lT7nDBdC7wWKTrbvMXKRaGudp/dzZCwL/863mZQ==", 171 | "cpu": [ 172 | "arm64" 173 | ], 174 | "dev": true, 175 | "optional": true, 176 | "os": [ 177 | "linux" 178 | ], 179 | "engines": { 180 | "node": ">=12" 181 | } 182 | }, 183 | "node_modules/@esbuild/linux-ia32": { 184 | "version": "0.17.18", 185 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.18.tgz", 186 | "integrity": "sha512-ygIMc3I7wxgXIxk6j3V00VlABIjq260i967Cp9BNAk5pOOpIXmd1RFQJQX9Io7KRsthDrQYrtcx7QCof4o3ZoQ==", 187 | "cpu": [ 188 | "ia32" 189 | ], 190 | "dev": true, 191 | "optional": true, 192 | "os": [ 193 | "linux" 194 | ], 195 | "engines": { 196 | "node": ">=12" 197 | } 198 | }, 199 | "node_modules/@esbuild/linux-loong64": { 200 | "version": "0.17.18", 201 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.18.tgz", 202 | "integrity": "sha512-bvPG+MyFs5ZlwYclCG1D744oHk1Pv7j8psF5TfYx7otCVmcJsEXgFEhQkbhNW8otDHL1a2KDINW20cfCgnzgMQ==", 203 | "cpu": [ 204 | "loong64" 205 | ], 206 | "dev": true, 207 | "optional": true, 208 | "os": [ 209 | "linux" 210 | ], 211 | "engines": { 212 | "node": ">=12" 213 | } 214 | }, 215 | "node_modules/@esbuild/linux-mips64el": { 216 | "version": "0.17.18", 217 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.18.tgz", 218 | "integrity": "sha512-oVqckATOAGuiUOa6wr8TXaVPSa+6IwVJrGidmNZS1cZVx0HqkTMkqFGD2HIx9H1RvOwFeWYdaYbdY6B89KUMxA==", 219 | "cpu": [ 220 | "mips64el" 221 | ], 222 | "dev": true, 223 | "optional": true, 224 | "os": [ 225 | "linux" 226 | ], 227 | "engines": { 228 | "node": ">=12" 229 | } 230 | }, 231 | "node_modules/@esbuild/linux-ppc64": { 232 | "version": "0.17.18", 233 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.18.tgz", 234 | "integrity": "sha512-3dLlQO+b/LnQNxgH4l9rqa2/IwRJVN9u/bK63FhOPB4xqiRqlQAU0qDU3JJuf0BmaH0yytTBdoSBHrb2jqc5qQ==", 235 | "cpu": [ 236 | "ppc64" 237 | ], 238 | "dev": true, 239 | "optional": true, 240 | "os": [ 241 | "linux" 242 | ], 243 | "engines": { 244 | "node": ">=12" 245 | } 246 | }, 247 | "node_modules/@esbuild/linux-riscv64": { 248 | "version": "0.17.18", 249 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.18.tgz", 250 | "integrity": "sha512-/x7leOyDPjZV3TcsdfrSI107zItVnsX1q2nho7hbbQoKnmoeUWjs+08rKKt4AUXju7+3aRZSsKrJtaRmsdL1xA==", 251 | "cpu": [ 252 | "riscv64" 253 | ], 254 | "dev": true, 255 | "optional": true, 256 | "os": [ 257 | "linux" 258 | ], 259 | "engines": { 260 | "node": ">=12" 261 | } 262 | }, 263 | "node_modules/@esbuild/linux-s390x": { 264 | "version": "0.17.18", 265 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.18.tgz", 266 | "integrity": "sha512-cX0I8Q9xQkL/6F5zWdYmVf5JSQt+ZfZD2bJudZrWD+4mnUvoZ3TDDXtDX2mUaq6upMFv9FlfIh4Gfun0tbGzuw==", 267 | "cpu": [ 268 | "s390x" 269 | ], 270 | "dev": true, 271 | "optional": true, 272 | "os": [ 273 | "linux" 274 | ], 275 | "engines": { 276 | "node": ">=12" 277 | } 278 | }, 279 | "node_modules/@esbuild/linux-x64": { 280 | "version": "0.17.18", 281 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.18.tgz", 282 | "integrity": "sha512-66RmRsPlYy4jFl0vG80GcNRdirx4nVWAzJmXkevgphP1qf4dsLQCpSKGM3DUQCojwU1hnepI63gNZdrr02wHUA==", 283 | "cpu": [ 284 | "x64" 285 | ], 286 | "dev": true, 287 | "optional": true, 288 | "os": [ 289 | "linux" 290 | ], 291 | "engines": { 292 | "node": ">=12" 293 | } 294 | }, 295 | "node_modules/@esbuild/netbsd-x64": { 296 | "version": "0.17.18", 297 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.18.tgz", 298 | "integrity": "sha512-95IRY7mI2yrkLlTLb1gpDxdC5WLC5mZDi+kA9dmM5XAGxCME0F8i4bYH4jZreaJ6lIZ0B8hTrweqG1fUyW7jbg==", 299 | "cpu": [ 300 | "x64" 301 | ], 302 | "dev": true, 303 | "optional": true, 304 | "os": [ 305 | "netbsd" 306 | ], 307 | "engines": { 308 | "node": ">=12" 309 | } 310 | }, 311 | "node_modules/@esbuild/openbsd-x64": { 312 | "version": "0.17.18", 313 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.18.tgz", 314 | "integrity": "sha512-WevVOgcng+8hSZ4Q3BKL3n1xTv5H6Nb53cBrtzzEjDbbnOmucEVcZeGCsCOi9bAOcDYEeBZbD2SJNBxlfP3qiA==", 315 | "cpu": [ 316 | "x64" 317 | ], 318 | "dev": true, 319 | "optional": true, 320 | "os": [ 321 | "openbsd" 322 | ], 323 | "engines": { 324 | "node": ">=12" 325 | } 326 | }, 327 | "node_modules/@esbuild/sunos-x64": { 328 | "version": "0.17.18", 329 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.18.tgz", 330 | "integrity": "sha512-Rzf4QfQagnwhQXVBS3BYUlxmEbcV7MY+BH5vfDZekU5eYpcffHSyjU8T0xucKVuOcdCsMo+Ur5wmgQJH2GfNrg==", 331 | "cpu": [ 332 | "x64" 333 | ], 334 | "dev": true, 335 | "optional": true, 336 | "os": [ 337 | "sunos" 338 | ], 339 | "engines": { 340 | "node": ">=12" 341 | } 342 | }, 343 | "node_modules/@esbuild/win32-arm64": { 344 | "version": "0.17.18", 345 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.18.tgz", 346 | "integrity": "sha512-Kb3Ko/KKaWhjeAm2YoT/cNZaHaD1Yk/pa3FTsmqo9uFh1D1Rfco7BBLIPdDOozrObj2sahslFuAQGvWbgWldAg==", 347 | "cpu": [ 348 | "arm64" 349 | ], 350 | "dev": true, 351 | "optional": true, 352 | "os": [ 353 | "win32" 354 | ], 355 | "engines": { 356 | "node": ">=12" 357 | } 358 | }, 359 | "node_modules/@esbuild/win32-ia32": { 360 | "version": "0.17.18", 361 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.18.tgz", 362 | "integrity": "sha512-0/xUMIdkVHwkvxfbd5+lfG7mHOf2FRrxNbPiKWg9C4fFrB8H0guClmaM3BFiRUYrznVoyxTIyC/Ou2B7QQSwmw==", 363 | "cpu": [ 364 | "ia32" 365 | ], 366 | "dev": true, 367 | "optional": true, 368 | "os": [ 369 | "win32" 370 | ], 371 | "engines": { 372 | "node": ">=12" 373 | } 374 | }, 375 | "node_modules/@esbuild/win32-x64": { 376 | "version": "0.17.18", 377 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.18.tgz", 378 | "integrity": "sha512-qU25Ma1I3NqTSHJUOKi9sAH1/Mzuvlke0ioMJRthLXKm7JiSKVwFghlGbDLOO2sARECGhja4xYfRAZNPAkooYg==", 379 | "cpu": [ 380 | "x64" 381 | ], 382 | "dev": true, 383 | "optional": true, 384 | "os": [ 385 | "win32" 386 | ], 387 | "engines": { 388 | "node": ">=12" 389 | } 390 | }, 391 | "node_modules/@istanbuljs/schema": { 392 | "version": "0.1.3", 393 | "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", 394 | "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", 395 | "dev": true, 396 | "engines": { 397 | "node": ">=8" 398 | } 399 | }, 400 | "node_modules/@jridgewell/gen-mapping": { 401 | "version": "0.3.3", 402 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", 403 | "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", 404 | "dev": true, 405 | "dependencies": { 406 | "@jridgewell/set-array": "^1.0.1", 407 | "@jridgewell/sourcemap-codec": "^1.4.10", 408 | "@jridgewell/trace-mapping": "^0.3.9" 409 | }, 410 | "engines": { 411 | "node": ">=6.0.0" 412 | } 413 | }, 414 | "node_modules/@jridgewell/resolve-uri": { 415 | "version": "3.1.0", 416 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", 417 | "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", 418 | "dev": true, 419 | "engines": { 420 | "node": ">=6.0.0" 421 | } 422 | }, 423 | "node_modules/@jridgewell/set-array": { 424 | "version": "1.1.2", 425 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", 426 | "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", 427 | "dev": true, 428 | "engines": { 429 | "node": ">=6.0.0" 430 | } 431 | }, 432 | "node_modules/@jridgewell/sourcemap-codec": { 433 | "version": "1.4.15", 434 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 435 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 436 | "dev": true 437 | }, 438 | "node_modules/@jridgewell/trace-mapping": { 439 | "version": "0.3.18", 440 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz", 441 | "integrity": "sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==", 442 | "dev": true, 443 | "dependencies": { 444 | "@jridgewell/resolve-uri": "3.1.0", 445 | "@jridgewell/sourcemap-codec": "1.4.14" 446 | } 447 | }, 448 | "node_modules/@jridgewell/trace-mapping/node_modules/@jridgewell/sourcemap-codec": { 449 | "version": "1.4.14", 450 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", 451 | "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", 452 | "dev": true 453 | }, 454 | "node_modules/@prisma/client": { 455 | "version": "4.14.0", 456 | "resolved": "https://registry.npmjs.org/@prisma/client/-/client-4.14.0.tgz", 457 | "integrity": "sha512-MK/XaA2sFdfaOa7I9MjNKz6dxeIEdeZlnpNRoF2w3JuRLlFJLkpp6cD3yaqw2nUUhbrn3Iqe3ZpVV+VuGGil7Q==", 458 | "dev": true, 459 | "hasInstallScript": true, 460 | "dependencies": { 461 | "@prisma/engines-version": "4.14.0-67.d9a4c5988f480fa576d43970d5a23641aa77bc9c" 462 | }, 463 | "engines": { 464 | "node": ">=14.17" 465 | }, 466 | "peerDependencies": { 467 | "prisma": "*" 468 | }, 469 | "peerDependenciesMeta": { 470 | "prisma": { 471 | "optional": true 472 | } 473 | } 474 | }, 475 | "node_modules/@prisma/engines": { 476 | "version": "4.14.0", 477 | "resolved": "https://registry.npmjs.org/@prisma/engines/-/engines-4.14.0.tgz", 478 | "integrity": "sha512-PDNlhP/1vyTgmNyiucGqGCdXIp7HIkkvKO50si3y3PcceeHvqtiKPaH1iJdz63jCWMVMbj2MElSxXPOeBvEVIQ==", 479 | "dev": true, 480 | "hasInstallScript": true 481 | }, 482 | "node_modules/@prisma/engines-version": { 483 | "version": "4.14.0-67.d9a4c5988f480fa576d43970d5a23641aa77bc9c", 484 | "resolved": "https://registry.npmjs.org/@prisma/engines-version/-/engines-version-4.14.0-67.d9a4c5988f480fa576d43970d5a23641aa77bc9c.tgz", 485 | "integrity": "sha512-3jum8/YSudeSN0zGW5qkpz+wAN2V/NYCQ+BPjvHYDfWatLWlQkqy99toX0GysDeaUoBIJg1vaz2yKqiA3CFcQw==", 486 | "dev": true 487 | }, 488 | "node_modules/@types/chai": { 489 | "version": "4.3.5", 490 | "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.5.tgz", 491 | "integrity": "sha512-mEo1sAde+UCE6b2hxn332f1g1E8WfYRu6p5SvTKr2ZKC1f7gFJXk4h5PyGP9Dt6gCaG8y8XhwnXWC6Iy2cmBng==", 492 | "dev": true 493 | }, 494 | "node_modules/@types/chai-subset": { 495 | "version": "1.3.3", 496 | "resolved": "https://registry.npmjs.org/@types/chai-subset/-/chai-subset-1.3.3.tgz", 497 | "integrity": "sha512-frBecisrNGz+F4T6bcc+NLeolfiojh5FxW2klu669+8BARtyQv2C/GkNW6FUodVe4BroGMP/wER/YDGc7rEllw==", 498 | "dev": true, 499 | "dependencies": { 500 | "@types/chai": "*" 501 | } 502 | }, 503 | "node_modules/@types/istanbul-lib-coverage": { 504 | "version": "2.0.4", 505 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", 506 | "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", 507 | "dev": true 508 | }, 509 | "node_modules/@types/node": { 510 | "version": "20.1.3", 511 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.1.3.tgz", 512 | "integrity": "sha512-NP2yfZpgmf2eDRPmgGq+fjGjSwFgYbihA8/gK+ey23qT9RkxsgNTZvGOEpXgzIGqesTYkElELLgtKoMQTys5vA==", 513 | "dev": true 514 | }, 515 | "node_modules/@vitest/coverage-c8": { 516 | "version": "0.31.0", 517 | "resolved": "https://registry.npmjs.org/@vitest/coverage-c8/-/coverage-c8-0.31.0.tgz", 518 | "integrity": "sha512-h72qN1D962AO7UefQVulm9JFP5ACS7OfhCdBHioXU8f7ohH/+NTZCgAqmgcfRNHHO/8wLFxx+93YVxhodkEJVA==", 519 | "dev": true, 520 | "dependencies": { 521 | "@ampproject/remapping": "^2.2.0", 522 | "c8": "^7.13.0", 523 | "magic-string": "^0.30.0", 524 | "picocolors": "^1.0.0", 525 | "std-env": "^3.3.2" 526 | }, 527 | "funding": { 528 | "url": "https://opencollective.com/vitest" 529 | }, 530 | "peerDependencies": { 531 | "vitest": ">=0.30.0 <1" 532 | } 533 | }, 534 | "node_modules/@vitest/expect": { 535 | "version": "0.31.0", 536 | "resolved": "https://registry.npmjs.org/@vitest/expect/-/expect-0.31.0.tgz", 537 | "integrity": "sha512-Jlm8ZTyp6vMY9iz9Ny9a0BHnCG4fqBa8neCF6Pk/c/6vkUk49Ls6UBlgGAU82QnzzoaUs9E/mUhq/eq9uMOv/g==", 538 | "dev": true, 539 | "dependencies": { 540 | "@vitest/spy": "0.31.0", 541 | "@vitest/utils": "0.31.0", 542 | "chai": "^4.3.7" 543 | }, 544 | "funding": { 545 | "url": "https://opencollective.com/vitest" 546 | } 547 | }, 548 | "node_modules/@vitest/runner": { 549 | "version": "0.31.0", 550 | "resolved": "https://registry.npmjs.org/@vitest/runner/-/runner-0.31.0.tgz", 551 | "integrity": "sha512-H1OE+Ly7JFeBwnpHTrKyCNm/oZgr+16N4qIlzzqSG/YRQDATBYmJb/KUn3GrZaiQQyL7GwpNHVZxSQd6juLCgw==", 552 | "dev": true, 553 | "dependencies": { 554 | "@vitest/utils": "0.31.0", 555 | "concordance": "^5.0.4", 556 | "p-limit": "^4.0.0", 557 | "pathe": "^1.1.0" 558 | }, 559 | "funding": { 560 | "url": "https://opencollective.com/vitest" 561 | } 562 | }, 563 | "node_modules/@vitest/snapshot": { 564 | "version": "0.31.0", 565 | "resolved": "https://registry.npmjs.org/@vitest/snapshot/-/snapshot-0.31.0.tgz", 566 | "integrity": "sha512-5dTXhbHnyUMTMOujZPB0wjFjQ6q5x9c8TvAsSPUNKjp1tVU7i9pbqcKPqntyu2oXtmVxKbuHCqrOd+Ft60r4tg==", 567 | "dev": true, 568 | "dependencies": { 569 | "magic-string": "^0.30.0", 570 | "pathe": "^1.1.0", 571 | "pretty-format": "^27.5.1" 572 | }, 573 | "funding": { 574 | "url": "https://opencollective.com/vitest" 575 | } 576 | }, 577 | "node_modules/@vitest/spy": { 578 | "version": "0.31.0", 579 | "resolved": "https://registry.npmjs.org/@vitest/spy/-/spy-0.31.0.tgz", 580 | "integrity": "sha512-IzCEQ85RN26GqjQNkYahgVLLkULOxOm5H/t364LG0JYb3Apg0PsYCHLBYGA006+SVRMWhQvHlBBCyuByAMFmkg==", 581 | "dev": true, 582 | "dependencies": { 583 | "tinyspy": "^2.1.0" 584 | }, 585 | "funding": { 586 | "url": "https://opencollective.com/vitest" 587 | } 588 | }, 589 | "node_modules/@vitest/utils": { 590 | "version": "0.31.0", 591 | "resolved": "https://registry.npmjs.org/@vitest/utils/-/utils-0.31.0.tgz", 592 | "integrity": "sha512-kahaRyLX7GS1urekRXN2752X4gIgOGVX4Wo8eDUGUkTWlGpXzf5ZS6N9RUUS+Re3XEE8nVGqNyxkSxF5HXlGhQ==", 593 | "dev": true, 594 | "dependencies": { 595 | "concordance": "^5.0.4", 596 | "loupe": "^2.3.6", 597 | "pretty-format": "^27.5.1" 598 | }, 599 | "funding": { 600 | "url": "https://opencollective.com/vitest" 601 | } 602 | }, 603 | "node_modules/acorn": { 604 | "version": "8.8.2", 605 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.2.tgz", 606 | "integrity": "sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw==", 607 | "dev": true, 608 | "bin": { 609 | "acorn": "bin/acorn" 610 | }, 611 | "engines": { 612 | "node": ">=0.4.0" 613 | } 614 | }, 615 | "node_modules/acorn-walk": { 616 | "version": "8.2.0", 617 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 618 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 619 | "dev": true, 620 | "engines": { 621 | "node": ">=0.4.0" 622 | } 623 | }, 624 | "node_modules/ansi-regex": { 625 | "version": "5.0.1", 626 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 627 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 628 | "dev": true, 629 | "engines": { 630 | "node": ">=8" 631 | } 632 | }, 633 | "node_modules/ansi-styles": { 634 | "version": "5.2.0", 635 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", 636 | "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", 637 | "dev": true, 638 | "engines": { 639 | "node": ">=10" 640 | }, 641 | "funding": { 642 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 643 | } 644 | }, 645 | "node_modules/assertion-error": { 646 | "version": "1.1.0", 647 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 648 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 649 | "dev": true, 650 | "engines": { 651 | "node": "*" 652 | } 653 | }, 654 | "node_modules/balanced-match": { 655 | "version": "1.0.2", 656 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 657 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 658 | "dev": true 659 | }, 660 | "node_modules/blueimp-md5": { 661 | "version": "2.19.0", 662 | "resolved": "https://registry.npmjs.org/blueimp-md5/-/blueimp-md5-2.19.0.tgz", 663 | "integrity": "sha512-DRQrD6gJyy8FbiE4s+bDoXS9hiW3Vbx5uCdwvcCf3zLHL+Iv7LtGHLpr+GZV8rHG8tK766FGYBwRbu8pELTt+w==", 664 | "dev": true 665 | }, 666 | "node_modules/brace-expansion": { 667 | "version": "1.1.11", 668 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 669 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 670 | "dev": true, 671 | "dependencies": { 672 | "balanced-match": "^1.0.0", 673 | "concat-map": "0.0.1" 674 | } 675 | }, 676 | "node_modules/c8": { 677 | "version": "7.13.0", 678 | "resolved": "https://registry.npmjs.org/c8/-/c8-7.13.0.tgz", 679 | "integrity": "sha512-/NL4hQTv1gBL6J6ei80zu3IiTrmePDKXKXOTLpHvcIWZTVYQlDhVWjjWvkhICylE8EwwnMVzDZugCvdx0/DIIA==", 680 | "dev": true, 681 | "dependencies": { 682 | "@bcoe/v8-coverage": "^0.2.3", 683 | "@istanbuljs/schema": "^0.1.3", 684 | "find-up": "^5.0.0", 685 | "foreground-child": "^2.0.0", 686 | "istanbul-lib-coverage": "^3.2.0", 687 | "istanbul-lib-report": "^3.0.0", 688 | "istanbul-reports": "^3.1.4", 689 | "rimraf": "^3.0.2", 690 | "test-exclude": "^6.0.0", 691 | "v8-to-istanbul": "^9.0.0", 692 | "yargs": "^16.2.0", 693 | "yargs-parser": "^20.2.9" 694 | }, 695 | "bin": { 696 | "c8": "bin/c8.js" 697 | }, 698 | "engines": { 699 | "node": ">=10.12.0" 700 | } 701 | }, 702 | "node_modules/cac": { 703 | "version": "6.7.14", 704 | "resolved": "https://registry.npmjs.org/cac/-/cac-6.7.14.tgz", 705 | "integrity": "sha512-b6Ilus+c3RrdDk+JhLKUAQfzzgLEPy6wcXqS7f/xe1EETvsDP6GORG7SFuOs6cID5YkqchW/LXZbX5bc8j7ZcQ==", 706 | "dev": true, 707 | "engines": { 708 | "node": ">=8" 709 | } 710 | }, 711 | "node_modules/chai": { 712 | "version": "4.3.7", 713 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.7.tgz", 714 | "integrity": "sha512-HLnAzZ2iupm25PlN0xFreAlBA5zaBSv3og0DdeGA4Ar6h6rJ3A0rolRUKJhSF2V10GZKDgWF/VmAEsNWjCRB+A==", 715 | "dev": true, 716 | "dependencies": { 717 | "assertion-error": "^1.1.0", 718 | "check-error": "^1.0.2", 719 | "deep-eql": "^4.1.2", 720 | "get-func-name": "^2.0.0", 721 | "loupe": "^2.3.1", 722 | "pathval": "^1.1.1", 723 | "type-detect": "^4.0.5" 724 | }, 725 | "engines": { 726 | "node": ">=4" 727 | } 728 | }, 729 | "node_modules/check-error": { 730 | "version": "1.0.2", 731 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 732 | "integrity": "sha512-BrgHpW9NURQgzoNyjfq0Wu6VFO6D7IZEmJNdtgNqpzGG8RuNFHt2jQxWlAs4HMe119chBnv+34syEZtc6IhLtA==", 733 | "dev": true, 734 | "engines": { 735 | "node": "*" 736 | } 737 | }, 738 | "node_modules/cliui": { 739 | "version": "7.0.4", 740 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 741 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 742 | "dev": true, 743 | "dependencies": { 744 | "string-width": "^4.2.0", 745 | "strip-ansi": "^6.0.0", 746 | "wrap-ansi": "^7.0.0" 747 | } 748 | }, 749 | "node_modules/color-convert": { 750 | "version": "2.0.1", 751 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 752 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 753 | "dev": true, 754 | "dependencies": { 755 | "color-name": "~1.1.4" 756 | }, 757 | "engines": { 758 | "node": ">=7.0.0" 759 | } 760 | }, 761 | "node_modules/color-name": { 762 | "version": "1.1.4", 763 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 764 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 765 | "dev": true 766 | }, 767 | "node_modules/concat-map": { 768 | "version": "0.0.1", 769 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 770 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 771 | "dev": true 772 | }, 773 | "node_modules/concordance": { 774 | "version": "5.0.4", 775 | "resolved": "https://registry.npmjs.org/concordance/-/concordance-5.0.4.tgz", 776 | "integrity": "sha512-OAcsnTEYu1ARJqWVGwf4zh4JDfHZEaSNlNccFmt8YjB2l/n19/PF2viLINHc57vO4FKIAFl2FWASIGZZWZ2Kxw==", 777 | "dev": true, 778 | "dependencies": { 779 | "date-time": "^3.1.0", 780 | "esutils": "^2.0.3", 781 | "fast-diff": "^1.2.0", 782 | "js-string-escape": "^1.0.1", 783 | "lodash": "^4.17.15", 784 | "md5-hex": "^3.0.1", 785 | "semver": "^7.3.2", 786 | "well-known-symbols": "^2.0.0" 787 | }, 788 | "engines": { 789 | "node": ">=10.18.0 <11 || >=12.14.0 <13 || >=14" 790 | } 791 | }, 792 | "node_modules/convert-source-map": { 793 | "version": "1.9.0", 794 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", 795 | "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", 796 | "dev": true 797 | }, 798 | "node_modules/cross-spawn": { 799 | "version": "7.0.3", 800 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 801 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 802 | "dev": true, 803 | "dependencies": { 804 | "path-key": "^3.1.0", 805 | "shebang-command": "^2.0.0", 806 | "which": "^2.0.1" 807 | }, 808 | "engines": { 809 | "node": ">= 8" 810 | } 811 | }, 812 | "node_modules/date-time": { 813 | "version": "3.1.0", 814 | "resolved": "https://registry.npmjs.org/date-time/-/date-time-3.1.0.tgz", 815 | "integrity": "sha512-uqCUKXE5q1PNBXjPqvwhwJf9SwMoAHBgWJ6DcrnS5o+W2JOiIILl0JEdVD8SGujrNS02GGxgwAg2PN2zONgtjg==", 816 | "dev": true, 817 | "dependencies": { 818 | "time-zone": "^1.0.0" 819 | }, 820 | "engines": { 821 | "node": ">=6" 822 | } 823 | }, 824 | "node_modules/debug": { 825 | "version": "4.3.4", 826 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 827 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 828 | "dev": true, 829 | "dependencies": { 830 | "ms": "2.1.2" 831 | }, 832 | "engines": { 833 | "node": ">=6.0" 834 | }, 835 | "peerDependenciesMeta": { 836 | "supports-color": { 837 | "optional": true 838 | } 839 | } 840 | }, 841 | "node_modules/deep-eql": { 842 | "version": "4.1.3", 843 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-4.1.3.tgz", 844 | "integrity": "sha512-WaEtAOpRA1MQ0eohqZjpGD8zdI0Ovsm8mmFhaDN8dvDZzyoUMcYDnf5Y6iu7HTXxf8JDS23qWa4a+hKCDyOPzw==", 845 | "dev": true, 846 | "dependencies": { 847 | "type-detect": "^4.0.0" 848 | }, 849 | "engines": { 850 | "node": ">=6" 851 | } 852 | }, 853 | "node_modules/emoji-regex": { 854 | "version": "8.0.0", 855 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 856 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 857 | "dev": true 858 | }, 859 | "node_modules/esbuild": { 860 | "version": "0.17.18", 861 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.18.tgz", 862 | "integrity": "sha512-z1lix43jBs6UKjcZVKOw2xx69ffE2aG0PygLL5qJ9OS/gy0Ewd1gW/PUQIOIQGXBHWNywSc0floSKoMFF8aK2w==", 863 | "dev": true, 864 | "hasInstallScript": true, 865 | "bin": { 866 | "esbuild": "bin/esbuild" 867 | }, 868 | "engines": { 869 | "node": ">=12" 870 | }, 871 | "optionalDependencies": { 872 | "@esbuild/android-arm": "0.17.18", 873 | "@esbuild/android-arm64": "0.17.18", 874 | "@esbuild/android-x64": "0.17.18", 875 | "@esbuild/darwin-arm64": "0.17.18", 876 | "@esbuild/darwin-x64": "0.17.18", 877 | "@esbuild/freebsd-arm64": "0.17.18", 878 | "@esbuild/freebsd-x64": "0.17.18", 879 | "@esbuild/linux-arm": "0.17.18", 880 | "@esbuild/linux-arm64": "0.17.18", 881 | "@esbuild/linux-ia32": "0.17.18", 882 | "@esbuild/linux-loong64": "0.17.18", 883 | "@esbuild/linux-mips64el": "0.17.18", 884 | "@esbuild/linux-ppc64": "0.17.18", 885 | "@esbuild/linux-riscv64": "0.17.18", 886 | "@esbuild/linux-s390x": "0.17.18", 887 | "@esbuild/linux-x64": "0.17.18", 888 | "@esbuild/netbsd-x64": "0.17.18", 889 | "@esbuild/openbsd-x64": "0.17.18", 890 | "@esbuild/sunos-x64": "0.17.18", 891 | "@esbuild/win32-arm64": "0.17.18", 892 | "@esbuild/win32-ia32": "0.17.18", 893 | "@esbuild/win32-x64": "0.17.18" 894 | } 895 | }, 896 | "node_modules/escalade": { 897 | "version": "3.1.1", 898 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 899 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 900 | "dev": true, 901 | "engines": { 902 | "node": ">=6" 903 | } 904 | }, 905 | "node_modules/esutils": { 906 | "version": "2.0.3", 907 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 908 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 909 | "dev": true, 910 | "engines": { 911 | "node": ">=0.10.0" 912 | } 913 | }, 914 | "node_modules/fast-diff": { 915 | "version": "1.2.0", 916 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 917 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 918 | "dev": true 919 | }, 920 | "node_modules/find-up": { 921 | "version": "5.0.0", 922 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 923 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 924 | "dev": true, 925 | "dependencies": { 926 | "locate-path": "^6.0.0", 927 | "path-exists": "^4.0.0" 928 | }, 929 | "engines": { 930 | "node": ">=10" 931 | }, 932 | "funding": { 933 | "url": "https://github.com/sponsors/sindresorhus" 934 | } 935 | }, 936 | "node_modules/foreground-child": { 937 | "version": "2.0.0", 938 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-2.0.0.tgz", 939 | "integrity": "sha512-dCIq9FpEcyQyXKCkyzmlPTFNgrCzPudOe+mhvJU5zAtlBnGVy2yKxtfsxK2tQBThwq225jcvBjpw1Gr40uzZCA==", 940 | "dev": true, 941 | "dependencies": { 942 | "cross-spawn": "^7.0.0", 943 | "signal-exit": "^3.0.2" 944 | }, 945 | "engines": { 946 | "node": ">=8.0.0" 947 | } 948 | }, 949 | "node_modules/fs.realpath": { 950 | "version": "1.0.0", 951 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 952 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 953 | "dev": true 954 | }, 955 | "node_modules/fsevents": { 956 | "version": "2.3.2", 957 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 958 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 959 | "dev": true, 960 | "hasInstallScript": true, 961 | "optional": true, 962 | "os": [ 963 | "darwin" 964 | ], 965 | "engines": { 966 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 967 | } 968 | }, 969 | "node_modules/get-caller-file": { 970 | "version": "2.0.5", 971 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 972 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 973 | "dev": true, 974 | "engines": { 975 | "node": "6.* || 8.* || >= 10.*" 976 | } 977 | }, 978 | "node_modules/get-func-name": { 979 | "version": "2.0.0", 980 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 981 | "integrity": "sha512-Hm0ixYtaSZ/V7C8FJrtZIuBBI+iSgL+1Aq82zSu8VQNB4S3Gk8e7Qs3VwBDJAhmRZcFqkl3tQu36g/Foh5I5ig==", 982 | "dev": true, 983 | "engines": { 984 | "node": "*" 985 | } 986 | }, 987 | "node_modules/glob": { 988 | "version": "7.2.3", 989 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 990 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 991 | "dev": true, 992 | "dependencies": { 993 | "fs.realpath": "^1.0.0", 994 | "inflight": "^1.0.4", 995 | "inherits": "2", 996 | "minimatch": "^3.1.1", 997 | "once": "^1.3.0", 998 | "path-is-absolute": "^1.0.0" 999 | }, 1000 | "engines": { 1001 | "node": "*" 1002 | }, 1003 | "funding": { 1004 | "url": "https://github.com/sponsors/isaacs" 1005 | } 1006 | }, 1007 | "node_modules/has-flag": { 1008 | "version": "4.0.0", 1009 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1010 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1011 | "dev": true, 1012 | "engines": { 1013 | "node": ">=8" 1014 | } 1015 | }, 1016 | "node_modules/html-escaper": { 1017 | "version": "2.0.2", 1018 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", 1019 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", 1020 | "dev": true 1021 | }, 1022 | "node_modules/inflight": { 1023 | "version": "1.0.6", 1024 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1025 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1026 | "dev": true, 1027 | "dependencies": { 1028 | "once": "^1.3.0", 1029 | "wrappy": "1" 1030 | } 1031 | }, 1032 | "node_modules/inherits": { 1033 | "version": "2.0.4", 1034 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1035 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1036 | "dev": true 1037 | }, 1038 | "node_modules/is-fullwidth-code-point": { 1039 | "version": "3.0.0", 1040 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1041 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1042 | "dev": true, 1043 | "engines": { 1044 | "node": ">=8" 1045 | } 1046 | }, 1047 | "node_modules/isexe": { 1048 | "version": "2.0.0", 1049 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1050 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1051 | "dev": true 1052 | }, 1053 | "node_modules/istanbul-lib-coverage": { 1054 | "version": "3.2.0", 1055 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", 1056 | "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", 1057 | "dev": true, 1058 | "engines": { 1059 | "node": ">=8" 1060 | } 1061 | }, 1062 | "node_modules/istanbul-lib-report": { 1063 | "version": "3.0.0", 1064 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 1065 | "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", 1066 | "dev": true, 1067 | "dependencies": { 1068 | "istanbul-lib-coverage": "^3.0.0", 1069 | "make-dir": "^3.0.0", 1070 | "supports-color": "^7.1.0" 1071 | }, 1072 | "engines": { 1073 | "node": ">=8" 1074 | } 1075 | }, 1076 | "node_modules/istanbul-reports": { 1077 | "version": "3.1.5", 1078 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz", 1079 | "integrity": "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==", 1080 | "dev": true, 1081 | "dependencies": { 1082 | "html-escaper": "^2.0.0", 1083 | "istanbul-lib-report": "^3.0.0" 1084 | }, 1085 | "engines": { 1086 | "node": ">=8" 1087 | } 1088 | }, 1089 | "node_modules/js-string-escape": { 1090 | "version": "1.0.1", 1091 | "resolved": "https://registry.npmjs.org/js-string-escape/-/js-string-escape-1.0.1.tgz", 1092 | "integrity": "sha512-Smw4xcfIQ5LVjAOuJCvN/zIodzA/BBSsluuoSykP+lUvScIi4U6RJLfwHet5cxFnCswUjISV8oAXaqaJDY3chg==", 1093 | "dev": true, 1094 | "engines": { 1095 | "node": ">= 0.8" 1096 | } 1097 | }, 1098 | "node_modules/jsonc-parser": { 1099 | "version": "3.2.0", 1100 | "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.2.0.tgz", 1101 | "integrity": "sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==", 1102 | "dev": true 1103 | }, 1104 | "node_modules/local-pkg": { 1105 | "version": "0.4.3", 1106 | "resolved": "https://registry.npmjs.org/local-pkg/-/local-pkg-0.4.3.tgz", 1107 | "integrity": "sha512-SFppqq5p42fe2qcZQqqEOiVRXl+WCP1MdT6k7BDEW1j++sp5fIY+/fdRQitvKgB5BrBcmrs5m/L0v2FrU5MY1g==", 1108 | "dev": true, 1109 | "engines": { 1110 | "node": ">=14" 1111 | }, 1112 | "funding": { 1113 | "url": "https://github.com/sponsors/antfu" 1114 | } 1115 | }, 1116 | "node_modules/locate-path": { 1117 | "version": "6.0.0", 1118 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1119 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1120 | "dev": true, 1121 | "dependencies": { 1122 | "p-locate": "^5.0.0" 1123 | }, 1124 | "engines": { 1125 | "node": ">=10" 1126 | }, 1127 | "funding": { 1128 | "url": "https://github.com/sponsors/sindresorhus" 1129 | } 1130 | }, 1131 | "node_modules/lodash": { 1132 | "version": "4.17.21", 1133 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1134 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 1135 | "dev": true 1136 | }, 1137 | "node_modules/loupe": { 1138 | "version": "2.3.6", 1139 | "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.6.tgz", 1140 | "integrity": "sha512-RaPMZKiMy8/JruncMU5Bt6na1eftNoo++R4Y+N2FrxkDVTrGvcyzFTsaGif4QTeKESheMGegbhw6iUAq+5A8zA==", 1141 | "dev": true, 1142 | "dependencies": { 1143 | "get-func-name": "^2.0.0" 1144 | } 1145 | }, 1146 | "node_modules/lru-cache": { 1147 | "version": "6.0.0", 1148 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1149 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1150 | "dev": true, 1151 | "dependencies": { 1152 | "yallist": "^4.0.0" 1153 | }, 1154 | "engines": { 1155 | "node": ">=10" 1156 | } 1157 | }, 1158 | "node_modules/magic-string": { 1159 | "version": "0.30.0", 1160 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.0.tgz", 1161 | "integrity": "sha512-LA+31JYDJLs82r2ScLrlz1GjSgu66ZV518eyWT+S8VhyQn/JL0u9MeBOvQMGYiPk1DBiSN9DDMOcXvigJZaViQ==", 1162 | "dev": true, 1163 | "dependencies": { 1164 | "@jridgewell/sourcemap-codec": "^1.4.13" 1165 | }, 1166 | "engines": { 1167 | "node": ">=12" 1168 | } 1169 | }, 1170 | "node_modules/make-dir": { 1171 | "version": "3.1.0", 1172 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 1173 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 1174 | "dev": true, 1175 | "dependencies": { 1176 | "semver": "^6.0.0" 1177 | }, 1178 | "engines": { 1179 | "node": ">=8" 1180 | }, 1181 | "funding": { 1182 | "url": "https://github.com/sponsors/sindresorhus" 1183 | } 1184 | }, 1185 | "node_modules/make-dir/node_modules/semver": { 1186 | "version": "6.3.0", 1187 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1188 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1189 | "dev": true, 1190 | "bin": { 1191 | "semver": "bin/semver.js" 1192 | } 1193 | }, 1194 | "node_modules/md5-hex": { 1195 | "version": "3.0.1", 1196 | "resolved": "https://registry.npmjs.org/md5-hex/-/md5-hex-3.0.1.tgz", 1197 | "integrity": "sha512-BUiRtTtV39LIJwinWBjqVsU9xhdnz7/i889V859IBFpuqGAj6LuOvHv5XLbgZ2R7ptJoJaEcxkv88/h25T7Ciw==", 1198 | "dev": true, 1199 | "dependencies": { 1200 | "blueimp-md5": "^2.10.0" 1201 | }, 1202 | "engines": { 1203 | "node": ">=8" 1204 | } 1205 | }, 1206 | "node_modules/minimatch": { 1207 | "version": "3.1.2", 1208 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1209 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1210 | "dev": true, 1211 | "dependencies": { 1212 | "brace-expansion": "^1.1.7" 1213 | }, 1214 | "engines": { 1215 | "node": "*" 1216 | } 1217 | }, 1218 | "node_modules/mlly": { 1219 | "version": "1.2.1", 1220 | "resolved": "https://registry.npmjs.org/mlly/-/mlly-1.2.1.tgz", 1221 | "integrity": "sha512-1aMEByaWgBPEbWV2BOPEMySRrzl7rIHXmQxam4DM8jVjalTQDjpN2ZKOLUrwyhfZQO7IXHml2StcHMhooDeEEQ==", 1222 | "dev": true, 1223 | "dependencies": { 1224 | "acorn": "^8.8.2", 1225 | "pathe": "^1.1.0", 1226 | "pkg-types": "^1.0.3", 1227 | "ufo": "^1.1.2" 1228 | } 1229 | }, 1230 | "node_modules/ms": { 1231 | "version": "2.1.2", 1232 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1233 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1234 | "dev": true 1235 | }, 1236 | "node_modules/nanoid": { 1237 | "version": "3.3.6", 1238 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz", 1239 | "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==", 1240 | "dev": true, 1241 | "funding": [ 1242 | { 1243 | "type": "github", 1244 | "url": "https://github.com/sponsors/ai" 1245 | } 1246 | ], 1247 | "bin": { 1248 | "nanoid": "bin/nanoid.cjs" 1249 | }, 1250 | "engines": { 1251 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1252 | } 1253 | }, 1254 | "node_modules/once": { 1255 | "version": "1.4.0", 1256 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1257 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1258 | "dev": true, 1259 | "dependencies": { 1260 | "wrappy": "1" 1261 | } 1262 | }, 1263 | "node_modules/p-limit": { 1264 | "version": "4.0.0", 1265 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-4.0.0.tgz", 1266 | "integrity": "sha512-5b0R4txpzjPWVw/cXXUResoD4hb6U/x9BH08L7nw+GN1sezDzPdxeRvpc9c433fZhBan/wusjbCsqwqm4EIBIQ==", 1267 | "dev": true, 1268 | "dependencies": { 1269 | "yocto-queue": "^1.0.0" 1270 | }, 1271 | "engines": { 1272 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 1273 | }, 1274 | "funding": { 1275 | "url": "https://github.com/sponsors/sindresorhus" 1276 | } 1277 | }, 1278 | "node_modules/p-locate": { 1279 | "version": "5.0.0", 1280 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1281 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1282 | "dev": true, 1283 | "dependencies": { 1284 | "p-limit": "^3.0.2" 1285 | }, 1286 | "engines": { 1287 | "node": ">=10" 1288 | }, 1289 | "funding": { 1290 | "url": "https://github.com/sponsors/sindresorhus" 1291 | } 1292 | }, 1293 | "node_modules/p-locate/node_modules/p-limit": { 1294 | "version": "3.1.0", 1295 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1296 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1297 | "dev": true, 1298 | "dependencies": { 1299 | "yocto-queue": "^0.1.0" 1300 | }, 1301 | "engines": { 1302 | "node": ">=10" 1303 | }, 1304 | "funding": { 1305 | "url": "https://github.com/sponsors/sindresorhus" 1306 | } 1307 | }, 1308 | "node_modules/p-locate/node_modules/yocto-queue": { 1309 | "version": "0.1.0", 1310 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1311 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1312 | "dev": true, 1313 | "engines": { 1314 | "node": ">=10" 1315 | }, 1316 | "funding": { 1317 | "url": "https://github.com/sponsors/sindresorhus" 1318 | } 1319 | }, 1320 | "node_modules/path-exists": { 1321 | "version": "4.0.0", 1322 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1323 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1324 | "dev": true, 1325 | "engines": { 1326 | "node": ">=8" 1327 | } 1328 | }, 1329 | "node_modules/path-is-absolute": { 1330 | "version": "1.0.1", 1331 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1332 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1333 | "dev": true, 1334 | "engines": { 1335 | "node": ">=0.10.0" 1336 | } 1337 | }, 1338 | "node_modules/path-key": { 1339 | "version": "3.1.1", 1340 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1341 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1342 | "dev": true, 1343 | "engines": { 1344 | "node": ">=8" 1345 | } 1346 | }, 1347 | "node_modules/pathe": { 1348 | "version": "1.1.0", 1349 | "resolved": "https://registry.npmjs.org/pathe/-/pathe-1.1.0.tgz", 1350 | "integrity": "sha512-ODbEPR0KKHqECXW1GoxdDb+AZvULmXjVPy4rt+pGo2+TnjJTIPJQSVS6N63n8T2Ip+syHhbn52OewKicV0373w==", 1351 | "dev": true 1352 | }, 1353 | "node_modules/pathval": { 1354 | "version": "1.1.1", 1355 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 1356 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 1357 | "dev": true, 1358 | "engines": { 1359 | "node": "*" 1360 | } 1361 | }, 1362 | "node_modules/picocolors": { 1363 | "version": "1.0.0", 1364 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 1365 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 1366 | "dev": true 1367 | }, 1368 | "node_modules/pkg-types": { 1369 | "version": "1.0.3", 1370 | "resolved": "https://registry.npmjs.org/pkg-types/-/pkg-types-1.0.3.tgz", 1371 | "integrity": "sha512-nN7pYi0AQqJnoLPC9eHFQ8AcyaixBUOwvqc5TDnIKCMEE6I0y8P7OKA7fPexsXGCGxQDl/cmrLAp26LhcwxZ4A==", 1372 | "dev": true, 1373 | "dependencies": { 1374 | "jsonc-parser": "^3.2.0", 1375 | "mlly": "^1.2.0", 1376 | "pathe": "^1.1.0" 1377 | } 1378 | }, 1379 | "node_modules/postcss": { 1380 | "version": "8.4.23", 1381 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.23.tgz", 1382 | "integrity": "sha512-bQ3qMcpF6A/YjR55xtoTr0jGOlnPOKAIMdOWiv0EIT6HVPEaJiJB4NLljSbiHoC2RX7DN5Uvjtpbg1NPdwv1oA==", 1383 | "dev": true, 1384 | "funding": [ 1385 | { 1386 | "type": "opencollective", 1387 | "url": "https://opencollective.com/postcss/" 1388 | }, 1389 | { 1390 | "type": "tidelift", 1391 | "url": "https://tidelift.com/funding/github/npm/postcss" 1392 | }, 1393 | { 1394 | "type": "github", 1395 | "url": "https://github.com/sponsors/ai" 1396 | } 1397 | ], 1398 | "dependencies": { 1399 | "nanoid": "^3.3.6", 1400 | "picocolors": "^1.0.0", 1401 | "source-map-js": "^1.0.2" 1402 | }, 1403 | "engines": { 1404 | "node": "^10 || ^12 || >=14" 1405 | } 1406 | }, 1407 | "node_modules/prettier": { 1408 | "version": "2.8.8", 1409 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.8.tgz", 1410 | "integrity": "sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q==", 1411 | "dev": true, 1412 | "bin": { 1413 | "prettier": "bin-prettier.js" 1414 | }, 1415 | "engines": { 1416 | "node": ">=10.13.0" 1417 | }, 1418 | "funding": { 1419 | "url": "https://github.com/prettier/prettier?sponsor=1" 1420 | } 1421 | }, 1422 | "node_modules/pretty-format": { 1423 | "version": "27.5.1", 1424 | "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-27.5.1.tgz", 1425 | "integrity": "sha512-Qb1gy5OrP5+zDf2Bvnzdl3jsTf1qXVMazbvCoKhtKqVs4/YK4ozX4gKQJJVyNe+cajNPn0KoC0MC3FUmaHWEmQ==", 1426 | "dev": true, 1427 | "dependencies": { 1428 | "ansi-regex": "^5.0.1", 1429 | "ansi-styles": "^5.0.0", 1430 | "react-is": "^17.0.1" 1431 | }, 1432 | "engines": { 1433 | "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" 1434 | } 1435 | }, 1436 | "node_modules/prisma": { 1437 | "version": "4.14.0", 1438 | "resolved": "https://registry.npmjs.org/prisma/-/prisma-4.14.0.tgz", 1439 | "integrity": "sha512-+5dMl1uxMQb4RepndY6AwR9xi1cDcaGFICu+ws6/Nmgt93mFPNj8tYxSfTdmfg+rkNrUId9rk/Ac2vTgLe/oXA==", 1440 | "dev": true, 1441 | "hasInstallScript": true, 1442 | "dependencies": { 1443 | "@prisma/engines": "4.14.0" 1444 | }, 1445 | "bin": { 1446 | "prisma": "build/index.js", 1447 | "prisma2": "build/index.js" 1448 | }, 1449 | "engines": { 1450 | "node": ">=14.17" 1451 | } 1452 | }, 1453 | "node_modules/react-is": { 1454 | "version": "17.0.2", 1455 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", 1456 | "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", 1457 | "dev": true 1458 | }, 1459 | "node_modules/require-directory": { 1460 | "version": "2.1.1", 1461 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1462 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 1463 | "dev": true, 1464 | "engines": { 1465 | "node": ">=0.10.0" 1466 | } 1467 | }, 1468 | "node_modules/rimraf": { 1469 | "version": "3.0.2", 1470 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1471 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1472 | "dev": true, 1473 | "dependencies": { 1474 | "glob": "^7.1.3" 1475 | }, 1476 | "bin": { 1477 | "rimraf": "bin.js" 1478 | }, 1479 | "funding": { 1480 | "url": "https://github.com/sponsors/isaacs" 1481 | } 1482 | }, 1483 | "node_modules/rollup": { 1484 | "version": "3.21.6", 1485 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-3.21.6.tgz", 1486 | "integrity": "sha512-SXIICxvxQxR3D4dp/3LDHZIJPC8a4anKMHd4E3Jiz2/JnY+2bEjqrOokAauc5ShGVNFHlEFjBXAXlaxkJqIqSg==", 1487 | "dev": true, 1488 | "bin": { 1489 | "rollup": "dist/bin/rollup" 1490 | }, 1491 | "engines": { 1492 | "node": ">=14.18.0", 1493 | "npm": ">=8.0.0" 1494 | }, 1495 | "optionalDependencies": { 1496 | "fsevents": "~2.3.2" 1497 | } 1498 | }, 1499 | "node_modules/semver": { 1500 | "version": "7.5.1", 1501 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.1.tgz", 1502 | "integrity": "sha512-Wvss5ivl8TMRZXXESstBA4uR5iXgEN/VC5/sOcuXdVLzcdkz4HWetIoRfG5gb5X+ij/G9rw9YoGn3QoQ8OCSpw==", 1503 | "dev": true, 1504 | "dependencies": { 1505 | "lru-cache": "^6.0.0" 1506 | }, 1507 | "bin": { 1508 | "semver": "bin/semver.js" 1509 | }, 1510 | "engines": { 1511 | "node": ">=10" 1512 | } 1513 | }, 1514 | "node_modules/shebang-command": { 1515 | "version": "2.0.0", 1516 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1517 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1518 | "dev": true, 1519 | "dependencies": { 1520 | "shebang-regex": "^3.0.0" 1521 | }, 1522 | "engines": { 1523 | "node": ">=8" 1524 | } 1525 | }, 1526 | "node_modules/shebang-regex": { 1527 | "version": "3.0.0", 1528 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1529 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1530 | "dev": true, 1531 | "engines": { 1532 | "node": ">=8" 1533 | } 1534 | }, 1535 | "node_modules/siginfo": { 1536 | "version": "2.0.0", 1537 | "resolved": "https://registry.npmjs.org/siginfo/-/siginfo-2.0.0.tgz", 1538 | "integrity": "sha512-ybx0WO1/8bSBLEWXZvEd7gMW3Sn3JFlW3TvX1nREbDLRNQNaeNN8WK0meBwPdAaOI7TtRRRJn/Es1zhrrCHu7g==", 1539 | "dev": true 1540 | }, 1541 | "node_modules/signal-exit": { 1542 | "version": "3.0.7", 1543 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 1544 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 1545 | "dev": true 1546 | }, 1547 | "node_modules/source-map-js": { 1548 | "version": "1.0.2", 1549 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", 1550 | "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", 1551 | "dev": true, 1552 | "engines": { 1553 | "node": ">=0.10.0" 1554 | } 1555 | }, 1556 | "node_modules/stackback": { 1557 | "version": "0.0.2", 1558 | "resolved": "https://registry.npmjs.org/stackback/-/stackback-0.0.2.tgz", 1559 | "integrity": "sha512-1XMJE5fQo1jGH6Y/7ebnwPOBEkIEnT4QF32d5R1+VXdXveM0IBMJt8zfaxX1P3QhVwrYe+576+jkANtSS2mBbw==", 1560 | "dev": true 1561 | }, 1562 | "node_modules/std-env": { 1563 | "version": "3.3.3", 1564 | "resolved": "https://registry.npmjs.org/std-env/-/std-env-3.3.3.tgz", 1565 | "integrity": "sha512-Rz6yejtVyWnVjC1RFvNmYL10kgjC49EOghxWn0RFqlCHGFpQx+Xe7yW3I4ceK1SGrWIGMjD5Kbue8W/udkbMJg==", 1566 | "dev": true 1567 | }, 1568 | "node_modules/string-width": { 1569 | "version": "4.2.3", 1570 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1571 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1572 | "dev": true, 1573 | "dependencies": { 1574 | "emoji-regex": "^8.0.0", 1575 | "is-fullwidth-code-point": "^3.0.0", 1576 | "strip-ansi": "^6.0.1" 1577 | }, 1578 | "engines": { 1579 | "node": ">=8" 1580 | } 1581 | }, 1582 | "node_modules/strip-ansi": { 1583 | "version": "6.0.1", 1584 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1585 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1586 | "dev": true, 1587 | "dependencies": { 1588 | "ansi-regex": "^5.0.1" 1589 | }, 1590 | "engines": { 1591 | "node": ">=8" 1592 | } 1593 | }, 1594 | "node_modules/strip-literal": { 1595 | "version": "1.0.1", 1596 | "resolved": "https://registry.npmjs.org/strip-literal/-/strip-literal-1.0.1.tgz", 1597 | "integrity": "sha512-QZTsipNpa2Ppr6v1AmJHESqJ3Uz247MUS0OjrnnZjFAvEoWqxuyFuXn2xLgMtRnijJShAa1HL0gtJyUs7u7n3Q==", 1598 | "dev": true, 1599 | "dependencies": { 1600 | "acorn": "^8.8.2" 1601 | }, 1602 | "funding": { 1603 | "url": "https://github.com/sponsors/antfu" 1604 | } 1605 | }, 1606 | "node_modules/supports-color": { 1607 | "version": "7.2.0", 1608 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1609 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1610 | "dev": true, 1611 | "dependencies": { 1612 | "has-flag": "^4.0.0" 1613 | }, 1614 | "engines": { 1615 | "node": ">=8" 1616 | } 1617 | }, 1618 | "node_modules/test-exclude": { 1619 | "version": "6.0.0", 1620 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", 1621 | "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", 1622 | "dev": true, 1623 | "dependencies": { 1624 | "@istanbuljs/schema": "^0.1.2", 1625 | "glob": "^7.1.4", 1626 | "minimatch": "^3.0.4" 1627 | }, 1628 | "engines": { 1629 | "node": ">=8" 1630 | } 1631 | }, 1632 | "node_modules/time-zone": { 1633 | "version": "1.0.0", 1634 | "resolved": "https://registry.npmjs.org/time-zone/-/time-zone-1.0.0.tgz", 1635 | "integrity": "sha512-TIsDdtKo6+XrPtiTm1ssmMngN1sAhyKnTO2kunQWqNPWIVvCm15Wmw4SWInwTVgJ5u/Tr04+8Ei9TNcw4x4ONA==", 1636 | "dev": true, 1637 | "engines": { 1638 | "node": ">=4" 1639 | } 1640 | }, 1641 | "node_modules/tinybench": { 1642 | "version": "2.5.0", 1643 | "resolved": "https://registry.npmjs.org/tinybench/-/tinybench-2.5.0.tgz", 1644 | "integrity": "sha512-kRwSG8Zx4tjF9ZiyH4bhaebu+EDz1BOx9hOigYHlUW4xxI/wKIUQUqo018UlU4ar6ATPBsaMrdbKZ+tmPdohFA==", 1645 | "dev": true 1646 | }, 1647 | "node_modules/tinypool": { 1648 | "version": "0.5.0", 1649 | "resolved": "https://registry.npmjs.org/tinypool/-/tinypool-0.5.0.tgz", 1650 | "integrity": "sha512-paHQtnrlS1QZYKF/GnLoOM/DN9fqaGOFbCbxzAhwniySnzl9Ebk8w73/dd34DAhe/obUbPAOldTyYXQZxnPBPQ==", 1651 | "dev": true, 1652 | "engines": { 1653 | "node": ">=14.0.0" 1654 | } 1655 | }, 1656 | "node_modules/tinyspy": { 1657 | "version": "2.1.0", 1658 | "resolved": "https://registry.npmjs.org/tinyspy/-/tinyspy-2.1.0.tgz", 1659 | "integrity": "sha512-7eORpyqImoOvkQJCSkL0d0mB4NHHIFAy4b1u8PHdDa7SjGS2njzl6/lyGoZLm+eyYEtlUmFGE0rFj66SWxZgQQ==", 1660 | "dev": true, 1661 | "engines": { 1662 | "node": ">=14.0.0" 1663 | } 1664 | }, 1665 | "node_modules/type-detect": { 1666 | "version": "4.0.8", 1667 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 1668 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 1669 | "dev": true, 1670 | "engines": { 1671 | "node": ">=4" 1672 | } 1673 | }, 1674 | "node_modules/typescript": { 1675 | "version": "5.0.4", 1676 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.0.4.tgz", 1677 | "integrity": "sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw==", 1678 | "dev": true, 1679 | "bin": { 1680 | "tsc": "bin/tsc", 1681 | "tsserver": "bin/tsserver" 1682 | }, 1683 | "engines": { 1684 | "node": ">=12.20" 1685 | } 1686 | }, 1687 | "node_modules/ufo": { 1688 | "version": "1.1.2", 1689 | "resolved": "https://registry.npmjs.org/ufo/-/ufo-1.1.2.tgz", 1690 | "integrity": "sha512-TrY6DsjTQQgyS3E3dBaOXf0TpPD8u9FVrVYmKVegJuFw51n/YB9XPt+U6ydzFG5ZIN7+DIjPbNmXoBj9esYhgQ==", 1691 | "dev": true 1692 | }, 1693 | "node_modules/v8-to-istanbul": { 1694 | "version": "9.1.0", 1695 | "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.1.0.tgz", 1696 | "integrity": "sha512-6z3GW9x8G1gd+JIIgQQQxXuiJtCXeAjp6RaPEPLv62mH3iPHPxV6W3robxtCzNErRo6ZwTmzWhsbNvjyEBKzKA==", 1697 | "dev": true, 1698 | "dependencies": { 1699 | "@jridgewell/trace-mapping": "^0.3.12", 1700 | "@types/istanbul-lib-coverage": "^2.0.1", 1701 | "convert-source-map": "^1.6.0" 1702 | }, 1703 | "engines": { 1704 | "node": ">=10.12.0" 1705 | } 1706 | }, 1707 | "node_modules/vite": { 1708 | "version": "4.3.5", 1709 | "resolved": "https://registry.npmjs.org/vite/-/vite-4.3.5.tgz", 1710 | "integrity": "sha512-0gEnL9wiRFxgz40o/i/eTBwm+NEbpUeTWhzKrZDSdKm6nplj+z4lKz8ANDgildxHm47Vg8EUia0aicKbawUVVA==", 1711 | "dev": true, 1712 | "dependencies": { 1713 | "esbuild": "^0.17.5", 1714 | "postcss": "^8.4.23", 1715 | "rollup": "^3.21.0" 1716 | }, 1717 | "bin": { 1718 | "vite": "bin/vite.js" 1719 | }, 1720 | "engines": { 1721 | "node": "^14.18.0 || >=16.0.0" 1722 | }, 1723 | "optionalDependencies": { 1724 | "fsevents": "~2.3.2" 1725 | }, 1726 | "peerDependencies": { 1727 | "@types/node": ">= 14", 1728 | "less": "*", 1729 | "sass": "*", 1730 | "stylus": "*", 1731 | "sugarss": "*", 1732 | "terser": "^5.4.0" 1733 | }, 1734 | "peerDependenciesMeta": { 1735 | "@types/node": { 1736 | "optional": true 1737 | }, 1738 | "less": { 1739 | "optional": true 1740 | }, 1741 | "sass": { 1742 | "optional": true 1743 | }, 1744 | "stylus": { 1745 | "optional": true 1746 | }, 1747 | "sugarss": { 1748 | "optional": true 1749 | }, 1750 | "terser": { 1751 | "optional": true 1752 | } 1753 | } 1754 | }, 1755 | "node_modules/vite-node": { 1756 | "version": "0.31.0", 1757 | "resolved": "https://registry.npmjs.org/vite-node/-/vite-node-0.31.0.tgz", 1758 | "integrity": "sha512-8x1x1LNuPvE2vIvkSB7c1mApX5oqlgsxzHQesYF7l5n1gKrEmrClIiZuOFbFDQcjLsmcWSwwmrWrcGWm9Fxc/g==", 1759 | "dev": true, 1760 | "dependencies": { 1761 | "cac": "^6.7.14", 1762 | "debug": "^4.3.4", 1763 | "mlly": "^1.2.0", 1764 | "pathe": "^1.1.0", 1765 | "picocolors": "^1.0.0", 1766 | "vite": "^3.0.0 || ^4.0.0" 1767 | }, 1768 | "bin": { 1769 | "vite-node": "vite-node.mjs" 1770 | }, 1771 | "engines": { 1772 | "node": ">=v14.18.0" 1773 | }, 1774 | "funding": { 1775 | "url": "https://opencollective.com/vitest" 1776 | } 1777 | }, 1778 | "node_modules/vitest": { 1779 | "version": "0.31.0", 1780 | "resolved": "https://registry.npmjs.org/vitest/-/vitest-0.31.0.tgz", 1781 | "integrity": "sha512-JwWJS9p3GU9GxkG7eBSmr4Q4x4bvVBSswaCFf1PBNHiPx00obfhHRJfgHcnI0ffn+NMlIh9QGvG75FlaIBdKGA==", 1782 | "dev": true, 1783 | "dependencies": { 1784 | "@types/chai": "^4.3.4", 1785 | "@types/chai-subset": "^1.3.3", 1786 | "@types/node": "*", 1787 | "@vitest/expect": "0.31.0", 1788 | "@vitest/runner": "0.31.0", 1789 | "@vitest/snapshot": "0.31.0", 1790 | "@vitest/spy": "0.31.0", 1791 | "@vitest/utils": "0.31.0", 1792 | "acorn": "^8.8.2", 1793 | "acorn-walk": "^8.2.0", 1794 | "cac": "^6.7.14", 1795 | "chai": "^4.3.7", 1796 | "concordance": "^5.0.4", 1797 | "debug": "^4.3.4", 1798 | "local-pkg": "^0.4.3", 1799 | "magic-string": "^0.30.0", 1800 | "pathe": "^1.1.0", 1801 | "picocolors": "^1.0.0", 1802 | "std-env": "^3.3.2", 1803 | "strip-literal": "^1.0.1", 1804 | "tinybench": "^2.4.0", 1805 | "tinypool": "^0.5.0", 1806 | "vite": "^3.0.0 || ^4.0.0", 1807 | "vite-node": "0.31.0", 1808 | "why-is-node-running": "^2.2.2" 1809 | }, 1810 | "bin": { 1811 | "vitest": "vitest.mjs" 1812 | }, 1813 | "engines": { 1814 | "node": ">=v14.18.0" 1815 | }, 1816 | "funding": { 1817 | "url": "https://opencollective.com/vitest" 1818 | }, 1819 | "peerDependencies": { 1820 | "@edge-runtime/vm": "*", 1821 | "@vitest/browser": "*", 1822 | "@vitest/ui": "*", 1823 | "happy-dom": "*", 1824 | "jsdom": "*", 1825 | "playwright": "*", 1826 | "safaridriver": "*", 1827 | "webdriverio": "*" 1828 | }, 1829 | "peerDependenciesMeta": { 1830 | "@edge-runtime/vm": { 1831 | "optional": true 1832 | }, 1833 | "@vitest/browser": { 1834 | "optional": true 1835 | }, 1836 | "@vitest/ui": { 1837 | "optional": true 1838 | }, 1839 | "happy-dom": { 1840 | "optional": true 1841 | }, 1842 | "jsdom": { 1843 | "optional": true 1844 | }, 1845 | "playwright": { 1846 | "optional": true 1847 | }, 1848 | "safaridriver": { 1849 | "optional": true 1850 | }, 1851 | "webdriverio": { 1852 | "optional": true 1853 | } 1854 | } 1855 | }, 1856 | "node_modules/well-known-symbols": { 1857 | "version": "2.0.0", 1858 | "resolved": "https://registry.npmjs.org/well-known-symbols/-/well-known-symbols-2.0.0.tgz", 1859 | "integrity": "sha512-ZMjC3ho+KXo0BfJb7JgtQ5IBuvnShdlACNkKkdsqBmYw3bPAaJfPeYUo6tLUaT5tG/Gkh7xkpBhKRQ9e7pyg9Q==", 1860 | "dev": true, 1861 | "engines": { 1862 | "node": ">=6" 1863 | } 1864 | }, 1865 | "node_modules/which": { 1866 | "version": "2.0.2", 1867 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1868 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1869 | "dev": true, 1870 | "dependencies": { 1871 | "isexe": "^2.0.0" 1872 | }, 1873 | "bin": { 1874 | "node-which": "bin/node-which" 1875 | }, 1876 | "engines": { 1877 | "node": ">= 8" 1878 | } 1879 | }, 1880 | "node_modules/why-is-node-running": { 1881 | "version": "2.2.2", 1882 | "resolved": "https://registry.npmjs.org/why-is-node-running/-/why-is-node-running-2.2.2.tgz", 1883 | "integrity": "sha512-6tSwToZxTOcotxHeA+qGCq1mVzKR3CwcJGmVcY+QE8SHy6TnpFnh8PAvPNHYr7EcuVeG0QSMxtYCuO1ta/G/oA==", 1884 | "dev": true, 1885 | "dependencies": { 1886 | "siginfo": "^2.0.0", 1887 | "stackback": "0.0.2" 1888 | }, 1889 | "bin": { 1890 | "why-is-node-running": "cli.js" 1891 | }, 1892 | "engines": { 1893 | "node": ">=8" 1894 | } 1895 | }, 1896 | "node_modules/wrap-ansi": { 1897 | "version": "7.0.0", 1898 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1899 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1900 | "dev": true, 1901 | "dependencies": { 1902 | "ansi-styles": "^4.0.0", 1903 | "string-width": "^4.1.0", 1904 | "strip-ansi": "^6.0.0" 1905 | }, 1906 | "engines": { 1907 | "node": ">=10" 1908 | }, 1909 | "funding": { 1910 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 1911 | } 1912 | }, 1913 | "node_modules/wrap-ansi/node_modules/ansi-styles": { 1914 | "version": "4.3.0", 1915 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1916 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1917 | "dev": true, 1918 | "dependencies": { 1919 | "color-convert": "^2.0.1" 1920 | }, 1921 | "engines": { 1922 | "node": ">=8" 1923 | }, 1924 | "funding": { 1925 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1926 | } 1927 | }, 1928 | "node_modules/wrappy": { 1929 | "version": "1.0.2", 1930 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1931 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 1932 | "dev": true 1933 | }, 1934 | "node_modules/y18n": { 1935 | "version": "5.0.8", 1936 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1937 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1938 | "dev": true, 1939 | "engines": { 1940 | "node": ">=10" 1941 | } 1942 | }, 1943 | "node_modules/yallist": { 1944 | "version": "4.0.0", 1945 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1946 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1947 | "dev": true 1948 | }, 1949 | "node_modules/yargs": { 1950 | "version": "16.2.0", 1951 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 1952 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 1953 | "dev": true, 1954 | "dependencies": { 1955 | "cliui": "^7.0.2", 1956 | "escalade": "^3.1.1", 1957 | "get-caller-file": "^2.0.5", 1958 | "require-directory": "^2.1.1", 1959 | "string-width": "^4.2.0", 1960 | "y18n": "^5.0.5", 1961 | "yargs-parser": "^20.2.2" 1962 | }, 1963 | "engines": { 1964 | "node": ">=10" 1965 | } 1966 | }, 1967 | "node_modules/yargs-parser": { 1968 | "version": "20.2.9", 1969 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 1970 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 1971 | "dev": true, 1972 | "engines": { 1973 | "node": ">=10" 1974 | } 1975 | }, 1976 | "node_modules/yocto-queue": { 1977 | "version": "1.0.0", 1978 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-1.0.0.tgz", 1979 | "integrity": "sha512-9bnSc/HEW2uRy67wc+T8UwauLuPJVn28jb+GtJY16iiKWyvmYJRXVT4UamsAEGQfPohgr2q4Tq0sQbQlxTfi1g==", 1980 | "dev": true, 1981 | "engines": { 1982 | "node": ">=12.20" 1983 | }, 1984 | "funding": { 1985 | "url": "https://github.com/sponsors/sindresorhus" 1986 | } 1987 | } 1988 | }, 1989 | "dependencies": { 1990 | "@ampproject/remapping": { 1991 | "version": "2.2.1", 1992 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", 1993 | "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", 1994 | "dev": true, 1995 | "requires": { 1996 | "@jridgewell/gen-mapping": "^0.3.0", 1997 | "@jridgewell/trace-mapping": "^0.3.9" 1998 | } 1999 | }, 2000 | "@bcoe/v8-coverage": { 2001 | "version": "0.2.3", 2002 | "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", 2003 | "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", 2004 | "dev": true 2005 | }, 2006 | "@esbuild/android-arm": { 2007 | "version": "0.17.18", 2008 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.18.tgz", 2009 | "integrity": "sha512-EmwL+vUBZJ7mhFCs5lA4ZimpUH3WMAoqvOIYhVQwdIgSpHC8ImHdsRyhHAVxpDYUSm0lWvd63z0XH1IlImS2Qw==", 2010 | "dev": true, 2011 | "optional": true 2012 | }, 2013 | "@esbuild/android-arm64": { 2014 | "version": "0.17.18", 2015 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.18.tgz", 2016 | "integrity": "sha512-/iq0aK0eeHgSC3z55ucMAHO05OIqmQehiGay8eP5l/5l+iEr4EIbh4/MI8xD9qRFjqzgkc0JkX0LculNC9mXBw==", 2017 | "dev": true, 2018 | "optional": true 2019 | }, 2020 | "@esbuild/android-x64": { 2021 | "version": "0.17.18", 2022 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.18.tgz", 2023 | "integrity": "sha512-x+0efYNBF3NPW2Xc5bFOSFW7tTXdAcpfEg2nXmxegm4mJuVeS+i109m/7HMiOQ6M12aVGGFlqJX3RhNdYM2lWg==", 2024 | "dev": true, 2025 | "optional": true 2026 | }, 2027 | "@esbuild/darwin-arm64": { 2028 | "version": "0.17.18", 2029 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.18.tgz", 2030 | "integrity": "sha512-6tY+djEAdF48M1ONWnQb1C+6LiXrKjmqjzPNPWXhu/GzOHTHX2nh8Mo2ZAmBFg0kIodHhciEgUBtcYCAIjGbjQ==", 2031 | "dev": true, 2032 | "optional": true 2033 | }, 2034 | "@esbuild/darwin-x64": { 2035 | "version": "0.17.18", 2036 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.18.tgz", 2037 | "integrity": "sha512-Qq84ykvLvya3dO49wVC9FFCNUfSrQJLbxhoQk/TE1r6MjHo3sFF2tlJCwMjhkBVq3/ahUisj7+EpRSz0/+8+9A==", 2038 | "dev": true, 2039 | "optional": true 2040 | }, 2041 | "@esbuild/freebsd-arm64": { 2042 | "version": "0.17.18", 2043 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.18.tgz", 2044 | "integrity": "sha512-fw/ZfxfAzuHfaQeMDhbzxp9mc+mHn1Y94VDHFHjGvt2Uxl10mT4CDavHm+/L9KG441t1QdABqkVYwakMUeyLRA==", 2045 | "dev": true, 2046 | "optional": true 2047 | }, 2048 | "@esbuild/freebsd-x64": { 2049 | "version": "0.17.18", 2050 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.18.tgz", 2051 | "integrity": "sha512-FQFbRtTaEi8ZBi/A6kxOC0V0E9B/97vPdYjY9NdawyLd4Qk5VD5g2pbWN2VR1c0xhzcJm74HWpObPszWC+qTew==", 2052 | "dev": true, 2053 | "optional": true 2054 | }, 2055 | "@esbuild/linux-arm": { 2056 | "version": "0.17.18", 2057 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.18.tgz", 2058 | "integrity": "sha512-jW+UCM40LzHcouIaqv3e/oRs0JM76JfhHjCavPxMUti7VAPh8CaGSlS7cmyrdpzSk7A+8f0hiedHqr/LMnfijg==", 2059 | "dev": true, 2060 | "optional": true 2061 | }, 2062 | "@esbuild/linux-arm64": { 2063 | "version": "0.17.18", 2064 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.18.tgz", 2065 | "integrity": "sha512-R7pZvQZFOY2sxUG8P6A21eq6q+eBv7JPQYIybHVf1XkQYC+lT7nDBdC7wWKTrbvMXKRaGudp/dzZCwL/863mZQ==", 2066 | "dev": true, 2067 | "optional": true 2068 | }, 2069 | "@esbuild/linux-ia32": { 2070 | "version": "0.17.18", 2071 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.18.tgz", 2072 | "integrity": "sha512-ygIMc3I7wxgXIxk6j3V00VlABIjq260i967Cp9BNAk5pOOpIXmd1RFQJQX9Io7KRsthDrQYrtcx7QCof4o3ZoQ==", 2073 | "dev": true, 2074 | "optional": true 2075 | }, 2076 | "@esbuild/linux-loong64": { 2077 | "version": "0.17.18", 2078 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.18.tgz", 2079 | "integrity": "sha512-bvPG+MyFs5ZlwYclCG1D744oHk1Pv7j8psF5TfYx7otCVmcJsEXgFEhQkbhNW8otDHL1a2KDINW20cfCgnzgMQ==", 2080 | "dev": true, 2081 | "optional": true 2082 | }, 2083 | "@esbuild/linux-mips64el": { 2084 | "version": "0.17.18", 2085 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.18.tgz", 2086 | "integrity": "sha512-oVqckATOAGuiUOa6wr8TXaVPSa+6IwVJrGidmNZS1cZVx0HqkTMkqFGD2HIx9H1RvOwFeWYdaYbdY6B89KUMxA==", 2087 | "dev": true, 2088 | "optional": true 2089 | }, 2090 | "@esbuild/linux-ppc64": { 2091 | "version": "0.17.18", 2092 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.18.tgz", 2093 | "integrity": "sha512-3dLlQO+b/LnQNxgH4l9rqa2/IwRJVN9u/bK63FhOPB4xqiRqlQAU0qDU3JJuf0BmaH0yytTBdoSBHrb2jqc5qQ==", 2094 | "dev": true, 2095 | "optional": true 2096 | }, 2097 | "@esbuild/linux-riscv64": { 2098 | "version": "0.17.18", 2099 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.18.tgz", 2100 | "integrity": "sha512-/x7leOyDPjZV3TcsdfrSI107zItVnsX1q2nho7hbbQoKnmoeUWjs+08rKKt4AUXju7+3aRZSsKrJtaRmsdL1xA==", 2101 | "dev": true, 2102 | "optional": true 2103 | }, 2104 | "@esbuild/linux-s390x": { 2105 | "version": "0.17.18", 2106 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.18.tgz", 2107 | "integrity": "sha512-cX0I8Q9xQkL/6F5zWdYmVf5JSQt+ZfZD2bJudZrWD+4mnUvoZ3TDDXtDX2mUaq6upMFv9FlfIh4Gfun0tbGzuw==", 2108 | "dev": true, 2109 | "optional": true 2110 | }, 2111 | "@esbuild/linux-x64": { 2112 | "version": "0.17.18", 2113 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.18.tgz", 2114 | "integrity": "sha512-66RmRsPlYy4jFl0vG80GcNRdirx4nVWAzJmXkevgphP1qf4dsLQCpSKGM3DUQCojwU1hnepI63gNZdrr02wHUA==", 2115 | "dev": true, 2116 | "optional": true 2117 | }, 2118 | "@esbuild/netbsd-x64": { 2119 | "version": "0.17.18", 2120 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.18.tgz", 2121 | "integrity": "sha512-95IRY7mI2yrkLlTLb1gpDxdC5WLC5mZDi+kA9dmM5XAGxCME0F8i4bYH4jZreaJ6lIZ0B8hTrweqG1fUyW7jbg==", 2122 | "dev": true, 2123 | "optional": true 2124 | }, 2125 | "@esbuild/openbsd-x64": { 2126 | "version": "0.17.18", 2127 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.18.tgz", 2128 | "integrity": "sha512-WevVOgcng+8hSZ4Q3BKL3n1xTv5H6Nb53cBrtzzEjDbbnOmucEVcZeGCsCOi9bAOcDYEeBZbD2SJNBxlfP3qiA==", 2129 | "dev": true, 2130 | "optional": true 2131 | }, 2132 | "@esbuild/sunos-x64": { 2133 | "version": "0.17.18", 2134 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.18.tgz", 2135 | "integrity": "sha512-Rzf4QfQagnwhQXVBS3BYUlxmEbcV7MY+BH5vfDZekU5eYpcffHSyjU8T0xucKVuOcdCsMo+Ur5wmgQJH2GfNrg==", 2136 | "dev": true, 2137 | "optional": true 2138 | }, 2139 | "@esbuild/win32-arm64": { 2140 | "version": "0.17.18", 2141 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.18.tgz", 2142 | "integrity": "sha512-Kb3Ko/KKaWhjeAm2YoT/cNZaHaD1Yk/pa3FTsmqo9uFh1D1Rfco7BBLIPdDOozrObj2sahslFuAQGvWbgWldAg==", 2143 | "dev": true, 2144 | "optional": true 2145 | }, 2146 | "@esbuild/win32-ia32": { 2147 | "version": "0.17.18", 2148 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.18.tgz", 2149 | "integrity": "sha512-0/xUMIdkVHwkvxfbd5+lfG7mHOf2FRrxNbPiKWg9C4fFrB8H0guClmaM3BFiRUYrznVoyxTIyC/Ou2B7QQSwmw==", 2150 | "dev": true, 2151 | "optional": true 2152 | }, 2153 | "@esbuild/win32-x64": { 2154 | "version": "0.17.18", 2155 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.18.tgz", 2156 | "integrity": "sha512-qU25Ma1I3NqTSHJUOKi9sAH1/Mzuvlke0ioMJRthLXKm7JiSKVwFghlGbDLOO2sARECGhja4xYfRAZNPAkooYg==", 2157 | "dev": true, 2158 | "optional": true 2159 | }, 2160 | "@istanbuljs/schema": { 2161 | "version": "0.1.3", 2162 | "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", 2163 | "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", 2164 | "dev": true 2165 | }, 2166 | "@jridgewell/gen-mapping": { 2167 | "version": "0.3.3", 2168 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", 2169 | "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", 2170 | "dev": true, 2171 | "requires": { 2172 | "@jridgewell/set-array": "^1.0.1", 2173 | "@jridgewell/sourcemap-codec": "^1.4.10", 2174 | "@jridgewell/trace-mapping": "^0.3.9" 2175 | } 2176 | }, 2177 | "@jridgewell/resolve-uri": { 2178 | "version": "3.1.0", 2179 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", 2180 | "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", 2181 | "dev": true 2182 | }, 2183 | "@jridgewell/set-array": { 2184 | "version": "1.1.2", 2185 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", 2186 | "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", 2187 | "dev": true 2188 | }, 2189 | "@jridgewell/sourcemap-codec": { 2190 | "version": "1.4.15", 2191 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 2192 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 2193 | "dev": true 2194 | }, 2195 | "@jridgewell/trace-mapping": { 2196 | "version": "0.3.18", 2197 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz", 2198 | "integrity": "sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==", 2199 | "dev": true, 2200 | "requires": { 2201 | "@jridgewell/resolve-uri": "3.1.0", 2202 | "@jridgewell/sourcemap-codec": "1.4.14" 2203 | }, 2204 | "dependencies": { 2205 | "@jridgewell/sourcemap-codec": { 2206 | "version": "1.4.14", 2207 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", 2208 | "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", 2209 | "dev": true 2210 | } 2211 | } 2212 | }, 2213 | "@prisma/client": { 2214 | "version": "4.14.0", 2215 | "resolved": "https://registry.npmjs.org/@prisma/client/-/client-4.14.0.tgz", 2216 | "integrity": "sha512-MK/XaA2sFdfaOa7I9MjNKz6dxeIEdeZlnpNRoF2w3JuRLlFJLkpp6cD3yaqw2nUUhbrn3Iqe3ZpVV+VuGGil7Q==", 2217 | "dev": true, 2218 | "requires": { 2219 | "@prisma/engines-version": "4.14.0-67.d9a4c5988f480fa576d43970d5a23641aa77bc9c" 2220 | } 2221 | }, 2222 | "@prisma/engines": { 2223 | "version": "4.14.0", 2224 | "resolved": "https://registry.npmjs.org/@prisma/engines/-/engines-4.14.0.tgz", 2225 | "integrity": "sha512-PDNlhP/1vyTgmNyiucGqGCdXIp7HIkkvKO50si3y3PcceeHvqtiKPaH1iJdz63jCWMVMbj2MElSxXPOeBvEVIQ==", 2226 | "dev": true 2227 | }, 2228 | "@prisma/engines-version": { 2229 | "version": "4.14.0-67.d9a4c5988f480fa576d43970d5a23641aa77bc9c", 2230 | "resolved": "https://registry.npmjs.org/@prisma/engines-version/-/engines-version-4.14.0-67.d9a4c5988f480fa576d43970d5a23641aa77bc9c.tgz", 2231 | "integrity": "sha512-3jum8/YSudeSN0zGW5qkpz+wAN2V/NYCQ+BPjvHYDfWatLWlQkqy99toX0GysDeaUoBIJg1vaz2yKqiA3CFcQw==", 2232 | "dev": true 2233 | }, 2234 | "@types/chai": { 2235 | "version": "4.3.5", 2236 | "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.5.tgz", 2237 | "integrity": "sha512-mEo1sAde+UCE6b2hxn332f1g1E8WfYRu6p5SvTKr2ZKC1f7gFJXk4h5PyGP9Dt6gCaG8y8XhwnXWC6Iy2cmBng==", 2238 | "dev": true 2239 | }, 2240 | "@types/chai-subset": { 2241 | "version": "1.3.3", 2242 | "resolved": "https://registry.npmjs.org/@types/chai-subset/-/chai-subset-1.3.3.tgz", 2243 | "integrity": "sha512-frBecisrNGz+F4T6bcc+NLeolfiojh5FxW2klu669+8BARtyQv2C/GkNW6FUodVe4BroGMP/wER/YDGc7rEllw==", 2244 | "dev": true, 2245 | "requires": { 2246 | "@types/chai": "*" 2247 | } 2248 | }, 2249 | "@types/istanbul-lib-coverage": { 2250 | "version": "2.0.4", 2251 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", 2252 | "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", 2253 | "dev": true 2254 | }, 2255 | "@types/node": { 2256 | "version": "20.1.3", 2257 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.1.3.tgz", 2258 | "integrity": "sha512-NP2yfZpgmf2eDRPmgGq+fjGjSwFgYbihA8/gK+ey23qT9RkxsgNTZvGOEpXgzIGqesTYkElELLgtKoMQTys5vA==", 2259 | "dev": true 2260 | }, 2261 | "@vitest/coverage-c8": { 2262 | "version": "0.31.0", 2263 | "resolved": "https://registry.npmjs.org/@vitest/coverage-c8/-/coverage-c8-0.31.0.tgz", 2264 | "integrity": "sha512-h72qN1D962AO7UefQVulm9JFP5ACS7OfhCdBHioXU8f7ohH/+NTZCgAqmgcfRNHHO/8wLFxx+93YVxhodkEJVA==", 2265 | "dev": true, 2266 | "requires": { 2267 | "@ampproject/remapping": "^2.2.0", 2268 | "c8": "^7.13.0", 2269 | "magic-string": "^0.30.0", 2270 | "picocolors": "^1.0.0", 2271 | "std-env": "^3.3.2" 2272 | } 2273 | }, 2274 | "@vitest/expect": { 2275 | "version": "0.31.0", 2276 | "resolved": "https://registry.npmjs.org/@vitest/expect/-/expect-0.31.0.tgz", 2277 | "integrity": "sha512-Jlm8ZTyp6vMY9iz9Ny9a0BHnCG4fqBa8neCF6Pk/c/6vkUk49Ls6UBlgGAU82QnzzoaUs9E/mUhq/eq9uMOv/g==", 2278 | "dev": true, 2279 | "requires": { 2280 | "@vitest/spy": "0.31.0", 2281 | "@vitest/utils": "0.31.0", 2282 | "chai": "^4.3.7" 2283 | } 2284 | }, 2285 | "@vitest/runner": { 2286 | "version": "0.31.0", 2287 | "resolved": "https://registry.npmjs.org/@vitest/runner/-/runner-0.31.0.tgz", 2288 | "integrity": "sha512-H1OE+Ly7JFeBwnpHTrKyCNm/oZgr+16N4qIlzzqSG/YRQDATBYmJb/KUn3GrZaiQQyL7GwpNHVZxSQd6juLCgw==", 2289 | "dev": true, 2290 | "requires": { 2291 | "@vitest/utils": "0.31.0", 2292 | "concordance": "^5.0.4", 2293 | "p-limit": "^4.0.0", 2294 | "pathe": "^1.1.0" 2295 | } 2296 | }, 2297 | "@vitest/snapshot": { 2298 | "version": "0.31.0", 2299 | "resolved": "https://registry.npmjs.org/@vitest/snapshot/-/snapshot-0.31.0.tgz", 2300 | "integrity": "sha512-5dTXhbHnyUMTMOujZPB0wjFjQ6q5x9c8TvAsSPUNKjp1tVU7i9pbqcKPqntyu2oXtmVxKbuHCqrOd+Ft60r4tg==", 2301 | "dev": true, 2302 | "requires": { 2303 | "magic-string": "^0.30.0", 2304 | "pathe": "^1.1.0", 2305 | "pretty-format": "^27.5.1" 2306 | } 2307 | }, 2308 | "@vitest/spy": { 2309 | "version": "0.31.0", 2310 | "resolved": "https://registry.npmjs.org/@vitest/spy/-/spy-0.31.0.tgz", 2311 | "integrity": "sha512-IzCEQ85RN26GqjQNkYahgVLLkULOxOm5H/t364LG0JYb3Apg0PsYCHLBYGA006+SVRMWhQvHlBBCyuByAMFmkg==", 2312 | "dev": true, 2313 | "requires": { 2314 | "tinyspy": "^2.1.0" 2315 | } 2316 | }, 2317 | "@vitest/utils": { 2318 | "version": "0.31.0", 2319 | "resolved": "https://registry.npmjs.org/@vitest/utils/-/utils-0.31.0.tgz", 2320 | "integrity": "sha512-kahaRyLX7GS1urekRXN2752X4gIgOGVX4Wo8eDUGUkTWlGpXzf5ZS6N9RUUS+Re3XEE8nVGqNyxkSxF5HXlGhQ==", 2321 | "dev": true, 2322 | "requires": { 2323 | "concordance": "^5.0.4", 2324 | "loupe": "^2.3.6", 2325 | "pretty-format": "^27.5.1" 2326 | } 2327 | }, 2328 | "acorn": { 2329 | "version": "8.8.2", 2330 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.2.tgz", 2331 | "integrity": "sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw==", 2332 | "dev": true 2333 | }, 2334 | "acorn-walk": { 2335 | "version": "8.2.0", 2336 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 2337 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 2338 | "dev": true 2339 | }, 2340 | "ansi-regex": { 2341 | "version": "5.0.1", 2342 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2343 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2344 | "dev": true 2345 | }, 2346 | "ansi-styles": { 2347 | "version": "5.2.0", 2348 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", 2349 | "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", 2350 | "dev": true 2351 | }, 2352 | "assertion-error": { 2353 | "version": "1.1.0", 2354 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 2355 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 2356 | "dev": true 2357 | }, 2358 | "balanced-match": { 2359 | "version": "1.0.2", 2360 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2361 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 2362 | "dev": true 2363 | }, 2364 | "blueimp-md5": { 2365 | "version": "2.19.0", 2366 | "resolved": "https://registry.npmjs.org/blueimp-md5/-/blueimp-md5-2.19.0.tgz", 2367 | "integrity": "sha512-DRQrD6gJyy8FbiE4s+bDoXS9hiW3Vbx5uCdwvcCf3zLHL+Iv7LtGHLpr+GZV8rHG8tK766FGYBwRbu8pELTt+w==", 2368 | "dev": true 2369 | }, 2370 | "brace-expansion": { 2371 | "version": "1.1.11", 2372 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2373 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2374 | "dev": true, 2375 | "requires": { 2376 | "balanced-match": "^1.0.0", 2377 | "concat-map": "0.0.1" 2378 | } 2379 | }, 2380 | "c8": { 2381 | "version": "7.13.0", 2382 | "resolved": "https://registry.npmjs.org/c8/-/c8-7.13.0.tgz", 2383 | "integrity": "sha512-/NL4hQTv1gBL6J6ei80zu3IiTrmePDKXKXOTLpHvcIWZTVYQlDhVWjjWvkhICylE8EwwnMVzDZugCvdx0/DIIA==", 2384 | "dev": true, 2385 | "requires": { 2386 | "@bcoe/v8-coverage": "^0.2.3", 2387 | "@istanbuljs/schema": "^0.1.3", 2388 | "find-up": "^5.0.0", 2389 | "foreground-child": "^2.0.0", 2390 | "istanbul-lib-coverage": "^3.2.0", 2391 | "istanbul-lib-report": "^3.0.0", 2392 | "istanbul-reports": "^3.1.4", 2393 | "rimraf": "^3.0.2", 2394 | "test-exclude": "^6.0.0", 2395 | "v8-to-istanbul": "^9.0.0", 2396 | "yargs": "^16.2.0", 2397 | "yargs-parser": "^20.2.9" 2398 | } 2399 | }, 2400 | "cac": { 2401 | "version": "6.7.14", 2402 | "resolved": "https://registry.npmjs.org/cac/-/cac-6.7.14.tgz", 2403 | "integrity": "sha512-b6Ilus+c3RrdDk+JhLKUAQfzzgLEPy6wcXqS7f/xe1EETvsDP6GORG7SFuOs6cID5YkqchW/LXZbX5bc8j7ZcQ==", 2404 | "dev": true 2405 | }, 2406 | "chai": { 2407 | "version": "4.3.7", 2408 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.7.tgz", 2409 | "integrity": "sha512-HLnAzZ2iupm25PlN0xFreAlBA5zaBSv3og0DdeGA4Ar6h6rJ3A0rolRUKJhSF2V10GZKDgWF/VmAEsNWjCRB+A==", 2410 | "dev": true, 2411 | "requires": { 2412 | "assertion-error": "^1.1.0", 2413 | "check-error": "^1.0.2", 2414 | "deep-eql": "^4.1.2", 2415 | "get-func-name": "^2.0.0", 2416 | "loupe": "^2.3.1", 2417 | "pathval": "^1.1.1", 2418 | "type-detect": "^4.0.5" 2419 | } 2420 | }, 2421 | "check-error": { 2422 | "version": "1.0.2", 2423 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 2424 | "integrity": "sha512-BrgHpW9NURQgzoNyjfq0Wu6VFO6D7IZEmJNdtgNqpzGG8RuNFHt2jQxWlAs4HMe119chBnv+34syEZtc6IhLtA==", 2425 | "dev": true 2426 | }, 2427 | "cliui": { 2428 | "version": "7.0.4", 2429 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 2430 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 2431 | "dev": true, 2432 | "requires": { 2433 | "string-width": "^4.2.0", 2434 | "strip-ansi": "^6.0.0", 2435 | "wrap-ansi": "^7.0.0" 2436 | } 2437 | }, 2438 | "color-convert": { 2439 | "version": "2.0.1", 2440 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2441 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2442 | "dev": true, 2443 | "requires": { 2444 | "color-name": "~1.1.4" 2445 | } 2446 | }, 2447 | "color-name": { 2448 | "version": "1.1.4", 2449 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2450 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2451 | "dev": true 2452 | }, 2453 | "concat-map": { 2454 | "version": "0.0.1", 2455 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2456 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 2457 | "dev": true 2458 | }, 2459 | "concordance": { 2460 | "version": "5.0.4", 2461 | "resolved": "https://registry.npmjs.org/concordance/-/concordance-5.0.4.tgz", 2462 | "integrity": "sha512-OAcsnTEYu1ARJqWVGwf4zh4JDfHZEaSNlNccFmt8YjB2l/n19/PF2viLINHc57vO4FKIAFl2FWASIGZZWZ2Kxw==", 2463 | "dev": true, 2464 | "requires": { 2465 | "date-time": "^3.1.0", 2466 | "esutils": "^2.0.3", 2467 | "fast-diff": "^1.2.0", 2468 | "js-string-escape": "^1.0.1", 2469 | "lodash": "^4.17.15", 2470 | "md5-hex": "^3.0.1", 2471 | "semver": "^7.3.2", 2472 | "well-known-symbols": "^2.0.0" 2473 | } 2474 | }, 2475 | "convert-source-map": { 2476 | "version": "1.9.0", 2477 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", 2478 | "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", 2479 | "dev": true 2480 | }, 2481 | "cross-spawn": { 2482 | "version": "7.0.3", 2483 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2484 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2485 | "dev": true, 2486 | "requires": { 2487 | "path-key": "^3.1.0", 2488 | "shebang-command": "^2.0.0", 2489 | "which": "^2.0.1" 2490 | } 2491 | }, 2492 | "date-time": { 2493 | "version": "3.1.0", 2494 | "resolved": "https://registry.npmjs.org/date-time/-/date-time-3.1.0.tgz", 2495 | "integrity": "sha512-uqCUKXE5q1PNBXjPqvwhwJf9SwMoAHBgWJ6DcrnS5o+W2JOiIILl0JEdVD8SGujrNS02GGxgwAg2PN2zONgtjg==", 2496 | "dev": true, 2497 | "requires": { 2498 | "time-zone": "^1.0.0" 2499 | } 2500 | }, 2501 | "debug": { 2502 | "version": "4.3.4", 2503 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2504 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2505 | "dev": true, 2506 | "requires": { 2507 | "ms": "2.1.2" 2508 | } 2509 | }, 2510 | "deep-eql": { 2511 | "version": "4.1.3", 2512 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-4.1.3.tgz", 2513 | "integrity": "sha512-WaEtAOpRA1MQ0eohqZjpGD8zdI0Ovsm8mmFhaDN8dvDZzyoUMcYDnf5Y6iu7HTXxf8JDS23qWa4a+hKCDyOPzw==", 2514 | "dev": true, 2515 | "requires": { 2516 | "type-detect": "^4.0.0" 2517 | } 2518 | }, 2519 | "emoji-regex": { 2520 | "version": "8.0.0", 2521 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2522 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2523 | "dev": true 2524 | }, 2525 | "esbuild": { 2526 | "version": "0.17.18", 2527 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.18.tgz", 2528 | "integrity": "sha512-z1lix43jBs6UKjcZVKOw2xx69ffE2aG0PygLL5qJ9OS/gy0Ewd1gW/PUQIOIQGXBHWNywSc0floSKoMFF8aK2w==", 2529 | "dev": true, 2530 | "requires": { 2531 | "@esbuild/android-arm": "0.17.18", 2532 | "@esbuild/android-arm64": "0.17.18", 2533 | "@esbuild/android-x64": "0.17.18", 2534 | "@esbuild/darwin-arm64": "0.17.18", 2535 | "@esbuild/darwin-x64": "0.17.18", 2536 | "@esbuild/freebsd-arm64": "0.17.18", 2537 | "@esbuild/freebsd-x64": "0.17.18", 2538 | "@esbuild/linux-arm": "0.17.18", 2539 | "@esbuild/linux-arm64": "0.17.18", 2540 | "@esbuild/linux-ia32": "0.17.18", 2541 | "@esbuild/linux-loong64": "0.17.18", 2542 | "@esbuild/linux-mips64el": "0.17.18", 2543 | "@esbuild/linux-ppc64": "0.17.18", 2544 | "@esbuild/linux-riscv64": "0.17.18", 2545 | "@esbuild/linux-s390x": "0.17.18", 2546 | "@esbuild/linux-x64": "0.17.18", 2547 | "@esbuild/netbsd-x64": "0.17.18", 2548 | "@esbuild/openbsd-x64": "0.17.18", 2549 | "@esbuild/sunos-x64": "0.17.18", 2550 | "@esbuild/win32-arm64": "0.17.18", 2551 | "@esbuild/win32-ia32": "0.17.18", 2552 | "@esbuild/win32-x64": "0.17.18" 2553 | } 2554 | }, 2555 | "escalade": { 2556 | "version": "3.1.1", 2557 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 2558 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 2559 | "dev": true 2560 | }, 2561 | "esutils": { 2562 | "version": "2.0.3", 2563 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2564 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2565 | "dev": true 2566 | }, 2567 | "fast-diff": { 2568 | "version": "1.2.0", 2569 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 2570 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 2571 | "dev": true 2572 | }, 2573 | "find-up": { 2574 | "version": "5.0.0", 2575 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2576 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2577 | "dev": true, 2578 | "requires": { 2579 | "locate-path": "^6.0.0", 2580 | "path-exists": "^4.0.0" 2581 | } 2582 | }, 2583 | "foreground-child": { 2584 | "version": "2.0.0", 2585 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-2.0.0.tgz", 2586 | "integrity": "sha512-dCIq9FpEcyQyXKCkyzmlPTFNgrCzPudOe+mhvJU5zAtlBnGVy2yKxtfsxK2tQBThwq225jcvBjpw1Gr40uzZCA==", 2587 | "dev": true, 2588 | "requires": { 2589 | "cross-spawn": "^7.0.0", 2590 | "signal-exit": "^3.0.2" 2591 | } 2592 | }, 2593 | "fs.realpath": { 2594 | "version": "1.0.0", 2595 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2596 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 2597 | "dev": true 2598 | }, 2599 | "fsevents": { 2600 | "version": "2.3.2", 2601 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2602 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2603 | "dev": true, 2604 | "optional": true 2605 | }, 2606 | "get-caller-file": { 2607 | "version": "2.0.5", 2608 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2609 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 2610 | "dev": true 2611 | }, 2612 | "get-func-name": { 2613 | "version": "2.0.0", 2614 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 2615 | "integrity": "sha512-Hm0ixYtaSZ/V7C8FJrtZIuBBI+iSgL+1Aq82zSu8VQNB4S3Gk8e7Qs3VwBDJAhmRZcFqkl3tQu36g/Foh5I5ig==", 2616 | "dev": true 2617 | }, 2618 | "glob": { 2619 | "version": "7.2.3", 2620 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2621 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2622 | "dev": true, 2623 | "requires": { 2624 | "fs.realpath": "^1.0.0", 2625 | "inflight": "^1.0.4", 2626 | "inherits": "2", 2627 | "minimatch": "^3.1.1", 2628 | "once": "^1.3.0", 2629 | "path-is-absolute": "^1.0.0" 2630 | } 2631 | }, 2632 | "has-flag": { 2633 | "version": "4.0.0", 2634 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2635 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2636 | "dev": true 2637 | }, 2638 | "html-escaper": { 2639 | "version": "2.0.2", 2640 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", 2641 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", 2642 | "dev": true 2643 | }, 2644 | "inflight": { 2645 | "version": "1.0.6", 2646 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2647 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2648 | "dev": true, 2649 | "requires": { 2650 | "once": "^1.3.0", 2651 | "wrappy": "1" 2652 | } 2653 | }, 2654 | "inherits": { 2655 | "version": "2.0.4", 2656 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2657 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2658 | "dev": true 2659 | }, 2660 | "is-fullwidth-code-point": { 2661 | "version": "3.0.0", 2662 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2663 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2664 | "dev": true 2665 | }, 2666 | "isexe": { 2667 | "version": "2.0.0", 2668 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2669 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2670 | "dev": true 2671 | }, 2672 | "istanbul-lib-coverage": { 2673 | "version": "3.2.0", 2674 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", 2675 | "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", 2676 | "dev": true 2677 | }, 2678 | "istanbul-lib-report": { 2679 | "version": "3.0.0", 2680 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 2681 | "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", 2682 | "dev": true, 2683 | "requires": { 2684 | "istanbul-lib-coverage": "^3.0.0", 2685 | "make-dir": "^3.0.0", 2686 | "supports-color": "^7.1.0" 2687 | } 2688 | }, 2689 | "istanbul-reports": { 2690 | "version": "3.1.5", 2691 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz", 2692 | "integrity": "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==", 2693 | "dev": true, 2694 | "requires": { 2695 | "html-escaper": "^2.0.0", 2696 | "istanbul-lib-report": "^3.0.0" 2697 | } 2698 | }, 2699 | "js-string-escape": { 2700 | "version": "1.0.1", 2701 | "resolved": "https://registry.npmjs.org/js-string-escape/-/js-string-escape-1.0.1.tgz", 2702 | "integrity": "sha512-Smw4xcfIQ5LVjAOuJCvN/zIodzA/BBSsluuoSykP+lUvScIi4U6RJLfwHet5cxFnCswUjISV8oAXaqaJDY3chg==", 2703 | "dev": true 2704 | }, 2705 | "jsonc-parser": { 2706 | "version": "3.2.0", 2707 | "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.2.0.tgz", 2708 | "integrity": "sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==", 2709 | "dev": true 2710 | }, 2711 | "local-pkg": { 2712 | "version": "0.4.3", 2713 | "resolved": "https://registry.npmjs.org/local-pkg/-/local-pkg-0.4.3.tgz", 2714 | "integrity": "sha512-SFppqq5p42fe2qcZQqqEOiVRXl+WCP1MdT6k7BDEW1j++sp5fIY+/fdRQitvKgB5BrBcmrs5m/L0v2FrU5MY1g==", 2715 | "dev": true 2716 | }, 2717 | "locate-path": { 2718 | "version": "6.0.0", 2719 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2720 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2721 | "dev": true, 2722 | "requires": { 2723 | "p-locate": "^5.0.0" 2724 | } 2725 | }, 2726 | "lodash": { 2727 | "version": "4.17.21", 2728 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 2729 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 2730 | "dev": true 2731 | }, 2732 | "loupe": { 2733 | "version": "2.3.6", 2734 | "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.6.tgz", 2735 | "integrity": "sha512-RaPMZKiMy8/JruncMU5Bt6na1eftNoo++R4Y+N2FrxkDVTrGvcyzFTsaGif4QTeKESheMGegbhw6iUAq+5A8zA==", 2736 | "dev": true, 2737 | "requires": { 2738 | "get-func-name": "^2.0.0" 2739 | } 2740 | }, 2741 | "lru-cache": { 2742 | "version": "6.0.0", 2743 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2744 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2745 | "dev": true, 2746 | "requires": { 2747 | "yallist": "^4.0.0" 2748 | } 2749 | }, 2750 | "magic-string": { 2751 | "version": "0.30.0", 2752 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.0.tgz", 2753 | "integrity": "sha512-LA+31JYDJLs82r2ScLrlz1GjSgu66ZV518eyWT+S8VhyQn/JL0u9MeBOvQMGYiPk1DBiSN9DDMOcXvigJZaViQ==", 2754 | "dev": true, 2755 | "requires": { 2756 | "@jridgewell/sourcemap-codec": "^1.4.13" 2757 | } 2758 | }, 2759 | "make-dir": { 2760 | "version": "3.1.0", 2761 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 2762 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 2763 | "dev": true, 2764 | "requires": { 2765 | "semver": "^6.0.0" 2766 | }, 2767 | "dependencies": { 2768 | "semver": { 2769 | "version": "6.3.0", 2770 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2771 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 2772 | "dev": true 2773 | } 2774 | } 2775 | }, 2776 | "md5-hex": { 2777 | "version": "3.0.1", 2778 | "resolved": "https://registry.npmjs.org/md5-hex/-/md5-hex-3.0.1.tgz", 2779 | "integrity": "sha512-BUiRtTtV39LIJwinWBjqVsU9xhdnz7/i889V859IBFpuqGAj6LuOvHv5XLbgZ2R7ptJoJaEcxkv88/h25T7Ciw==", 2780 | "dev": true, 2781 | "requires": { 2782 | "blueimp-md5": "^2.10.0" 2783 | } 2784 | }, 2785 | "minimatch": { 2786 | "version": "3.1.2", 2787 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2788 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2789 | "dev": true, 2790 | "requires": { 2791 | "brace-expansion": "^1.1.7" 2792 | } 2793 | }, 2794 | "mlly": { 2795 | "version": "1.2.1", 2796 | "resolved": "https://registry.npmjs.org/mlly/-/mlly-1.2.1.tgz", 2797 | "integrity": "sha512-1aMEByaWgBPEbWV2BOPEMySRrzl7rIHXmQxam4DM8jVjalTQDjpN2ZKOLUrwyhfZQO7IXHml2StcHMhooDeEEQ==", 2798 | "dev": true, 2799 | "requires": { 2800 | "acorn": "^8.8.2", 2801 | "pathe": "^1.1.0", 2802 | "pkg-types": "^1.0.3", 2803 | "ufo": "^1.1.2" 2804 | } 2805 | }, 2806 | "ms": { 2807 | "version": "2.1.2", 2808 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2809 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2810 | "dev": true 2811 | }, 2812 | "nanoid": { 2813 | "version": "3.3.6", 2814 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz", 2815 | "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==", 2816 | "dev": true 2817 | }, 2818 | "once": { 2819 | "version": "1.4.0", 2820 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2821 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2822 | "dev": true, 2823 | "requires": { 2824 | "wrappy": "1" 2825 | } 2826 | }, 2827 | "p-limit": { 2828 | "version": "4.0.0", 2829 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-4.0.0.tgz", 2830 | "integrity": "sha512-5b0R4txpzjPWVw/cXXUResoD4hb6U/x9BH08L7nw+GN1sezDzPdxeRvpc9c433fZhBan/wusjbCsqwqm4EIBIQ==", 2831 | "dev": true, 2832 | "requires": { 2833 | "yocto-queue": "^1.0.0" 2834 | } 2835 | }, 2836 | "p-locate": { 2837 | "version": "5.0.0", 2838 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2839 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2840 | "dev": true, 2841 | "requires": { 2842 | "p-limit": "^3.0.2" 2843 | }, 2844 | "dependencies": { 2845 | "p-limit": { 2846 | "version": "3.1.0", 2847 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2848 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2849 | "dev": true, 2850 | "requires": { 2851 | "yocto-queue": "^0.1.0" 2852 | } 2853 | }, 2854 | "yocto-queue": { 2855 | "version": "0.1.0", 2856 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 2857 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 2858 | "dev": true 2859 | } 2860 | } 2861 | }, 2862 | "path-exists": { 2863 | "version": "4.0.0", 2864 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2865 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2866 | "dev": true 2867 | }, 2868 | "path-is-absolute": { 2869 | "version": "1.0.1", 2870 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2871 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 2872 | "dev": true 2873 | }, 2874 | "path-key": { 2875 | "version": "3.1.1", 2876 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2877 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2878 | "dev": true 2879 | }, 2880 | "pathe": { 2881 | "version": "1.1.0", 2882 | "resolved": "https://registry.npmjs.org/pathe/-/pathe-1.1.0.tgz", 2883 | "integrity": "sha512-ODbEPR0KKHqECXW1GoxdDb+AZvULmXjVPy4rt+pGo2+TnjJTIPJQSVS6N63n8T2Ip+syHhbn52OewKicV0373w==", 2884 | "dev": true 2885 | }, 2886 | "pathval": { 2887 | "version": "1.1.1", 2888 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 2889 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 2890 | "dev": true 2891 | }, 2892 | "picocolors": { 2893 | "version": "1.0.0", 2894 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 2895 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 2896 | "dev": true 2897 | }, 2898 | "pkg-types": { 2899 | "version": "1.0.3", 2900 | "resolved": "https://registry.npmjs.org/pkg-types/-/pkg-types-1.0.3.tgz", 2901 | "integrity": "sha512-nN7pYi0AQqJnoLPC9eHFQ8AcyaixBUOwvqc5TDnIKCMEE6I0y8P7OKA7fPexsXGCGxQDl/cmrLAp26LhcwxZ4A==", 2902 | "dev": true, 2903 | "requires": { 2904 | "jsonc-parser": "^3.2.0", 2905 | "mlly": "^1.2.0", 2906 | "pathe": "^1.1.0" 2907 | } 2908 | }, 2909 | "postcss": { 2910 | "version": "8.4.23", 2911 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.23.tgz", 2912 | "integrity": "sha512-bQ3qMcpF6A/YjR55xtoTr0jGOlnPOKAIMdOWiv0EIT6HVPEaJiJB4NLljSbiHoC2RX7DN5Uvjtpbg1NPdwv1oA==", 2913 | "dev": true, 2914 | "requires": { 2915 | "nanoid": "^3.3.6", 2916 | "picocolors": "^1.0.0", 2917 | "source-map-js": "^1.0.2" 2918 | } 2919 | }, 2920 | "prettier": { 2921 | "version": "2.8.8", 2922 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.8.tgz", 2923 | "integrity": "sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q==", 2924 | "dev": true 2925 | }, 2926 | "pretty-format": { 2927 | "version": "27.5.1", 2928 | "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-27.5.1.tgz", 2929 | "integrity": "sha512-Qb1gy5OrP5+zDf2Bvnzdl3jsTf1qXVMazbvCoKhtKqVs4/YK4ozX4gKQJJVyNe+cajNPn0KoC0MC3FUmaHWEmQ==", 2930 | "dev": true, 2931 | "requires": { 2932 | "ansi-regex": "^5.0.1", 2933 | "ansi-styles": "^5.0.0", 2934 | "react-is": "^17.0.1" 2935 | } 2936 | }, 2937 | "prisma": { 2938 | "version": "4.14.0", 2939 | "resolved": "https://registry.npmjs.org/prisma/-/prisma-4.14.0.tgz", 2940 | "integrity": "sha512-+5dMl1uxMQb4RepndY6AwR9xi1cDcaGFICu+ws6/Nmgt93mFPNj8tYxSfTdmfg+rkNrUId9rk/Ac2vTgLe/oXA==", 2941 | "dev": true, 2942 | "requires": { 2943 | "@prisma/engines": "4.14.0" 2944 | } 2945 | }, 2946 | "react-is": { 2947 | "version": "17.0.2", 2948 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", 2949 | "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", 2950 | "dev": true 2951 | }, 2952 | "require-directory": { 2953 | "version": "2.1.1", 2954 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2955 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 2956 | "dev": true 2957 | }, 2958 | "rimraf": { 2959 | "version": "3.0.2", 2960 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2961 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2962 | "dev": true, 2963 | "requires": { 2964 | "glob": "^7.1.3" 2965 | } 2966 | }, 2967 | "rollup": { 2968 | "version": "3.21.6", 2969 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-3.21.6.tgz", 2970 | "integrity": "sha512-SXIICxvxQxR3D4dp/3LDHZIJPC8a4anKMHd4E3Jiz2/JnY+2bEjqrOokAauc5ShGVNFHlEFjBXAXlaxkJqIqSg==", 2971 | "dev": true, 2972 | "requires": { 2973 | "fsevents": "~2.3.2" 2974 | } 2975 | }, 2976 | "semver": { 2977 | "version": "7.5.1", 2978 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.1.tgz", 2979 | "integrity": "sha512-Wvss5ivl8TMRZXXESstBA4uR5iXgEN/VC5/sOcuXdVLzcdkz4HWetIoRfG5gb5X+ij/G9rw9YoGn3QoQ8OCSpw==", 2980 | "dev": true, 2981 | "requires": { 2982 | "lru-cache": "^6.0.0" 2983 | } 2984 | }, 2985 | "shebang-command": { 2986 | "version": "2.0.0", 2987 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2988 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2989 | "dev": true, 2990 | "requires": { 2991 | "shebang-regex": "^3.0.0" 2992 | } 2993 | }, 2994 | "shebang-regex": { 2995 | "version": "3.0.0", 2996 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2997 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2998 | "dev": true 2999 | }, 3000 | "siginfo": { 3001 | "version": "2.0.0", 3002 | "resolved": "https://registry.npmjs.org/siginfo/-/siginfo-2.0.0.tgz", 3003 | "integrity": "sha512-ybx0WO1/8bSBLEWXZvEd7gMW3Sn3JFlW3TvX1nREbDLRNQNaeNN8WK0meBwPdAaOI7TtRRRJn/Es1zhrrCHu7g==", 3004 | "dev": true 3005 | }, 3006 | "signal-exit": { 3007 | "version": "3.0.7", 3008 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 3009 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 3010 | "dev": true 3011 | }, 3012 | "source-map-js": { 3013 | "version": "1.0.2", 3014 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", 3015 | "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", 3016 | "dev": true 3017 | }, 3018 | "stackback": { 3019 | "version": "0.0.2", 3020 | "resolved": "https://registry.npmjs.org/stackback/-/stackback-0.0.2.tgz", 3021 | "integrity": "sha512-1XMJE5fQo1jGH6Y/7ebnwPOBEkIEnT4QF32d5R1+VXdXveM0IBMJt8zfaxX1P3QhVwrYe+576+jkANtSS2mBbw==", 3022 | "dev": true 3023 | }, 3024 | "std-env": { 3025 | "version": "3.3.3", 3026 | "resolved": "https://registry.npmjs.org/std-env/-/std-env-3.3.3.tgz", 3027 | "integrity": "sha512-Rz6yejtVyWnVjC1RFvNmYL10kgjC49EOghxWn0RFqlCHGFpQx+Xe7yW3I4ceK1SGrWIGMjD5Kbue8W/udkbMJg==", 3028 | "dev": true 3029 | }, 3030 | "string-width": { 3031 | "version": "4.2.3", 3032 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3033 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3034 | "dev": true, 3035 | "requires": { 3036 | "emoji-regex": "^8.0.0", 3037 | "is-fullwidth-code-point": "^3.0.0", 3038 | "strip-ansi": "^6.0.1" 3039 | } 3040 | }, 3041 | "strip-ansi": { 3042 | "version": "6.0.1", 3043 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3044 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3045 | "dev": true, 3046 | "requires": { 3047 | "ansi-regex": "^5.0.1" 3048 | } 3049 | }, 3050 | "strip-literal": { 3051 | "version": "1.0.1", 3052 | "resolved": "https://registry.npmjs.org/strip-literal/-/strip-literal-1.0.1.tgz", 3053 | "integrity": "sha512-QZTsipNpa2Ppr6v1AmJHESqJ3Uz247MUS0OjrnnZjFAvEoWqxuyFuXn2xLgMtRnijJShAa1HL0gtJyUs7u7n3Q==", 3054 | "dev": true, 3055 | "requires": { 3056 | "acorn": "^8.8.2" 3057 | } 3058 | }, 3059 | "supports-color": { 3060 | "version": "7.2.0", 3061 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3062 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3063 | "dev": true, 3064 | "requires": { 3065 | "has-flag": "^4.0.0" 3066 | } 3067 | }, 3068 | "test-exclude": { 3069 | "version": "6.0.0", 3070 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", 3071 | "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", 3072 | "dev": true, 3073 | "requires": { 3074 | "@istanbuljs/schema": "^0.1.2", 3075 | "glob": "^7.1.4", 3076 | "minimatch": "^3.0.4" 3077 | } 3078 | }, 3079 | "time-zone": { 3080 | "version": "1.0.0", 3081 | "resolved": "https://registry.npmjs.org/time-zone/-/time-zone-1.0.0.tgz", 3082 | "integrity": "sha512-TIsDdtKo6+XrPtiTm1ssmMngN1sAhyKnTO2kunQWqNPWIVvCm15Wmw4SWInwTVgJ5u/Tr04+8Ei9TNcw4x4ONA==", 3083 | "dev": true 3084 | }, 3085 | "tinybench": { 3086 | "version": "2.5.0", 3087 | "resolved": "https://registry.npmjs.org/tinybench/-/tinybench-2.5.0.tgz", 3088 | "integrity": "sha512-kRwSG8Zx4tjF9ZiyH4bhaebu+EDz1BOx9hOigYHlUW4xxI/wKIUQUqo018UlU4ar6ATPBsaMrdbKZ+tmPdohFA==", 3089 | "dev": true 3090 | }, 3091 | "tinypool": { 3092 | "version": "0.5.0", 3093 | "resolved": "https://registry.npmjs.org/tinypool/-/tinypool-0.5.0.tgz", 3094 | "integrity": "sha512-paHQtnrlS1QZYKF/GnLoOM/DN9fqaGOFbCbxzAhwniySnzl9Ebk8w73/dd34DAhe/obUbPAOldTyYXQZxnPBPQ==", 3095 | "dev": true 3096 | }, 3097 | "tinyspy": { 3098 | "version": "2.1.0", 3099 | "resolved": "https://registry.npmjs.org/tinyspy/-/tinyspy-2.1.0.tgz", 3100 | "integrity": "sha512-7eORpyqImoOvkQJCSkL0d0mB4NHHIFAy4b1u8PHdDa7SjGS2njzl6/lyGoZLm+eyYEtlUmFGE0rFj66SWxZgQQ==", 3101 | "dev": true 3102 | }, 3103 | "type-detect": { 3104 | "version": "4.0.8", 3105 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 3106 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 3107 | "dev": true 3108 | }, 3109 | "typescript": { 3110 | "version": "5.0.4", 3111 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.0.4.tgz", 3112 | "integrity": "sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw==", 3113 | "dev": true 3114 | }, 3115 | "ufo": { 3116 | "version": "1.1.2", 3117 | "resolved": "https://registry.npmjs.org/ufo/-/ufo-1.1.2.tgz", 3118 | "integrity": "sha512-TrY6DsjTQQgyS3E3dBaOXf0TpPD8u9FVrVYmKVegJuFw51n/YB9XPt+U6ydzFG5ZIN7+DIjPbNmXoBj9esYhgQ==", 3119 | "dev": true 3120 | }, 3121 | "v8-to-istanbul": { 3122 | "version": "9.1.0", 3123 | "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.1.0.tgz", 3124 | "integrity": "sha512-6z3GW9x8G1gd+JIIgQQQxXuiJtCXeAjp6RaPEPLv62mH3iPHPxV6W3robxtCzNErRo6ZwTmzWhsbNvjyEBKzKA==", 3125 | "dev": true, 3126 | "requires": { 3127 | "@jridgewell/trace-mapping": "^0.3.12", 3128 | "@types/istanbul-lib-coverage": "^2.0.1", 3129 | "convert-source-map": "^1.6.0" 3130 | } 3131 | }, 3132 | "vite": { 3133 | "version": "4.3.5", 3134 | "resolved": "https://registry.npmjs.org/vite/-/vite-4.3.5.tgz", 3135 | "integrity": "sha512-0gEnL9wiRFxgz40o/i/eTBwm+NEbpUeTWhzKrZDSdKm6nplj+z4lKz8ANDgildxHm47Vg8EUia0aicKbawUVVA==", 3136 | "dev": true, 3137 | "requires": { 3138 | "esbuild": "^0.17.5", 3139 | "fsevents": "~2.3.2", 3140 | "postcss": "^8.4.23", 3141 | "rollup": "^3.21.0" 3142 | } 3143 | }, 3144 | "vite-node": { 3145 | "version": "0.31.0", 3146 | "resolved": "https://registry.npmjs.org/vite-node/-/vite-node-0.31.0.tgz", 3147 | "integrity": "sha512-8x1x1LNuPvE2vIvkSB7c1mApX5oqlgsxzHQesYF7l5n1gKrEmrClIiZuOFbFDQcjLsmcWSwwmrWrcGWm9Fxc/g==", 3148 | "dev": true, 3149 | "requires": { 3150 | "cac": "^6.7.14", 3151 | "debug": "^4.3.4", 3152 | "mlly": "^1.2.0", 3153 | "pathe": "^1.1.0", 3154 | "picocolors": "^1.0.0", 3155 | "vite": "^3.0.0 || ^4.0.0" 3156 | } 3157 | }, 3158 | "vitest": { 3159 | "version": "0.31.0", 3160 | "resolved": "https://registry.npmjs.org/vitest/-/vitest-0.31.0.tgz", 3161 | "integrity": "sha512-JwWJS9p3GU9GxkG7eBSmr4Q4x4bvVBSswaCFf1PBNHiPx00obfhHRJfgHcnI0ffn+NMlIh9QGvG75FlaIBdKGA==", 3162 | "dev": true, 3163 | "requires": { 3164 | "@types/chai": "^4.3.4", 3165 | "@types/chai-subset": "^1.3.3", 3166 | "@types/node": "*", 3167 | "@vitest/expect": "0.31.0", 3168 | "@vitest/runner": "0.31.0", 3169 | "@vitest/snapshot": "0.31.0", 3170 | "@vitest/spy": "0.31.0", 3171 | "@vitest/utils": "0.31.0", 3172 | "acorn": "^8.8.2", 3173 | "acorn-walk": "^8.2.0", 3174 | "cac": "^6.7.14", 3175 | "chai": "^4.3.7", 3176 | "concordance": "^5.0.4", 3177 | "debug": "^4.3.4", 3178 | "local-pkg": "^0.4.3", 3179 | "magic-string": "^0.30.0", 3180 | "pathe": "^1.1.0", 3181 | "picocolors": "^1.0.0", 3182 | "std-env": "^3.3.2", 3183 | "strip-literal": "^1.0.1", 3184 | "tinybench": "^2.4.0", 3185 | "tinypool": "^0.5.0", 3186 | "vite": "^3.0.0 || ^4.0.0", 3187 | "vite-node": "0.31.0", 3188 | "why-is-node-running": "^2.2.2" 3189 | } 3190 | }, 3191 | "well-known-symbols": { 3192 | "version": "2.0.0", 3193 | "resolved": "https://registry.npmjs.org/well-known-symbols/-/well-known-symbols-2.0.0.tgz", 3194 | "integrity": "sha512-ZMjC3ho+KXo0BfJb7JgtQ5IBuvnShdlACNkKkdsqBmYw3bPAaJfPeYUo6tLUaT5tG/Gkh7xkpBhKRQ9e7pyg9Q==", 3195 | "dev": true 3196 | }, 3197 | "which": { 3198 | "version": "2.0.2", 3199 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3200 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3201 | "dev": true, 3202 | "requires": { 3203 | "isexe": "^2.0.0" 3204 | } 3205 | }, 3206 | "why-is-node-running": { 3207 | "version": "2.2.2", 3208 | "resolved": "https://registry.npmjs.org/why-is-node-running/-/why-is-node-running-2.2.2.tgz", 3209 | "integrity": "sha512-6tSwToZxTOcotxHeA+qGCq1mVzKR3CwcJGmVcY+QE8SHy6TnpFnh8PAvPNHYr7EcuVeG0QSMxtYCuO1ta/G/oA==", 3210 | "dev": true, 3211 | "requires": { 3212 | "siginfo": "^2.0.0", 3213 | "stackback": "0.0.2" 3214 | } 3215 | }, 3216 | "wrap-ansi": { 3217 | "version": "7.0.0", 3218 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3219 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3220 | "dev": true, 3221 | "requires": { 3222 | "ansi-styles": "^4.0.0", 3223 | "string-width": "^4.1.0", 3224 | "strip-ansi": "^6.0.0" 3225 | }, 3226 | "dependencies": { 3227 | "ansi-styles": { 3228 | "version": "4.3.0", 3229 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 3230 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 3231 | "dev": true, 3232 | "requires": { 3233 | "color-convert": "^2.0.1" 3234 | } 3235 | } 3236 | } 3237 | }, 3238 | "wrappy": { 3239 | "version": "1.0.2", 3240 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3241 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3242 | "dev": true 3243 | }, 3244 | "y18n": { 3245 | "version": "5.0.8", 3246 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3247 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3248 | "dev": true 3249 | }, 3250 | "yallist": { 3251 | "version": "4.0.0", 3252 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3253 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3254 | "dev": true 3255 | }, 3256 | "yargs": { 3257 | "version": "16.2.0", 3258 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3259 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3260 | "dev": true, 3261 | "requires": { 3262 | "cliui": "^7.0.2", 3263 | "escalade": "^3.1.1", 3264 | "get-caller-file": "^2.0.5", 3265 | "require-directory": "^2.1.1", 3266 | "string-width": "^4.2.0", 3267 | "y18n": "^5.0.5", 3268 | "yargs-parser": "^20.2.2" 3269 | } 3270 | }, 3271 | "yargs-parser": { 3272 | "version": "20.2.9", 3273 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 3274 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 3275 | "dev": true 3276 | }, 3277 | "yocto-queue": { 3278 | "version": "1.0.0", 3279 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-1.0.0.tgz", 3280 | "integrity": "sha512-9bnSc/HEW2uRy67wc+T8UwauLuPJVn28jb+GtJY16iiKWyvmYJRXVT4UamsAEGQfPohgr2q4Tq0sQbQlxTfi1g==", 3281 | "dev": true 3282 | } 3283 | } 3284 | } 3285 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "factory-prisma", 3 | "version": "0.2.0", 4 | "author": "Ahmed Al-Jawahiry", 5 | "license": "MIT", 6 | "description": "Create factories, that create objects with Prisma.", 7 | "repository": "https://github.com/ahmedaljawahiry/factory-prisma", 8 | "keywords": [ 9 | "prisma", 10 | "factory", 11 | "orm", 12 | "tests", 13 | "testing-tools" 14 | ], 15 | "main": "dist/index.js", 16 | "types": "dist/index.d.ts", 17 | "files": [ 18 | "dist" 19 | ], 20 | "scripts": { 21 | "migrate": "npx prisma migrate dev", 22 | "test": "vitest --config ./tests/vitest.config.ts --coverage" 23 | }, 24 | "devDependencies": { 25 | "@prisma/client": "^4.14.0", 26 | "@vitest/coverage-c8": "^0.31.0", 27 | "prettier": "^2.8.8", 28 | "prisma": "^4.14.0", 29 | "typescript": "^5.0.4", 30 | "vitest": "^0.31.0" 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /prisma/factories.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * Factories for testing purposes. 3 | */ 4 | import { PitchType, PlayerPosition, SquadType, TeamType } from "@prisma/client"; 5 | import { factory, random } from "../src"; 6 | import db from "."; 7 | 8 | /** 9 | * Factory for the Team model, with random values for required fields. 10 | */ 11 | export const TeamFactory = factory(db.team, () => ({ 12 | name: random.string(), 13 | key: random.string(), 14 | type: TeamType.CLUB, 15 | website: random.url(), 16 | })); 17 | 18 | /** 19 | * Factory for the Squad model, with random values for required fields. 20 | */ 21 | export const SquadFactory = factory(db.squad, () => ({ 22 | team: { create: TeamFactory.fields() }, 23 | type: SquadType.SENIOR_MEN, 24 | })); 25 | 26 | /** 27 | * Factory for the Player model, with random values for required fields. 28 | */ 29 | export const PlayerFactory = factory(db.player, () => ({ 30 | key: random.string(), 31 | name: random.string(), 32 | dob: random.date(), 33 | position: PlayerPosition.CM, 34 | })); 35 | 36 | /** 37 | * Factory for the Stadium model, with random values for required fields. 38 | */ 39 | export const StadiumFactory = factory(db.stadium, () => ({ 40 | name: random.string(), 41 | key: random.string(), 42 | capacity: random.int(), 43 | })); 44 | 45 | /** 46 | * Factory for the Pitch model, with random values for required fields. 47 | */ 48 | export const PitchFactory = factory(db.pitch, () => ({ 49 | stadium: { create: StadiumFactory.fields() }, 50 | surfaceType: PitchType.GRASS, 51 | width: random.float(), 52 | length: random.float(), 53 | })); 54 | -------------------------------------------------------------------------------- /prisma/index.ts: -------------------------------------------------------------------------------- 1 | import { PrismaClient } from '@prisma/client'; 2 | 3 | const prisma = new PrismaClient(); 4 | 5 | export default prisma; -------------------------------------------------------------------------------- /prisma/migrations/20230512232905_/migration.sql: -------------------------------------------------------------------------------- 1 | -- CreateEnum 2 | CREATE TYPE "TeamType" AS ENUM ('CLUB', 'NATIONAL'); 3 | 4 | -- CreateEnum 5 | CREATE TYPE "SquadType" AS ENUM ('SENIOR_MEN', 'SENIOR_WOMEN', 'ACADEMY'); 6 | 7 | -- CreateEnum 8 | CREATE TYPE "PlayerPosition" AS ENUM ('GK', 'LB', 'CB', 'RB', 'DM', 'CM', 'AM', 'LW', 'RW', 'ST'); 9 | 10 | -- CreateEnum 11 | CREATE TYPE "PitchType" AS ENUM ('GRASS', 'HYBRID', 'ARTIFICIAL'); 12 | 13 | -- CreateTable 14 | CREATE TABLE "Team" ( 15 | "id" SERIAL NOT NULL, 16 | "name" TEXT NOT NULL, 17 | "key" TEXT NOT NULL, 18 | "type" "TeamType" NOT NULL, 19 | "website" TEXT NOT NULL, 20 | "motto" TEXT, 21 | "description" TEXT, 22 | "stadiumId" INTEGER, 23 | 24 | CONSTRAINT "Team_pkey" PRIMARY KEY ("id") 25 | ); 26 | 27 | -- CreateTable 28 | CREATE TABLE "Squad" ( 29 | "id" SERIAL NOT NULL, 30 | "teamId" INTEGER NOT NULL, 31 | "type" "SquadType" NOT NULL, 32 | 33 | CONSTRAINT "Squad_pkey" PRIMARY KEY ("id") 34 | ); 35 | 36 | -- CreateTable 37 | CREATE TABLE "Player" ( 38 | "id" SERIAL NOT NULL, 39 | "name" TEXT NOT NULL, 40 | "nickname" TEXT, 41 | "dob" TIMESTAMP(3) NOT NULL, 42 | "key" TEXT NOT NULL, 43 | "position" "PlayerPosition" NOT NULL, 44 | "squadId" INTEGER, 45 | 46 | CONSTRAINT "Player_pkey" PRIMARY KEY ("id") 47 | ); 48 | 49 | -- CreateTable 50 | CREATE TABLE "Stadium" ( 51 | "id" SERIAL NOT NULL, 52 | "name" TEXT NOT NULL, 53 | "key" TEXT NOT NULL, 54 | "capacity" INTEGER NOT NULL, 55 | 56 | CONSTRAINT "Stadium_pkey" PRIMARY KEY ("id") 57 | ); 58 | 59 | -- CreateTable 60 | CREATE TABLE "Pitch" ( 61 | "id" SERIAL NOT NULL, 62 | "stadiumId" INTEGER NOT NULL, 63 | "surfaceType" "PitchType" NOT NULL, 64 | "width" DOUBLE PRECISION NOT NULL, 65 | "length" DOUBLE PRECISION NOT NULL, 66 | 67 | CONSTRAINT "Pitch_pkey" PRIMARY KEY ("id") 68 | ); 69 | 70 | -- CreateIndex 71 | CREATE UNIQUE INDEX "Team_key_key" ON "Team"("key"); 72 | 73 | -- CreateIndex 74 | CREATE UNIQUE INDEX "Player_key_key" ON "Player"("key"); 75 | 76 | -- CreateIndex 77 | CREATE UNIQUE INDEX "Stadium_key_key" ON "Stadium"("key"); 78 | 79 | -- CreateIndex 80 | CREATE UNIQUE INDEX "Pitch_stadiumId_key" ON "Pitch"("stadiumId"); 81 | 82 | -- AddForeignKey 83 | ALTER TABLE "Team" ADD CONSTRAINT "Team_stadiumId_fkey" FOREIGN KEY ("stadiumId") REFERENCES "Stadium"("id") ON DELETE SET NULL ON UPDATE CASCADE; 84 | 85 | -- AddForeignKey 86 | ALTER TABLE "Squad" ADD CONSTRAINT "Squad_teamId_fkey" FOREIGN KEY ("teamId") REFERENCES "Team"("id") ON DELETE RESTRICT ON UPDATE CASCADE; 87 | 88 | -- AddForeignKey 89 | ALTER TABLE "Player" ADD CONSTRAINT "Player_squadId_fkey" FOREIGN KEY ("squadId") REFERENCES "Squad"("id") ON DELETE SET NULL ON UPDATE CASCADE; 90 | 91 | -- AddForeignKey 92 | ALTER TABLE "Pitch" ADD CONSTRAINT "Pitch_stadiumId_fkey" FOREIGN KEY ("stadiumId") REFERENCES "Stadium"("id") ON DELETE RESTRICT ON UPDATE CASCADE; 93 | -------------------------------------------------------------------------------- /prisma/migrations/migration_lock.toml: -------------------------------------------------------------------------------- 1 | # Please do not edit this file manually 2 | # It should be added in your version-control system (i.e. Git) 3 | provider = "postgresql" -------------------------------------------------------------------------------- /prisma/schema.prisma: -------------------------------------------------------------------------------- 1 | generator client { 2 | provider = "prisma-client-js" 3 | } 4 | 5 | datasource db { 6 | provider = "postgresql" 7 | url = "postgresql://postgres:prisma@localhost:5435/dev" 8 | } 9 | 10 | enum TeamType { 11 | CLUB 12 | NATIONAL 13 | } 14 | 15 | model Team { 16 | id Int @id @default(autoincrement()) 17 | name String 18 | key String @unique 19 | type TeamType 20 | website String 21 | motto String? 22 | description String? 23 | stadium Stadium? @relation(fields: [stadiumId], references: [id]) 24 | stadiumId Int? 25 | squad Squad[] 26 | } 27 | 28 | enum SquadType { 29 | SENIOR_MEN 30 | SENIOR_WOMEN 31 | ACADEMY 32 | } 33 | 34 | model Squad { 35 | id Int @id @default(autoincrement()) 36 | team Team @relation(fields: [teamId], references: [id]) 37 | teamId Int 38 | type SquadType 39 | players Player[] 40 | } 41 | 42 | enum PlayerPosition { 43 | GK 44 | LB 45 | CB 46 | RB 47 | DM 48 | CM 49 | AM 50 | LW 51 | RW 52 | ST 53 | } 54 | 55 | model Player { 56 | id Int @id @default(autoincrement()) 57 | name String 58 | nickname String? 59 | dob DateTime 60 | key String @unique 61 | position PlayerPosition 62 | squad Squad? @relation(fields: [squadId], references: [id]) 63 | squadId Int? 64 | } 65 | 66 | model Stadium { 67 | id Int @id @default(autoincrement()) 68 | name String 69 | key String @unique 70 | capacity Int 71 | pitch Pitch? 72 | team Team[] 73 | } 74 | 75 | enum PitchType { 76 | GRASS 77 | HYBRID 78 | ARTIFICIAL 79 | } 80 | 81 | model Pitch { 82 | id Int @id @default(autoincrement()) 83 | stadium Stadium @relation(fields: [stadiumId], references: [id]) 84 | stadiumId Int @unique 85 | surfaceType PitchType 86 | width Float 87 | length Float 88 | } 89 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * Base interface, for the minimum required type. I.e. a Prisma model with a create() function. 3 | */ 4 | interface ModelBase { 5 | create: (args: { data: any }) => any; 6 | } 7 | 8 | /** 9 | * Required fields, passed as "data" to the Model's create() method. 10 | */ 11 | type CreateData = Parameters< 12 | Model["create"] 13 | >[0]["data"]; 14 | 15 | /** 16 | * The result of the Model's create() method, i.e. the created instance. 17 | */ 18 | type CreateResult = Promise< 19 | ReturnType 20 | >; 21 | 22 | /** 23 | * A factory instance, with fields() and instance() functions typed generically. 24 | */ 25 | type Factory = { 26 | fields: (overrides?: Partial>) => CreateData; 27 | instance: (overrides?: Partial>) => CreateResult; 28 | }; 29 | 30 | /** 31 | * Creates a Factory instance, for creating fields or instances of a Model. 32 | * 33 | * @param model - Prisma client for the Model: prisma.. 34 | * @param fieldsFactory - function for creating fields for the instance. 35 | */ 36 | export function factory( 37 | model: Model, 38 | fieldsFactory: (overrides: Partial>) => CreateData 39 | ): Factory { 40 | const fieldsFunc: Factory["fields"] = (overrides) => ({ 41 | ...fieldsFactory(overrides ?? {}), 42 | ...overrides, 43 | }); 44 | 45 | return { 46 | fields: fieldsFunc, 47 | instance: (overrides) => model.create({ data: fieldsFunc(overrides) }), 48 | }; 49 | } 50 | 51 | /** 52 | * Basic helper functions, for generating random data. 53 | */ 54 | export const random: { 55 | int: (max?: number) => number; 56 | float: () => number; 57 | string: () => string; 58 | date: () => Date; 59 | url: () => string; 60 | } = { 61 | /** 62 | * Returns a random integer, with an (optional) maximum. 63 | */ 64 | int: (max = 500) => Math.ceil(Math.random() * max), 65 | /** 66 | * Returns a random float. 67 | */ 68 | float: () => Math.random(), 69 | /** 70 | * Returns a string, made up of 11 random chars. 71 | */ 72 | string: () => Math.random().toString(36).slice(2), 73 | /** 74 | * Returns a random date in the past. 75 | */ 76 | date: () => { 77 | const maxDate = Date.now(); 78 | const timestamp = Math.floor(Math.random() * maxDate); 79 | return new Date(timestamp); 80 | }, 81 | /** 82 | * Returns a URL in the form: https://.com 83 | */ 84 | url: () => `https://${Math.random().toString(36).slice(2)}.com`, 85 | }; 86 | -------------------------------------------------------------------------------- /tests/fields.test.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * Tests verifying the fields() function. 3 | */ 4 | import { PlayerPosition } from "@prisma/client"; 5 | import { expect, test } from "vitest"; 6 | import db from "../prisma"; 7 | import { 8 | PitchFactory, 9 | PlayerFactory, 10 | SquadFactory, 11 | StadiumFactory, 12 | TeamFactory, 13 | } from "../prisma/factories"; 14 | import { factory, random } from "../src"; 15 | 16 | test("no relation", () => { 17 | const team = TeamFactory.fields(); 18 | 19 | expect(team.name).not.toBeUndefined(); 20 | expect(team.key).not.toBeUndefined(); 21 | expect(team.type).not.toBeUndefined(); 22 | expect(team.website).not.toBeUndefined(); 23 | expect(team.motto).toBeUndefined(); 24 | expect(team.description).toBeUndefined(); 25 | expect(team.stadium).toBeUndefined(); 26 | }); 27 | 28 | test("with relation", () => { 29 | const squad = SquadFactory.fields(); 30 | 31 | expect(squad.type).not.toBeUndefined(); 32 | expect(squad.team?.create?.name).not.toBeUndefined(); 33 | expect(squad.team?.create?.key).not.toBeUndefined(); 34 | expect(squad.team?.create?.type).not.toBeUndefined(); 35 | expect(squad.team?.create?.website).not.toBeUndefined(); 36 | expect(squad.team?.create?.motto).toBeUndefined(); 37 | expect(squad.team?.create?.description).toBeUndefined(); 38 | expect(squad.team?.create?.stadium).toBeUndefined(); 39 | }); 40 | 41 | test("with values", () => { 42 | const dob = new Date(); 43 | const player = PlayerFactory.fields({ 44 | name: "Bukayo Saka", 45 | nickname: "Starboy", 46 | key: "bukayo-saka", 47 | dob, 48 | position: "RW", 49 | }); 50 | 51 | expect(player.name).toBe("Bukayo Saka"); 52 | expect(player.key).toBe("bukayo-saka"); 53 | expect(player.dob).toStrictEqual(dob); 54 | expect(player.position).toBe("RW"); 55 | }); 56 | 57 | test("with relation values", () => { 58 | const stadium = StadiumFactory.fields({ 59 | name: "Emirates Stadium", 60 | key: "emirates-stadium", 61 | capacity: 60704, 62 | pitch: { 63 | create: PitchFactory.fields({ 64 | surfaceType: "GRASS", 65 | width: 68, 66 | length: 105, 67 | }), 68 | }, 69 | }); 70 | 71 | expect(stadium.name).toBe("Emirates Stadium"); 72 | expect(stadium.key).toBe("emirates-stadium"); 73 | expect(stadium.capacity).toBe(60704); 74 | expect(stadium.pitch?.create?.surfaceType).toBe("GRASS"); 75 | expect(stadium.pitch?.create?.width).toBe(68); 76 | expect(stadium.pitch?.create?.length).toBe(105); 77 | }); 78 | 79 | test.each([ 80 | [{ name: "Saka" }, PlayerPosition.RW], 81 | [{ name: "Raya" }, PlayerPosition.GK], 82 | [undefined, PlayerPosition.GK], 83 | ])("with conditional (%p)", (override, result) => { 84 | const conditionalFactory = factory(db.player, ({ name }) => ({ 85 | key: random.string(), 86 | name: random.string(), 87 | dob: random.date(), 88 | position: name === "Saka" ? PlayerPosition.RW : PlayerPosition.GK, 89 | })); 90 | 91 | const player = conditionalFactory.fields(override); 92 | 93 | expect(player.position).toBe(result); 94 | }); 95 | -------------------------------------------------------------------------------- /tests/instance.test.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * Tests verifying the instance() function. 3 | */ 4 | import { describe, expect, test } from "vitest"; 5 | import db from "../prisma"; 6 | import { 7 | PitchFactory, 8 | PlayerFactory, 9 | SquadFactory, 10 | StadiumFactory, 11 | TeamFactory, 12 | } from "../prisma/factories"; 13 | 14 | describe("Created", () => { 15 | test("no relations", async () => { 16 | await TeamFactory.instance(); 17 | 18 | expect(await db.team.count()).toBe(1); 19 | }); 20 | 21 | test("with relations", async () => { 22 | await SquadFactory.instance(); 23 | 24 | const team = await db.team.findFirstOrThrow(); 25 | const squad = await db.squad.findFirstOrThrow(); 26 | 27 | expect(await db.team.count()).toBe(1); 28 | expect(await db.squad.count()).toBe(1); 29 | expect(team.id).toBe(squad.teamId); 30 | }); 31 | 32 | test("connected", async () => { 33 | const { id } = await TeamFactory.instance(); 34 | await SquadFactory.instance({ team: { connect: { id } } }); 35 | 36 | const team = await db.team.findFirstOrThrow(); 37 | const squad = await db.squad.findFirstOrThrow(); 38 | 39 | expect(await db.team.count()).toBe(1); 40 | expect(await db.squad.count()).toBe(1); 41 | expect(team.id).toBe(squad.teamId); 42 | }); 43 | }); 44 | 45 | describe("Values", () => { 46 | test("no relation", async () => { 47 | const team = await TeamFactory.instance(); 48 | 49 | expect(team.name).not.toBeNull(); 50 | expect(team.key).not.toBeNull(); 51 | expect(team.type).not.toBeNull(); 52 | expect(team.website).not.toBeNull(); 53 | expect(team.motto).toBeNull(); 54 | expect(team.description).toBeNull(); 55 | expect(team.stadiumId).toBeNull(); 56 | }); 57 | 58 | test("with relation", async () => { 59 | const squad = await SquadFactory.instance(); 60 | const team = await db.team.findFirstOrThrow(); 61 | 62 | expect(squad.type).not.toBeNull(); 63 | expect(team.name).not.toBeNull(); 64 | expect(team.key).not.toBeNull(); 65 | expect(team.type).not.toBeNull(); 66 | expect(team.website).not.toBeNull(); 67 | expect(team.motto).toBeNull(); 68 | expect(team.description).toBeNull(); 69 | }); 70 | 71 | test("with values", async () => { 72 | const dob = new Date(); 73 | const player = await PlayerFactory.instance({ 74 | name: "Bukayo Saka", 75 | nickname: "Starboy", 76 | key: "bukayo-saka", 77 | dob, 78 | position: "RW", 79 | }); 80 | 81 | expect(player.name).toBe("Bukayo Saka"); 82 | expect(player.key).toBe("bukayo-saka"); 83 | expect(player.dob).toStrictEqual(dob); 84 | expect(player.position).toBe("RW"); 85 | }); 86 | 87 | test("with relation values", async () => { 88 | const stadium = await StadiumFactory.instance({ 89 | name: "Emirates Stadium", 90 | key: "emirates-stadium", 91 | capacity: 60704, 92 | pitch: { 93 | create: PitchFactory.fields({ 94 | surfaceType: "GRASS", 95 | width: 68, 96 | length: 105, 97 | stadium: undefined, 98 | }), 99 | }, 100 | }); 101 | 102 | const pitch = await db.pitch.findFirstOrThrow({ 103 | where: { id: stadium.id }, 104 | }); 105 | 106 | expect(stadium.name).toBe("Emirates Stadium"); 107 | expect(stadium.key).toBe("emirates-stadium"); 108 | expect(stadium.capacity).toBe(60704); 109 | expect(pitch.surfaceType).toBe("GRASS"); 110 | expect(pitch.width).toBe(68); 111 | expect(pitch.length).toBe(105); 112 | }); 113 | }); 114 | -------------------------------------------------------------------------------- /tests/setup-tests.ts: -------------------------------------------------------------------------------- 1 | import { beforeEach } from "vitest"; 2 | import db from "../prisma"; 3 | 4 | /** 5 | * Truncate all tables, apart from the Prisma migrations table. 6 | */ 7 | beforeEach(async () => { 8 | const tables = await db.$queryRaw< 9 | Array<{ tablename: string }> 10 | >`SELECT tablename FROM pg_tables WHERE schemaname='public' AND tablename != '_prisma_migrations'`; 11 | 12 | const names = tables.map((t) => `"public"."${t.tablename}"`).join(", "); 13 | await db.$executeRawUnsafe(`TRUNCATE TABLE ${names} CASCADE;`); 14 | }); 15 | -------------------------------------------------------------------------------- /tests/vitest.config.ts: -------------------------------------------------------------------------------- 1 | import { defineConfig } from "vitest/config"; 2 | 3 | export default defineConfig({ 4 | test: { 5 | watch: false, 6 | threads: false, // tests use a real DB, so parallel runs are a no-go 7 | setupFiles: "tests/setup-tests.ts", 8 | coverage: { 9 | provider: "c8", 10 | include: ["src/**"], 11 | lines: 100, 12 | functions: 100, 13 | branches: 100, 14 | statements: 100, 15 | }, 16 | }, 17 | }); 18 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es5", 4 | "module": "commonjs", 5 | "declaration": true, 6 | "outDir": "dist", 7 | "strict": true, 8 | "esModuleInterop": true, 9 | "skipLibCheck": true 10 | }, 11 | "include": ["src"], 12 | "exclude": ["node_modules", "dist"] 13 | } 14 | --------------------------------------------------------------------------------