├── .github └── workflows │ └── semgrep.yml ├── .gitignore ├── LICENSE ├── README.md ├── consumer ├── .gitignore ├── package-lock.json ├── package.json ├── src │ └── index.ts ├── tsconfig.json └── wrangler.toml ├── img └── Products-Diagram.png └── pages ├── functions ├── page │ └── [url].js └── requestToCrawlSite.js └── index.html /.github/workflows/semgrep.yml: -------------------------------------------------------------------------------- 1 | 2 | on: 3 | pull_request: {} 4 | workflow_dispatch: {} 5 | push: 6 | branches: 7 | - main 8 | - master 9 | schedule: 10 | - cron: '0 0 * * *' 11 | name: Semgrep config 12 | jobs: 13 | semgrep: 14 | name: semgrep/ci 15 | runs-on: ubuntu-20.04 16 | env: 17 | SEMGREP_APP_TOKEN: ${{ secrets.SEMGREP_APP_TOKEN }} 18 | SEMGREP_URL: https://cloudflare.semgrep.dev 19 | SEMGREP_APP_URL: https://cloudflare.semgrep.dev 20 | SEMGREP_VERSION_CHECK_URL: https://cloudflare.semgrep.dev/api/check-version 21 | container: 22 | image: returntocorp/semgrep 23 | steps: 24 | - uses: actions/checkout@v3 25 | - run: semgrep ci 26 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | pages/.wrangler/** 2 | pages/node_modules/** 3 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Copyright (c) 2023 Cloudflare, Inc. 2 | 3 | Licensed under the Apache License, Version 2.0 (the "License"); 4 | you may not use this file except in compliance with the License. 5 | You may obtain a copy of the License at 6 | 7 | http://www.apache.org/licenses/LICENSE-2.0 8 | 9 | Unless required by applicable law or agreed to in writing, software 10 | distributed under the License is distributed on an "AS IS" BASIS, 11 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 | See the License for the specific language governing permissions and 13 | limitations under the License. 14 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Queues Web Crawler Example 2 | 3 | An example use-case for [Queues](https://developers.cloudflare.com/queues/): a web crawler built on [Browser Rendering](https://developers.cloudflare.com/browser-rendering/) and Puppeteer. The crawler finds the number of links to Cloudflare.com on the site, and archives a screenshot to Workers KV. 4 | 5 | For this project, Queues helps batch sites to be crawled, which limits the overhead of opening and closing new Puppeteer instances. Because loading pages and scraping links takes some time, Queues makes it possible to respond to inbound crawl requests instantly while providing peace of mind that the long-running crawl will be triggered. Queues also helps handle bursty traffic and reliability issues! 6 | 7 | ![Products used: Pages Functions, Queues, and Browser Rendering](./img/Products-Diagram.png) 8 | 9 | ## Development 10 | 11 | This assumes you have access to the Browser Rendering feature - you can join the waitlist [here](https://www.cloudflare.com/lp/workers-browser-rendering-api). 12 | 13 | First, fork this project. Install [Node.js](https://nodejs.org/en/download) and [Wrangler](https://developers.cloudflare.com/workers/wrangler/install-and-update/), and run `npm install`. 14 | 15 | Then, to configure your project and deploy on Cloudflare Workers: 16 | 17 | 1. Go to the [Dash](https://dash.cloudflare.com) and click on Workers & Pages > Queues > Create queue. Enter a Queue name. 18 | 2. In the `pages` directory, `wrangler pages deploy .`, and enter a project name (`PROJECT_NAME`). 19 | 3. Go to the [Dash](https://dash.cloudflare.com) and click on Workers & Pages > Overview > `PROJECT_NAME` > Settings > Functions > Queue Producers bindings > Add binding. 20 | 4. Set the variable name to `CRAWLER_QUEUE` and select your queue as the Queue name. Click "Save". 21 | 5. In the Dash, click on Workers & Pages > KV > Create a namespace. Create one namespace called `crawler_screenshots` and one called `crawler_links`. 22 | 6. Create two KV namespace bindings. Set `CRAWLER_LINKS_KV` as first's variable name and `crawler_links` as the KV namespace. Then, set `CRAWLER_SCREENSHOTS_KV` as the second's variable name and `crawler_screenshots` as the KV namespace. 23 | 7. In the `consumer` directory, update the `wrangler.toml` file with your new KV namespace IDs. Also update the `[[queues.consumers]]` name to the Queue you created. 24 | 8. In the `consumer` directory, `wrangler deploy`. 25 | 26 | Your Queues-powered web crawler will be live! 27 | -------------------------------------------------------------------------------- /consumer/.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/* 2 | .secret.wrangler.toml 3 | -------------------------------------------------------------------------------- /consumer/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "queues-web-crawler-consumer", 3 | "version": "0.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "queues-web-crawler-consumer", 9 | "version": "0.0.0", 10 | "dependencies": { 11 | "@cloudflare/puppeteer": "^0.0.2-alpha", 12 | "archiver": "^5.3.1", 13 | "robots-parser": "^3.0.1" 14 | }, 15 | "devDependencies": { 16 | "@cloudflare/workers-types": "^4.20230518.0", 17 | "typescript": "^5.1.3", 18 | "wrangler": "2.20.0" 19 | } 20 | }, 21 | "node_modules/@cloudflare/kv-asset-handler": { 22 | "version": "0.2.0", 23 | "resolved": "https://registry.npmjs.org/@cloudflare/kv-asset-handler/-/kv-asset-handler-0.2.0.tgz", 24 | "integrity": "sha512-MVbXLbTcAotOPUj0pAMhVtJ+3/kFkwJqc5qNOleOZTv6QkZZABDMS21dSrSlVswEHwrpWC03e4fWytjqKvuE2A==", 25 | "dev": true, 26 | "dependencies": { 27 | "mime": "^3.0.0" 28 | } 29 | }, 30 | "node_modules/@cloudflare/puppeteer": { 31 | "version": "0.0.2-alpha", 32 | "resolved": "https://registry.npmjs.org/@cloudflare/puppeteer/-/puppeteer-0.0.2-alpha.tgz", 33 | "integrity": "sha512-TIMKvtPdyctv/GK405a6LgkJ/bSkT4MAJAHhR3cpmhfxh7Ohti9GDgusdyycAcYASQIWDmucQunMYQwEh81iwg==", 34 | "dependencies": { 35 | "debug": "4.3.4", 36 | "devtools-protocol": "0.0.1019158", 37 | "events": "3.3.0", 38 | "stream": "0.0.2", 39 | "url": "0.11.0", 40 | "util": "0.12.5" 41 | }, 42 | "engines": { 43 | "node": ">=14.1.0" 44 | } 45 | }, 46 | "node_modules/@cloudflare/workers-types": { 47 | "version": "4.20230518.0", 48 | "resolved": "https://registry.npmjs.org/@cloudflare/workers-types/-/workers-types-4.20230518.0.tgz", 49 | "integrity": "sha512-A0w1V+5SUawGaaPRlhFhSC/SCDT9oQG8TMoWOKFLA4qbqagELqEAFD4KySBIkeVOvCBLT1DZSYBMCxbXddl0kw==", 50 | "dev": true 51 | }, 52 | "node_modules/@esbuild-plugins/node-globals-polyfill": { 53 | "version": "0.1.1", 54 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-globals-polyfill/-/node-globals-polyfill-0.1.1.tgz", 55 | "integrity": "sha512-MR0oAA+mlnJWrt1RQVQ+4VYuRJW/P2YmRTv1AsplObyvuBMnPHiizUF95HHYiSsMGLhyGtWufaq2XQg6+iurBg==", 56 | "dev": true, 57 | "peerDependencies": { 58 | "esbuild": "*" 59 | } 60 | }, 61 | "node_modules/@esbuild-plugins/node-modules-polyfill": { 62 | "version": "0.1.4", 63 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-modules-polyfill/-/node-modules-polyfill-0.1.4.tgz", 64 | "integrity": "sha512-uZbcXi0zbmKC/050p3gJnne5Qdzw8vkXIv+c2BW0Lsc1ji1SkrxbKPUy5Efr0blbTu1SL8w4eyfpnSdPg3G0Qg==", 65 | "dev": true, 66 | "dependencies": { 67 | "escape-string-regexp": "^4.0.0", 68 | "rollup-plugin-node-polyfills": "^0.2.1" 69 | }, 70 | "peerDependencies": { 71 | "esbuild": "*" 72 | } 73 | }, 74 | "node_modules/@esbuild/android-arm": { 75 | "version": "0.16.3", 76 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.16.3.tgz", 77 | "integrity": "sha512-mueuEoh+s1eRbSJqq9KNBQwI4QhQV6sRXIfTyLXSHGMpyew61rOK4qY21uKbXl1iBoMb0AdL1deWFCQVlN2qHA==", 78 | "cpu": [ 79 | "arm" 80 | ], 81 | "dev": true, 82 | "optional": true, 83 | "os": [ 84 | "android" 85 | ], 86 | "engines": { 87 | "node": ">=12" 88 | } 89 | }, 90 | "node_modules/@esbuild/android-arm64": { 91 | "version": "0.16.3", 92 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.16.3.tgz", 93 | "integrity": "sha512-RolFVeinkeraDvN/OoRf1F/lP0KUfGNb5jxy/vkIMeRRChkrX/HTYN6TYZosRJs3a1+8wqpxAo5PI5hFmxyPRg==", 94 | "cpu": [ 95 | "arm64" 96 | ], 97 | "dev": true, 98 | "optional": true, 99 | "os": [ 100 | "android" 101 | ], 102 | "engines": { 103 | "node": ">=12" 104 | } 105 | }, 106 | "node_modules/@esbuild/android-x64": { 107 | "version": "0.16.3", 108 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.16.3.tgz", 109 | "integrity": "sha512-SFpTUcIT1bIJuCCBMCQWq1bL2gPTjWoLZdjmIhjdcQHaUfV41OQfho6Ici5uvvkMmZRXIUGpM3GxysP/EU7ifQ==", 110 | "cpu": [ 111 | "x64" 112 | ], 113 | "dev": true, 114 | "optional": true, 115 | "os": [ 116 | "android" 117 | ], 118 | "engines": { 119 | "node": ">=12" 120 | } 121 | }, 122 | "node_modules/@esbuild/darwin-arm64": { 123 | "version": "0.16.3", 124 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.16.3.tgz", 125 | "integrity": "sha512-DO8WykMyB+N9mIDfI/Hug70Dk1KipavlGAecxS3jDUwAbTpDXj0Lcwzw9svkhxfpCagDmpaTMgxWK8/C/XcXvw==", 126 | "cpu": [ 127 | "arm64" 128 | ], 129 | "dev": true, 130 | "optional": true, 131 | "os": [ 132 | "darwin" 133 | ], 134 | "engines": { 135 | "node": ">=12" 136 | } 137 | }, 138 | "node_modules/@esbuild/darwin-x64": { 139 | "version": "0.16.3", 140 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.16.3.tgz", 141 | "integrity": "sha512-uEqZQ2omc6BvWqdCiyZ5+XmxuHEi1SPzpVxXCSSV2+Sh7sbXbpeNhHIeFrIpRjAs0lI1FmA1iIOxFozKBhKgRQ==", 142 | "cpu": [ 143 | "x64" 144 | ], 145 | "dev": true, 146 | "optional": true, 147 | "os": [ 148 | "darwin" 149 | ], 150 | "engines": { 151 | "node": ">=12" 152 | } 153 | }, 154 | "node_modules/@esbuild/freebsd-arm64": { 155 | "version": "0.16.3", 156 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.16.3.tgz", 157 | "integrity": "sha512-nJansp3sSXakNkOD5i5mIz2Is/HjzIhFs49b1tjrPrpCmwgBmH9SSzhC/Z1UqlkivqMYkhfPwMw1dGFUuwmXhw==", 158 | "cpu": [ 159 | "arm64" 160 | ], 161 | "dev": true, 162 | "optional": true, 163 | "os": [ 164 | "freebsd" 165 | ], 166 | "engines": { 167 | "node": ">=12" 168 | } 169 | }, 170 | "node_modules/@esbuild/freebsd-x64": { 171 | "version": "0.16.3", 172 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.16.3.tgz", 173 | "integrity": "sha512-TfoDzLw+QHfc4a8aKtGSQ96Wa+6eimljjkq9HKR0rHlU83vw8aldMOUSJTUDxbcUdcgnJzPaX8/vGWm7vyV7ug==", 174 | "cpu": [ 175 | "x64" 176 | ], 177 | "dev": true, 178 | "optional": true, 179 | "os": [ 180 | "freebsd" 181 | ], 182 | "engines": { 183 | "node": ">=12" 184 | } 185 | }, 186 | "node_modules/@esbuild/linux-arm": { 187 | "version": "0.16.3", 188 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.16.3.tgz", 189 | "integrity": "sha512-VwswmSYwVAAq6LysV59Fyqk3UIjbhuc6wb3vEcJ7HEJUtFuLK9uXWuFoH1lulEbE4+5GjtHi3MHX+w1gNHdOWQ==", 190 | "cpu": [ 191 | "arm" 192 | ], 193 | "dev": true, 194 | "optional": true, 195 | "os": [ 196 | "linux" 197 | ], 198 | "engines": { 199 | "node": ">=12" 200 | } 201 | }, 202 | "node_modules/@esbuild/linux-arm64": { 203 | "version": "0.16.3", 204 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.16.3.tgz", 205 | "integrity": "sha512-7I3RlsnxEFCHVZNBLb2w7unamgZ5sVwO0/ikE2GaYvYuUQs9Qte/w7TqWcXHtCwxvZx/2+F97ndiUQAWs47ZfQ==", 206 | "cpu": [ 207 | "arm64" 208 | ], 209 | "dev": true, 210 | "optional": true, 211 | "os": [ 212 | "linux" 213 | ], 214 | "engines": { 215 | "node": ">=12" 216 | } 217 | }, 218 | "node_modules/@esbuild/linux-ia32": { 219 | "version": "0.16.3", 220 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.16.3.tgz", 221 | "integrity": "sha512-X8FDDxM9cqda2rJE+iblQhIMYY49LfvW4kaEjoFbTTQ4Go8G96Smj2w3BRTwA8IHGoi9dPOPGAX63dhuv19UqA==", 222 | "cpu": [ 223 | "ia32" 224 | ], 225 | "dev": true, 226 | "optional": true, 227 | "os": [ 228 | "linux" 229 | ], 230 | "engines": { 231 | "node": ">=12" 232 | } 233 | }, 234 | "node_modules/@esbuild/linux-loong64": { 235 | "version": "0.16.3", 236 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.16.3.tgz", 237 | "integrity": "sha512-hIbeejCOyO0X9ujfIIOKjBjNAs9XD/YdJ9JXAy1lHA+8UXuOqbFe4ErMCqMr8dhlMGBuvcQYGF7+kO7waj2KHw==", 238 | "cpu": [ 239 | "loong64" 240 | ], 241 | "dev": true, 242 | "optional": true, 243 | "os": [ 244 | "linux" 245 | ], 246 | "engines": { 247 | "node": ">=12" 248 | } 249 | }, 250 | "node_modules/@esbuild/linux-mips64el": { 251 | "version": "0.16.3", 252 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.16.3.tgz", 253 | "integrity": "sha512-znFRzICT/V8VZQMt6rjb21MtAVJv/3dmKRMlohlShrbVXdBuOdDrGb+C2cZGQAR8RFyRe7HS6klmHq103WpmVw==", 254 | "cpu": [ 255 | "mips64el" 256 | ], 257 | "dev": true, 258 | "optional": true, 259 | "os": [ 260 | "linux" 261 | ], 262 | "engines": { 263 | "node": ">=12" 264 | } 265 | }, 266 | "node_modules/@esbuild/linux-ppc64": { 267 | "version": "0.16.3", 268 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.16.3.tgz", 269 | "integrity": "sha512-EV7LuEybxhXrVTDpbqWF2yehYRNz5e5p+u3oQUS2+ZFpknyi1NXxr8URk4ykR8Efm7iu04//4sBg249yNOwy5Q==", 270 | "cpu": [ 271 | "ppc64" 272 | ], 273 | "dev": true, 274 | "optional": true, 275 | "os": [ 276 | "linux" 277 | ], 278 | "engines": { 279 | "node": ">=12" 280 | } 281 | }, 282 | "node_modules/@esbuild/linux-riscv64": { 283 | "version": "0.16.3", 284 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.16.3.tgz", 285 | "integrity": "sha512-uDxqFOcLzFIJ+r/pkTTSE9lsCEaV/Y6rMlQjUI9BkzASEChYL/aSQjZjchtEmdnVxDKETnUAmsaZ4pqK1eE5BQ==", 286 | "cpu": [ 287 | "riscv64" 288 | ], 289 | "dev": true, 290 | "optional": true, 291 | "os": [ 292 | "linux" 293 | ], 294 | "engines": { 295 | "node": ">=12" 296 | } 297 | }, 298 | "node_modules/@esbuild/linux-s390x": { 299 | "version": "0.16.3", 300 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.16.3.tgz", 301 | "integrity": "sha512-NbeREhzSxYwFhnCAQOQZmajsPYtX71Ufej3IQ8W2Gxskfz9DK58ENEju4SbpIj48VenktRASC52N5Fhyf/aliQ==", 302 | "cpu": [ 303 | "s390x" 304 | ], 305 | "dev": true, 306 | "optional": true, 307 | "os": [ 308 | "linux" 309 | ], 310 | "engines": { 311 | "node": ">=12" 312 | } 313 | }, 314 | "node_modules/@esbuild/linux-x64": { 315 | "version": "0.16.3", 316 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.16.3.tgz", 317 | "integrity": "sha512-SDiG0nCixYO9JgpehoKgScwic7vXXndfasjnD5DLbp1xltANzqZ425l7LSdHynt19UWOcDjG9wJJzSElsPvk0w==", 318 | "cpu": [ 319 | "x64" 320 | ], 321 | "dev": true, 322 | "optional": true, 323 | "os": [ 324 | "linux" 325 | ], 326 | "engines": { 327 | "node": ">=12" 328 | } 329 | }, 330 | "node_modules/@esbuild/netbsd-x64": { 331 | "version": "0.16.3", 332 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.16.3.tgz", 333 | "integrity": "sha512-AzbsJqiHEq1I/tUvOfAzCY15h4/7Ivp3ff/o1GpP16n48JMNAtbW0qui2WCgoIZArEHD0SUQ95gvR0oSO7ZbdA==", 334 | "cpu": [ 335 | "x64" 336 | ], 337 | "dev": true, 338 | "optional": true, 339 | "os": [ 340 | "netbsd" 341 | ], 342 | "engines": { 343 | "node": ">=12" 344 | } 345 | }, 346 | "node_modules/@esbuild/openbsd-x64": { 347 | "version": "0.16.3", 348 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.16.3.tgz", 349 | "integrity": "sha512-gSABi8qHl8k3Cbi/4toAzHiykuBuWLZs43JomTcXkjMZVkp0gj3gg9mO+9HJW/8GB5H89RX/V0QP4JGL7YEEVg==", 350 | "cpu": [ 351 | "x64" 352 | ], 353 | "dev": true, 354 | "optional": true, 355 | "os": [ 356 | "openbsd" 357 | ], 358 | "engines": { 359 | "node": ">=12" 360 | } 361 | }, 362 | "node_modules/@esbuild/sunos-x64": { 363 | "version": "0.16.3", 364 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.16.3.tgz", 365 | "integrity": "sha512-SF9Kch5Ete4reovvRO6yNjMxrvlfT0F0Flm+NPoUw5Z4Q3r1d23LFTgaLwm3Cp0iGbrU/MoUI+ZqwCv5XJijCw==", 366 | "cpu": [ 367 | "x64" 368 | ], 369 | "dev": true, 370 | "optional": true, 371 | "os": [ 372 | "sunos" 373 | ], 374 | "engines": { 375 | "node": ">=12" 376 | } 377 | }, 378 | "node_modules/@esbuild/win32-arm64": { 379 | "version": "0.16.3", 380 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.16.3.tgz", 381 | "integrity": "sha512-u5aBonZIyGopAZyOnoPAA6fGsDeHByZ9CnEzyML9NqntK6D/xl5jteZUKm/p6nD09+v3pTM6TuUIqSPcChk5gg==", 382 | "cpu": [ 383 | "arm64" 384 | ], 385 | "dev": true, 386 | "optional": true, 387 | "os": [ 388 | "win32" 389 | ], 390 | "engines": { 391 | "node": ">=12" 392 | } 393 | }, 394 | "node_modules/@esbuild/win32-ia32": { 395 | "version": "0.16.3", 396 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.16.3.tgz", 397 | "integrity": "sha512-GlgVq1WpvOEhNioh74TKelwla9KDuAaLZrdxuuUgsP2vayxeLgVc+rbpIv0IYF4+tlIzq2vRhofV+KGLD+37EQ==", 398 | "cpu": [ 399 | "ia32" 400 | ], 401 | "dev": true, 402 | "optional": true, 403 | "os": [ 404 | "win32" 405 | ], 406 | "engines": { 407 | "node": ">=12" 408 | } 409 | }, 410 | "node_modules/@esbuild/win32-x64": { 411 | "version": "0.16.3", 412 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.16.3.tgz", 413 | "integrity": "sha512-5/JuTd8OWW8UzEtyf19fbrtMJENza+C9JoPIkvItgTBQ1FO2ZLvjbPO6Xs54vk0s5JB5QsfieUEshRQfu7ZHow==", 414 | "cpu": [ 415 | "x64" 416 | ], 417 | "dev": true, 418 | "optional": true, 419 | "os": [ 420 | "win32" 421 | ], 422 | "engines": { 423 | "node": ">=12" 424 | } 425 | }, 426 | "node_modules/@iarna/toml": { 427 | "version": "2.2.5", 428 | "resolved": "https://registry.npmjs.org/@iarna/toml/-/toml-2.2.5.tgz", 429 | "integrity": "sha512-trnsAYxU3xnS1gPHPyU961coFyLkh4gAD/0zQ5mymY4yOZ+CYvsPqUbOFSw0aDM4y0tV7tiFxL/1XfXPNC6IPg==", 430 | "dev": true 431 | }, 432 | "node_modules/@miniflare/cache": { 433 | "version": "2.13.0", 434 | "resolved": "https://registry.npmjs.org/@miniflare/cache/-/cache-2.13.0.tgz", 435 | "integrity": "sha512-y3SdN3SVyPECWmLAEGkkrv0RB+LugEPs/FeXn8QtN9aE1vyj69clOAgmsDzoh1DpFfFsLKRiv05aWs4m79P8Xw==", 436 | "dev": true, 437 | "dependencies": { 438 | "@miniflare/core": "2.13.0", 439 | "@miniflare/shared": "2.13.0", 440 | "http-cache-semantics": "^4.1.0", 441 | "undici": "5.20.0" 442 | }, 443 | "engines": { 444 | "node": ">=16.13" 445 | } 446 | }, 447 | "node_modules/@miniflare/cli-parser": { 448 | "version": "2.13.0", 449 | "resolved": "https://registry.npmjs.org/@miniflare/cli-parser/-/cli-parser-2.13.0.tgz", 450 | "integrity": "sha512-Nx1PIfuMZ3mK9Dg/JojWZAjHR16h1pcdCFSqYln/ME7y5ifx+P1E5UkShWUQ1cBlibNaltjbJ2n/7stSAsIGPQ==", 451 | "dev": true, 452 | "dependencies": { 453 | "@miniflare/shared": "2.13.0", 454 | "kleur": "^4.1.4" 455 | }, 456 | "engines": { 457 | "node": ">=16.13" 458 | } 459 | }, 460 | "node_modules/@miniflare/core": { 461 | "version": "2.13.0", 462 | "resolved": "https://registry.npmjs.org/@miniflare/core/-/core-2.13.0.tgz", 463 | "integrity": "sha512-YJ/C0J3k+7xn4gvlMpvePnM3xC8nOnkweW96cc0IA8kJ1JSmScOO2tZ7rrU1RyDgp6StkAtQBw4yC0wYeFycBw==", 464 | "dev": true, 465 | "dependencies": { 466 | "@iarna/toml": "^2.2.5", 467 | "@miniflare/queues": "2.13.0", 468 | "@miniflare/shared": "2.13.0", 469 | "@miniflare/watcher": "2.13.0", 470 | "busboy": "^1.6.0", 471 | "dotenv": "^10.0.0", 472 | "kleur": "^4.1.4", 473 | "set-cookie-parser": "^2.4.8", 474 | "undici": "5.20.0", 475 | "urlpattern-polyfill": "^4.0.3" 476 | }, 477 | "engines": { 478 | "node": ">=16.13" 479 | } 480 | }, 481 | "node_modules/@miniflare/d1": { 482 | "version": "2.13.0", 483 | "resolved": "https://registry.npmjs.org/@miniflare/d1/-/d1-2.13.0.tgz", 484 | "integrity": "sha512-OslqjO8iTcvzyrC0spByftMboRmHJEyHyTHnlKkjWDGdQQztEOjso2Xj+3I4SZIeUYvbzDRhKLS2QXI9a8LS5A==", 485 | "dev": true, 486 | "dependencies": { 487 | "@miniflare/core": "2.13.0", 488 | "@miniflare/shared": "2.13.0" 489 | }, 490 | "engines": { 491 | "node": ">=16.7" 492 | } 493 | }, 494 | "node_modules/@miniflare/durable-objects": { 495 | "version": "2.13.0", 496 | "resolved": "https://registry.npmjs.org/@miniflare/durable-objects/-/durable-objects-2.13.0.tgz", 497 | "integrity": "sha512-CRGVBPO9vY4Fc3aV+pdPRVVeYIt64vQqvw+BJbyW+TQtqVP2CGQeziJGnCfcONNNKyooZxGyUkHewUypyH+Qhg==", 498 | "dev": true, 499 | "dependencies": { 500 | "@miniflare/core": "2.13.0", 501 | "@miniflare/shared": "2.13.0", 502 | "@miniflare/storage-memory": "2.13.0", 503 | "undici": "5.20.0" 504 | }, 505 | "engines": { 506 | "node": ">=16.13" 507 | } 508 | }, 509 | "node_modules/@miniflare/html-rewriter": { 510 | "version": "2.13.0", 511 | "resolved": "https://registry.npmjs.org/@miniflare/html-rewriter/-/html-rewriter-2.13.0.tgz", 512 | "integrity": "sha512-XhN7Icyzvtvu+o/A0hrnSiSmla78seCaNwQ9M1TDHxt352I/ahPX4wtPXs6GbKqY0/i+V6yoG2KGFRQ/j59cQQ==", 513 | "dev": true, 514 | "dependencies": { 515 | "@miniflare/core": "2.13.0", 516 | "@miniflare/shared": "2.13.0", 517 | "html-rewriter-wasm": "^0.4.1", 518 | "undici": "5.20.0" 519 | }, 520 | "engines": { 521 | "node": ">=16.13" 522 | } 523 | }, 524 | "node_modules/@miniflare/http-server": { 525 | "version": "2.13.0", 526 | "resolved": "https://registry.npmjs.org/@miniflare/http-server/-/http-server-2.13.0.tgz", 527 | "integrity": "sha512-aMS/nUMTKP15hKnyZboeuWCiqmNrrCu+XRBY/TxDDl07iXcLpiHGf3oVv+yXxXkWlJHJVCbK7i/nXSNPllRMSw==", 528 | "dev": true, 529 | "dependencies": { 530 | "@miniflare/core": "2.13.0", 531 | "@miniflare/shared": "2.13.0", 532 | "@miniflare/web-sockets": "2.13.0", 533 | "kleur": "^4.1.4", 534 | "selfsigned": "^2.0.0", 535 | "undici": "5.20.0", 536 | "ws": "^8.2.2", 537 | "youch": "^2.2.2" 538 | }, 539 | "engines": { 540 | "node": ">=16.13" 541 | } 542 | }, 543 | "node_modules/@miniflare/kv": { 544 | "version": "2.13.0", 545 | "resolved": "https://registry.npmjs.org/@miniflare/kv/-/kv-2.13.0.tgz", 546 | "integrity": "sha512-J0AS5x3g/YVOmHMxMAZs07nRXRvSo9jyuC0eikTBf+4AABvBIyvVYmdTjYNjCmr8O5smcfWBX5S27HelD3aAAQ==", 547 | "dev": true, 548 | "dependencies": { 549 | "@miniflare/shared": "2.13.0" 550 | }, 551 | "engines": { 552 | "node": ">=16.13" 553 | } 554 | }, 555 | "node_modules/@miniflare/queues": { 556 | "version": "2.13.0", 557 | "resolved": "https://registry.npmjs.org/@miniflare/queues/-/queues-2.13.0.tgz", 558 | "integrity": "sha512-Gf/a6M1mJL03iOvNqh3JNahcBfvEMPHnO28n0gkCoyYWGvddIr9lwCdFIa0qwNJsC1fIDRxhPg8PZ5cQLBMwRA==", 559 | "dev": true, 560 | "dependencies": { 561 | "@miniflare/shared": "2.13.0" 562 | }, 563 | "engines": { 564 | "node": ">=16.7" 565 | } 566 | }, 567 | "node_modules/@miniflare/r2": { 568 | "version": "2.13.0", 569 | "resolved": "https://registry.npmjs.org/@miniflare/r2/-/r2-2.13.0.tgz", 570 | "integrity": "sha512-/5k6GHOYMNV/oBtilV9HDXBkJUrx8oXVigG5vxbnzEGRXyVRmR+Glzu7mFT8JiE94XiEbXHk9Qvu1S5Dej3wBw==", 571 | "dev": true, 572 | "dependencies": { 573 | "@miniflare/shared": "2.13.0", 574 | "undici": "5.20.0" 575 | }, 576 | "engines": { 577 | "node": ">=16.13" 578 | } 579 | }, 580 | "node_modules/@miniflare/runner-vm": { 581 | "version": "2.13.0", 582 | "resolved": "https://registry.npmjs.org/@miniflare/runner-vm/-/runner-vm-2.13.0.tgz", 583 | "integrity": "sha512-VmKtF2cA8HmTuLXor1THWY0v+DmaobPct63iLcgWIaUdP3MIvL+9X8HDXFAviCR7bCTe6MKxckHkaOj0IE0aJQ==", 584 | "dev": true, 585 | "dependencies": { 586 | "@miniflare/shared": "2.13.0" 587 | }, 588 | "engines": { 589 | "node": ">=16.13" 590 | } 591 | }, 592 | "node_modules/@miniflare/scheduler": { 593 | "version": "2.13.0", 594 | "resolved": "https://registry.npmjs.org/@miniflare/scheduler/-/scheduler-2.13.0.tgz", 595 | "integrity": "sha512-AOaQanoR4NjVEzVGWHnrL15A7aMx+d9AKLJhSDF7KaP+4NrT2Wo2BQuXCpn5oStx3itOdlQpMfqQ139e/I8WhQ==", 596 | "dev": true, 597 | "dependencies": { 598 | "@miniflare/core": "2.13.0", 599 | "@miniflare/shared": "2.13.0", 600 | "cron-schedule": "^3.0.4" 601 | }, 602 | "engines": { 603 | "node": ">=16.13" 604 | } 605 | }, 606 | "node_modules/@miniflare/shared": { 607 | "version": "2.13.0", 608 | "resolved": "https://registry.npmjs.org/@miniflare/shared/-/shared-2.13.0.tgz", 609 | "integrity": "sha512-m8YFQzKmbjberrV9hPzNcQjNCXxjTjXUpuNrIGjAJO7g+BDztUHaZbdd26H9maBDlkeiWxA3hf0mDyCT/6MCMA==", 610 | "dev": true, 611 | "dependencies": { 612 | "@types/better-sqlite3": "^7.6.0", 613 | "kleur": "^4.1.4", 614 | "npx-import": "^1.1.4", 615 | "picomatch": "^2.3.1" 616 | }, 617 | "engines": { 618 | "node": ">=16.13" 619 | } 620 | }, 621 | "node_modules/@miniflare/sites": { 622 | "version": "2.13.0", 623 | "resolved": "https://registry.npmjs.org/@miniflare/sites/-/sites-2.13.0.tgz", 624 | "integrity": "sha512-/tuzIu00o6CF2tkSv01q02MgEShXBSKx85h9jwWvc+6u7prGacAOer0FA1YNRFbE+t9QIfutAkoPGMA9zYf8+Q==", 625 | "dev": true, 626 | "dependencies": { 627 | "@miniflare/kv": "2.13.0", 628 | "@miniflare/shared": "2.13.0", 629 | "@miniflare/storage-file": "2.13.0" 630 | }, 631 | "engines": { 632 | "node": ">=16.13" 633 | } 634 | }, 635 | "node_modules/@miniflare/storage-file": { 636 | "version": "2.13.0", 637 | "resolved": "https://registry.npmjs.org/@miniflare/storage-file/-/storage-file-2.13.0.tgz", 638 | "integrity": "sha512-LuAeAAY5046rq5U1eFLVkz+ppiFEWytWacpkQw92DvVKFFquZcXSj6WPxZF4rSs23WDk+rdcwuLekbb52aDR7A==", 639 | "dev": true, 640 | "dependencies": { 641 | "@miniflare/shared": "2.13.0", 642 | "@miniflare/storage-memory": "2.13.0" 643 | }, 644 | "engines": { 645 | "node": ">=16.13" 646 | } 647 | }, 648 | "node_modules/@miniflare/storage-memory": { 649 | "version": "2.13.0", 650 | "resolved": "https://registry.npmjs.org/@miniflare/storage-memory/-/storage-memory-2.13.0.tgz", 651 | "integrity": "sha512-FnkYcBNXa/ym1ksNilNZycg9WYYKo6cWKplVBeSthRon3e8QY6t3n7/XRseBUo7O6mhDybVTy4wNCP1R2nBiEw==", 652 | "dev": true, 653 | "dependencies": { 654 | "@miniflare/shared": "2.13.0" 655 | }, 656 | "engines": { 657 | "node": ">=16.13" 658 | } 659 | }, 660 | "node_modules/@miniflare/watcher": { 661 | "version": "2.13.0", 662 | "resolved": "https://registry.npmjs.org/@miniflare/watcher/-/watcher-2.13.0.tgz", 663 | "integrity": "sha512-teAacWcpMStoBLbLae95IUaL5lPzjPlXa9lhK9CbRaio/KRMibTMRGWrYos3IVGQRZvklvLwcms/nTvgcdb6yw==", 664 | "dev": true, 665 | "dependencies": { 666 | "@miniflare/shared": "2.13.0" 667 | }, 668 | "engines": { 669 | "node": ">=16.13" 670 | } 671 | }, 672 | "node_modules/@miniflare/web-sockets": { 673 | "version": "2.13.0", 674 | "resolved": "https://registry.npmjs.org/@miniflare/web-sockets/-/web-sockets-2.13.0.tgz", 675 | "integrity": "sha512-+U2/HCf+BetRIgjAnNQjkuN6UeAjQmXifhQC+7CCaX834XJhrKXoR6z2xr2xkg1qj0qQs4D2jWG0KzrO5OUpug==", 676 | "dev": true, 677 | "dependencies": { 678 | "@miniflare/core": "2.13.0", 679 | "@miniflare/shared": "2.13.0", 680 | "undici": "5.20.0", 681 | "ws": "^8.2.2" 682 | }, 683 | "engines": { 684 | "node": ">=16.13" 685 | } 686 | }, 687 | "node_modules/@types/better-sqlite3": { 688 | "version": "7.6.4", 689 | "resolved": "https://registry.npmjs.org/@types/better-sqlite3/-/better-sqlite3-7.6.4.tgz", 690 | "integrity": "sha512-dzrRZCYPXIXfSR1/surNbJ/grU3scTaygS0OMzjlGf71i9sc2fGyHPXXiXmEvNIoE0cGwsanEFMVJxPXmco9Eg==", 691 | "dev": true, 692 | "dependencies": { 693 | "@types/node": "*" 694 | } 695 | }, 696 | "node_modules/@types/node": { 697 | "version": "20.2.5", 698 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.2.5.tgz", 699 | "integrity": "sha512-JJulVEQXmiY9Px5axXHeYGLSjhkZEnD+MDPDGbCbIAbMslkKwmygtZFy1X6s/075Yo94sf8GuSlFfPzysQrWZQ==", 700 | "dev": true 701 | }, 702 | "node_modules/@types/stack-trace": { 703 | "version": "0.0.29", 704 | "resolved": "https://registry.npmjs.org/@types/stack-trace/-/stack-trace-0.0.29.tgz", 705 | "integrity": "sha512-TgfOX+mGY/NyNxJLIbDWrO9DjGoVSW9+aB8H2yy1fy32jsvxijhmyJI9fDFgvz3YP4lvJaq9DzdR/M1bOgVc9g==", 706 | "dev": true 707 | }, 708 | "node_modules/anymatch": { 709 | "version": "3.1.3", 710 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 711 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 712 | "dev": true, 713 | "dependencies": { 714 | "normalize-path": "^3.0.0", 715 | "picomatch": "^2.0.4" 716 | }, 717 | "engines": { 718 | "node": ">= 8" 719 | } 720 | }, 721 | "node_modules/archiver": { 722 | "version": "5.3.1", 723 | "resolved": "https://registry.npmjs.org/archiver/-/archiver-5.3.1.tgz", 724 | "integrity": "sha512-8KyabkmbYrH+9ibcTScQ1xCJC/CGcugdVIwB+53f5sZziXgwUh3iXlAlANMxcZyDEfTHMe6+Z5FofV8nopXP7w==", 725 | "dependencies": { 726 | "archiver-utils": "^2.1.0", 727 | "async": "^3.2.3", 728 | "buffer-crc32": "^0.2.1", 729 | "readable-stream": "^3.6.0", 730 | "readdir-glob": "^1.0.0", 731 | "tar-stream": "^2.2.0", 732 | "zip-stream": "^4.1.0" 733 | }, 734 | "engines": { 735 | "node": ">= 10" 736 | } 737 | }, 738 | "node_modules/archiver-utils": { 739 | "version": "2.1.0", 740 | "resolved": "https://registry.npmjs.org/archiver-utils/-/archiver-utils-2.1.0.tgz", 741 | "integrity": "sha512-bEL/yUb/fNNiNTuUz979Z0Yg5L+LzLxGJz8x79lYmR54fmTIb6ob/hNQgkQnIUDWIFjZVQwl9Xs356I6BAMHfw==", 742 | "dependencies": { 743 | "glob": "^7.1.4", 744 | "graceful-fs": "^4.2.0", 745 | "lazystream": "^1.0.0", 746 | "lodash.defaults": "^4.2.0", 747 | "lodash.difference": "^4.5.0", 748 | "lodash.flatten": "^4.4.0", 749 | "lodash.isplainobject": "^4.0.6", 750 | "lodash.union": "^4.6.0", 751 | "normalize-path": "^3.0.0", 752 | "readable-stream": "^2.0.0" 753 | }, 754 | "engines": { 755 | "node": ">= 6" 756 | } 757 | }, 758 | "node_modules/archiver-utils/node_modules/readable-stream": { 759 | "version": "2.3.8", 760 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", 761 | "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", 762 | "dependencies": { 763 | "core-util-is": "~1.0.0", 764 | "inherits": "~2.0.3", 765 | "isarray": "~1.0.0", 766 | "process-nextick-args": "~2.0.0", 767 | "safe-buffer": "~5.1.1", 768 | "string_decoder": "~1.1.1", 769 | "util-deprecate": "~1.0.1" 770 | } 771 | }, 772 | "node_modules/archiver-utils/node_modules/safe-buffer": { 773 | "version": "5.1.2", 774 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 775 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 776 | }, 777 | "node_modules/archiver-utils/node_modules/string_decoder": { 778 | "version": "1.1.1", 779 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 780 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 781 | "dependencies": { 782 | "safe-buffer": "~5.1.0" 783 | } 784 | }, 785 | "node_modules/async": { 786 | "version": "3.2.4", 787 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.4.tgz", 788 | "integrity": "sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ==" 789 | }, 790 | "node_modules/available-typed-arrays": { 791 | "version": "1.0.5", 792 | "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz", 793 | "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==", 794 | "engines": { 795 | "node": ">= 0.4" 796 | }, 797 | "funding": { 798 | "url": "https://github.com/sponsors/ljharb" 799 | } 800 | }, 801 | "node_modules/balanced-match": { 802 | "version": "1.0.2", 803 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 804 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 805 | }, 806 | "node_modules/base64-js": { 807 | "version": "1.5.1", 808 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 809 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 810 | "funding": [ 811 | { 812 | "type": "github", 813 | "url": "https://github.com/sponsors/feross" 814 | }, 815 | { 816 | "type": "patreon", 817 | "url": "https://www.patreon.com/feross" 818 | }, 819 | { 820 | "type": "consulting", 821 | "url": "https://feross.org/support" 822 | } 823 | ] 824 | }, 825 | "node_modules/binary-extensions": { 826 | "version": "2.2.0", 827 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 828 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 829 | "dev": true, 830 | "engines": { 831 | "node": ">=8" 832 | } 833 | }, 834 | "node_modules/bl": { 835 | "version": "4.1.0", 836 | "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz", 837 | "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==", 838 | "dependencies": { 839 | "buffer": "^5.5.0", 840 | "inherits": "^2.0.4", 841 | "readable-stream": "^3.4.0" 842 | } 843 | }, 844 | "node_modules/blake3-wasm": { 845 | "version": "2.1.5", 846 | "resolved": "https://registry.npmjs.org/blake3-wasm/-/blake3-wasm-2.1.5.tgz", 847 | "integrity": "sha512-F1+K8EbfOZE49dtoPtmxUQrpXaBIl3ICvasLh+nJta0xkz+9kF/7uet9fLnwKqhDrmj6g+6K3Tw9yQPUg2ka5g==", 848 | "dev": true 849 | }, 850 | "node_modules/brace-expansion": { 851 | "version": "1.1.11", 852 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 853 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 854 | "dependencies": { 855 | "balanced-match": "^1.0.0", 856 | "concat-map": "0.0.1" 857 | } 858 | }, 859 | "node_modules/braces": { 860 | "version": "3.0.2", 861 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 862 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 863 | "dev": true, 864 | "dependencies": { 865 | "fill-range": "^7.0.1" 866 | }, 867 | "engines": { 868 | "node": ">=8" 869 | } 870 | }, 871 | "node_modules/buffer": { 872 | "version": "5.7.1", 873 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", 874 | "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", 875 | "funding": [ 876 | { 877 | "type": "github", 878 | "url": "https://github.com/sponsors/feross" 879 | }, 880 | { 881 | "type": "patreon", 882 | "url": "https://www.patreon.com/feross" 883 | }, 884 | { 885 | "type": "consulting", 886 | "url": "https://feross.org/support" 887 | } 888 | ], 889 | "dependencies": { 890 | "base64-js": "^1.3.1", 891 | "ieee754": "^1.1.13" 892 | } 893 | }, 894 | "node_modules/buffer-crc32": { 895 | "version": "0.2.13", 896 | "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", 897 | "integrity": "sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==", 898 | "engines": { 899 | "node": "*" 900 | } 901 | }, 902 | "node_modules/buffer-from": { 903 | "version": "1.1.2", 904 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 905 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 906 | "dev": true 907 | }, 908 | "node_modules/builtins": { 909 | "version": "5.0.1", 910 | "resolved": "https://registry.npmjs.org/builtins/-/builtins-5.0.1.tgz", 911 | "integrity": "sha512-qwVpFEHNfhYJIzNRBvd2C1kyo6jz3ZSMPyyuR47OPdiKWlbYnZNyDWuyR175qDnAJLiCo5fBBqPb3RiXgWlkOQ==", 912 | "dev": true, 913 | "dependencies": { 914 | "semver": "^7.0.0" 915 | } 916 | }, 917 | "node_modules/busboy": { 918 | "version": "1.6.0", 919 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", 920 | "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", 921 | "dev": true, 922 | "dependencies": { 923 | "streamsearch": "^1.1.0" 924 | }, 925 | "engines": { 926 | "node": ">=10.16.0" 927 | } 928 | }, 929 | "node_modules/call-bind": { 930 | "version": "1.0.2", 931 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 932 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 933 | "dependencies": { 934 | "function-bind": "^1.1.1", 935 | "get-intrinsic": "^1.0.2" 936 | }, 937 | "funding": { 938 | "url": "https://github.com/sponsors/ljharb" 939 | } 940 | }, 941 | "node_modules/chokidar": { 942 | "version": "3.5.3", 943 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 944 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 945 | "dev": true, 946 | "funding": [ 947 | { 948 | "type": "individual", 949 | "url": "https://paulmillr.com/funding/" 950 | } 951 | ], 952 | "dependencies": { 953 | "anymatch": "~3.1.2", 954 | "braces": "~3.0.2", 955 | "glob-parent": "~5.1.2", 956 | "is-binary-path": "~2.1.0", 957 | "is-glob": "~4.0.1", 958 | "normalize-path": "~3.0.0", 959 | "readdirp": "~3.6.0" 960 | }, 961 | "engines": { 962 | "node": ">= 8.10.0" 963 | }, 964 | "optionalDependencies": { 965 | "fsevents": "~2.3.2" 966 | } 967 | }, 968 | "node_modules/compress-commons": { 969 | "version": "4.1.1", 970 | "resolved": "https://registry.npmjs.org/compress-commons/-/compress-commons-4.1.1.tgz", 971 | "integrity": "sha512-QLdDLCKNV2dtoTorqgxngQCMA+gWXkM/Nwu7FpeBhk/RdkzimqC3jueb/FDmaZeXh+uby1jkBqE3xArsLBE5wQ==", 972 | "dependencies": { 973 | "buffer-crc32": "^0.2.13", 974 | "crc32-stream": "^4.0.2", 975 | "normalize-path": "^3.0.0", 976 | "readable-stream": "^3.6.0" 977 | }, 978 | "engines": { 979 | "node": ">= 10" 980 | } 981 | }, 982 | "node_modules/concat-map": { 983 | "version": "0.0.1", 984 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 985 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" 986 | }, 987 | "node_modules/cookie": { 988 | "version": "0.4.2", 989 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz", 990 | "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==", 991 | "dev": true, 992 | "engines": { 993 | "node": ">= 0.6" 994 | } 995 | }, 996 | "node_modules/core-util-is": { 997 | "version": "1.0.3", 998 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 999 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==" 1000 | }, 1001 | "node_modules/crc-32": { 1002 | "version": "1.2.2", 1003 | "resolved": "https://registry.npmjs.org/crc-32/-/crc-32-1.2.2.tgz", 1004 | "integrity": "sha512-ROmzCKrTnOwybPcJApAA6WBWij23HVfGVNKqqrZpuyZOHqK2CwHSvpGuyt/UNNvaIjEd8X5IFGp4Mh+Ie1IHJQ==", 1005 | "bin": { 1006 | "crc32": "bin/crc32.njs" 1007 | }, 1008 | "engines": { 1009 | "node": ">=0.8" 1010 | } 1011 | }, 1012 | "node_modules/crc32-stream": { 1013 | "version": "4.0.2", 1014 | "resolved": "https://registry.npmjs.org/crc32-stream/-/crc32-stream-4.0.2.tgz", 1015 | "integrity": "sha512-DxFZ/Hk473b/muq1VJ///PMNLj0ZMnzye9thBpmjpJKCc5eMgB95aK8zCGrGfQ90cWo561Te6HK9D+j4KPdM6w==", 1016 | "dependencies": { 1017 | "crc-32": "^1.2.0", 1018 | "readable-stream": "^3.4.0" 1019 | }, 1020 | "engines": { 1021 | "node": ">= 10" 1022 | } 1023 | }, 1024 | "node_modules/cron-schedule": { 1025 | "version": "3.0.6", 1026 | "resolved": "https://registry.npmjs.org/cron-schedule/-/cron-schedule-3.0.6.tgz", 1027 | "integrity": "sha512-izfGgKyzzIyLaeb1EtZ3KbglkS6AKp9cv7LxmiyoOu+fXfol1tQDC0Cof0enVZGNtudTHW+3lfuW9ZkLQss4Wg==", 1028 | "dev": true 1029 | }, 1030 | "node_modules/cross-spawn": { 1031 | "version": "7.0.3", 1032 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1033 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1034 | "dev": true, 1035 | "dependencies": { 1036 | "path-key": "^3.1.0", 1037 | "shebang-command": "^2.0.0", 1038 | "which": "^2.0.1" 1039 | }, 1040 | "engines": { 1041 | "node": ">= 8" 1042 | } 1043 | }, 1044 | "node_modules/debug": { 1045 | "version": "4.3.4", 1046 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1047 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1048 | "dependencies": { 1049 | "ms": "2.1.2" 1050 | }, 1051 | "engines": { 1052 | "node": ">=6.0" 1053 | }, 1054 | "peerDependenciesMeta": { 1055 | "supports-color": { 1056 | "optional": true 1057 | } 1058 | } 1059 | }, 1060 | "node_modules/devtools-protocol": { 1061 | "version": "0.0.1019158", 1062 | "resolved": "https://registry.npmjs.org/devtools-protocol/-/devtools-protocol-0.0.1019158.tgz", 1063 | "integrity": "sha512-wvq+KscQ7/6spEV7czhnZc9RM/woz1AY+/Vpd8/h2HFMwJSdTliu7f/yr1A6vDdJfKICZsShqsYpEQbdhg8AFQ==" 1064 | }, 1065 | "node_modules/dotenv": { 1066 | "version": "10.0.0", 1067 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-10.0.0.tgz", 1068 | "integrity": "sha512-rlBi9d8jpv9Sf1klPjNfFAuWDjKLwTIJJ/VxtoTwIR6hnZxcEOQCZg2oIL3MWBYw5GpUDKOEnND7LXTbIpQ03Q==", 1069 | "dev": true, 1070 | "engines": { 1071 | "node": ">=10" 1072 | } 1073 | }, 1074 | "node_modules/emitter-component": { 1075 | "version": "1.1.1", 1076 | "resolved": "https://registry.npmjs.org/emitter-component/-/emitter-component-1.1.1.tgz", 1077 | "integrity": "sha512-G+mpdiAySMuB7kesVRLuyvYRqDmshB7ReKEVuyBPkzQlmiDiLrt7hHHIy4Aff552bgknVN7B2/d3lzhGO5dvpQ==" 1078 | }, 1079 | "node_modules/end-of-stream": { 1080 | "version": "1.4.4", 1081 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 1082 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 1083 | "dependencies": { 1084 | "once": "^1.4.0" 1085 | } 1086 | }, 1087 | "node_modules/esbuild": { 1088 | "version": "0.16.3", 1089 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.16.3.tgz", 1090 | "integrity": "sha512-71f7EjPWTiSguen8X/kxEpkAS7BFHwtQKisCDDV3Y4GLGWBaoSCyD5uXkaUew6JDzA9FEN1W23mdnSwW9kqCeg==", 1091 | "dev": true, 1092 | "hasInstallScript": true, 1093 | "bin": { 1094 | "esbuild": "bin/esbuild" 1095 | }, 1096 | "engines": { 1097 | "node": ">=12" 1098 | }, 1099 | "optionalDependencies": { 1100 | "@esbuild/android-arm": "0.16.3", 1101 | "@esbuild/android-arm64": "0.16.3", 1102 | "@esbuild/android-x64": "0.16.3", 1103 | "@esbuild/darwin-arm64": "0.16.3", 1104 | "@esbuild/darwin-x64": "0.16.3", 1105 | "@esbuild/freebsd-arm64": "0.16.3", 1106 | "@esbuild/freebsd-x64": "0.16.3", 1107 | "@esbuild/linux-arm": "0.16.3", 1108 | "@esbuild/linux-arm64": "0.16.3", 1109 | "@esbuild/linux-ia32": "0.16.3", 1110 | "@esbuild/linux-loong64": "0.16.3", 1111 | "@esbuild/linux-mips64el": "0.16.3", 1112 | "@esbuild/linux-ppc64": "0.16.3", 1113 | "@esbuild/linux-riscv64": "0.16.3", 1114 | "@esbuild/linux-s390x": "0.16.3", 1115 | "@esbuild/linux-x64": "0.16.3", 1116 | "@esbuild/netbsd-x64": "0.16.3", 1117 | "@esbuild/openbsd-x64": "0.16.3", 1118 | "@esbuild/sunos-x64": "0.16.3", 1119 | "@esbuild/win32-arm64": "0.16.3", 1120 | "@esbuild/win32-ia32": "0.16.3", 1121 | "@esbuild/win32-x64": "0.16.3" 1122 | } 1123 | }, 1124 | "node_modules/escape-string-regexp": { 1125 | "version": "4.0.0", 1126 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1127 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1128 | "dev": true, 1129 | "engines": { 1130 | "node": ">=10" 1131 | }, 1132 | "funding": { 1133 | "url": "https://github.com/sponsors/sindresorhus" 1134 | } 1135 | }, 1136 | "node_modules/estree-walker": { 1137 | "version": "0.6.1", 1138 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", 1139 | "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", 1140 | "dev": true 1141 | }, 1142 | "node_modules/events": { 1143 | "version": "3.3.0", 1144 | "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", 1145 | "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", 1146 | "engines": { 1147 | "node": ">=0.8.x" 1148 | } 1149 | }, 1150 | "node_modules/execa": { 1151 | "version": "6.1.0", 1152 | "resolved": "https://registry.npmjs.org/execa/-/execa-6.1.0.tgz", 1153 | "integrity": "sha512-QVWlX2e50heYJcCPG0iWtf8r0xjEYfz/OYLGDYH+IyjWezzPNxz63qNFOu0l4YftGWuizFVZHHs8PrLU5p2IDA==", 1154 | "dev": true, 1155 | "dependencies": { 1156 | "cross-spawn": "^7.0.3", 1157 | "get-stream": "^6.0.1", 1158 | "human-signals": "^3.0.1", 1159 | "is-stream": "^3.0.0", 1160 | "merge-stream": "^2.0.0", 1161 | "npm-run-path": "^5.1.0", 1162 | "onetime": "^6.0.0", 1163 | "signal-exit": "^3.0.7", 1164 | "strip-final-newline": "^3.0.0" 1165 | }, 1166 | "engines": { 1167 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 1168 | }, 1169 | "funding": { 1170 | "url": "https://github.com/sindresorhus/execa?sponsor=1" 1171 | } 1172 | }, 1173 | "node_modules/fill-range": { 1174 | "version": "7.0.1", 1175 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1176 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1177 | "dev": true, 1178 | "dependencies": { 1179 | "to-regex-range": "^5.0.1" 1180 | }, 1181 | "engines": { 1182 | "node": ">=8" 1183 | } 1184 | }, 1185 | "node_modules/for-each": { 1186 | "version": "0.3.3", 1187 | "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", 1188 | "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", 1189 | "dependencies": { 1190 | "is-callable": "^1.1.3" 1191 | } 1192 | }, 1193 | "node_modules/fs-constants": { 1194 | "version": "1.0.0", 1195 | "resolved": "https://registry.npmjs.org/fs-constants/-/fs-constants-1.0.0.tgz", 1196 | "integrity": "sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==" 1197 | }, 1198 | "node_modules/fs.realpath": { 1199 | "version": "1.0.0", 1200 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1201 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" 1202 | }, 1203 | "node_modules/fsevents": { 1204 | "version": "2.3.2", 1205 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1206 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1207 | "dev": true, 1208 | "hasInstallScript": true, 1209 | "optional": true, 1210 | "os": [ 1211 | "darwin" 1212 | ], 1213 | "engines": { 1214 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1215 | } 1216 | }, 1217 | "node_modules/function-bind": { 1218 | "version": "1.1.1", 1219 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1220 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 1221 | }, 1222 | "node_modules/get-intrinsic": { 1223 | "version": "1.2.1", 1224 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", 1225 | "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", 1226 | "dependencies": { 1227 | "function-bind": "^1.1.1", 1228 | "has": "^1.0.3", 1229 | "has-proto": "^1.0.1", 1230 | "has-symbols": "^1.0.3" 1231 | }, 1232 | "funding": { 1233 | "url": "https://github.com/sponsors/ljharb" 1234 | } 1235 | }, 1236 | "node_modules/get-stream": { 1237 | "version": "6.0.1", 1238 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 1239 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 1240 | "dev": true, 1241 | "engines": { 1242 | "node": ">=10" 1243 | }, 1244 | "funding": { 1245 | "url": "https://github.com/sponsors/sindresorhus" 1246 | } 1247 | }, 1248 | "node_modules/glob": { 1249 | "version": "7.2.3", 1250 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1251 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1252 | "dependencies": { 1253 | "fs.realpath": "^1.0.0", 1254 | "inflight": "^1.0.4", 1255 | "inherits": "2", 1256 | "minimatch": "^3.1.1", 1257 | "once": "^1.3.0", 1258 | "path-is-absolute": "^1.0.0" 1259 | }, 1260 | "engines": { 1261 | "node": "*" 1262 | }, 1263 | "funding": { 1264 | "url": "https://github.com/sponsors/isaacs" 1265 | } 1266 | }, 1267 | "node_modules/glob-parent": { 1268 | "version": "5.1.2", 1269 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1270 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1271 | "dev": true, 1272 | "dependencies": { 1273 | "is-glob": "^4.0.1" 1274 | }, 1275 | "engines": { 1276 | "node": ">= 6" 1277 | } 1278 | }, 1279 | "node_modules/gopd": { 1280 | "version": "1.0.1", 1281 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", 1282 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", 1283 | "dependencies": { 1284 | "get-intrinsic": "^1.1.3" 1285 | }, 1286 | "funding": { 1287 | "url": "https://github.com/sponsors/ljharb" 1288 | } 1289 | }, 1290 | "node_modules/graceful-fs": { 1291 | "version": "4.2.11", 1292 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 1293 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==" 1294 | }, 1295 | "node_modules/has": { 1296 | "version": "1.0.3", 1297 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1298 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1299 | "dependencies": { 1300 | "function-bind": "^1.1.1" 1301 | }, 1302 | "engines": { 1303 | "node": ">= 0.4.0" 1304 | } 1305 | }, 1306 | "node_modules/has-proto": { 1307 | "version": "1.0.1", 1308 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", 1309 | "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", 1310 | "engines": { 1311 | "node": ">= 0.4" 1312 | }, 1313 | "funding": { 1314 | "url": "https://github.com/sponsors/ljharb" 1315 | } 1316 | }, 1317 | "node_modules/has-symbols": { 1318 | "version": "1.0.3", 1319 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 1320 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 1321 | "engines": { 1322 | "node": ">= 0.4" 1323 | }, 1324 | "funding": { 1325 | "url": "https://github.com/sponsors/ljharb" 1326 | } 1327 | }, 1328 | "node_modules/has-tostringtag": { 1329 | "version": "1.0.0", 1330 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", 1331 | "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", 1332 | "dependencies": { 1333 | "has-symbols": "^1.0.2" 1334 | }, 1335 | "engines": { 1336 | "node": ">= 0.4" 1337 | }, 1338 | "funding": { 1339 | "url": "https://github.com/sponsors/ljharb" 1340 | } 1341 | }, 1342 | "node_modules/html-rewriter-wasm": { 1343 | "version": "0.4.1", 1344 | "resolved": "https://registry.npmjs.org/html-rewriter-wasm/-/html-rewriter-wasm-0.4.1.tgz", 1345 | "integrity": "sha512-lNovG8CMCCmcVB1Q7xggMSf7tqPCijZXaH4gL6iE8BFghdQCbaY5Met9i1x2Ex8m/cZHDUtXK9H6/znKamRP8Q==", 1346 | "dev": true 1347 | }, 1348 | "node_modules/http-cache-semantics": { 1349 | "version": "4.1.1", 1350 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz", 1351 | "integrity": "sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==", 1352 | "dev": true 1353 | }, 1354 | "node_modules/human-signals": { 1355 | "version": "3.0.1", 1356 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-3.0.1.tgz", 1357 | "integrity": "sha512-rQLskxnM/5OCldHo+wNXbpVgDn5A17CUoKX+7Sokwaknlq7CdSnphy0W39GU8dw59XiCXmFXDg4fRuckQRKewQ==", 1358 | "dev": true, 1359 | "engines": { 1360 | "node": ">=12.20.0" 1361 | } 1362 | }, 1363 | "node_modules/ieee754": { 1364 | "version": "1.2.1", 1365 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 1366 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", 1367 | "funding": [ 1368 | { 1369 | "type": "github", 1370 | "url": "https://github.com/sponsors/feross" 1371 | }, 1372 | { 1373 | "type": "patreon", 1374 | "url": "https://www.patreon.com/feross" 1375 | }, 1376 | { 1377 | "type": "consulting", 1378 | "url": "https://feross.org/support" 1379 | } 1380 | ] 1381 | }, 1382 | "node_modules/inflight": { 1383 | "version": "1.0.6", 1384 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1385 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1386 | "dependencies": { 1387 | "once": "^1.3.0", 1388 | "wrappy": "1" 1389 | } 1390 | }, 1391 | "node_modules/inherits": { 1392 | "version": "2.0.4", 1393 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1394 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1395 | }, 1396 | "node_modules/is-arguments": { 1397 | "version": "1.1.1", 1398 | "resolved": "https://registry.npmjs.org/is-arguments/-/is-arguments-1.1.1.tgz", 1399 | "integrity": "sha512-8Q7EARjzEnKpt/PCD7e1cgUS0a6X8u5tdSiMqXhojOdoV9TsMsiO+9VLC5vAmO8N7/GmXn7yjR8qnA6bVAEzfA==", 1400 | "dependencies": { 1401 | "call-bind": "^1.0.2", 1402 | "has-tostringtag": "^1.0.0" 1403 | }, 1404 | "engines": { 1405 | "node": ">= 0.4" 1406 | }, 1407 | "funding": { 1408 | "url": "https://github.com/sponsors/ljharb" 1409 | } 1410 | }, 1411 | "node_modules/is-binary-path": { 1412 | "version": "2.1.0", 1413 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1414 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1415 | "dev": true, 1416 | "dependencies": { 1417 | "binary-extensions": "^2.0.0" 1418 | }, 1419 | "engines": { 1420 | "node": ">=8" 1421 | } 1422 | }, 1423 | "node_modules/is-callable": { 1424 | "version": "1.2.7", 1425 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", 1426 | "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", 1427 | "engines": { 1428 | "node": ">= 0.4" 1429 | }, 1430 | "funding": { 1431 | "url": "https://github.com/sponsors/ljharb" 1432 | } 1433 | }, 1434 | "node_modules/is-extglob": { 1435 | "version": "2.1.1", 1436 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1437 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1438 | "dev": true, 1439 | "engines": { 1440 | "node": ">=0.10.0" 1441 | } 1442 | }, 1443 | "node_modules/is-generator-function": { 1444 | "version": "1.0.10", 1445 | "resolved": "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz", 1446 | "integrity": "sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==", 1447 | "dependencies": { 1448 | "has-tostringtag": "^1.0.0" 1449 | }, 1450 | "engines": { 1451 | "node": ">= 0.4" 1452 | }, 1453 | "funding": { 1454 | "url": "https://github.com/sponsors/ljharb" 1455 | } 1456 | }, 1457 | "node_modules/is-glob": { 1458 | "version": "4.0.3", 1459 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1460 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1461 | "dev": true, 1462 | "dependencies": { 1463 | "is-extglob": "^2.1.1" 1464 | }, 1465 | "engines": { 1466 | "node": ">=0.10.0" 1467 | } 1468 | }, 1469 | "node_modules/is-number": { 1470 | "version": "7.0.0", 1471 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1472 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1473 | "dev": true, 1474 | "engines": { 1475 | "node": ">=0.12.0" 1476 | } 1477 | }, 1478 | "node_modules/is-stream": { 1479 | "version": "3.0.0", 1480 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-3.0.0.tgz", 1481 | "integrity": "sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==", 1482 | "dev": true, 1483 | "engines": { 1484 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 1485 | }, 1486 | "funding": { 1487 | "url": "https://github.com/sponsors/sindresorhus" 1488 | } 1489 | }, 1490 | "node_modules/is-typed-array": { 1491 | "version": "1.1.10", 1492 | "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.10.tgz", 1493 | "integrity": "sha512-PJqgEHiWZvMpaFZ3uTc8kHPM4+4ADTlDniuQL7cU/UDA0Ql7F70yGfHph3cLNe+c9toaigv+DFzTJKhc2CtO6A==", 1494 | "dependencies": { 1495 | "available-typed-arrays": "^1.0.5", 1496 | "call-bind": "^1.0.2", 1497 | "for-each": "^0.3.3", 1498 | "gopd": "^1.0.1", 1499 | "has-tostringtag": "^1.0.0" 1500 | }, 1501 | "engines": { 1502 | "node": ">= 0.4" 1503 | }, 1504 | "funding": { 1505 | "url": "https://github.com/sponsors/ljharb" 1506 | } 1507 | }, 1508 | "node_modules/isarray": { 1509 | "version": "1.0.0", 1510 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1511 | "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==" 1512 | }, 1513 | "node_modules/isexe": { 1514 | "version": "2.0.0", 1515 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1516 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1517 | "dev": true 1518 | }, 1519 | "node_modules/kleur": { 1520 | "version": "4.1.5", 1521 | "resolved": "https://registry.npmjs.org/kleur/-/kleur-4.1.5.tgz", 1522 | "integrity": "sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ==", 1523 | "dev": true, 1524 | "engines": { 1525 | "node": ">=6" 1526 | } 1527 | }, 1528 | "node_modules/lazystream": { 1529 | "version": "1.0.1", 1530 | "resolved": "https://registry.npmjs.org/lazystream/-/lazystream-1.0.1.tgz", 1531 | "integrity": "sha512-b94GiNHQNy6JNTrt5w6zNyffMrNkXZb3KTkCZJb2V1xaEGCk093vkZ2jk3tpaeP33/OiXC+WvK9AxUebnf5nbw==", 1532 | "dependencies": { 1533 | "readable-stream": "^2.0.5" 1534 | }, 1535 | "engines": { 1536 | "node": ">= 0.6.3" 1537 | } 1538 | }, 1539 | "node_modules/lazystream/node_modules/readable-stream": { 1540 | "version": "2.3.8", 1541 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", 1542 | "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", 1543 | "dependencies": { 1544 | "core-util-is": "~1.0.0", 1545 | "inherits": "~2.0.3", 1546 | "isarray": "~1.0.0", 1547 | "process-nextick-args": "~2.0.0", 1548 | "safe-buffer": "~5.1.1", 1549 | "string_decoder": "~1.1.1", 1550 | "util-deprecate": "~1.0.1" 1551 | } 1552 | }, 1553 | "node_modules/lazystream/node_modules/safe-buffer": { 1554 | "version": "5.1.2", 1555 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1556 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1557 | }, 1558 | "node_modules/lazystream/node_modules/string_decoder": { 1559 | "version": "1.1.1", 1560 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1561 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1562 | "dependencies": { 1563 | "safe-buffer": "~5.1.0" 1564 | } 1565 | }, 1566 | "node_modules/lodash.defaults": { 1567 | "version": "4.2.0", 1568 | "resolved": "https://registry.npmjs.org/lodash.defaults/-/lodash.defaults-4.2.0.tgz", 1569 | "integrity": "sha512-qjxPLHd3r5DnsdGacqOMU6pb/avJzdh9tFX2ymgoZE27BmjXrNy/y4LoaiTeAb+O3gL8AfpJGtqfX/ae2leYYQ==" 1570 | }, 1571 | "node_modules/lodash.difference": { 1572 | "version": "4.5.0", 1573 | "resolved": "https://registry.npmjs.org/lodash.difference/-/lodash.difference-4.5.0.tgz", 1574 | "integrity": "sha512-dS2j+W26TQ7taQBGN8Lbbq04ssV3emRw4NY58WErlTO29pIqS0HmoT5aJ9+TUQ1N3G+JOZSji4eugsWwGp9yPA==" 1575 | }, 1576 | "node_modules/lodash.flatten": { 1577 | "version": "4.4.0", 1578 | "resolved": "https://registry.npmjs.org/lodash.flatten/-/lodash.flatten-4.4.0.tgz", 1579 | "integrity": "sha512-C5N2Z3DgnnKr0LOpv/hKCgKdb7ZZwafIrsesve6lmzvZIRZRGaZ/l6Q8+2W7NaT+ZwO3fFlSCzCzrDCFdJfZ4g==" 1580 | }, 1581 | "node_modules/lodash.isplainobject": { 1582 | "version": "4.0.6", 1583 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 1584 | "integrity": "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==" 1585 | }, 1586 | "node_modules/lodash.union": { 1587 | "version": "4.6.0", 1588 | "resolved": "https://registry.npmjs.org/lodash.union/-/lodash.union-4.6.0.tgz", 1589 | "integrity": "sha512-c4pB2CdGrGdjMKYLA+XiRDO7Y0PRQbm/Gzg8qMj+QH+pFVAoTp5sBpO0odL3FjoPCGjK96p6qsP+yQoiLoOBcw==" 1590 | }, 1591 | "node_modules/lru-cache": { 1592 | "version": "6.0.0", 1593 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1594 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1595 | "dev": true, 1596 | "dependencies": { 1597 | "yallist": "^4.0.0" 1598 | }, 1599 | "engines": { 1600 | "node": ">=10" 1601 | } 1602 | }, 1603 | "node_modules/magic-string": { 1604 | "version": "0.25.9", 1605 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz", 1606 | "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==", 1607 | "dev": true, 1608 | "dependencies": { 1609 | "sourcemap-codec": "^1.4.8" 1610 | } 1611 | }, 1612 | "node_modules/merge-stream": { 1613 | "version": "2.0.0", 1614 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 1615 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 1616 | "dev": true 1617 | }, 1618 | "node_modules/mime": { 1619 | "version": "3.0.0", 1620 | "resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz", 1621 | "integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==", 1622 | "dev": true, 1623 | "bin": { 1624 | "mime": "cli.js" 1625 | }, 1626 | "engines": { 1627 | "node": ">=10.0.0" 1628 | } 1629 | }, 1630 | "node_modules/mimic-fn": { 1631 | "version": "4.0.0", 1632 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", 1633 | "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==", 1634 | "dev": true, 1635 | "engines": { 1636 | "node": ">=12" 1637 | }, 1638 | "funding": { 1639 | "url": "https://github.com/sponsors/sindresorhus" 1640 | } 1641 | }, 1642 | "node_modules/miniflare": { 1643 | "version": "2.13.0", 1644 | "resolved": "https://registry.npmjs.org/miniflare/-/miniflare-2.13.0.tgz", 1645 | "integrity": "sha512-ayNhVa4a6bZiOuHtrPmOt4BCYcmW1fBQ/+qGL85smq1m2OBBm3aUs6f4ISf38xH8tk+qewgmAywetyVtn6KHPw==", 1646 | "dev": true, 1647 | "dependencies": { 1648 | "@miniflare/cache": "2.13.0", 1649 | "@miniflare/cli-parser": "2.13.0", 1650 | "@miniflare/core": "2.13.0", 1651 | "@miniflare/d1": "2.13.0", 1652 | "@miniflare/durable-objects": "2.13.0", 1653 | "@miniflare/html-rewriter": "2.13.0", 1654 | "@miniflare/http-server": "2.13.0", 1655 | "@miniflare/kv": "2.13.0", 1656 | "@miniflare/queues": "2.13.0", 1657 | "@miniflare/r2": "2.13.0", 1658 | "@miniflare/runner-vm": "2.13.0", 1659 | "@miniflare/scheduler": "2.13.0", 1660 | "@miniflare/shared": "2.13.0", 1661 | "@miniflare/sites": "2.13.0", 1662 | "@miniflare/storage-file": "2.13.0", 1663 | "@miniflare/storage-memory": "2.13.0", 1664 | "@miniflare/web-sockets": "2.13.0", 1665 | "kleur": "^4.1.4", 1666 | "semiver": "^1.1.0", 1667 | "source-map-support": "^0.5.20", 1668 | "undici": "5.20.0" 1669 | }, 1670 | "bin": { 1671 | "miniflare": "bootstrap.js" 1672 | }, 1673 | "engines": { 1674 | "node": ">=16.13" 1675 | }, 1676 | "peerDependencies": { 1677 | "@miniflare/storage-redis": "2.13.0", 1678 | "cron-schedule": "^3.0.4", 1679 | "ioredis": "^4.27.9" 1680 | }, 1681 | "peerDependenciesMeta": { 1682 | "@miniflare/storage-redis": { 1683 | "optional": true 1684 | }, 1685 | "cron-schedule": { 1686 | "optional": true 1687 | }, 1688 | "ioredis": { 1689 | "optional": true 1690 | } 1691 | } 1692 | }, 1693 | "node_modules/minimatch": { 1694 | "version": "3.1.2", 1695 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1696 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1697 | "dependencies": { 1698 | "brace-expansion": "^1.1.7" 1699 | }, 1700 | "engines": { 1701 | "node": "*" 1702 | } 1703 | }, 1704 | "node_modules/ms": { 1705 | "version": "2.1.2", 1706 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1707 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1708 | }, 1709 | "node_modules/mustache": { 1710 | "version": "4.2.0", 1711 | "resolved": "https://registry.npmjs.org/mustache/-/mustache-4.2.0.tgz", 1712 | "integrity": "sha512-71ippSywq5Yb7/tVYyGbkBggbU8H3u5Rz56fH60jGFgr8uHwxs+aSKeqmluIVzM0m0kB7xQjKS6qPfd0b2ZoqQ==", 1713 | "dev": true, 1714 | "bin": { 1715 | "mustache": "bin/mustache" 1716 | } 1717 | }, 1718 | "node_modules/nanoid": { 1719 | "version": "3.3.6", 1720 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz", 1721 | "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==", 1722 | "dev": true, 1723 | "funding": [ 1724 | { 1725 | "type": "github", 1726 | "url": "https://github.com/sponsors/ai" 1727 | } 1728 | ], 1729 | "bin": { 1730 | "nanoid": "bin/nanoid.cjs" 1731 | }, 1732 | "engines": { 1733 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1734 | } 1735 | }, 1736 | "node_modules/node-forge": { 1737 | "version": "1.3.1", 1738 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", 1739 | "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==", 1740 | "dev": true, 1741 | "engines": { 1742 | "node": ">= 6.13.0" 1743 | } 1744 | }, 1745 | "node_modules/normalize-path": { 1746 | "version": "3.0.0", 1747 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1748 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1749 | "engines": { 1750 | "node": ">=0.10.0" 1751 | } 1752 | }, 1753 | "node_modules/npm-run-path": { 1754 | "version": "5.1.0", 1755 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.1.0.tgz", 1756 | "integrity": "sha512-sJOdmRGrY2sjNTRMbSvluQqg+8X7ZK61yvzBEIDhz4f8z1TZFYABsqjjCBd/0PUNE9M6QDgHJXQkGUEm7Q+l9Q==", 1757 | "dev": true, 1758 | "dependencies": { 1759 | "path-key": "^4.0.0" 1760 | }, 1761 | "engines": { 1762 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 1763 | }, 1764 | "funding": { 1765 | "url": "https://github.com/sponsors/sindresorhus" 1766 | } 1767 | }, 1768 | "node_modules/npm-run-path/node_modules/path-key": { 1769 | "version": "4.0.0", 1770 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-4.0.0.tgz", 1771 | "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==", 1772 | "dev": true, 1773 | "engines": { 1774 | "node": ">=12" 1775 | }, 1776 | "funding": { 1777 | "url": "https://github.com/sponsors/sindresorhus" 1778 | } 1779 | }, 1780 | "node_modules/npx-import": { 1781 | "version": "1.1.4", 1782 | "resolved": "https://registry.npmjs.org/npx-import/-/npx-import-1.1.4.tgz", 1783 | "integrity": "sha512-3ShymTWOgqGyNlh5lMJAejLuIv3W1K3fbI5Ewc6YErZU3Sp0PqsNs8UIU1O8z5+KVl/Du5ag56Gza9vdorGEoA==", 1784 | "dev": true, 1785 | "dependencies": { 1786 | "execa": "^6.1.0", 1787 | "parse-package-name": "^1.0.0", 1788 | "semver": "^7.3.7", 1789 | "validate-npm-package-name": "^4.0.0" 1790 | } 1791 | }, 1792 | "node_modules/once": { 1793 | "version": "1.4.0", 1794 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1795 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1796 | "dependencies": { 1797 | "wrappy": "1" 1798 | } 1799 | }, 1800 | "node_modules/onetime": { 1801 | "version": "6.0.0", 1802 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz", 1803 | "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==", 1804 | "dev": true, 1805 | "dependencies": { 1806 | "mimic-fn": "^4.0.0" 1807 | }, 1808 | "engines": { 1809 | "node": ">=12" 1810 | }, 1811 | "funding": { 1812 | "url": "https://github.com/sponsors/sindresorhus" 1813 | } 1814 | }, 1815 | "node_modules/parse-package-name": { 1816 | "version": "1.0.0", 1817 | "resolved": "https://registry.npmjs.org/parse-package-name/-/parse-package-name-1.0.0.tgz", 1818 | "integrity": "sha512-kBeTUtcj+SkyfaW4+KBe0HtsloBJ/mKTPoxpVdA57GZiPerREsUWJOhVj9anXweFiJkm5y8FG1sxFZkZ0SN6wg==", 1819 | "dev": true 1820 | }, 1821 | "node_modules/path-is-absolute": { 1822 | "version": "1.0.1", 1823 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1824 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1825 | "engines": { 1826 | "node": ">=0.10.0" 1827 | } 1828 | }, 1829 | "node_modules/path-key": { 1830 | "version": "3.1.1", 1831 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1832 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1833 | "dev": true, 1834 | "engines": { 1835 | "node": ">=8" 1836 | } 1837 | }, 1838 | "node_modules/path-to-regexp": { 1839 | "version": "6.2.1", 1840 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz", 1841 | "integrity": "sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw==", 1842 | "dev": true 1843 | }, 1844 | "node_modules/picomatch": { 1845 | "version": "2.3.1", 1846 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1847 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1848 | "dev": true, 1849 | "engines": { 1850 | "node": ">=8.6" 1851 | }, 1852 | "funding": { 1853 | "url": "https://github.com/sponsors/jonschlinkert" 1854 | } 1855 | }, 1856 | "node_modules/process-nextick-args": { 1857 | "version": "2.0.1", 1858 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1859 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 1860 | }, 1861 | "node_modules/querystring": { 1862 | "version": "0.2.0", 1863 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", 1864 | "integrity": "sha512-X/xY82scca2tau62i9mDyU9K+I+djTMUsvwf7xnUX5GLvVzgJybOJf4Y6o9Zx3oJK/LSXg5tTZBjwzqVPaPO2g==", 1865 | "deprecated": "The querystring API is considered Legacy. new code should use the URLSearchParams API instead.", 1866 | "engines": { 1867 | "node": ">=0.4.x" 1868 | } 1869 | }, 1870 | "node_modules/readable-stream": { 1871 | "version": "3.6.2", 1872 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", 1873 | "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", 1874 | "dependencies": { 1875 | "inherits": "^2.0.3", 1876 | "string_decoder": "^1.1.1", 1877 | "util-deprecate": "^1.0.1" 1878 | }, 1879 | "engines": { 1880 | "node": ">= 6" 1881 | } 1882 | }, 1883 | "node_modules/readdir-glob": { 1884 | "version": "1.1.3", 1885 | "resolved": "https://registry.npmjs.org/readdir-glob/-/readdir-glob-1.1.3.tgz", 1886 | "integrity": "sha512-v05I2k7xN8zXvPD9N+z/uhXPaj0sUFCe2rcWZIpBsqxfP7xXFQ0tipAd/wjj1YxWyWtUS5IDJpOG82JKt2EAVA==", 1887 | "dependencies": { 1888 | "minimatch": "^5.1.0" 1889 | } 1890 | }, 1891 | "node_modules/readdir-glob/node_modules/brace-expansion": { 1892 | "version": "2.0.1", 1893 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1894 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1895 | "dependencies": { 1896 | "balanced-match": "^1.0.0" 1897 | } 1898 | }, 1899 | "node_modules/readdir-glob/node_modules/minimatch": { 1900 | "version": "5.1.6", 1901 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 1902 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 1903 | "dependencies": { 1904 | "brace-expansion": "^2.0.1" 1905 | }, 1906 | "engines": { 1907 | "node": ">=10" 1908 | } 1909 | }, 1910 | "node_modules/readdirp": { 1911 | "version": "3.6.0", 1912 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1913 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1914 | "dev": true, 1915 | "dependencies": { 1916 | "picomatch": "^2.2.1" 1917 | }, 1918 | "engines": { 1919 | "node": ">=8.10.0" 1920 | } 1921 | }, 1922 | "node_modules/robots-parser": { 1923 | "version": "3.0.1", 1924 | "resolved": "https://registry.npmjs.org/robots-parser/-/robots-parser-3.0.1.tgz", 1925 | "integrity": "sha512-s+pyvQeIKIZ0dx5iJiQk1tPLJAWln39+MI5jtM8wnyws+G5azk+dMnMX0qfbqNetKKNgcWWOdi0sfm+FbQbgdQ==", 1926 | "engines": { 1927 | "node": ">=10.0.0" 1928 | } 1929 | }, 1930 | "node_modules/rollup-plugin-inject": { 1931 | "version": "3.0.2", 1932 | "resolved": "https://registry.npmjs.org/rollup-plugin-inject/-/rollup-plugin-inject-3.0.2.tgz", 1933 | "integrity": "sha512-ptg9PQwzs3orn4jkgXJ74bfs5vYz1NCZlSQMBUA0wKcGp5i5pA1AO3fOUEte8enhGUC+iapTCzEWw2jEFFUO/w==", 1934 | "deprecated": "This package has been deprecated and is no longer maintained. Please use @rollup/plugin-inject.", 1935 | "dev": true, 1936 | "dependencies": { 1937 | "estree-walker": "^0.6.1", 1938 | "magic-string": "^0.25.3", 1939 | "rollup-pluginutils": "^2.8.1" 1940 | } 1941 | }, 1942 | "node_modules/rollup-plugin-node-polyfills": { 1943 | "version": "0.2.1", 1944 | "resolved": "https://registry.npmjs.org/rollup-plugin-node-polyfills/-/rollup-plugin-node-polyfills-0.2.1.tgz", 1945 | "integrity": "sha512-4kCrKPTJ6sK4/gLL/U5QzVT8cxJcofO0OU74tnB19F40cmuAKSzH5/siithxlofFEjwvw1YAhPmbvGNA6jEroA==", 1946 | "dev": true, 1947 | "dependencies": { 1948 | "rollup-plugin-inject": "^3.0.0" 1949 | } 1950 | }, 1951 | "node_modules/rollup-pluginutils": { 1952 | "version": "2.8.2", 1953 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", 1954 | "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", 1955 | "dev": true, 1956 | "dependencies": { 1957 | "estree-walker": "^0.6.1" 1958 | } 1959 | }, 1960 | "node_modules/safe-buffer": { 1961 | "version": "5.2.1", 1962 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1963 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1964 | "funding": [ 1965 | { 1966 | "type": "github", 1967 | "url": "https://github.com/sponsors/feross" 1968 | }, 1969 | { 1970 | "type": "patreon", 1971 | "url": "https://www.patreon.com/feross" 1972 | }, 1973 | { 1974 | "type": "consulting", 1975 | "url": "https://feross.org/support" 1976 | } 1977 | ] 1978 | }, 1979 | "node_modules/selfsigned": { 1980 | "version": "2.1.1", 1981 | "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.1.1.tgz", 1982 | "integrity": "sha512-GSL3aowiF7wa/WtSFwnUrludWFoNhftq8bUkH9pkzjpN2XSPOAYEgg6e0sS9s0rZwgJzJiQRPU18A6clnoW5wQ==", 1983 | "dev": true, 1984 | "dependencies": { 1985 | "node-forge": "^1" 1986 | }, 1987 | "engines": { 1988 | "node": ">=10" 1989 | } 1990 | }, 1991 | "node_modules/semiver": { 1992 | "version": "1.1.0", 1993 | "resolved": "https://registry.npmjs.org/semiver/-/semiver-1.1.0.tgz", 1994 | "integrity": "sha512-QNI2ChmuioGC1/xjyYwyZYADILWyW6AmS1UH6gDj/SFUUUS4MBAWs/7mxnkRPc/F4iHezDP+O8t0dO8WHiEOdg==", 1995 | "dev": true, 1996 | "engines": { 1997 | "node": ">=6" 1998 | } 1999 | }, 2000 | "node_modules/semver": { 2001 | "version": "7.5.1", 2002 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.1.tgz", 2003 | "integrity": "sha512-Wvss5ivl8TMRZXXESstBA4uR5iXgEN/VC5/sOcuXdVLzcdkz4HWetIoRfG5gb5X+ij/G9rw9YoGn3QoQ8OCSpw==", 2004 | "dev": true, 2005 | "dependencies": { 2006 | "lru-cache": "^6.0.0" 2007 | }, 2008 | "bin": { 2009 | "semver": "bin/semver.js" 2010 | }, 2011 | "engines": { 2012 | "node": ">=10" 2013 | } 2014 | }, 2015 | "node_modules/set-cookie-parser": { 2016 | "version": "2.6.0", 2017 | "resolved": "https://registry.npmjs.org/set-cookie-parser/-/set-cookie-parser-2.6.0.tgz", 2018 | "integrity": "sha512-RVnVQxTXuerk653XfuliOxBP81Sf0+qfQE73LIYKcyMYHG94AuH0kgrQpRDuTZnSmjpysHmzxJXKNfa6PjFhyQ==", 2019 | "dev": true 2020 | }, 2021 | "node_modules/shebang-command": { 2022 | "version": "2.0.0", 2023 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2024 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2025 | "dev": true, 2026 | "dependencies": { 2027 | "shebang-regex": "^3.0.0" 2028 | }, 2029 | "engines": { 2030 | "node": ">=8" 2031 | } 2032 | }, 2033 | "node_modules/shebang-regex": { 2034 | "version": "3.0.0", 2035 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2036 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2037 | "dev": true, 2038 | "engines": { 2039 | "node": ">=8" 2040 | } 2041 | }, 2042 | "node_modules/signal-exit": { 2043 | "version": "3.0.7", 2044 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 2045 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 2046 | "dev": true 2047 | }, 2048 | "node_modules/source-map": { 2049 | "version": "0.7.4", 2050 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", 2051 | "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", 2052 | "dev": true, 2053 | "engines": { 2054 | "node": ">= 8" 2055 | } 2056 | }, 2057 | "node_modules/source-map-support": { 2058 | "version": "0.5.21", 2059 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 2060 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 2061 | "dev": true, 2062 | "dependencies": { 2063 | "buffer-from": "^1.0.0", 2064 | "source-map": "^0.6.0" 2065 | } 2066 | }, 2067 | "node_modules/source-map-support/node_modules/source-map": { 2068 | "version": "0.6.1", 2069 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2070 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2071 | "dev": true, 2072 | "engines": { 2073 | "node": ">=0.10.0" 2074 | } 2075 | }, 2076 | "node_modules/sourcemap-codec": { 2077 | "version": "1.4.8", 2078 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 2079 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 2080 | "deprecated": "Please use @jridgewell/sourcemap-codec instead", 2081 | "dev": true 2082 | }, 2083 | "node_modules/stack-trace": { 2084 | "version": "0.0.10", 2085 | "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz", 2086 | "integrity": "sha512-KGzahc7puUKkzyMt+IqAep+TVNbKP+k2Lmwhub39m1AsTSkaDutx56aDCo+HLDzf/D26BIHTJWNiTG1KAJiQCg==", 2087 | "dev": true, 2088 | "engines": { 2089 | "node": "*" 2090 | } 2091 | }, 2092 | "node_modules/stream": { 2093 | "version": "0.0.2", 2094 | "resolved": "https://registry.npmjs.org/stream/-/stream-0.0.2.tgz", 2095 | "integrity": "sha512-gCq3NDI2P35B2n6t76YJuOp7d6cN/C7Rt0577l91wllh0sY9ZBuw9KaSGqH/b0hzn3CWWJbpbW0W0WvQ1H/Q7g==", 2096 | "dependencies": { 2097 | "emitter-component": "^1.1.1" 2098 | } 2099 | }, 2100 | "node_modules/streamsearch": { 2101 | "version": "1.1.0", 2102 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", 2103 | "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", 2104 | "dev": true, 2105 | "engines": { 2106 | "node": ">=10.0.0" 2107 | } 2108 | }, 2109 | "node_modules/string_decoder": { 2110 | "version": "1.3.0", 2111 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 2112 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 2113 | "dependencies": { 2114 | "safe-buffer": "~5.2.0" 2115 | } 2116 | }, 2117 | "node_modules/strip-final-newline": { 2118 | "version": "3.0.0", 2119 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-3.0.0.tgz", 2120 | "integrity": "sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==", 2121 | "dev": true, 2122 | "engines": { 2123 | "node": ">=12" 2124 | }, 2125 | "funding": { 2126 | "url": "https://github.com/sponsors/sindresorhus" 2127 | } 2128 | }, 2129 | "node_modules/tar-stream": { 2130 | "version": "2.2.0", 2131 | "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-2.2.0.tgz", 2132 | "integrity": "sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ==", 2133 | "dependencies": { 2134 | "bl": "^4.0.3", 2135 | "end-of-stream": "^1.4.1", 2136 | "fs-constants": "^1.0.0", 2137 | "inherits": "^2.0.3", 2138 | "readable-stream": "^3.1.1" 2139 | }, 2140 | "engines": { 2141 | "node": ">=6" 2142 | } 2143 | }, 2144 | "node_modules/to-regex-range": { 2145 | "version": "5.0.1", 2146 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2147 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2148 | "dev": true, 2149 | "dependencies": { 2150 | "is-number": "^7.0.0" 2151 | }, 2152 | "engines": { 2153 | "node": ">=8.0" 2154 | } 2155 | }, 2156 | "node_modules/typescript": { 2157 | "version": "5.1.3", 2158 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.1.3.tgz", 2159 | "integrity": "sha512-XH627E9vkeqhlZFQuL+UsyAXEnibT0kWR2FWONlr4sTjvxyJYnyefgrkyECLzM5NenmKzRAy2rR/OlYLA1HkZw==", 2160 | "dev": true, 2161 | "bin": { 2162 | "tsc": "bin/tsc", 2163 | "tsserver": "bin/tsserver" 2164 | }, 2165 | "engines": { 2166 | "node": ">=14.17" 2167 | } 2168 | }, 2169 | "node_modules/undici": { 2170 | "version": "5.20.0", 2171 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.20.0.tgz", 2172 | "integrity": "sha512-J3j60dYzuo6Eevbawwp1sdg16k5Tf768bxYK4TUJRH7cBM4kFCbf3mOnM/0E3vQYXvpxITbbWmBafaDbxLDz3g==", 2173 | "dev": true, 2174 | "dependencies": { 2175 | "busboy": "^1.6.0" 2176 | }, 2177 | "engines": { 2178 | "node": ">=12.18" 2179 | } 2180 | }, 2181 | "node_modules/url": { 2182 | "version": "0.11.0", 2183 | "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", 2184 | "integrity": "sha512-kbailJa29QrtXnxgq+DdCEGlbTeYM2eJUxsz6vjZavrCYPMIFHMKQmSKYAIuUK2i7hgPm28a8piX5NTUtM/LKQ==", 2185 | "dependencies": { 2186 | "punycode": "1.3.2", 2187 | "querystring": "0.2.0" 2188 | } 2189 | }, 2190 | "node_modules/url/node_modules/punycode": { 2191 | "version": "1.3.2", 2192 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", 2193 | "integrity": "sha512-RofWgt/7fL5wP1Y7fxE7/EmTLzQVnB0ycyibJ0OOHIlJqTNzglYFxVwETOcIoJqJmpDXJ9xImDv+Fq34F/d4Dw==" 2194 | }, 2195 | "node_modules/urlpattern-polyfill": { 2196 | "version": "4.0.3", 2197 | "resolved": "https://registry.npmjs.org/urlpattern-polyfill/-/urlpattern-polyfill-4.0.3.tgz", 2198 | "integrity": "sha512-DOE84vZT2fEcl9gqCUTcnAw5ZY5Id55ikUcziSUntuEFL3pRvavg5kwDmTEUJkeCHInTlV/HexFomgYnzO5kdQ==", 2199 | "dev": true 2200 | }, 2201 | "node_modules/util": { 2202 | "version": "0.12.5", 2203 | "resolved": "https://registry.npmjs.org/util/-/util-0.12.5.tgz", 2204 | "integrity": "sha512-kZf/K6hEIrWHI6XqOFUiiMa+79wE/D8Q+NCNAWclkyg3b4d2k7s0QGepNjiABc+aR3N1PAyHL7p6UcLY6LmrnA==", 2205 | "dependencies": { 2206 | "inherits": "^2.0.3", 2207 | "is-arguments": "^1.0.4", 2208 | "is-generator-function": "^1.0.7", 2209 | "is-typed-array": "^1.1.3", 2210 | "which-typed-array": "^1.1.2" 2211 | } 2212 | }, 2213 | "node_modules/util-deprecate": { 2214 | "version": "1.0.2", 2215 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2216 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" 2217 | }, 2218 | "node_modules/validate-npm-package-name": { 2219 | "version": "4.0.0", 2220 | "resolved": "https://registry.npmjs.org/validate-npm-package-name/-/validate-npm-package-name-4.0.0.tgz", 2221 | "integrity": "sha512-mzR0L8ZDktZjpX4OB46KT+56MAhl4EIazWP/+G/HPGuvfdaqg4YsCdtOm6U9+LOFyYDoh4dpnpxZRB9MQQns5Q==", 2222 | "dev": true, 2223 | "dependencies": { 2224 | "builtins": "^5.0.0" 2225 | }, 2226 | "engines": { 2227 | "node": "^12.13.0 || ^14.15.0 || >=16.0.0" 2228 | } 2229 | }, 2230 | "node_modules/which": { 2231 | "version": "2.0.2", 2232 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2233 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2234 | "dev": true, 2235 | "dependencies": { 2236 | "isexe": "^2.0.0" 2237 | }, 2238 | "bin": { 2239 | "node-which": "bin/node-which" 2240 | }, 2241 | "engines": { 2242 | "node": ">= 8" 2243 | } 2244 | }, 2245 | "node_modules/which-typed-array": { 2246 | "version": "1.1.9", 2247 | "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.9.tgz", 2248 | "integrity": "sha512-w9c4xkx6mPidwp7180ckYWfMmvxpjlZuIudNtDf4N/tTAUB8VJbX25qZoAsrtGuYNnGw3pa0AXgbGKRB8/EceA==", 2249 | "dependencies": { 2250 | "available-typed-arrays": "^1.0.5", 2251 | "call-bind": "^1.0.2", 2252 | "for-each": "^0.3.3", 2253 | "gopd": "^1.0.1", 2254 | "has-tostringtag": "^1.0.0", 2255 | "is-typed-array": "^1.1.10" 2256 | }, 2257 | "engines": { 2258 | "node": ">= 0.4" 2259 | }, 2260 | "funding": { 2261 | "url": "https://github.com/sponsors/ljharb" 2262 | } 2263 | }, 2264 | "node_modules/wrangler": { 2265 | "version": "2.20.0", 2266 | "resolved": "https://registry.npmjs.org/wrangler/-/wrangler-2.20.0.tgz", 2267 | "integrity": "sha512-UdKJ2LD7qgDxDvll/GkR1HnRP+bcEdqi/HJjDI+7eF4lv9V940jmm3orxCkSEosGyE14q0q6dBRM95+fBI8tdQ==", 2268 | "dev": true, 2269 | "dependencies": { 2270 | "@cloudflare/kv-asset-handler": "^0.2.0", 2271 | "@esbuild-plugins/node-globals-polyfill": "^0.1.1", 2272 | "@esbuild-plugins/node-modules-polyfill": "^0.1.4", 2273 | "@miniflare/core": "2.13.0", 2274 | "@miniflare/d1": "2.13.0", 2275 | "@miniflare/durable-objects": "2.13.0", 2276 | "blake3-wasm": "^2.1.5", 2277 | "chokidar": "^3.5.3", 2278 | "esbuild": "0.16.3", 2279 | "miniflare": "2.13.0", 2280 | "nanoid": "^3.3.3", 2281 | "path-to-regexp": "^6.2.0", 2282 | "selfsigned": "^2.0.1", 2283 | "source-map": "^0.7.4", 2284 | "xxhash-wasm": "^1.0.1" 2285 | }, 2286 | "bin": { 2287 | "wrangler": "bin/wrangler.js", 2288 | "wrangler2": "bin/wrangler.js" 2289 | }, 2290 | "engines": { 2291 | "node": ">=16.13.0" 2292 | }, 2293 | "optionalDependencies": { 2294 | "fsevents": "~2.3.2" 2295 | } 2296 | }, 2297 | "node_modules/wrappy": { 2298 | "version": "1.0.2", 2299 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2300 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" 2301 | }, 2302 | "node_modules/ws": { 2303 | "version": "8.13.0", 2304 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.13.0.tgz", 2305 | "integrity": "sha512-x9vcZYTrFPC7aSIbj7sRCYo7L/Xb8Iy+pW0ng0wt2vCJv7M9HOMy0UoN3rr+IFC7hb7vXoqS+P9ktyLLLhO+LA==", 2306 | "dev": true, 2307 | "engines": { 2308 | "node": ">=10.0.0" 2309 | }, 2310 | "peerDependencies": { 2311 | "bufferutil": "^4.0.1", 2312 | "utf-8-validate": ">=5.0.2" 2313 | }, 2314 | "peerDependenciesMeta": { 2315 | "bufferutil": { 2316 | "optional": true 2317 | }, 2318 | "utf-8-validate": { 2319 | "optional": true 2320 | } 2321 | } 2322 | }, 2323 | "node_modules/xxhash-wasm": { 2324 | "version": "1.0.2", 2325 | "resolved": "https://registry.npmjs.org/xxhash-wasm/-/xxhash-wasm-1.0.2.tgz", 2326 | "integrity": "sha512-ibF0Or+FivM9lNrg+HGJfVX8WJqgo+kCLDc4vx6xMeTce7Aj+DLttKbxxRR/gNLSAelRc1omAPlJ77N/Jem07A==", 2327 | "dev": true 2328 | }, 2329 | "node_modules/yallist": { 2330 | "version": "4.0.0", 2331 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2332 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2333 | "dev": true 2334 | }, 2335 | "node_modules/youch": { 2336 | "version": "2.2.2", 2337 | "resolved": "https://registry.npmjs.org/youch/-/youch-2.2.2.tgz", 2338 | "integrity": "sha512-/FaCeG3GkuJwaMR34GHVg0l8jCbafZLHiFowSjqLlqhC6OMyf2tPJBu8UirF7/NI9X/R5ai4QfEKUCOxMAGxZQ==", 2339 | "dev": true, 2340 | "dependencies": { 2341 | "@types/stack-trace": "0.0.29", 2342 | "cookie": "^0.4.1", 2343 | "mustache": "^4.2.0", 2344 | "stack-trace": "0.0.10" 2345 | } 2346 | }, 2347 | "node_modules/zip-stream": { 2348 | "version": "4.1.0", 2349 | "resolved": "https://registry.npmjs.org/zip-stream/-/zip-stream-4.1.0.tgz", 2350 | "integrity": "sha512-zshzwQW7gG7hjpBlgeQP9RuyPGNxvJdzR8SUM3QhxCnLjWN2E7j3dOvpeDcQoETfHx0urRS7EtmVToql7YpU4A==", 2351 | "dependencies": { 2352 | "archiver-utils": "^2.1.0", 2353 | "compress-commons": "^4.1.0", 2354 | "readable-stream": "^3.6.0" 2355 | }, 2356 | "engines": { 2357 | "node": ">= 10" 2358 | } 2359 | } 2360 | }, 2361 | "dependencies": { 2362 | "@cloudflare/kv-asset-handler": { 2363 | "version": "0.2.0", 2364 | "resolved": "https://registry.npmjs.org/@cloudflare/kv-asset-handler/-/kv-asset-handler-0.2.0.tgz", 2365 | "integrity": "sha512-MVbXLbTcAotOPUj0pAMhVtJ+3/kFkwJqc5qNOleOZTv6QkZZABDMS21dSrSlVswEHwrpWC03e4fWytjqKvuE2A==", 2366 | "dev": true, 2367 | "requires": { 2368 | "mime": "^3.0.0" 2369 | } 2370 | }, 2371 | "@cloudflare/puppeteer": { 2372 | "version": "0.0.2-alpha", 2373 | "resolved": "https://registry.npmjs.org/@cloudflare/puppeteer/-/puppeteer-0.0.2-alpha.tgz", 2374 | "integrity": "sha512-TIMKvtPdyctv/GK405a6LgkJ/bSkT4MAJAHhR3cpmhfxh7Ohti9GDgusdyycAcYASQIWDmucQunMYQwEh81iwg==", 2375 | "requires": { 2376 | "debug": "4.3.4", 2377 | "devtools-protocol": "0.0.1019158", 2378 | "events": "3.3.0", 2379 | "stream": "0.0.2", 2380 | "url": "0.11.0", 2381 | "util": "0.12.5" 2382 | } 2383 | }, 2384 | "@cloudflare/workers-types": { 2385 | "version": "4.20230518.0", 2386 | "resolved": "https://registry.npmjs.org/@cloudflare/workers-types/-/workers-types-4.20230518.0.tgz", 2387 | "integrity": "sha512-A0w1V+5SUawGaaPRlhFhSC/SCDT9oQG8TMoWOKFLA4qbqagELqEAFD4KySBIkeVOvCBLT1DZSYBMCxbXddl0kw==", 2388 | "dev": true 2389 | }, 2390 | "@esbuild-plugins/node-globals-polyfill": { 2391 | "version": "0.1.1", 2392 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-globals-polyfill/-/node-globals-polyfill-0.1.1.tgz", 2393 | "integrity": "sha512-MR0oAA+mlnJWrt1RQVQ+4VYuRJW/P2YmRTv1AsplObyvuBMnPHiizUF95HHYiSsMGLhyGtWufaq2XQg6+iurBg==", 2394 | "dev": true, 2395 | "requires": {} 2396 | }, 2397 | "@esbuild-plugins/node-modules-polyfill": { 2398 | "version": "0.1.4", 2399 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-modules-polyfill/-/node-modules-polyfill-0.1.4.tgz", 2400 | "integrity": "sha512-uZbcXi0zbmKC/050p3gJnne5Qdzw8vkXIv+c2BW0Lsc1ji1SkrxbKPUy5Efr0blbTu1SL8w4eyfpnSdPg3G0Qg==", 2401 | "dev": true, 2402 | "requires": { 2403 | "escape-string-regexp": "^4.0.0", 2404 | "rollup-plugin-node-polyfills": "^0.2.1" 2405 | } 2406 | }, 2407 | "@esbuild/android-arm": { 2408 | "version": "0.16.3", 2409 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.16.3.tgz", 2410 | "integrity": "sha512-mueuEoh+s1eRbSJqq9KNBQwI4QhQV6sRXIfTyLXSHGMpyew61rOK4qY21uKbXl1iBoMb0AdL1deWFCQVlN2qHA==", 2411 | "dev": true, 2412 | "optional": true 2413 | }, 2414 | "@esbuild/android-arm64": { 2415 | "version": "0.16.3", 2416 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.16.3.tgz", 2417 | "integrity": "sha512-RolFVeinkeraDvN/OoRf1F/lP0KUfGNb5jxy/vkIMeRRChkrX/HTYN6TYZosRJs3a1+8wqpxAo5PI5hFmxyPRg==", 2418 | "dev": true, 2419 | "optional": true 2420 | }, 2421 | "@esbuild/android-x64": { 2422 | "version": "0.16.3", 2423 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.16.3.tgz", 2424 | "integrity": "sha512-SFpTUcIT1bIJuCCBMCQWq1bL2gPTjWoLZdjmIhjdcQHaUfV41OQfho6Ici5uvvkMmZRXIUGpM3GxysP/EU7ifQ==", 2425 | "dev": true, 2426 | "optional": true 2427 | }, 2428 | "@esbuild/darwin-arm64": { 2429 | "version": "0.16.3", 2430 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.16.3.tgz", 2431 | "integrity": "sha512-DO8WykMyB+N9mIDfI/Hug70Dk1KipavlGAecxS3jDUwAbTpDXj0Lcwzw9svkhxfpCagDmpaTMgxWK8/C/XcXvw==", 2432 | "dev": true, 2433 | "optional": true 2434 | }, 2435 | "@esbuild/darwin-x64": { 2436 | "version": "0.16.3", 2437 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.16.3.tgz", 2438 | "integrity": "sha512-uEqZQ2omc6BvWqdCiyZ5+XmxuHEi1SPzpVxXCSSV2+Sh7sbXbpeNhHIeFrIpRjAs0lI1FmA1iIOxFozKBhKgRQ==", 2439 | "dev": true, 2440 | "optional": true 2441 | }, 2442 | "@esbuild/freebsd-arm64": { 2443 | "version": "0.16.3", 2444 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.16.3.tgz", 2445 | "integrity": "sha512-nJansp3sSXakNkOD5i5mIz2Is/HjzIhFs49b1tjrPrpCmwgBmH9SSzhC/Z1UqlkivqMYkhfPwMw1dGFUuwmXhw==", 2446 | "dev": true, 2447 | "optional": true 2448 | }, 2449 | "@esbuild/freebsd-x64": { 2450 | "version": "0.16.3", 2451 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.16.3.tgz", 2452 | "integrity": "sha512-TfoDzLw+QHfc4a8aKtGSQ96Wa+6eimljjkq9HKR0rHlU83vw8aldMOUSJTUDxbcUdcgnJzPaX8/vGWm7vyV7ug==", 2453 | "dev": true, 2454 | "optional": true 2455 | }, 2456 | "@esbuild/linux-arm": { 2457 | "version": "0.16.3", 2458 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.16.3.tgz", 2459 | "integrity": "sha512-VwswmSYwVAAq6LysV59Fyqk3UIjbhuc6wb3vEcJ7HEJUtFuLK9uXWuFoH1lulEbE4+5GjtHi3MHX+w1gNHdOWQ==", 2460 | "dev": true, 2461 | "optional": true 2462 | }, 2463 | "@esbuild/linux-arm64": { 2464 | "version": "0.16.3", 2465 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.16.3.tgz", 2466 | "integrity": "sha512-7I3RlsnxEFCHVZNBLb2w7unamgZ5sVwO0/ikE2GaYvYuUQs9Qte/w7TqWcXHtCwxvZx/2+F97ndiUQAWs47ZfQ==", 2467 | "dev": true, 2468 | "optional": true 2469 | }, 2470 | "@esbuild/linux-ia32": { 2471 | "version": "0.16.3", 2472 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.16.3.tgz", 2473 | "integrity": "sha512-X8FDDxM9cqda2rJE+iblQhIMYY49LfvW4kaEjoFbTTQ4Go8G96Smj2w3BRTwA8IHGoi9dPOPGAX63dhuv19UqA==", 2474 | "dev": true, 2475 | "optional": true 2476 | }, 2477 | "@esbuild/linux-loong64": { 2478 | "version": "0.16.3", 2479 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.16.3.tgz", 2480 | "integrity": "sha512-hIbeejCOyO0X9ujfIIOKjBjNAs9XD/YdJ9JXAy1lHA+8UXuOqbFe4ErMCqMr8dhlMGBuvcQYGF7+kO7waj2KHw==", 2481 | "dev": true, 2482 | "optional": true 2483 | }, 2484 | "@esbuild/linux-mips64el": { 2485 | "version": "0.16.3", 2486 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.16.3.tgz", 2487 | "integrity": "sha512-znFRzICT/V8VZQMt6rjb21MtAVJv/3dmKRMlohlShrbVXdBuOdDrGb+C2cZGQAR8RFyRe7HS6klmHq103WpmVw==", 2488 | "dev": true, 2489 | "optional": true 2490 | }, 2491 | "@esbuild/linux-ppc64": { 2492 | "version": "0.16.3", 2493 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.16.3.tgz", 2494 | "integrity": "sha512-EV7LuEybxhXrVTDpbqWF2yehYRNz5e5p+u3oQUS2+ZFpknyi1NXxr8URk4ykR8Efm7iu04//4sBg249yNOwy5Q==", 2495 | "dev": true, 2496 | "optional": true 2497 | }, 2498 | "@esbuild/linux-riscv64": { 2499 | "version": "0.16.3", 2500 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.16.3.tgz", 2501 | "integrity": "sha512-uDxqFOcLzFIJ+r/pkTTSE9lsCEaV/Y6rMlQjUI9BkzASEChYL/aSQjZjchtEmdnVxDKETnUAmsaZ4pqK1eE5BQ==", 2502 | "dev": true, 2503 | "optional": true 2504 | }, 2505 | "@esbuild/linux-s390x": { 2506 | "version": "0.16.3", 2507 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.16.3.tgz", 2508 | "integrity": "sha512-NbeREhzSxYwFhnCAQOQZmajsPYtX71Ufej3IQ8W2Gxskfz9DK58ENEju4SbpIj48VenktRASC52N5Fhyf/aliQ==", 2509 | "dev": true, 2510 | "optional": true 2511 | }, 2512 | "@esbuild/linux-x64": { 2513 | "version": "0.16.3", 2514 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.16.3.tgz", 2515 | "integrity": "sha512-SDiG0nCixYO9JgpehoKgScwic7vXXndfasjnD5DLbp1xltANzqZ425l7LSdHynt19UWOcDjG9wJJzSElsPvk0w==", 2516 | "dev": true, 2517 | "optional": true 2518 | }, 2519 | "@esbuild/netbsd-x64": { 2520 | "version": "0.16.3", 2521 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.16.3.tgz", 2522 | "integrity": "sha512-AzbsJqiHEq1I/tUvOfAzCY15h4/7Ivp3ff/o1GpP16n48JMNAtbW0qui2WCgoIZArEHD0SUQ95gvR0oSO7ZbdA==", 2523 | "dev": true, 2524 | "optional": true 2525 | }, 2526 | "@esbuild/openbsd-x64": { 2527 | "version": "0.16.3", 2528 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.16.3.tgz", 2529 | "integrity": "sha512-gSABi8qHl8k3Cbi/4toAzHiykuBuWLZs43JomTcXkjMZVkp0gj3gg9mO+9HJW/8GB5H89RX/V0QP4JGL7YEEVg==", 2530 | "dev": true, 2531 | "optional": true 2532 | }, 2533 | "@esbuild/sunos-x64": { 2534 | "version": "0.16.3", 2535 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.16.3.tgz", 2536 | "integrity": "sha512-SF9Kch5Ete4reovvRO6yNjMxrvlfT0F0Flm+NPoUw5Z4Q3r1d23LFTgaLwm3Cp0iGbrU/MoUI+ZqwCv5XJijCw==", 2537 | "dev": true, 2538 | "optional": true 2539 | }, 2540 | "@esbuild/win32-arm64": { 2541 | "version": "0.16.3", 2542 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.16.3.tgz", 2543 | "integrity": "sha512-u5aBonZIyGopAZyOnoPAA6fGsDeHByZ9CnEzyML9NqntK6D/xl5jteZUKm/p6nD09+v3pTM6TuUIqSPcChk5gg==", 2544 | "dev": true, 2545 | "optional": true 2546 | }, 2547 | "@esbuild/win32-ia32": { 2548 | "version": "0.16.3", 2549 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.16.3.tgz", 2550 | "integrity": "sha512-GlgVq1WpvOEhNioh74TKelwla9KDuAaLZrdxuuUgsP2vayxeLgVc+rbpIv0IYF4+tlIzq2vRhofV+KGLD+37EQ==", 2551 | "dev": true, 2552 | "optional": true 2553 | }, 2554 | "@esbuild/win32-x64": { 2555 | "version": "0.16.3", 2556 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.16.3.tgz", 2557 | "integrity": "sha512-5/JuTd8OWW8UzEtyf19fbrtMJENza+C9JoPIkvItgTBQ1FO2ZLvjbPO6Xs54vk0s5JB5QsfieUEshRQfu7ZHow==", 2558 | "dev": true, 2559 | "optional": true 2560 | }, 2561 | "@iarna/toml": { 2562 | "version": "2.2.5", 2563 | "resolved": "https://registry.npmjs.org/@iarna/toml/-/toml-2.2.5.tgz", 2564 | "integrity": "sha512-trnsAYxU3xnS1gPHPyU961coFyLkh4gAD/0zQ5mymY4yOZ+CYvsPqUbOFSw0aDM4y0tV7tiFxL/1XfXPNC6IPg==", 2565 | "dev": true 2566 | }, 2567 | "@miniflare/cache": { 2568 | "version": "2.13.0", 2569 | "resolved": "https://registry.npmjs.org/@miniflare/cache/-/cache-2.13.0.tgz", 2570 | "integrity": "sha512-y3SdN3SVyPECWmLAEGkkrv0RB+LugEPs/FeXn8QtN9aE1vyj69clOAgmsDzoh1DpFfFsLKRiv05aWs4m79P8Xw==", 2571 | "dev": true, 2572 | "requires": { 2573 | "@miniflare/core": "2.13.0", 2574 | "@miniflare/shared": "2.13.0", 2575 | "http-cache-semantics": "^4.1.0", 2576 | "undici": "5.20.0" 2577 | } 2578 | }, 2579 | "@miniflare/cli-parser": { 2580 | "version": "2.13.0", 2581 | "resolved": "https://registry.npmjs.org/@miniflare/cli-parser/-/cli-parser-2.13.0.tgz", 2582 | "integrity": "sha512-Nx1PIfuMZ3mK9Dg/JojWZAjHR16h1pcdCFSqYln/ME7y5ifx+P1E5UkShWUQ1cBlibNaltjbJ2n/7stSAsIGPQ==", 2583 | "dev": true, 2584 | "requires": { 2585 | "@miniflare/shared": "2.13.0", 2586 | "kleur": "^4.1.4" 2587 | } 2588 | }, 2589 | "@miniflare/core": { 2590 | "version": "2.13.0", 2591 | "resolved": "https://registry.npmjs.org/@miniflare/core/-/core-2.13.0.tgz", 2592 | "integrity": "sha512-YJ/C0J3k+7xn4gvlMpvePnM3xC8nOnkweW96cc0IA8kJ1JSmScOO2tZ7rrU1RyDgp6StkAtQBw4yC0wYeFycBw==", 2593 | "dev": true, 2594 | "requires": { 2595 | "@iarna/toml": "^2.2.5", 2596 | "@miniflare/queues": "2.13.0", 2597 | "@miniflare/shared": "2.13.0", 2598 | "@miniflare/watcher": "2.13.0", 2599 | "busboy": "^1.6.0", 2600 | "dotenv": "^10.0.0", 2601 | "kleur": "^4.1.4", 2602 | "set-cookie-parser": "^2.4.8", 2603 | "undici": "5.20.0", 2604 | "urlpattern-polyfill": "^4.0.3" 2605 | } 2606 | }, 2607 | "@miniflare/d1": { 2608 | "version": "2.13.0", 2609 | "resolved": "https://registry.npmjs.org/@miniflare/d1/-/d1-2.13.0.tgz", 2610 | "integrity": "sha512-OslqjO8iTcvzyrC0spByftMboRmHJEyHyTHnlKkjWDGdQQztEOjso2Xj+3I4SZIeUYvbzDRhKLS2QXI9a8LS5A==", 2611 | "dev": true, 2612 | "requires": { 2613 | "@miniflare/core": "2.13.0", 2614 | "@miniflare/shared": "2.13.0" 2615 | } 2616 | }, 2617 | "@miniflare/durable-objects": { 2618 | "version": "2.13.0", 2619 | "resolved": "https://registry.npmjs.org/@miniflare/durable-objects/-/durable-objects-2.13.0.tgz", 2620 | "integrity": "sha512-CRGVBPO9vY4Fc3aV+pdPRVVeYIt64vQqvw+BJbyW+TQtqVP2CGQeziJGnCfcONNNKyooZxGyUkHewUypyH+Qhg==", 2621 | "dev": true, 2622 | "requires": { 2623 | "@miniflare/core": "2.13.0", 2624 | "@miniflare/shared": "2.13.0", 2625 | "@miniflare/storage-memory": "2.13.0", 2626 | "undici": "5.20.0" 2627 | } 2628 | }, 2629 | "@miniflare/html-rewriter": { 2630 | "version": "2.13.0", 2631 | "resolved": "https://registry.npmjs.org/@miniflare/html-rewriter/-/html-rewriter-2.13.0.tgz", 2632 | "integrity": "sha512-XhN7Icyzvtvu+o/A0hrnSiSmla78seCaNwQ9M1TDHxt352I/ahPX4wtPXs6GbKqY0/i+V6yoG2KGFRQ/j59cQQ==", 2633 | "dev": true, 2634 | "requires": { 2635 | "@miniflare/core": "2.13.0", 2636 | "@miniflare/shared": "2.13.0", 2637 | "html-rewriter-wasm": "^0.4.1", 2638 | "undici": "5.20.0" 2639 | } 2640 | }, 2641 | "@miniflare/http-server": { 2642 | "version": "2.13.0", 2643 | "resolved": "https://registry.npmjs.org/@miniflare/http-server/-/http-server-2.13.0.tgz", 2644 | "integrity": "sha512-aMS/nUMTKP15hKnyZboeuWCiqmNrrCu+XRBY/TxDDl07iXcLpiHGf3oVv+yXxXkWlJHJVCbK7i/nXSNPllRMSw==", 2645 | "dev": true, 2646 | "requires": { 2647 | "@miniflare/core": "2.13.0", 2648 | "@miniflare/shared": "2.13.0", 2649 | "@miniflare/web-sockets": "2.13.0", 2650 | "kleur": "^4.1.4", 2651 | "selfsigned": "^2.0.0", 2652 | "undici": "5.20.0", 2653 | "ws": "^8.2.2", 2654 | "youch": "^2.2.2" 2655 | } 2656 | }, 2657 | "@miniflare/kv": { 2658 | "version": "2.13.0", 2659 | "resolved": "https://registry.npmjs.org/@miniflare/kv/-/kv-2.13.0.tgz", 2660 | "integrity": "sha512-J0AS5x3g/YVOmHMxMAZs07nRXRvSo9jyuC0eikTBf+4AABvBIyvVYmdTjYNjCmr8O5smcfWBX5S27HelD3aAAQ==", 2661 | "dev": true, 2662 | "requires": { 2663 | "@miniflare/shared": "2.13.0" 2664 | } 2665 | }, 2666 | "@miniflare/queues": { 2667 | "version": "2.13.0", 2668 | "resolved": "https://registry.npmjs.org/@miniflare/queues/-/queues-2.13.0.tgz", 2669 | "integrity": "sha512-Gf/a6M1mJL03iOvNqh3JNahcBfvEMPHnO28n0gkCoyYWGvddIr9lwCdFIa0qwNJsC1fIDRxhPg8PZ5cQLBMwRA==", 2670 | "dev": true, 2671 | "requires": { 2672 | "@miniflare/shared": "2.13.0" 2673 | } 2674 | }, 2675 | "@miniflare/r2": { 2676 | "version": "2.13.0", 2677 | "resolved": "https://registry.npmjs.org/@miniflare/r2/-/r2-2.13.0.tgz", 2678 | "integrity": "sha512-/5k6GHOYMNV/oBtilV9HDXBkJUrx8oXVigG5vxbnzEGRXyVRmR+Glzu7mFT8JiE94XiEbXHk9Qvu1S5Dej3wBw==", 2679 | "dev": true, 2680 | "requires": { 2681 | "@miniflare/shared": "2.13.0", 2682 | "undici": "5.20.0" 2683 | } 2684 | }, 2685 | "@miniflare/runner-vm": { 2686 | "version": "2.13.0", 2687 | "resolved": "https://registry.npmjs.org/@miniflare/runner-vm/-/runner-vm-2.13.0.tgz", 2688 | "integrity": "sha512-VmKtF2cA8HmTuLXor1THWY0v+DmaobPct63iLcgWIaUdP3MIvL+9X8HDXFAviCR7bCTe6MKxckHkaOj0IE0aJQ==", 2689 | "dev": true, 2690 | "requires": { 2691 | "@miniflare/shared": "2.13.0" 2692 | } 2693 | }, 2694 | "@miniflare/scheduler": { 2695 | "version": "2.13.0", 2696 | "resolved": "https://registry.npmjs.org/@miniflare/scheduler/-/scheduler-2.13.0.tgz", 2697 | "integrity": "sha512-AOaQanoR4NjVEzVGWHnrL15A7aMx+d9AKLJhSDF7KaP+4NrT2Wo2BQuXCpn5oStx3itOdlQpMfqQ139e/I8WhQ==", 2698 | "dev": true, 2699 | "requires": { 2700 | "@miniflare/core": "2.13.0", 2701 | "@miniflare/shared": "2.13.0", 2702 | "cron-schedule": "^3.0.4" 2703 | } 2704 | }, 2705 | "@miniflare/shared": { 2706 | "version": "2.13.0", 2707 | "resolved": "https://registry.npmjs.org/@miniflare/shared/-/shared-2.13.0.tgz", 2708 | "integrity": "sha512-m8YFQzKmbjberrV9hPzNcQjNCXxjTjXUpuNrIGjAJO7g+BDztUHaZbdd26H9maBDlkeiWxA3hf0mDyCT/6MCMA==", 2709 | "dev": true, 2710 | "requires": { 2711 | "@types/better-sqlite3": "^7.6.0", 2712 | "kleur": "^4.1.4", 2713 | "npx-import": "^1.1.4", 2714 | "picomatch": "^2.3.1" 2715 | } 2716 | }, 2717 | "@miniflare/sites": { 2718 | "version": "2.13.0", 2719 | "resolved": "https://registry.npmjs.org/@miniflare/sites/-/sites-2.13.0.tgz", 2720 | "integrity": "sha512-/tuzIu00o6CF2tkSv01q02MgEShXBSKx85h9jwWvc+6u7prGacAOer0FA1YNRFbE+t9QIfutAkoPGMA9zYf8+Q==", 2721 | "dev": true, 2722 | "requires": { 2723 | "@miniflare/kv": "2.13.0", 2724 | "@miniflare/shared": "2.13.0", 2725 | "@miniflare/storage-file": "2.13.0" 2726 | } 2727 | }, 2728 | "@miniflare/storage-file": { 2729 | "version": "2.13.0", 2730 | "resolved": "https://registry.npmjs.org/@miniflare/storage-file/-/storage-file-2.13.0.tgz", 2731 | "integrity": "sha512-LuAeAAY5046rq5U1eFLVkz+ppiFEWytWacpkQw92DvVKFFquZcXSj6WPxZF4rSs23WDk+rdcwuLekbb52aDR7A==", 2732 | "dev": true, 2733 | "requires": { 2734 | "@miniflare/shared": "2.13.0", 2735 | "@miniflare/storage-memory": "2.13.0" 2736 | } 2737 | }, 2738 | "@miniflare/storage-memory": { 2739 | "version": "2.13.0", 2740 | "resolved": "https://registry.npmjs.org/@miniflare/storage-memory/-/storage-memory-2.13.0.tgz", 2741 | "integrity": "sha512-FnkYcBNXa/ym1ksNilNZycg9WYYKo6cWKplVBeSthRon3e8QY6t3n7/XRseBUo7O6mhDybVTy4wNCP1R2nBiEw==", 2742 | "dev": true, 2743 | "requires": { 2744 | "@miniflare/shared": "2.13.0" 2745 | } 2746 | }, 2747 | "@miniflare/watcher": { 2748 | "version": "2.13.0", 2749 | "resolved": "https://registry.npmjs.org/@miniflare/watcher/-/watcher-2.13.0.tgz", 2750 | "integrity": "sha512-teAacWcpMStoBLbLae95IUaL5lPzjPlXa9lhK9CbRaio/KRMibTMRGWrYos3IVGQRZvklvLwcms/nTvgcdb6yw==", 2751 | "dev": true, 2752 | "requires": { 2753 | "@miniflare/shared": "2.13.0" 2754 | } 2755 | }, 2756 | "@miniflare/web-sockets": { 2757 | "version": "2.13.0", 2758 | "resolved": "https://registry.npmjs.org/@miniflare/web-sockets/-/web-sockets-2.13.0.tgz", 2759 | "integrity": "sha512-+U2/HCf+BetRIgjAnNQjkuN6UeAjQmXifhQC+7CCaX834XJhrKXoR6z2xr2xkg1qj0qQs4D2jWG0KzrO5OUpug==", 2760 | "dev": true, 2761 | "requires": { 2762 | "@miniflare/core": "2.13.0", 2763 | "@miniflare/shared": "2.13.0", 2764 | "undici": "5.20.0", 2765 | "ws": "^8.2.2" 2766 | } 2767 | }, 2768 | "@types/better-sqlite3": { 2769 | "version": "7.6.4", 2770 | "resolved": "https://registry.npmjs.org/@types/better-sqlite3/-/better-sqlite3-7.6.4.tgz", 2771 | "integrity": "sha512-dzrRZCYPXIXfSR1/surNbJ/grU3scTaygS0OMzjlGf71i9sc2fGyHPXXiXmEvNIoE0cGwsanEFMVJxPXmco9Eg==", 2772 | "dev": true, 2773 | "requires": { 2774 | "@types/node": "*" 2775 | } 2776 | }, 2777 | "@types/node": { 2778 | "version": "20.2.5", 2779 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.2.5.tgz", 2780 | "integrity": "sha512-JJulVEQXmiY9Px5axXHeYGLSjhkZEnD+MDPDGbCbIAbMslkKwmygtZFy1X6s/075Yo94sf8GuSlFfPzysQrWZQ==", 2781 | "dev": true 2782 | }, 2783 | "@types/stack-trace": { 2784 | "version": "0.0.29", 2785 | "resolved": "https://registry.npmjs.org/@types/stack-trace/-/stack-trace-0.0.29.tgz", 2786 | "integrity": "sha512-TgfOX+mGY/NyNxJLIbDWrO9DjGoVSW9+aB8H2yy1fy32jsvxijhmyJI9fDFgvz3YP4lvJaq9DzdR/M1bOgVc9g==", 2787 | "dev": true 2788 | }, 2789 | "anymatch": { 2790 | "version": "3.1.3", 2791 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 2792 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 2793 | "dev": true, 2794 | "requires": { 2795 | "normalize-path": "^3.0.0", 2796 | "picomatch": "^2.0.4" 2797 | } 2798 | }, 2799 | "archiver": { 2800 | "version": "5.3.1", 2801 | "resolved": "https://registry.npmjs.org/archiver/-/archiver-5.3.1.tgz", 2802 | "integrity": "sha512-8KyabkmbYrH+9ibcTScQ1xCJC/CGcugdVIwB+53f5sZziXgwUh3iXlAlANMxcZyDEfTHMe6+Z5FofV8nopXP7w==", 2803 | "requires": { 2804 | "archiver-utils": "^2.1.0", 2805 | "async": "^3.2.3", 2806 | "buffer-crc32": "^0.2.1", 2807 | "readable-stream": "^3.6.0", 2808 | "readdir-glob": "^1.0.0", 2809 | "tar-stream": "^2.2.0", 2810 | "zip-stream": "^4.1.0" 2811 | } 2812 | }, 2813 | "archiver-utils": { 2814 | "version": "2.1.0", 2815 | "resolved": "https://registry.npmjs.org/archiver-utils/-/archiver-utils-2.1.0.tgz", 2816 | "integrity": "sha512-bEL/yUb/fNNiNTuUz979Z0Yg5L+LzLxGJz8x79lYmR54fmTIb6ob/hNQgkQnIUDWIFjZVQwl9Xs356I6BAMHfw==", 2817 | "requires": { 2818 | "glob": "^7.1.4", 2819 | "graceful-fs": "^4.2.0", 2820 | "lazystream": "^1.0.0", 2821 | "lodash.defaults": "^4.2.0", 2822 | "lodash.difference": "^4.5.0", 2823 | "lodash.flatten": "^4.4.0", 2824 | "lodash.isplainobject": "^4.0.6", 2825 | "lodash.union": "^4.6.0", 2826 | "normalize-path": "^3.0.0", 2827 | "readable-stream": "^2.0.0" 2828 | }, 2829 | "dependencies": { 2830 | "readable-stream": { 2831 | "version": "2.3.8", 2832 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", 2833 | "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", 2834 | "requires": { 2835 | "core-util-is": "~1.0.0", 2836 | "inherits": "~2.0.3", 2837 | "isarray": "~1.0.0", 2838 | "process-nextick-args": "~2.0.0", 2839 | "safe-buffer": "~5.1.1", 2840 | "string_decoder": "~1.1.1", 2841 | "util-deprecate": "~1.0.1" 2842 | } 2843 | }, 2844 | "safe-buffer": { 2845 | "version": "5.1.2", 2846 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2847 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2848 | }, 2849 | "string_decoder": { 2850 | "version": "1.1.1", 2851 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2852 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2853 | "requires": { 2854 | "safe-buffer": "~5.1.0" 2855 | } 2856 | } 2857 | } 2858 | }, 2859 | "async": { 2860 | "version": "3.2.4", 2861 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.4.tgz", 2862 | "integrity": "sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ==" 2863 | }, 2864 | "available-typed-arrays": { 2865 | "version": "1.0.5", 2866 | "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz", 2867 | "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==" 2868 | }, 2869 | "balanced-match": { 2870 | "version": "1.0.2", 2871 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2872 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 2873 | }, 2874 | "base64-js": { 2875 | "version": "1.5.1", 2876 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 2877 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==" 2878 | }, 2879 | "binary-extensions": { 2880 | "version": "2.2.0", 2881 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 2882 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 2883 | "dev": true 2884 | }, 2885 | "bl": { 2886 | "version": "4.1.0", 2887 | "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz", 2888 | "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==", 2889 | "requires": { 2890 | "buffer": "^5.5.0", 2891 | "inherits": "^2.0.4", 2892 | "readable-stream": "^3.4.0" 2893 | } 2894 | }, 2895 | "blake3-wasm": { 2896 | "version": "2.1.5", 2897 | "resolved": "https://registry.npmjs.org/blake3-wasm/-/blake3-wasm-2.1.5.tgz", 2898 | "integrity": "sha512-F1+K8EbfOZE49dtoPtmxUQrpXaBIl3ICvasLh+nJta0xkz+9kF/7uet9fLnwKqhDrmj6g+6K3Tw9yQPUg2ka5g==", 2899 | "dev": true 2900 | }, 2901 | "brace-expansion": { 2902 | "version": "1.1.11", 2903 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2904 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2905 | "requires": { 2906 | "balanced-match": "^1.0.0", 2907 | "concat-map": "0.0.1" 2908 | } 2909 | }, 2910 | "braces": { 2911 | "version": "3.0.2", 2912 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2913 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2914 | "dev": true, 2915 | "requires": { 2916 | "fill-range": "^7.0.1" 2917 | } 2918 | }, 2919 | "buffer": { 2920 | "version": "5.7.1", 2921 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", 2922 | "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", 2923 | "requires": { 2924 | "base64-js": "^1.3.1", 2925 | "ieee754": "^1.1.13" 2926 | } 2927 | }, 2928 | "buffer-crc32": { 2929 | "version": "0.2.13", 2930 | "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", 2931 | "integrity": "sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==" 2932 | }, 2933 | "buffer-from": { 2934 | "version": "1.1.2", 2935 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 2936 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 2937 | "dev": true 2938 | }, 2939 | "builtins": { 2940 | "version": "5.0.1", 2941 | "resolved": "https://registry.npmjs.org/builtins/-/builtins-5.0.1.tgz", 2942 | "integrity": "sha512-qwVpFEHNfhYJIzNRBvd2C1kyo6jz3ZSMPyyuR47OPdiKWlbYnZNyDWuyR175qDnAJLiCo5fBBqPb3RiXgWlkOQ==", 2943 | "dev": true, 2944 | "requires": { 2945 | "semver": "^7.0.0" 2946 | } 2947 | }, 2948 | "busboy": { 2949 | "version": "1.6.0", 2950 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", 2951 | "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", 2952 | "dev": true, 2953 | "requires": { 2954 | "streamsearch": "^1.1.0" 2955 | } 2956 | }, 2957 | "call-bind": { 2958 | "version": "1.0.2", 2959 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 2960 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 2961 | "requires": { 2962 | "function-bind": "^1.1.1", 2963 | "get-intrinsic": "^1.0.2" 2964 | } 2965 | }, 2966 | "chokidar": { 2967 | "version": "3.5.3", 2968 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 2969 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 2970 | "dev": true, 2971 | "requires": { 2972 | "anymatch": "~3.1.2", 2973 | "braces": "~3.0.2", 2974 | "fsevents": "~2.3.2", 2975 | "glob-parent": "~5.1.2", 2976 | "is-binary-path": "~2.1.0", 2977 | "is-glob": "~4.0.1", 2978 | "normalize-path": "~3.0.0", 2979 | "readdirp": "~3.6.0" 2980 | } 2981 | }, 2982 | "compress-commons": { 2983 | "version": "4.1.1", 2984 | "resolved": "https://registry.npmjs.org/compress-commons/-/compress-commons-4.1.1.tgz", 2985 | "integrity": "sha512-QLdDLCKNV2dtoTorqgxngQCMA+gWXkM/Nwu7FpeBhk/RdkzimqC3jueb/FDmaZeXh+uby1jkBqE3xArsLBE5wQ==", 2986 | "requires": { 2987 | "buffer-crc32": "^0.2.13", 2988 | "crc32-stream": "^4.0.2", 2989 | "normalize-path": "^3.0.0", 2990 | "readable-stream": "^3.6.0" 2991 | } 2992 | }, 2993 | "concat-map": { 2994 | "version": "0.0.1", 2995 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2996 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" 2997 | }, 2998 | "cookie": { 2999 | "version": "0.4.2", 3000 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz", 3001 | "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==", 3002 | "dev": true 3003 | }, 3004 | "core-util-is": { 3005 | "version": "1.0.3", 3006 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 3007 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==" 3008 | }, 3009 | "crc-32": { 3010 | "version": "1.2.2", 3011 | "resolved": "https://registry.npmjs.org/crc-32/-/crc-32-1.2.2.tgz", 3012 | "integrity": "sha512-ROmzCKrTnOwybPcJApAA6WBWij23HVfGVNKqqrZpuyZOHqK2CwHSvpGuyt/UNNvaIjEd8X5IFGp4Mh+Ie1IHJQ==" 3013 | }, 3014 | "crc32-stream": { 3015 | "version": "4.0.2", 3016 | "resolved": "https://registry.npmjs.org/crc32-stream/-/crc32-stream-4.0.2.tgz", 3017 | "integrity": "sha512-DxFZ/Hk473b/muq1VJ///PMNLj0ZMnzye9thBpmjpJKCc5eMgB95aK8zCGrGfQ90cWo561Te6HK9D+j4KPdM6w==", 3018 | "requires": { 3019 | "crc-32": "^1.2.0", 3020 | "readable-stream": "^3.4.0" 3021 | } 3022 | }, 3023 | "cron-schedule": { 3024 | "version": "3.0.6", 3025 | "resolved": "https://registry.npmjs.org/cron-schedule/-/cron-schedule-3.0.6.tgz", 3026 | "integrity": "sha512-izfGgKyzzIyLaeb1EtZ3KbglkS6AKp9cv7LxmiyoOu+fXfol1tQDC0Cof0enVZGNtudTHW+3lfuW9ZkLQss4Wg==", 3027 | "dev": true 3028 | }, 3029 | "cross-spawn": { 3030 | "version": "7.0.3", 3031 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 3032 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 3033 | "dev": true, 3034 | "requires": { 3035 | "path-key": "^3.1.0", 3036 | "shebang-command": "^2.0.0", 3037 | "which": "^2.0.1" 3038 | } 3039 | }, 3040 | "debug": { 3041 | "version": "4.3.4", 3042 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 3043 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 3044 | "requires": { 3045 | "ms": "2.1.2" 3046 | } 3047 | }, 3048 | "devtools-protocol": { 3049 | "version": "0.0.1019158", 3050 | "resolved": "https://registry.npmjs.org/devtools-protocol/-/devtools-protocol-0.0.1019158.tgz", 3051 | "integrity": "sha512-wvq+KscQ7/6spEV7czhnZc9RM/woz1AY+/Vpd8/h2HFMwJSdTliu7f/yr1A6vDdJfKICZsShqsYpEQbdhg8AFQ==" 3052 | }, 3053 | "dotenv": { 3054 | "version": "10.0.0", 3055 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-10.0.0.tgz", 3056 | "integrity": "sha512-rlBi9d8jpv9Sf1klPjNfFAuWDjKLwTIJJ/VxtoTwIR6hnZxcEOQCZg2oIL3MWBYw5GpUDKOEnND7LXTbIpQ03Q==", 3057 | "dev": true 3058 | }, 3059 | "emitter-component": { 3060 | "version": "1.1.1", 3061 | "resolved": "https://registry.npmjs.org/emitter-component/-/emitter-component-1.1.1.tgz", 3062 | "integrity": "sha512-G+mpdiAySMuB7kesVRLuyvYRqDmshB7ReKEVuyBPkzQlmiDiLrt7hHHIy4Aff552bgknVN7B2/d3lzhGO5dvpQ==" 3063 | }, 3064 | "end-of-stream": { 3065 | "version": "1.4.4", 3066 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 3067 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 3068 | "requires": { 3069 | "once": "^1.4.0" 3070 | } 3071 | }, 3072 | "esbuild": { 3073 | "version": "0.16.3", 3074 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.16.3.tgz", 3075 | "integrity": "sha512-71f7EjPWTiSguen8X/kxEpkAS7BFHwtQKisCDDV3Y4GLGWBaoSCyD5uXkaUew6JDzA9FEN1W23mdnSwW9kqCeg==", 3076 | "dev": true, 3077 | "requires": { 3078 | "@esbuild/android-arm": "0.16.3", 3079 | "@esbuild/android-arm64": "0.16.3", 3080 | "@esbuild/android-x64": "0.16.3", 3081 | "@esbuild/darwin-arm64": "0.16.3", 3082 | "@esbuild/darwin-x64": "0.16.3", 3083 | "@esbuild/freebsd-arm64": "0.16.3", 3084 | "@esbuild/freebsd-x64": "0.16.3", 3085 | "@esbuild/linux-arm": "0.16.3", 3086 | "@esbuild/linux-arm64": "0.16.3", 3087 | "@esbuild/linux-ia32": "0.16.3", 3088 | "@esbuild/linux-loong64": "0.16.3", 3089 | "@esbuild/linux-mips64el": "0.16.3", 3090 | "@esbuild/linux-ppc64": "0.16.3", 3091 | "@esbuild/linux-riscv64": "0.16.3", 3092 | "@esbuild/linux-s390x": "0.16.3", 3093 | "@esbuild/linux-x64": "0.16.3", 3094 | "@esbuild/netbsd-x64": "0.16.3", 3095 | "@esbuild/openbsd-x64": "0.16.3", 3096 | "@esbuild/sunos-x64": "0.16.3", 3097 | "@esbuild/win32-arm64": "0.16.3", 3098 | "@esbuild/win32-ia32": "0.16.3", 3099 | "@esbuild/win32-x64": "0.16.3" 3100 | } 3101 | }, 3102 | "escape-string-regexp": { 3103 | "version": "4.0.0", 3104 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 3105 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 3106 | "dev": true 3107 | }, 3108 | "estree-walker": { 3109 | "version": "0.6.1", 3110 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", 3111 | "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", 3112 | "dev": true 3113 | }, 3114 | "events": { 3115 | "version": "3.3.0", 3116 | "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", 3117 | "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==" 3118 | }, 3119 | "execa": { 3120 | "version": "6.1.0", 3121 | "resolved": "https://registry.npmjs.org/execa/-/execa-6.1.0.tgz", 3122 | "integrity": "sha512-QVWlX2e50heYJcCPG0iWtf8r0xjEYfz/OYLGDYH+IyjWezzPNxz63qNFOu0l4YftGWuizFVZHHs8PrLU5p2IDA==", 3123 | "dev": true, 3124 | "requires": { 3125 | "cross-spawn": "^7.0.3", 3126 | "get-stream": "^6.0.1", 3127 | "human-signals": "^3.0.1", 3128 | "is-stream": "^3.0.0", 3129 | "merge-stream": "^2.0.0", 3130 | "npm-run-path": "^5.1.0", 3131 | "onetime": "^6.0.0", 3132 | "signal-exit": "^3.0.7", 3133 | "strip-final-newline": "^3.0.0" 3134 | } 3135 | }, 3136 | "fill-range": { 3137 | "version": "7.0.1", 3138 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 3139 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 3140 | "dev": true, 3141 | "requires": { 3142 | "to-regex-range": "^5.0.1" 3143 | } 3144 | }, 3145 | "for-each": { 3146 | "version": "0.3.3", 3147 | "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", 3148 | "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", 3149 | "requires": { 3150 | "is-callable": "^1.1.3" 3151 | } 3152 | }, 3153 | "fs-constants": { 3154 | "version": "1.0.0", 3155 | "resolved": "https://registry.npmjs.org/fs-constants/-/fs-constants-1.0.0.tgz", 3156 | "integrity": "sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==" 3157 | }, 3158 | "fs.realpath": { 3159 | "version": "1.0.0", 3160 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 3161 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" 3162 | }, 3163 | "fsevents": { 3164 | "version": "2.3.2", 3165 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 3166 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 3167 | "dev": true, 3168 | "optional": true 3169 | }, 3170 | "function-bind": { 3171 | "version": "1.1.1", 3172 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 3173 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 3174 | }, 3175 | "get-intrinsic": { 3176 | "version": "1.2.1", 3177 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", 3178 | "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", 3179 | "requires": { 3180 | "function-bind": "^1.1.1", 3181 | "has": "^1.0.3", 3182 | "has-proto": "^1.0.1", 3183 | "has-symbols": "^1.0.3" 3184 | } 3185 | }, 3186 | "get-stream": { 3187 | "version": "6.0.1", 3188 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 3189 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 3190 | "dev": true 3191 | }, 3192 | "glob": { 3193 | "version": "7.2.3", 3194 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 3195 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 3196 | "requires": { 3197 | "fs.realpath": "^1.0.0", 3198 | "inflight": "^1.0.4", 3199 | "inherits": "2", 3200 | "minimatch": "^3.1.1", 3201 | "once": "^1.3.0", 3202 | "path-is-absolute": "^1.0.0" 3203 | } 3204 | }, 3205 | "glob-parent": { 3206 | "version": "5.1.2", 3207 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 3208 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 3209 | "dev": true, 3210 | "requires": { 3211 | "is-glob": "^4.0.1" 3212 | } 3213 | }, 3214 | "gopd": { 3215 | "version": "1.0.1", 3216 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", 3217 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", 3218 | "requires": { 3219 | "get-intrinsic": "^1.1.3" 3220 | } 3221 | }, 3222 | "graceful-fs": { 3223 | "version": "4.2.11", 3224 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 3225 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==" 3226 | }, 3227 | "has": { 3228 | "version": "1.0.3", 3229 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 3230 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 3231 | "requires": { 3232 | "function-bind": "^1.1.1" 3233 | } 3234 | }, 3235 | "has-proto": { 3236 | "version": "1.0.1", 3237 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", 3238 | "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==" 3239 | }, 3240 | "has-symbols": { 3241 | "version": "1.0.3", 3242 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 3243 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==" 3244 | }, 3245 | "has-tostringtag": { 3246 | "version": "1.0.0", 3247 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", 3248 | "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", 3249 | "requires": { 3250 | "has-symbols": "^1.0.2" 3251 | } 3252 | }, 3253 | "html-rewriter-wasm": { 3254 | "version": "0.4.1", 3255 | "resolved": "https://registry.npmjs.org/html-rewriter-wasm/-/html-rewriter-wasm-0.4.1.tgz", 3256 | "integrity": "sha512-lNovG8CMCCmcVB1Q7xggMSf7tqPCijZXaH4gL6iE8BFghdQCbaY5Met9i1x2Ex8m/cZHDUtXK9H6/znKamRP8Q==", 3257 | "dev": true 3258 | }, 3259 | "http-cache-semantics": { 3260 | "version": "4.1.1", 3261 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz", 3262 | "integrity": "sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==", 3263 | "dev": true 3264 | }, 3265 | "human-signals": { 3266 | "version": "3.0.1", 3267 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-3.0.1.tgz", 3268 | "integrity": "sha512-rQLskxnM/5OCldHo+wNXbpVgDn5A17CUoKX+7Sokwaknlq7CdSnphy0W39GU8dw59XiCXmFXDg4fRuckQRKewQ==", 3269 | "dev": true 3270 | }, 3271 | "ieee754": { 3272 | "version": "1.2.1", 3273 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 3274 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==" 3275 | }, 3276 | "inflight": { 3277 | "version": "1.0.6", 3278 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 3279 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 3280 | "requires": { 3281 | "once": "^1.3.0", 3282 | "wrappy": "1" 3283 | } 3284 | }, 3285 | "inherits": { 3286 | "version": "2.0.4", 3287 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 3288 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 3289 | }, 3290 | "is-arguments": { 3291 | "version": "1.1.1", 3292 | "resolved": "https://registry.npmjs.org/is-arguments/-/is-arguments-1.1.1.tgz", 3293 | "integrity": "sha512-8Q7EARjzEnKpt/PCD7e1cgUS0a6X8u5tdSiMqXhojOdoV9TsMsiO+9VLC5vAmO8N7/GmXn7yjR8qnA6bVAEzfA==", 3294 | "requires": { 3295 | "call-bind": "^1.0.2", 3296 | "has-tostringtag": "^1.0.0" 3297 | } 3298 | }, 3299 | "is-binary-path": { 3300 | "version": "2.1.0", 3301 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 3302 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 3303 | "dev": true, 3304 | "requires": { 3305 | "binary-extensions": "^2.0.0" 3306 | } 3307 | }, 3308 | "is-callable": { 3309 | "version": "1.2.7", 3310 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", 3311 | "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==" 3312 | }, 3313 | "is-extglob": { 3314 | "version": "2.1.1", 3315 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 3316 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 3317 | "dev": true 3318 | }, 3319 | "is-generator-function": { 3320 | "version": "1.0.10", 3321 | "resolved": "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz", 3322 | "integrity": "sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==", 3323 | "requires": { 3324 | "has-tostringtag": "^1.0.0" 3325 | } 3326 | }, 3327 | "is-glob": { 3328 | "version": "4.0.3", 3329 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 3330 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 3331 | "dev": true, 3332 | "requires": { 3333 | "is-extglob": "^2.1.1" 3334 | } 3335 | }, 3336 | "is-number": { 3337 | "version": "7.0.0", 3338 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 3339 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 3340 | "dev": true 3341 | }, 3342 | "is-stream": { 3343 | "version": "3.0.0", 3344 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-3.0.0.tgz", 3345 | "integrity": "sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==", 3346 | "dev": true 3347 | }, 3348 | "is-typed-array": { 3349 | "version": "1.1.10", 3350 | "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.10.tgz", 3351 | "integrity": "sha512-PJqgEHiWZvMpaFZ3uTc8kHPM4+4ADTlDniuQL7cU/UDA0Ql7F70yGfHph3cLNe+c9toaigv+DFzTJKhc2CtO6A==", 3352 | "requires": { 3353 | "available-typed-arrays": "^1.0.5", 3354 | "call-bind": "^1.0.2", 3355 | "for-each": "^0.3.3", 3356 | "gopd": "^1.0.1", 3357 | "has-tostringtag": "^1.0.0" 3358 | } 3359 | }, 3360 | "isarray": { 3361 | "version": "1.0.0", 3362 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 3363 | "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==" 3364 | }, 3365 | "isexe": { 3366 | "version": "2.0.0", 3367 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 3368 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 3369 | "dev": true 3370 | }, 3371 | "kleur": { 3372 | "version": "4.1.5", 3373 | "resolved": "https://registry.npmjs.org/kleur/-/kleur-4.1.5.tgz", 3374 | "integrity": "sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ==", 3375 | "dev": true 3376 | }, 3377 | "lazystream": { 3378 | "version": "1.0.1", 3379 | "resolved": "https://registry.npmjs.org/lazystream/-/lazystream-1.0.1.tgz", 3380 | "integrity": "sha512-b94GiNHQNy6JNTrt5w6zNyffMrNkXZb3KTkCZJb2V1xaEGCk093vkZ2jk3tpaeP33/OiXC+WvK9AxUebnf5nbw==", 3381 | "requires": { 3382 | "readable-stream": "^2.0.5" 3383 | }, 3384 | "dependencies": { 3385 | "readable-stream": { 3386 | "version": "2.3.8", 3387 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", 3388 | "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", 3389 | "requires": { 3390 | "core-util-is": "~1.0.0", 3391 | "inherits": "~2.0.3", 3392 | "isarray": "~1.0.0", 3393 | "process-nextick-args": "~2.0.0", 3394 | "safe-buffer": "~5.1.1", 3395 | "string_decoder": "~1.1.1", 3396 | "util-deprecate": "~1.0.1" 3397 | } 3398 | }, 3399 | "safe-buffer": { 3400 | "version": "5.1.2", 3401 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 3402 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 3403 | }, 3404 | "string_decoder": { 3405 | "version": "1.1.1", 3406 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 3407 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 3408 | "requires": { 3409 | "safe-buffer": "~5.1.0" 3410 | } 3411 | } 3412 | } 3413 | }, 3414 | "lodash.defaults": { 3415 | "version": "4.2.0", 3416 | "resolved": "https://registry.npmjs.org/lodash.defaults/-/lodash.defaults-4.2.0.tgz", 3417 | "integrity": "sha512-qjxPLHd3r5DnsdGacqOMU6pb/avJzdh9tFX2ymgoZE27BmjXrNy/y4LoaiTeAb+O3gL8AfpJGtqfX/ae2leYYQ==" 3418 | }, 3419 | "lodash.difference": { 3420 | "version": "4.5.0", 3421 | "resolved": "https://registry.npmjs.org/lodash.difference/-/lodash.difference-4.5.0.tgz", 3422 | "integrity": "sha512-dS2j+W26TQ7taQBGN8Lbbq04ssV3emRw4NY58WErlTO29pIqS0HmoT5aJ9+TUQ1N3G+JOZSji4eugsWwGp9yPA==" 3423 | }, 3424 | "lodash.flatten": { 3425 | "version": "4.4.0", 3426 | "resolved": "https://registry.npmjs.org/lodash.flatten/-/lodash.flatten-4.4.0.tgz", 3427 | "integrity": "sha512-C5N2Z3DgnnKr0LOpv/hKCgKdb7ZZwafIrsesve6lmzvZIRZRGaZ/l6Q8+2W7NaT+ZwO3fFlSCzCzrDCFdJfZ4g==" 3428 | }, 3429 | "lodash.isplainobject": { 3430 | "version": "4.0.6", 3431 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 3432 | "integrity": "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==" 3433 | }, 3434 | "lodash.union": { 3435 | "version": "4.6.0", 3436 | "resolved": "https://registry.npmjs.org/lodash.union/-/lodash.union-4.6.0.tgz", 3437 | "integrity": "sha512-c4pB2CdGrGdjMKYLA+XiRDO7Y0PRQbm/Gzg8qMj+QH+pFVAoTp5sBpO0odL3FjoPCGjK96p6qsP+yQoiLoOBcw==" 3438 | }, 3439 | "lru-cache": { 3440 | "version": "6.0.0", 3441 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 3442 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 3443 | "dev": true, 3444 | "requires": { 3445 | "yallist": "^4.0.0" 3446 | } 3447 | }, 3448 | "magic-string": { 3449 | "version": "0.25.9", 3450 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz", 3451 | "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==", 3452 | "dev": true, 3453 | "requires": { 3454 | "sourcemap-codec": "^1.4.8" 3455 | } 3456 | }, 3457 | "merge-stream": { 3458 | "version": "2.0.0", 3459 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 3460 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 3461 | "dev": true 3462 | }, 3463 | "mime": { 3464 | "version": "3.0.0", 3465 | "resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz", 3466 | "integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==", 3467 | "dev": true 3468 | }, 3469 | "mimic-fn": { 3470 | "version": "4.0.0", 3471 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", 3472 | "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==", 3473 | "dev": true 3474 | }, 3475 | "miniflare": { 3476 | "version": "2.13.0", 3477 | "resolved": "https://registry.npmjs.org/miniflare/-/miniflare-2.13.0.tgz", 3478 | "integrity": "sha512-ayNhVa4a6bZiOuHtrPmOt4BCYcmW1fBQ/+qGL85smq1m2OBBm3aUs6f4ISf38xH8tk+qewgmAywetyVtn6KHPw==", 3479 | "dev": true, 3480 | "requires": { 3481 | "@miniflare/cache": "2.13.0", 3482 | "@miniflare/cli-parser": "2.13.0", 3483 | "@miniflare/core": "2.13.0", 3484 | "@miniflare/d1": "2.13.0", 3485 | "@miniflare/durable-objects": "2.13.0", 3486 | "@miniflare/html-rewriter": "2.13.0", 3487 | "@miniflare/http-server": "2.13.0", 3488 | "@miniflare/kv": "2.13.0", 3489 | "@miniflare/queues": "2.13.0", 3490 | "@miniflare/r2": "2.13.0", 3491 | "@miniflare/runner-vm": "2.13.0", 3492 | "@miniflare/scheduler": "2.13.0", 3493 | "@miniflare/shared": "2.13.0", 3494 | "@miniflare/sites": "2.13.0", 3495 | "@miniflare/storage-file": "2.13.0", 3496 | "@miniflare/storage-memory": "2.13.0", 3497 | "@miniflare/web-sockets": "2.13.0", 3498 | "kleur": "^4.1.4", 3499 | "semiver": "^1.1.0", 3500 | "source-map-support": "^0.5.20", 3501 | "undici": "5.20.0" 3502 | } 3503 | }, 3504 | "minimatch": { 3505 | "version": "3.1.2", 3506 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 3507 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 3508 | "requires": { 3509 | "brace-expansion": "^1.1.7" 3510 | } 3511 | }, 3512 | "ms": { 3513 | "version": "2.1.2", 3514 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3515 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 3516 | }, 3517 | "mustache": { 3518 | "version": "4.2.0", 3519 | "resolved": "https://registry.npmjs.org/mustache/-/mustache-4.2.0.tgz", 3520 | "integrity": "sha512-71ippSywq5Yb7/tVYyGbkBggbU8H3u5Rz56fH60jGFgr8uHwxs+aSKeqmluIVzM0m0kB7xQjKS6qPfd0b2ZoqQ==", 3521 | "dev": true 3522 | }, 3523 | "nanoid": { 3524 | "version": "3.3.6", 3525 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz", 3526 | "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==", 3527 | "dev": true 3528 | }, 3529 | "node-forge": { 3530 | "version": "1.3.1", 3531 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", 3532 | "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==", 3533 | "dev": true 3534 | }, 3535 | "normalize-path": { 3536 | "version": "3.0.0", 3537 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 3538 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==" 3539 | }, 3540 | "npm-run-path": { 3541 | "version": "5.1.0", 3542 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.1.0.tgz", 3543 | "integrity": "sha512-sJOdmRGrY2sjNTRMbSvluQqg+8X7ZK61yvzBEIDhz4f8z1TZFYABsqjjCBd/0PUNE9M6QDgHJXQkGUEm7Q+l9Q==", 3544 | "dev": true, 3545 | "requires": { 3546 | "path-key": "^4.0.0" 3547 | }, 3548 | "dependencies": { 3549 | "path-key": { 3550 | "version": "4.0.0", 3551 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-4.0.0.tgz", 3552 | "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==", 3553 | "dev": true 3554 | } 3555 | } 3556 | }, 3557 | "npx-import": { 3558 | "version": "1.1.4", 3559 | "resolved": "https://registry.npmjs.org/npx-import/-/npx-import-1.1.4.tgz", 3560 | "integrity": "sha512-3ShymTWOgqGyNlh5lMJAejLuIv3W1K3fbI5Ewc6YErZU3Sp0PqsNs8UIU1O8z5+KVl/Du5ag56Gza9vdorGEoA==", 3561 | "dev": true, 3562 | "requires": { 3563 | "execa": "^6.1.0", 3564 | "parse-package-name": "^1.0.0", 3565 | "semver": "^7.3.7", 3566 | "validate-npm-package-name": "^4.0.0" 3567 | } 3568 | }, 3569 | "once": { 3570 | "version": "1.4.0", 3571 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3572 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 3573 | "requires": { 3574 | "wrappy": "1" 3575 | } 3576 | }, 3577 | "onetime": { 3578 | "version": "6.0.0", 3579 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz", 3580 | "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==", 3581 | "dev": true, 3582 | "requires": { 3583 | "mimic-fn": "^4.0.0" 3584 | } 3585 | }, 3586 | "parse-package-name": { 3587 | "version": "1.0.0", 3588 | "resolved": "https://registry.npmjs.org/parse-package-name/-/parse-package-name-1.0.0.tgz", 3589 | "integrity": "sha512-kBeTUtcj+SkyfaW4+KBe0HtsloBJ/mKTPoxpVdA57GZiPerREsUWJOhVj9anXweFiJkm5y8FG1sxFZkZ0SN6wg==", 3590 | "dev": true 3591 | }, 3592 | "path-is-absolute": { 3593 | "version": "1.0.1", 3594 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3595 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==" 3596 | }, 3597 | "path-key": { 3598 | "version": "3.1.1", 3599 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3600 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3601 | "dev": true 3602 | }, 3603 | "path-to-regexp": { 3604 | "version": "6.2.1", 3605 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz", 3606 | "integrity": "sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw==", 3607 | "dev": true 3608 | }, 3609 | "picomatch": { 3610 | "version": "2.3.1", 3611 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 3612 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 3613 | "dev": true 3614 | }, 3615 | "process-nextick-args": { 3616 | "version": "2.0.1", 3617 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 3618 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 3619 | }, 3620 | "querystring": { 3621 | "version": "0.2.0", 3622 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", 3623 | "integrity": "sha512-X/xY82scca2tau62i9mDyU9K+I+djTMUsvwf7xnUX5GLvVzgJybOJf4Y6o9Zx3oJK/LSXg5tTZBjwzqVPaPO2g==" 3624 | }, 3625 | "readable-stream": { 3626 | "version": "3.6.2", 3627 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", 3628 | "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", 3629 | "requires": { 3630 | "inherits": "^2.0.3", 3631 | "string_decoder": "^1.1.1", 3632 | "util-deprecate": "^1.0.1" 3633 | } 3634 | }, 3635 | "readdir-glob": { 3636 | "version": "1.1.3", 3637 | "resolved": "https://registry.npmjs.org/readdir-glob/-/readdir-glob-1.1.3.tgz", 3638 | "integrity": "sha512-v05I2k7xN8zXvPD9N+z/uhXPaj0sUFCe2rcWZIpBsqxfP7xXFQ0tipAd/wjj1YxWyWtUS5IDJpOG82JKt2EAVA==", 3639 | "requires": { 3640 | "minimatch": "^5.1.0" 3641 | }, 3642 | "dependencies": { 3643 | "brace-expansion": { 3644 | "version": "2.0.1", 3645 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 3646 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 3647 | "requires": { 3648 | "balanced-match": "^1.0.0" 3649 | } 3650 | }, 3651 | "minimatch": { 3652 | "version": "5.1.6", 3653 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 3654 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 3655 | "requires": { 3656 | "brace-expansion": "^2.0.1" 3657 | } 3658 | } 3659 | } 3660 | }, 3661 | "readdirp": { 3662 | "version": "3.6.0", 3663 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 3664 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 3665 | "dev": true, 3666 | "requires": { 3667 | "picomatch": "^2.2.1" 3668 | } 3669 | }, 3670 | "robots-parser": { 3671 | "version": "3.0.1", 3672 | "resolved": "https://registry.npmjs.org/robots-parser/-/robots-parser-3.0.1.tgz", 3673 | "integrity": "sha512-s+pyvQeIKIZ0dx5iJiQk1tPLJAWln39+MI5jtM8wnyws+G5azk+dMnMX0qfbqNetKKNgcWWOdi0sfm+FbQbgdQ==" 3674 | }, 3675 | "rollup-plugin-inject": { 3676 | "version": "3.0.2", 3677 | "resolved": "https://registry.npmjs.org/rollup-plugin-inject/-/rollup-plugin-inject-3.0.2.tgz", 3678 | "integrity": "sha512-ptg9PQwzs3orn4jkgXJ74bfs5vYz1NCZlSQMBUA0wKcGp5i5pA1AO3fOUEte8enhGUC+iapTCzEWw2jEFFUO/w==", 3679 | "dev": true, 3680 | "requires": { 3681 | "estree-walker": "^0.6.1", 3682 | "magic-string": "^0.25.3", 3683 | "rollup-pluginutils": "^2.8.1" 3684 | } 3685 | }, 3686 | "rollup-plugin-node-polyfills": { 3687 | "version": "0.2.1", 3688 | "resolved": "https://registry.npmjs.org/rollup-plugin-node-polyfills/-/rollup-plugin-node-polyfills-0.2.1.tgz", 3689 | "integrity": "sha512-4kCrKPTJ6sK4/gLL/U5QzVT8cxJcofO0OU74tnB19F40cmuAKSzH5/siithxlofFEjwvw1YAhPmbvGNA6jEroA==", 3690 | "dev": true, 3691 | "requires": { 3692 | "rollup-plugin-inject": "^3.0.0" 3693 | } 3694 | }, 3695 | "rollup-pluginutils": { 3696 | "version": "2.8.2", 3697 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", 3698 | "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", 3699 | "dev": true, 3700 | "requires": { 3701 | "estree-walker": "^0.6.1" 3702 | } 3703 | }, 3704 | "safe-buffer": { 3705 | "version": "5.2.1", 3706 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 3707 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 3708 | }, 3709 | "selfsigned": { 3710 | "version": "2.1.1", 3711 | "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.1.1.tgz", 3712 | "integrity": "sha512-GSL3aowiF7wa/WtSFwnUrludWFoNhftq8bUkH9pkzjpN2XSPOAYEgg6e0sS9s0rZwgJzJiQRPU18A6clnoW5wQ==", 3713 | "dev": true, 3714 | "requires": { 3715 | "node-forge": "^1" 3716 | } 3717 | }, 3718 | "semiver": { 3719 | "version": "1.1.0", 3720 | "resolved": "https://registry.npmjs.org/semiver/-/semiver-1.1.0.tgz", 3721 | "integrity": "sha512-QNI2ChmuioGC1/xjyYwyZYADILWyW6AmS1UH6gDj/SFUUUS4MBAWs/7mxnkRPc/F4iHezDP+O8t0dO8WHiEOdg==", 3722 | "dev": true 3723 | }, 3724 | "semver": { 3725 | "version": "7.5.1", 3726 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.1.tgz", 3727 | "integrity": "sha512-Wvss5ivl8TMRZXXESstBA4uR5iXgEN/VC5/sOcuXdVLzcdkz4HWetIoRfG5gb5X+ij/G9rw9YoGn3QoQ8OCSpw==", 3728 | "dev": true, 3729 | "requires": { 3730 | "lru-cache": "^6.0.0" 3731 | } 3732 | }, 3733 | "set-cookie-parser": { 3734 | "version": "2.6.0", 3735 | "resolved": "https://registry.npmjs.org/set-cookie-parser/-/set-cookie-parser-2.6.0.tgz", 3736 | "integrity": "sha512-RVnVQxTXuerk653XfuliOxBP81Sf0+qfQE73LIYKcyMYHG94AuH0kgrQpRDuTZnSmjpysHmzxJXKNfa6PjFhyQ==", 3737 | "dev": true 3738 | }, 3739 | "shebang-command": { 3740 | "version": "2.0.0", 3741 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3742 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3743 | "dev": true, 3744 | "requires": { 3745 | "shebang-regex": "^3.0.0" 3746 | } 3747 | }, 3748 | "shebang-regex": { 3749 | "version": "3.0.0", 3750 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3751 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3752 | "dev": true 3753 | }, 3754 | "signal-exit": { 3755 | "version": "3.0.7", 3756 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 3757 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 3758 | "dev": true 3759 | }, 3760 | "source-map": { 3761 | "version": "0.7.4", 3762 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", 3763 | "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", 3764 | "dev": true 3765 | }, 3766 | "source-map-support": { 3767 | "version": "0.5.21", 3768 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 3769 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 3770 | "dev": true, 3771 | "requires": { 3772 | "buffer-from": "^1.0.0", 3773 | "source-map": "^0.6.0" 3774 | }, 3775 | "dependencies": { 3776 | "source-map": { 3777 | "version": "0.6.1", 3778 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3779 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3780 | "dev": true 3781 | } 3782 | } 3783 | }, 3784 | "sourcemap-codec": { 3785 | "version": "1.4.8", 3786 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 3787 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 3788 | "dev": true 3789 | }, 3790 | "stack-trace": { 3791 | "version": "0.0.10", 3792 | "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz", 3793 | "integrity": "sha512-KGzahc7puUKkzyMt+IqAep+TVNbKP+k2Lmwhub39m1AsTSkaDutx56aDCo+HLDzf/D26BIHTJWNiTG1KAJiQCg==", 3794 | "dev": true 3795 | }, 3796 | "stream": { 3797 | "version": "0.0.2", 3798 | "resolved": "https://registry.npmjs.org/stream/-/stream-0.0.2.tgz", 3799 | "integrity": "sha512-gCq3NDI2P35B2n6t76YJuOp7d6cN/C7Rt0577l91wllh0sY9ZBuw9KaSGqH/b0hzn3CWWJbpbW0W0WvQ1H/Q7g==", 3800 | "requires": { 3801 | "emitter-component": "^1.1.1" 3802 | } 3803 | }, 3804 | "streamsearch": { 3805 | "version": "1.1.0", 3806 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", 3807 | "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", 3808 | "dev": true 3809 | }, 3810 | "string_decoder": { 3811 | "version": "1.3.0", 3812 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 3813 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 3814 | "requires": { 3815 | "safe-buffer": "~5.2.0" 3816 | } 3817 | }, 3818 | "strip-final-newline": { 3819 | "version": "3.0.0", 3820 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-3.0.0.tgz", 3821 | "integrity": "sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==", 3822 | "dev": true 3823 | }, 3824 | "tar-stream": { 3825 | "version": "2.2.0", 3826 | "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-2.2.0.tgz", 3827 | "integrity": "sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ==", 3828 | "requires": { 3829 | "bl": "^4.0.3", 3830 | "end-of-stream": "^1.4.1", 3831 | "fs-constants": "^1.0.0", 3832 | "inherits": "^2.0.3", 3833 | "readable-stream": "^3.1.1" 3834 | } 3835 | }, 3836 | "to-regex-range": { 3837 | "version": "5.0.1", 3838 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3839 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3840 | "dev": true, 3841 | "requires": { 3842 | "is-number": "^7.0.0" 3843 | } 3844 | }, 3845 | "typescript": { 3846 | "version": "5.1.3", 3847 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.1.3.tgz", 3848 | "integrity": "sha512-XH627E9vkeqhlZFQuL+UsyAXEnibT0kWR2FWONlr4sTjvxyJYnyefgrkyECLzM5NenmKzRAy2rR/OlYLA1HkZw==", 3849 | "dev": true 3850 | }, 3851 | "undici": { 3852 | "version": "5.20.0", 3853 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.20.0.tgz", 3854 | "integrity": "sha512-J3j60dYzuo6Eevbawwp1sdg16k5Tf768bxYK4TUJRH7cBM4kFCbf3mOnM/0E3vQYXvpxITbbWmBafaDbxLDz3g==", 3855 | "dev": true, 3856 | "requires": { 3857 | "busboy": "^1.6.0" 3858 | } 3859 | }, 3860 | "url": { 3861 | "version": "0.11.0", 3862 | "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", 3863 | "integrity": "sha512-kbailJa29QrtXnxgq+DdCEGlbTeYM2eJUxsz6vjZavrCYPMIFHMKQmSKYAIuUK2i7hgPm28a8piX5NTUtM/LKQ==", 3864 | "requires": { 3865 | "punycode": "1.3.2", 3866 | "querystring": "0.2.0" 3867 | }, 3868 | "dependencies": { 3869 | "punycode": { 3870 | "version": "1.3.2", 3871 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", 3872 | "integrity": "sha512-RofWgt/7fL5wP1Y7fxE7/EmTLzQVnB0ycyibJ0OOHIlJqTNzglYFxVwETOcIoJqJmpDXJ9xImDv+Fq34F/d4Dw==" 3873 | } 3874 | } 3875 | }, 3876 | "urlpattern-polyfill": { 3877 | "version": "4.0.3", 3878 | "resolved": "https://registry.npmjs.org/urlpattern-polyfill/-/urlpattern-polyfill-4.0.3.tgz", 3879 | "integrity": "sha512-DOE84vZT2fEcl9gqCUTcnAw5ZY5Id55ikUcziSUntuEFL3pRvavg5kwDmTEUJkeCHInTlV/HexFomgYnzO5kdQ==", 3880 | "dev": true 3881 | }, 3882 | "util": { 3883 | "version": "0.12.5", 3884 | "resolved": "https://registry.npmjs.org/util/-/util-0.12.5.tgz", 3885 | "integrity": "sha512-kZf/K6hEIrWHI6XqOFUiiMa+79wE/D8Q+NCNAWclkyg3b4d2k7s0QGepNjiABc+aR3N1PAyHL7p6UcLY6LmrnA==", 3886 | "requires": { 3887 | "inherits": "^2.0.3", 3888 | "is-arguments": "^1.0.4", 3889 | "is-generator-function": "^1.0.7", 3890 | "is-typed-array": "^1.1.3", 3891 | "which-typed-array": "^1.1.2" 3892 | } 3893 | }, 3894 | "util-deprecate": { 3895 | "version": "1.0.2", 3896 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3897 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" 3898 | }, 3899 | "validate-npm-package-name": { 3900 | "version": "4.0.0", 3901 | "resolved": "https://registry.npmjs.org/validate-npm-package-name/-/validate-npm-package-name-4.0.0.tgz", 3902 | "integrity": "sha512-mzR0L8ZDktZjpX4OB46KT+56MAhl4EIazWP/+G/HPGuvfdaqg4YsCdtOm6U9+LOFyYDoh4dpnpxZRB9MQQns5Q==", 3903 | "dev": true, 3904 | "requires": { 3905 | "builtins": "^5.0.0" 3906 | } 3907 | }, 3908 | "which": { 3909 | "version": "2.0.2", 3910 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3911 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3912 | "dev": true, 3913 | "requires": { 3914 | "isexe": "^2.0.0" 3915 | } 3916 | }, 3917 | "which-typed-array": { 3918 | "version": "1.1.9", 3919 | "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.9.tgz", 3920 | "integrity": "sha512-w9c4xkx6mPidwp7180ckYWfMmvxpjlZuIudNtDf4N/tTAUB8VJbX25qZoAsrtGuYNnGw3pa0AXgbGKRB8/EceA==", 3921 | "requires": { 3922 | "available-typed-arrays": "^1.0.5", 3923 | "call-bind": "^1.0.2", 3924 | "for-each": "^0.3.3", 3925 | "gopd": "^1.0.1", 3926 | "has-tostringtag": "^1.0.0", 3927 | "is-typed-array": "^1.1.10" 3928 | } 3929 | }, 3930 | "wrangler": { 3931 | "version": "2.20.0", 3932 | "resolved": "https://registry.npmjs.org/wrangler/-/wrangler-2.20.0.tgz", 3933 | "integrity": "sha512-UdKJ2LD7qgDxDvll/GkR1HnRP+bcEdqi/HJjDI+7eF4lv9V940jmm3orxCkSEosGyE14q0q6dBRM95+fBI8tdQ==", 3934 | "dev": true, 3935 | "requires": { 3936 | "@cloudflare/kv-asset-handler": "^0.2.0", 3937 | "@esbuild-plugins/node-globals-polyfill": "^0.1.1", 3938 | "@esbuild-plugins/node-modules-polyfill": "^0.1.4", 3939 | "@miniflare/core": "2.13.0", 3940 | "@miniflare/d1": "2.13.0", 3941 | "@miniflare/durable-objects": "2.13.0", 3942 | "blake3-wasm": "^2.1.5", 3943 | "chokidar": "^3.5.3", 3944 | "esbuild": "0.16.3", 3945 | "fsevents": "~2.3.2", 3946 | "miniflare": "2.13.0", 3947 | "nanoid": "^3.3.3", 3948 | "path-to-regexp": "^6.2.0", 3949 | "selfsigned": "^2.0.1", 3950 | "source-map": "^0.7.4", 3951 | "xxhash-wasm": "^1.0.1" 3952 | } 3953 | }, 3954 | "wrappy": { 3955 | "version": "1.0.2", 3956 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3957 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" 3958 | }, 3959 | "ws": { 3960 | "version": "8.13.0", 3961 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.13.0.tgz", 3962 | "integrity": "sha512-x9vcZYTrFPC7aSIbj7sRCYo7L/Xb8Iy+pW0ng0wt2vCJv7M9HOMy0UoN3rr+IFC7hb7vXoqS+P9ktyLLLhO+LA==", 3963 | "dev": true, 3964 | "requires": {} 3965 | }, 3966 | "xxhash-wasm": { 3967 | "version": "1.0.2", 3968 | "resolved": "https://registry.npmjs.org/xxhash-wasm/-/xxhash-wasm-1.0.2.tgz", 3969 | "integrity": "sha512-ibF0Or+FivM9lNrg+HGJfVX8WJqgo+kCLDc4vx6xMeTce7Aj+DLttKbxxRR/gNLSAelRc1omAPlJ77N/Jem07A==", 3970 | "dev": true 3971 | }, 3972 | "yallist": { 3973 | "version": "4.0.0", 3974 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3975 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3976 | "dev": true 3977 | }, 3978 | "youch": { 3979 | "version": "2.2.2", 3980 | "resolved": "https://registry.npmjs.org/youch/-/youch-2.2.2.tgz", 3981 | "integrity": "sha512-/FaCeG3GkuJwaMR34GHVg0l8jCbafZLHiFowSjqLlqhC6OMyf2tPJBu8UirF7/NI9X/R5ai4QfEKUCOxMAGxZQ==", 3982 | "dev": true, 3983 | "requires": { 3984 | "@types/stack-trace": "0.0.29", 3985 | "cookie": "^0.4.1", 3986 | "mustache": "^4.2.0", 3987 | "stack-trace": "0.0.10" 3988 | } 3989 | }, 3990 | "zip-stream": { 3991 | "version": "4.1.0", 3992 | "resolved": "https://registry.npmjs.org/zip-stream/-/zip-stream-4.1.0.tgz", 3993 | "integrity": "sha512-zshzwQW7gG7hjpBlgeQP9RuyPGNxvJdzR8SUM3QhxCnLjWN2E7j3dOvpeDcQoETfHx0urRS7EtmVToql7YpU4A==", 3994 | "requires": { 3995 | "archiver-utils": "^2.1.0", 3996 | "compress-commons": "^4.1.0", 3997 | "readable-stream": "^3.6.0" 3998 | } 3999 | } 4000 | } 4001 | } 4002 | -------------------------------------------------------------------------------- /consumer/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "queues-web-crawler-consumer", 3 | "version": "0.0.0", 4 | "devDependencies": { 5 | "@cloudflare/workers-types": "^4.20230518.0", 6 | "typescript": "^5.1.3", 7 | "wrangler": "2.20.0" 8 | }, 9 | "private": true, 10 | "scripts": { 11 | "start": "wrangler dev", 12 | "deploy": "wrangler deploy" 13 | }, 14 | "dependencies": { 15 | "@cloudflare/puppeteer": "^0.0.2-alpha", 16 | "robots-parser": "^3.0.1" 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /consumer/src/index.ts: -------------------------------------------------------------------------------- 1 | import puppeteer, { BrowserWorker } from "@cloudflare/puppeteer"; 2 | import robotsParser from "robots-parser"; 3 | 4 | type Message = { 5 | url: string; 6 | }; 7 | 8 | export interface Env { 9 | CRAWLER_QUEUE: Queue; 10 | CRAWLER_SCREENSHOTS_KV: KVNamespace; 11 | CRAWLER_LINKS_KV: KVNamespace; 12 | CRAWLER_BROWSER: BrowserWorker; 13 | } 14 | 15 | type Result = { 16 | numCloudflareLinks: number; 17 | screenshot: ArrayBuffer; 18 | }; 19 | 20 | type KeyMetadata = { 21 | date: number; 22 | }; 23 | 24 | export default { 25 | async fetch(req: Request, env: Env): Promise { 26 | // util endpoint for testing purposes 27 | await env.CRAWLER_QUEUE.send({ url: await req.text() }); 28 | return new Response("Success!"); 29 | }, 30 | async queue(batch: MessageBatch, env: Env): Promise { 31 | const crawlPage = async (url: string): Promise => { 32 | const page = await (browser as puppeteer.Browser).newPage(); 33 | 34 | await page.goto(url, { 35 | waitUntil: "load", 36 | }); 37 | 38 | const numCloudflareLinks = await page.$$eval("a", (links) => { 39 | links = links.filter((link) => { 40 | try { 41 | return new URL(link.href).hostname.includes("cloudflare.com"); 42 | } catch { 43 | return false; 44 | } 45 | }); 46 | return links.length; 47 | }); 48 | 49 | // to crawl recursively - uncomment this! 50 | /*await page.$$eval("a", async (links) => { 51 | const urls: MessageSendRequest[] = links.map((link) => { 52 | return { 53 | body: { 54 | url: link.href, 55 | }, 56 | }; 57 | }); 58 | try { 59 | await env.CRAWLER_QUEUE.sendBatch(urls); 60 | } catch {} // do nothing, might've hit subrequest limit 61 | });*/ 62 | 63 | await page.setViewport({ 64 | width: 1920, 65 | height: 1080, 66 | deviceScaleFactor: 1, 67 | }); 68 | 69 | return { 70 | numCloudflareLinks, 71 | screenshot: ((await page.screenshot({ fullPage: true })) as Buffer) 72 | .buffer, 73 | }; 74 | }; 75 | 76 | let browser: puppeteer.Browser | null = null; 77 | try { 78 | browser = await puppeteer.launch(env.CRAWLER_BROWSER); 79 | } catch { 80 | batch.retryAll(); 81 | return; 82 | } 83 | 84 | for (const message of batch.messages) { 85 | const { url } = message.body; 86 | const timestamp = new Date().getTime(); 87 | const resultKey = `${encodeURIComponent(url)}-${timestamp}`; 88 | 89 | const sameUrlCrawls = await env.CRAWLER_LINKS_KV.list({ 90 | prefix: `${encodeURIComponent(url)}`, 91 | }); 92 | 93 | let shouldSkip = false; 94 | for (const key of sameUrlCrawls.keys) { 95 | if (timestamp - (key.metadata as KeyMetadata)?.date < 60 * 60 * 1000) { 96 | // if crawled in last hour, skip 97 | message.ack(); 98 | shouldSkip = true; 99 | break; 100 | } 101 | } 102 | if (shouldSkip) { 103 | continue; 104 | } 105 | 106 | let isAllowed = true; 107 | try { 108 | const robotsTextPath = new URL(url).origin + "/robots.txt"; 109 | const response = await fetch(robotsTextPath); 110 | 111 | const robots = robotsParser(robotsTextPath, await response.text()); 112 | isAllowed = robots.isAllowed(url) ?? true; // respect robots.txt! 113 | } catch {} 114 | 115 | if (!isAllowed) { 116 | message.ack(); 117 | continue; 118 | } 119 | 120 | try { 121 | const { numCloudflareLinks, screenshot } = await crawlPage(url); 122 | await env.CRAWLER_LINKS_KV.put( 123 | resultKey, 124 | numCloudflareLinks.toString(), 125 | { metadata: { date: timestamp } } 126 | ); 127 | await env.CRAWLER_SCREENSHOTS_KV.put(resultKey, screenshot, { 128 | metadata: { date: timestamp }, 129 | }); 130 | message.ack(); 131 | } catch { 132 | message.retry(); 133 | } 134 | } 135 | 136 | await browser.close(); 137 | }, 138 | }; 139 | -------------------------------------------------------------------------------- /consumer/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | /* Visit https://aka.ms/tsconfig.json to read more about this file */ 4 | 5 | /* Projects */ 6 | // "incremental": true, /* Enable incremental compilation */ 7 | // "composite": true, /* Enable constraints that allow a TypeScript project to be used with project references. */ 8 | // "tsBuildInfoFile": "./", /* Specify the folder for .tsbuildinfo incremental compilation files. */ 9 | // "disableSourceOfProjectReferenceRedirect": true, /* Disable preferring source files instead of declaration files when referencing composite projects */ 10 | // "disableSolutionSearching": true, /* Opt a project out of multi-project reference checking when editing. */ 11 | // "disableReferencedProjectLoad": true, /* Reduce the number of projects loaded automatically by TypeScript. */ 12 | 13 | /* Language and Environment */ 14 | "target": "es2021" /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */, 15 | "lib": [ 16 | "es2021" 17 | ] /* Specify a set of bundled library declaration files that describe the target runtime environment. */, 18 | "jsx": "react" /* Specify what JSX code is generated. */, 19 | // "experimentalDecorators": true, /* Enable experimental support for TC39 stage 2 draft decorators. */ 20 | // "emitDecoratorMetadata": true, /* Emit design-type metadata for decorated declarations in source files. */ 21 | // "jsxFactory": "", /* Specify the JSX factory function used when targeting React JSX emit, e.g. 'React.createElement' or 'h' */ 22 | // "jsxFragmentFactory": "", /* Specify the JSX Fragment reference used for fragments when targeting React JSX emit e.g. 'React.Fragment' or 'Fragment'. */ 23 | // "jsxImportSource": "", /* Specify module specifier used to import the JSX factory functions when using `jsx: react-jsx*`.` */ 24 | // "reactNamespace": "", /* Specify the object invoked for `createElement`. This only applies when targeting `react` JSX emit. */ 25 | // "noLib": true, /* Disable including any library files, including the default lib.d.ts. */ 26 | // "useDefineForClassFields": true, /* Emit ECMAScript-standard-compliant class fields. */ 27 | 28 | /* Modules */ 29 | "module": "es2022" /* Specify what module code is generated. */, 30 | // "rootDir": "./", /* Specify the root folder within your source files. */ 31 | "moduleResolution": "node" /* Specify how TypeScript looks up a file from a given module specifier. */, 32 | // "baseUrl": "./", /* Specify the base directory to resolve non-relative module names. */ 33 | // "paths": {}, /* Specify a set of entries that re-map imports to additional lookup locations. */ 34 | // "rootDirs": [], /* Allow multiple folders to be treated as one when resolving modules. */ 35 | // "typeRoots": [], /* Specify multiple folders that act like `./node_modules/@types`. */ 36 | "types": [ 37 | "@cloudflare/workers-types" 38 | ] /* Specify type package names to be included without being referenced in a source file. */, 39 | // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ 40 | "resolveJsonModule": true /* Enable importing .json files */, 41 | // "noResolve": true, /* Disallow `import`s, `require`s or ``s from expanding the number of files TypeScript should add to a project. */ 42 | 43 | /* JavaScript Support */ 44 | "allowJs": true /* Allow JavaScript files to be a part of your program. Use the `checkJS` option to get errors from these files. */, 45 | "checkJs": false /* Enable error reporting in type-checked JavaScript files. */, 46 | // "maxNodeModuleJsDepth": 1, /* Specify the maximum folder depth used for checking JavaScript files from `node_modules`. Only applicable with `allowJs`. */ 47 | 48 | /* Emit */ 49 | // "declaration": true, /* Generate .d.ts files from TypeScript and JavaScript files in your project. */ 50 | // "declarationMap": true, /* Create sourcemaps for d.ts files. */ 51 | // "emitDeclarationOnly": true, /* Only output d.ts files and not JavaScript files. */ 52 | // "sourceMap": true, /* Create source map files for emitted JavaScript files. */ 53 | // "outFile": "./", /* Specify a file that bundles all outputs into one JavaScript file. If `declaration` is true, also designates a file that bundles all .d.ts output. */ 54 | // "outDir": "./", /* Specify an output folder for all emitted files. */ 55 | // "removeComments": true, /* Disable emitting comments. */ 56 | "noEmit": true /* Disable emitting files from a compilation. */, 57 | // "importHelpers": true, /* Allow importing helper functions from tslib once per project, instead of including them per-file. */ 58 | // "importsNotUsedAsValues": "remove", /* Specify emit/checking behavior for imports that are only used for types */ 59 | // "downlevelIteration": true, /* Emit more compliant, but verbose and less performant JavaScript for iteration. */ 60 | // "sourceRoot": "", /* Specify the root path for debuggers to find the reference source code. */ 61 | // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ 62 | // "inlineSourceMap": true, /* Include sourcemap files inside the emitted JavaScript. */ 63 | // "inlineSources": true, /* Include source code in the sourcemaps inside the emitted JavaScript. */ 64 | // "emitBOM": true, /* Emit a UTF-8 Byte Order Mark (BOM) in the beginning of output files. */ 65 | // "newLine": "crlf", /* Set the newline character for emitting files. */ 66 | // "stripInternal": true, /* Disable emitting declarations that have `@internal` in their JSDoc comments. */ 67 | // "noEmitHelpers": true, /* Disable generating custom helper functions like `__extends` in compiled output. */ 68 | // "noEmitOnError": true, /* Disable emitting files if any type checking errors are reported. */ 69 | // "preserveConstEnums": true, /* Disable erasing `const enum` declarations in generated code. */ 70 | // "declarationDir": "./", /* Specify the output directory for generated declaration files. */ 71 | // "preserveValueImports": true, /* Preserve unused imported values in the JavaScript output that would otherwise be removed. */ 72 | 73 | /* Interop Constraints */ 74 | "isolatedModules": true /* Ensure that each file can be safely transpiled without relying on other imports. */, 75 | "allowSyntheticDefaultImports": true /* Allow 'import x from y' when a module doesn't have a default export. */, 76 | // "esModuleInterop": true /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables `allowSyntheticDefaultImports` for type compatibility. */, 77 | // "preserveSymlinks": true, /* Disable resolving symlinks to their realpath. This correlates to the same flag in node. */ 78 | "forceConsistentCasingInFileNames": true /* Ensure that casing is correct in imports. */, 79 | 80 | /* Type Checking */ 81 | "strict": true /* Enable all strict type-checking options. */, 82 | // "noImplicitAny": true, /* Enable error reporting for expressions and declarations with an implied `any` type.. */ 83 | // "strictNullChecks": true, /* When type checking, take into account `null` and `undefined`. */ 84 | // "strictFunctionTypes": true, /* When assigning functions, check to ensure parameters and the return values are subtype-compatible. */ 85 | // "strictBindCallApply": true, /* Check that the arguments for `bind`, `call`, and `apply` methods match the original function. */ 86 | // "strictPropertyInitialization": true, /* Check for class properties that are declared but not set in the constructor. */ 87 | // "noImplicitThis": true, /* Enable error reporting when `this` is given the type `any`. */ 88 | // "useUnknownInCatchVariables": true, /* Type catch clause variables as 'unknown' instead of 'any'. */ 89 | // "alwaysStrict": true, /* Ensure 'use strict' is always emitted. */ 90 | // "noUnusedLocals": true, /* Enable error reporting when a local variables aren't read. */ 91 | // "noUnusedParameters": true, /* Raise an error when a function parameter isn't read */ 92 | // "exactOptionalPropertyTypes": true, /* Interpret optional property types as written, rather than adding 'undefined'. */ 93 | // "noImplicitReturns": true, /* Enable error reporting for codepaths that do not explicitly return in a function. */ 94 | // "noFallthroughCasesInSwitch": true, /* Enable error reporting for fallthrough cases in switch statements. */ 95 | // "noUncheckedIndexedAccess": true, /* Include 'undefined' in index signature results */ 96 | // "noImplicitOverride": true, /* Ensure overriding members in derived classes are marked with an override modifier. */ 97 | // "noPropertyAccessFromIndexSignature": true, /* Enforces using indexed accessors for keys declared using an indexed type */ 98 | // "allowUnusedLabels": true, /* Disable error reporting for unused labels. */ 99 | // "allowUnreachableCode": true, /* Disable error reporting for unreachable code. */ 100 | 101 | /* Completeness */ 102 | // "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */ 103 | "skipLibCheck": true /* Skip type checking all .d.ts files. */ 104 | } 105 | } 106 | -------------------------------------------------------------------------------- /consumer/wrangler.toml: -------------------------------------------------------------------------------- 1 | name = "queues-web-crawler-consumer" 2 | main = "src/index.ts" 3 | compatibility_date = "2023-06-09" 4 | node_compat = true 5 | usage_model = "unbound" 6 | 7 | browser = { binding = "CRAWLER_BROWSER", type = "browser" } 8 | kv_namespaces = [ 9 | { binding = "CRAWLER_SCREENSHOTS_KV", id = "", preview_id = "" }, 10 | { binding = "CRAWLER_LINKS_KV", id = "", preview_id = "" } 11 | ] 12 | 13 | [[queues.consumers]] 14 | queue = "" 15 | max_batch_timeout = 60 16 | 17 | [[queues.producers]] 18 | queue = "" 19 | binding = "CRAWLER_QUEUE" 20 | -------------------------------------------------------------------------------- /img/Products-Diagram.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/cloudflare/queues-web-crawler/7d9bd009881e26e852ae850d739a70837df0dd67/img/Products-Diagram.png -------------------------------------------------------------------------------- /pages/functions/page/[url].js: -------------------------------------------------------------------------------- 1 | export async function onRequest(context) { 2 | const url = decodeURIComponent(context.params.url); 3 | 4 | const keys = await context.env.CRAWLER_LINKS_KV.list({ 5 | prefix: context.params.url, 6 | }); 7 | 8 | const uint8ToBase64 = (data) => { 9 | let result = ""; 10 | for (let index = 0; index < data.length; index += 0x8000) { 11 | const slice = data.subarray(index, Math.min(index + 0x8000, data.length)); 12 | result += String.fromCharCode.apply(null, slice); 13 | } 14 | return btoa(result); 15 | }; 16 | 17 | let result = []; 18 | for (const key of keys.keys) { 19 | const screenshot = await context.env.CRAWLER_SCREENSHOTS_KV.get(key.name, { 20 | type: "arrayBuffer", 21 | }); 22 | try { 23 | result.push({ 24 | key: parseInt(key.name.split("-")[1]), 25 | numCloudflareLinks: 26 | (await context.env.CRAWLER_LINKS_KV.get(key.name)) ?? "-", 27 | screenshot: screenshot ? uint8ToBase64(new Uint8Array(screenshot)) : "", // Base64 encode screenshot contents 28 | }); 29 | } catch (e) { 30 | return new Response(JSON.stringify({ e: e.message })); 31 | } 32 | } 33 | 34 | // KVNamespace.list() orders by lexographical order, and because keys are in the form `{url}-{unix timestamp}`, the results for a given url will be ordered from oldest to newest 35 | result.reverse(); // but we want reverse chronological order! 36 | 37 | let tableString = ""; 38 | for (const res of result) { 39 | tableString = tableString.concat( 40 | `${new Date(res.key).toString()}${ 41 | res.numCloudflareLinks 42 | }` 43 | ); 44 | } 45 | 46 | const html = ` 47 | 48 | 49 | 50 | Queues Web Crawler: ${url} Results 51 | 55 | 56 | 66 |
67 |

Queues Web Crawler: ${url} Results

68 |

Results, from newest to oldest. If there aren't any results, you may need to request that the page be crawled here. Pages are crawled a maximum of once per hour.

69 | 70 | 71 | 72 | 73 | 74 | 75 | 76 | 77 | ${tableString} 78 |
DateNumber of Cloudflare.com LinksScreenshot
79 |
80 | 81 | `; 82 | 83 | return new Response(html, { 84 | headers: { 85 | "content-type": "text/html;charset=UTF-8", 86 | }, 87 | }); 88 | } 89 | -------------------------------------------------------------------------------- /pages/functions/requestToCrawlSite.js: -------------------------------------------------------------------------------- 1 | export async function onRequest(context) { 2 | const urlParams = new URL(context.request.url).searchParams; 3 | const url = urlParams.get("url"); 4 | 5 | if (!url) { 6 | return new Response("No URL provided.", { status: 400 }); 7 | } 8 | 9 | await context.env.CRAWLER_QUEUE.send({ 10 | url, 11 | }); 12 | 13 | return new Response( 14 | `Sent! Go to .pages.dev/page/${encodeURIComponent( 15 | url 16 | )} to see results` 17 | ); 18 | } 19 | -------------------------------------------------------------------------------- /pages/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | Queues Web Crawler Example 6 | 10 | 11 | 21 |
22 |

Queues Web Crawler Example

23 |

24 | A web crawler + archiving tool built with 25 | Queues, 26 | Pages Functions, and 29 | Browser Rendering. A Pages Function bound to a Queue sends the requested site to the 32 | Queue, which uses Browser Rendering and Puppeteer to do some crawling. A 33 | Worker consuming from the Queue archives some site details to Workers 34 | KV. 35 |

36 |
37 | 38 | 39 | 40 |
41 |
42 | 43 | 44 | 50 | 51 | 67 | 68 | --------------------------------------------------------------------------------