├── .gitattributes ├── .prettierrc ├── serve-robots ├── robots-files │ ├── paste.pythondiscord.com │ └── www.pythondiscord.com ├── package.json ├── wrangler.toml ├── update_robots.sh ├── tsconfig.json ├── src │ └── worker.ts ├── README.md └── package-lock.json ├── url-unfurler ├── .prettierrc ├── wrangler.toml ├── tsconfig.json ├── package.json ├── README.md └── src │ └── index.ts ├── .gitignore ├── report-uri ├── wrangler.toml ├── README.md ├── package.json ├── tsconfig.json ├── src │ └── index.ts └── package-lock.json ├── short-urls ├── wrangler.toml ├── tsconfig.json ├── package.json ├── README.md ├── src │ └── index.ts └── package-lock.json ├── README.md ├── .github ├── workflows │ ├── main.yaml │ ├── lint.yaml │ └── deploy.yaml └── dependabot.yml └── LICENSE /.gitattributes: -------------------------------------------------------------------------------- 1 | * text=auto 2 | -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "printWidth": 140, 3 | "singleQuote": false, 4 | "semi": true, 5 | "useTabs": false 6 | } 7 | -------------------------------------------------------------------------------- /serve-robots/robots-files/paste.pythondiscord.com: -------------------------------------------------------------------------------- 1 | User-agent: * 2 | Allow: /$ 3 | Allow: /about 4 | Allow: /removal 5 | Disallow: / 6 | -------------------------------------------------------------------------------- /serve-robots/robots-files/www.pythondiscord.com: -------------------------------------------------------------------------------- 1 | User-agent: * 2 | Disallow: /api/ 3 | Disallow: /staff/ 4 | Disallow: /admin/ 5 | Allow: / 6 | -------------------------------------------------------------------------------- /url-unfurler/.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "singleQuote": true, 3 | "semi": false, 4 | "trailingComma": "all", 5 | "tabWidth": 2, 6 | "printWidth": 80 7 | } 8 | -------------------------------------------------------------------------------- /url-unfurler/wrangler.toml: -------------------------------------------------------------------------------- 1 | name = "url-unfurler" 2 | account_id = "502aea548379e08369697540cc0bb0d1" 3 | workers_dev = true 4 | compatibility_date = "2023-09-04" 5 | main = "src/index.ts" 6 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # General 2 | worker/ 3 | *.log 4 | 5 | # Build output 6 | dist/ 7 | build/ 8 | 9 | # Javascript Workers 10 | node_modules/ 11 | transpiled/ 12 | 13 | # Rust workers 14 | target/ 15 | **/*.rs.bk 16 | -------------------------------------------------------------------------------- /report-uri/wrangler.toml: -------------------------------------------------------------------------------- 1 | name = "report-uri" 2 | main = "src/index.ts" 3 | compatibility_date = "2023-09-04" 4 | account_id = "502aea548379e08369697540cc0bb0d1" 5 | routes = [{ pattern = "csp.pythondiscord.com", custom_domain = true }] 6 | -------------------------------------------------------------------------------- /short-urls/wrangler.toml: -------------------------------------------------------------------------------- 1 | name = "short-urls" 2 | main = "src/index.ts" 3 | compatibility_date = "2023-09-04" 4 | account_id = "502aea548379e08369697540cc0bb0d1" 5 | workers_dev = false 6 | routes = [{ pattern = "pydis.com", custom_domain = true }] 7 | kv_namespaces = [{ binding = "urls", id = "c6d38750203b40e89579731430d22429" }] 8 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # 👷 Workers 2 | Cloudflare Workers in use at Python Discord. 3 | 4 | READMEs in respective directories have instructions on deployment and usage. 5 | 6 | All workers are licensed under MIT. 7 | 8 | ## Deployment 9 | 10 | All workers are linted on Pull Requests and deployed to Cloudflare automatically upon merge. 11 | -------------------------------------------------------------------------------- /.github/workflows/main.yaml: -------------------------------------------------------------------------------- 1 | name: CI 2 | 3 | on: 4 | push: 5 | branches: 6 | - main 7 | pull_request: 8 | merge_group: 9 | 10 | concurrency: 11 | group: ${{ github.workflow }}-${{ github.ref }} 12 | cancel-in-progress: true 13 | 14 | jobs: 15 | lint: 16 | uses: ./.github/workflows/lint.yaml 17 | 18 | build-deploy: 19 | uses: ./.github/workflows/deploy.yaml 20 | needs: 21 | - lint 22 | secrets: inherit 23 | -------------------------------------------------------------------------------- /serve-robots/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "serve-robots", 3 | "version": "1.0.0", 4 | "scripts": { 5 | "deploy": "wrangler deploy", 6 | "start": "wrangler dev", 7 | "format": "prettier --write .", 8 | "lint": "prettier --check ." 9 | }, 10 | "devDependencies": { 11 | "@cloudflare/workers-types": "^4.20240405.0", 12 | "prettier": "^3.2.5", 13 | "typescript": "^5.4.5", 14 | "wrangler": "^3.48.0" 15 | } 16 | } 17 | -------------------------------------------------------------------------------- /serve-robots/wrangler.toml: -------------------------------------------------------------------------------- 1 | name = "serve-robots" 2 | main = "src/worker.ts" 3 | account_id = "502aea548379e08369697540cc0bb0d1" 4 | compatibility_date = "2023-09-04" 5 | routes = [ 6 | { pattern = "*pythondiscord.com/robots.txt", zone_id = "989c984a358bfcd1e9b9d188cc86c1df" }, 7 | "www.pythondiscord.com/robots.txt", 8 | ] 9 | kv_namespaces = [ 10 | { binding = "robots_files", id = "f37779daf76a4cafbed199b8746dfe69" }, 11 | ] 12 | workers_dev = false 13 | -------------------------------------------------------------------------------- /report-uri/README.md: -------------------------------------------------------------------------------- 1 | # 👷 Report URI 2 | 3 | This worker proxies CSP and other report URI requests over Cloudflare Workers to anonymise the origin. 4 | 5 | ## Deployment 6 | 7 | Install local dependencies with `npm install`. 8 | 9 | Login to wrangler with `npx wrangler login`. 10 | 11 | After you've authorised, you can make modifications to the worker and run `npm run deploy` to deploy. 12 | 13 | ## Usage 14 | 15 | Once the worker is activated it will respond to requests at `csp.pythondiscord.com`. 16 | -------------------------------------------------------------------------------- /report-uri/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "report-uri", 3 | "version": "1.0.0", 4 | "description": "Python Discord report URI", 5 | "scripts": { 6 | "deploy": "wrangler deploy", 7 | "start": "wrangler dev", 8 | "format": "prettier --write .", 9 | "lint": "prettier --check ." 10 | }, 11 | "author": "Joe Banks", 12 | "license": "MIT", 13 | "devDependencies": { 14 | "@cloudflare/workers-types": "^4.20240405.0", 15 | "prettier": "^3.2.5", 16 | "typescript": "^5.4.5", 17 | "wrangler": "^3.48.0" 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /serve-robots/update_robots.sh: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | set -euo pipefail 3 | 4 | DEL_FILE=$(mktemp) 5 | ROBOTS_FILE=$(mktemp) 6 | 7 | echo "Removing all keys from Cloudflare KV" 8 | npx wrangler kv:key list --binding=robots_files | jq -r '[.[] | .name]' > $DEL_FILE 9 | npx wrangler kv:bulk delete --binding=robots_files $DEL_FILE -f 10 | 11 | echo "== Adding robots.txt files ==" 12 | 13 | for file in $(find ./robots-files -type f); do 14 | echo "Processing $file" 15 | npx wrangler kv:key put --binding=robots_files $(basename $file) "$(cat $file)" 16 | done 17 | -------------------------------------------------------------------------------- /report-uri/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es2021", 4 | "lib": ["es2021"], 5 | "jsx": "react", 6 | "module": "es2022", 7 | "moduleResolution": "node", 8 | "types": ["@cloudflare/workers-types"], 9 | "resolveJsonModule": true, 10 | "allowJs": true, 11 | "checkJs": false, 12 | "noEmit": true, 13 | "isolatedModules": true, 14 | "allowSyntheticDefaultImports": true, 15 | "forceConsistentCasingInFileNames": true, 16 | "strict": true, 17 | "skipLibCheck": true 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /serve-robots/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es2021", 4 | "lib": ["es2021"], 5 | "jsx": "react", 6 | "module": "es2022", 7 | "moduleResolution": "node", 8 | "types": ["@cloudflare/workers-types"], 9 | "resolveJsonModule": true, 10 | "allowJs": true, 11 | "checkJs": false, 12 | "noEmit": true, 13 | "isolatedModules": true, 14 | "allowSyntheticDefaultImports": true, 15 | "forceConsistentCasingInFileNames": true, 16 | "strict": true, 17 | "skipLibCheck": true 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /short-urls/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es2021", 4 | "lib": ["es2021"], 5 | "jsx": "react", 6 | "module": "es2022", 7 | "moduleResolution": "node", 8 | "types": ["@cloudflare/workers-types"], 9 | "resolveJsonModule": true, 10 | "allowJs": true, 11 | "checkJs": false, 12 | "noEmit": true, 13 | "isolatedModules": true, 14 | "allowSyntheticDefaultImports": true, 15 | "forceConsistentCasingInFileNames": true, 16 | "strict": true, 17 | "skipLibCheck": true 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /url-unfurler/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es2021", 4 | "lib": ["es2021"], 5 | "jsx": "react", 6 | "module": "es2022", 7 | "moduleResolution": "node", 8 | "types": ["@cloudflare/workers-types"], 9 | "resolveJsonModule": true, 10 | "allowJs": true, 11 | "checkJs": false, 12 | "noEmit": true, 13 | "isolatedModules": true, 14 | "allowSyntheticDefaultImports": true, 15 | "forceConsistentCasingInFileNames": true, 16 | "strict": true, 17 | "skipLibCheck": true 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /serve-robots/src/worker.ts: -------------------------------------------------------------------------------- 1 | interface Env { 2 | robots_files: KVNamespace; 3 | } 4 | 5 | export default { 6 | async fetch(request: Request, env: Env, ctx: ExecutionContext): Promise { 7 | let hostname = new URL(request.url).hostname; 8 | let robots; 9 | if ((robots = await env.robots_files.get(hostname))) { 10 | return new Response(robots, { 11 | headers: { 12 | "Content-Type": "text/plain", 13 | }, 14 | }); 15 | } else { 16 | return await fetch(request.url, request); 17 | } 18 | }, 19 | }; 20 | -------------------------------------------------------------------------------- /.github/workflows/lint.yaml: -------------------------------------------------------------------------------- 1 | name: Lint Workers 2 | 3 | on: 4 | workflow_call: 5 | 6 | jobs: 7 | lint: 8 | name: Lint code 9 | runs-on: ubuntu-latest 10 | steps: 11 | - uses: actions/checkout@v4 12 | - name: Install dependencies for all sub-workers 13 | run: find . -mindepth 1 -maxdepth 1 -type d -not -path '*/.*' -exec sh -c 'cd {} && npm install' \; 14 | - name: Run lint task for all workers 15 | run: xargs -n1 -r0a <(find . -mindepth 1 -maxdepth 1 -type d -not -path '*/.*' -print0) sh -c 'for file do cd $file && npm run lint && cd ..; done;' sh 16 | -------------------------------------------------------------------------------- /short-urls/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "short-urls", 3 | "version": "1.0.0", 4 | "description": "Short URLs for Python Discord", 5 | "scripts": { 6 | "deploy": "wrangler deploy", 7 | "start": "wrangler dev", 8 | "format": "prettier --write .", 9 | "lint": "prettier --check ." 10 | }, 11 | "author": "Joe Banks", 12 | "license": "MIT", 13 | "devDependencies": { 14 | "@cloudflare/workers-types": "^4.20240405.0", 15 | "prettier": "^3.2.5", 16 | "typescript": "^5.4.5", 17 | "wrangler": "^3.48.0" 18 | }, 19 | "dependencies": { 20 | "@cloudflare/workers-honeycomb-logger": "^2.3.3" 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /url-unfurler/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "url-unfurler", 3 | "version": "1.0.0", 4 | "description": "Find the root of an HTTP redirect chain.", 5 | "scripts": { 6 | "deploy": "wrangler deploy", 7 | "start": "wrangler dev", 8 | "format": "prettier --write .", 9 | "lint": "prettier --check ." 10 | }, 11 | "author": "Hassan Abouelela", 12 | "license": "MIT", 13 | "devDependencies": { 14 | "@cloudflare/workers-types": "^4.20240405.0", 15 | "prettier": "^3.2.5", 16 | "typescript": "^5.4.5", 17 | "wrangler": "^3.48.0" 18 | }, 19 | "dependencies": { 20 | "@cloudflare/workers-honeycomb-logger": "^2.3.3" 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /report-uri/src/index.ts: -------------------------------------------------------------------------------- 1 | import type { Request as WorkerRequest, ExecutionContext as WorkerExecutionContext, RequestInit } from "@cloudflare/workers-types"; 2 | 3 | export default { 4 | async fetch(req: WorkerRequest, _env: unknown, _ctx: WorkerExecutionContext) { 5 | let newHdrs = new Headers(); 6 | newHdrs.set("User-Agent", req.headers.get("User-Agent")!); 7 | 8 | const init = { 9 | body: req.body, 10 | headers: newHdrs, 11 | method: "POST", 12 | }; 13 | 14 | let path = new URL(req.url).pathname; 15 | let address = "https://pythondiscord.report-uri.com" + path; 16 | let response = await fetch(address, init); 17 | 18 | return new Response(response.body, { 19 | status: response.status, 20 | statusText: response.statusText, 21 | }); 22 | }, 23 | }; 24 | -------------------------------------------------------------------------------- /.github/workflows/deploy.yaml: -------------------------------------------------------------------------------- 1 | name: Deploy Workers 2 | 3 | on: 4 | workflow_call: 5 | 6 | jobs: 7 | deploy: 8 | name: Deploy Workers 9 | if: ${{ github.ref == 'refs/heads/main' }} 10 | environment: production 11 | runs-on: ubuntu-latest 12 | steps: 13 | - uses: actions/checkout@v4 14 | 15 | - name: Install dependencies for all sub-workers 16 | run: find . -mindepth 1 -maxdepth 1 -type d -not -path '*/.*' -exec sh -c 'cd {} && npm install' \; 17 | 18 | - name: Deploy workers to Cloudflare Edge 19 | run: xargs -n1 -r0a <(find . -mindepth 1 -maxdepth 1 -type d -not -path '*/.*' -print0) sh -c 'for file do cd $file && npm run deploy && cd ..; done;' sh 20 | env: 21 | CLOUDFLARE_ACCOUNT_ID: 502aea548379e08369697540cc0bb0d1 22 | CLOUDFLARE_API_TOKEN: ${{ secrets.CF_API_TOKEN }} 23 | -------------------------------------------------------------------------------- /serve-robots/README.md: -------------------------------------------------------------------------------- 1 | # 👷 Serve Robots 2 | 3 | This worker servers `robots.txt` files at any domain proxied through Cloudflare with a matching file in the `robots-files` folder. Matching is performed on the hostname. 4 | 5 | ## Deployment 6 | 7 | Install local dependencies with `npm install`. 8 | 9 | Login to wrangler with `npx wrangler login`. 10 | 11 | After you've authorised, you can make modifications to the worker and run `npm run deploy` to deploy. 12 | 13 | ## Usage 14 | 15 | Create files in `robots-files` with the hostname of the desired service. Ensure they are proxied through Cloudflare. 16 | 17 | Run the `./update_robots.sh` bash script on a system with NPM installed and wrangler logged in to push new robots.txt files to the Cloudflare KV storage. 18 | 19 | Changes should be live within a few seconds at `/robots.txt` on your provisioned domain. 20 | -------------------------------------------------------------------------------- /short-urls/README.md: -------------------------------------------------------------------------------- 1 | # Short URLs 2 | 3 | This worker handles short URls redirection on pydis.com (for example, https://pydis.com/admin). 4 | 5 | URLs are stored in Workers KV and can be added in the Cloudflare Dashboard or through the Wrangler CLI. 6 | 7 | ## Publishing 8 | 9 | You need to install `wrangler` with `npm install -g @cloudflare/wrangler`. 10 | 11 | Once you've installed this run `wrangler login`. 12 | 13 | After you've authorised, you can make modifications to the worker and run `wrangler publish` to push them to the edge. 14 | 15 | ### Environment Variables 16 | 17 | The following environment variables are required: 18 | 19 | | Key | Description | 20 | | ------------------- | -------------------------------------- | 21 | | `HONEYCOMB_API_KEY` | API Key for Honeycomb tracing platform | 22 | 23 | ## Adding new URLs with wrangler 24 | 25 | Change directory to the root of this worker and run: 26 | 27 | ``` 28 | $ npx wrangler kv:key put --binding urls 29 | ``` 30 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2021 Python Discord 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /.github/dependabot.yml: -------------------------------------------------------------------------------- 1 | version: 2 2 | updates: 3 | - package-ecosystem: "npm" 4 | directory: "/report-uri" 5 | schedule: 6 | interval: "daily" 7 | groups: 8 | production-dependencies: 9 | dependency-type: "production" 10 | development-dependencies: 11 | dependency-type: "development" 12 | - package-ecosystem: "npm" 13 | directory: "/serve-robots" 14 | schedule: 15 | interval: "daily" 16 | groups: 17 | production-dependencies: 18 | dependency-type: "production" 19 | development-dependencies: 20 | dependency-type: "development" 21 | - package-ecosystem: "npm" 22 | directory: "/short-urls" 23 | schedule: 24 | interval: "daily" 25 | groups: 26 | production-dependencies: 27 | dependency-type: "production" 28 | development-dependencies: 29 | dependency-type: "development" 30 | - package-ecosystem: "npm" 31 | directory: "/url-unfurler" 32 | schedule: 33 | interval: "daily" 34 | groups: 35 | production-dependencies: 36 | dependency-type: "production" 37 | development-dependencies: 38 | dependency-type: "development" 39 | -------------------------------------------------------------------------------- /short-urls/src/index.ts: -------------------------------------------------------------------------------- 1 | import { Config, wrapModule } from "@cloudflare/workers-honeycomb-logger"; 2 | 3 | const hcConfig: Config = { 4 | dataset: "worker-short-urls", 5 | sampleRates: { 6 | "1xx": 1, 7 | "2xx": 1, 8 | "3xx": 1, 9 | "4xx": 1, 10 | "5xx": 1, 11 | exception: 1, 12 | }, 13 | }; 14 | 15 | interface Env { 16 | urls: KVNamespace; 17 | } 18 | 19 | const worker = { 20 | async fetch(request: Request, env: Env, ctx: ExecutionContext): Promise { 21 | let path = new URL(request.url).pathname.slice(1).replace(/\//, ""); 22 | 23 | if (!path) { 24 | request.tracer.log("No path, forwarding to host."); 25 | return await request.tracer.fetch(request.url, request); 26 | } 27 | 28 | request.tracer.log("Fetching from KV"); 29 | let redirect = await env.urls.get(path); 30 | 31 | request.tracer.addData({ path: path }); 32 | 33 | if (redirect) { 34 | request.tracer.log(`Path found for ${path}, redirecting.`); 35 | return Response.redirect(redirect, 302); 36 | } else { 37 | request.tracer.log(`No path found, forwarding to origin.`); 38 | return await request.tracer.fetch(request.url, request); 39 | } 40 | }, 41 | }; 42 | 43 | export default wrapModule(hcConfig, worker); 44 | -------------------------------------------------------------------------------- /url-unfurler/README.md: -------------------------------------------------------------------------------- 1 | # 👷 URL Unfurler 2 | 3 | This worker unfurls redirects to return the destination address. It will follow any number of redirects to reach the source. 4 | 5 | This can be useful for finding out what's behind a shortened link, or any other deliberately hidden address. 6 | 7 | ## Deployment 8 | 9 | Install dependencies with `npm install`. 10 | 11 | Once you've installed this run `npx wrangler login`. 12 | 13 | After you've authorised, you can make modifications to the worker and run `npm run deploy` to push them to the edge. 14 | 15 | ### Environment Variables 16 | 17 | The following environment variables are required: 18 | 19 | | Key | Description | 20 | | ------------------- | -------------------------------------- | 21 | | `HONEYCOMB_API_KEY` | API Key for Honeycomb tracing platform | 22 | 23 | ## Usage 24 | 25 | You can utilize this worker by making a POST request to `https://example.com/`. 26 | The JSON body should include a `url` key representing the URL to unfurl, 27 | and optionally a `max-depth` key representing how many redirects to follow before giving up. 28 | The default max-depth if not specified is `6`. 29 | 30 | The worker will try to unfurl nested redirects as far as it can, but it may timeout before it reaches the end. 31 | In those cases, you should be prepared to handle errors. The worker may also throw other errors on invalid input. 32 | 33 | > Warning: This worker doesn't cache anything, and will blindly attempt to unfurl any url you give it. 34 | > If ratelimits or speed are concerns, make sure you do caching elsewhere. 35 | 36 | ## Return Values 37 | 38 | The worker defines the response status codes listed in the table below. 39 | Clicking on any of the status codes will take you to the section with more details 40 | about the causes, and expected output of those codes. 41 | 42 | | Code | Description | 43 | | ----------- | ------------------------------ | 44 | | [200](#200) | Success. | 45 | | [400](#400) | Input error. | 46 | | [416](#416) | Max depth reached. | 47 | | [418](#418) | Unset location, panic! | 48 | | 5xx | Internal error, please report. | 49 | 50 | ### 200 51 | 52 | This is returned if: 53 | 54 | - You've made a non-POST request to the server. Make a POST request instead. 55 | - We've managed to successfully unfurl the redirect. 56 | 57 | You can expect the following JSON response if it's the latter: 58 | 59 | ```json 60 | { 61 | "destination": "The actual URL behind the redirects.", 62 | "depth": "int. The actual number of redirects followed." 63 | } 64 | ``` 65 | 66 | ### 400 67 | 68 | If you receive this error, it can indicate one of multiple things. 69 | It can either indicate an error with the input you passed in, or an error fetching some URL. 70 | 71 | In the case of a 400, expect a JSON response body as follows: 72 | 73 | ```JSON 74 | { 75 | "error": "Explanation of what went wrong." 76 | } 77 | ``` 78 | 79 | ### 416 80 | 81 | This error indicates that the worker has hit the maximum redirects allowable, 82 | be that the one set by `max-depth`, or other system limitations. 83 | 84 | In this case, expect the following JSON response body: 85 | 86 | ```JSON 87 | { 88 | "error": "Details about the type of limit hit.", 89 | "depth": "int. Current depth at time of failure", 90 | "final": "The final URL we made a request to, before reaching the limit.", 91 | "next": "The next URL in the chain. Can be useful if you intend on continuing in another worker." 92 | } 93 | ``` 94 | 95 | ### 418 96 | 97 | You should theoretically never have to deal with this error. If a request returns 98 | a 301 or 301, it is expected to return a `location` header. If it does not, 99 | no browser will follow the redirect, and the link will be broken. 100 | 101 | This sort of thing is either the work of a bug in the redirection, 102 | or a computer scientist looking to prove a point. Either way, you should panic! 103 | 104 | Expect the following JSON response body: 105 | 106 | ```JSON 107 | { 108 | "error": "Details about the error.", 109 | "depth": "int. Current depth at time of failure", 110 | "final": "The URL which returned the missing location header." 111 | } 112 | ``` 113 | -------------------------------------------------------------------------------- /url-unfurler/src/index.ts: -------------------------------------------------------------------------------- 1 | import { Config, wrapModule } from '@cloudflare/workers-honeycomb-logger' 2 | 3 | const DEFAULT_MAX_REDIRECTS = 6 4 | 5 | const JSON_HEADERS = { 6 | 'Content-Type': 'application/json', 7 | } 8 | 9 | const hcConfig: Config = { 10 | dataset: 'worker-url-unfurler', 11 | sampleRates: { 12 | '1xx': 1, 13 | '2xx': 20, 14 | '3xx': 20, 15 | '4xx': 5, 16 | '5xx': 1, 17 | exception: 1, 18 | }, 19 | } 20 | 21 | /** 22 | * Try and get input from the request body. 23 | * Any errors produced by this function are meant for the end user. 24 | * 25 | * @param request The POST request received in event. 26 | * @return [string, number] An array of the URL and depth limit. 27 | */ 28 | async function parseInput(request: Request): Promise<[string, number]> { 29 | // Try to read the body of the request 30 | let body 31 | try { 32 | body = JSON.parse(await request.text()) 33 | 34 | // eslint-disable-next-line @typescript-eslint/no-explicit-any 35 | } catch (error: any) { 36 | throw new Error(`Could not parse body, error: ${error.message}`) 37 | } 38 | 39 | // Validate input 40 | let url = body['url'] 41 | if (url === undefined) { 42 | throw new Error('Invalid input, `url` key not found in body.') 43 | } 44 | 45 | if (!(url.startsWith('http://') || url.startsWith('https://'))) { 46 | url = 'https://' + url 47 | } 48 | 49 | let max_depth = body['max-depth'] 50 | if (max_depth === undefined) { 51 | max_depth = DEFAULT_MAX_REDIRECTS 52 | } 53 | 54 | const _max_depth = Number.parseInt(max_depth) 55 | if (isNaN(_max_depth)) { 56 | throw new Error( 57 | `Invalid input \`max-depth: ${max_depth}\` could not be parsed as a number.`, 58 | ) 59 | } 60 | 61 | return [url, _max_depth] 62 | } 63 | 64 | /** 65 | * Unfurl a URL, as far as necessary. 66 | * 67 | * @param tracer The HoneyComb tracer from the request. 68 | * @param url The URL to unfurl. 69 | * @param max_depth How far to go before giving up. 70 | */ 71 | async function unfurl( 72 | { tracer }: Request, 73 | url: string, 74 | max_depth: number, 75 | ): Promise<[number, string?, Response?]> { 76 | let previous = undefined 77 | let next = url 78 | let new_request 79 | 80 | let depth = 0 81 | let location 82 | 83 | while (previous !== next) { 84 | // Get the next request in the chain 85 | try { 86 | new_request = await tracer.fetch(next, { redirect: 'manual' }) 87 | 88 | // eslint-disable-next-line @typescript-eslint/no-explicit-any 89 | } catch (e: any) { 90 | if (e.message.startsWith('Fetch API cannot load')) { 91 | return [ 92 | depth, 93 | undefined, 94 | new Response(JSON.stringify({ error: 'Fetch request failed.' }), { 95 | status: 400, 96 | headers: JSON_HEADERS, 97 | }), 98 | ] 99 | } else if (e.message.startsWith('Too many subrequests')) { 100 | tracer.log('Hit max depth allowed without resolving.') 101 | tracer.addData({ 102 | final_url: previous, 103 | next_url: next, 104 | depth: depth + 1, 105 | }) 106 | 107 | return [ 108 | depth, 109 | undefined, 110 | new Response( 111 | JSON.stringify({ 112 | error: 113 | 'Reached the max depth allowable for subrequests without resolving.', 114 | depth: depth, 115 | final: previous, 116 | next: next, 117 | }), 118 | { status: 416, headers: JSON_HEADERS }, 119 | ), 120 | ] 121 | } 122 | 123 | throw e 124 | } 125 | 126 | if (![301, 302, 307, 308].includes(new_request.status)) { 127 | // We've reached the bottom 128 | break 129 | } 130 | 131 | location = new_request.headers.get('location') 132 | if (location === undefined || location === null) { 133 | // No clear way to proceed, exit early 134 | tracer.log('Received a redirect without a location header.') 135 | return [ 136 | depth, 137 | undefined, 138 | new Response( 139 | JSON.stringify({ 140 | error: 141 | 'Reached an uncertain conclusion, since no location header was set.', 142 | depth: depth, 143 | final: previous ? previous : url, 144 | }), 145 | { status: 418, headers: JSON_HEADERS }, 146 | ), 147 | ] 148 | } 149 | 150 | if (!(location.startsWith('http://') || location.startsWith('https://'))) { 151 | // Relative redirect 152 | const { protocol, hostname } = new URL(next) 153 | location = protocol + '//' + hostname + location 154 | } 155 | 156 | previous = next 157 | next = location 158 | depth++ 159 | 160 | if (depth > max_depth) { 161 | return [ 162 | depth, 163 | undefined, 164 | new Response( 165 | JSON.stringify({ 166 | error: 'Reached the max depth defined without resolving.', 167 | depth: depth - 1, 168 | final: previous, 169 | next: next, 170 | }), 171 | { status: 416, headers: JSON_HEADERS }, 172 | ), 173 | ] 174 | } 175 | } 176 | 177 | return [depth, next, undefined] 178 | } 179 | 180 | const worker = { 181 | async fetch(request: Request, _env: unknown, _ctx: ExecutionContext) { 182 | if (request.method !== 'POST') { 183 | return new Response('Ignoring non-POST request.') 184 | } 185 | 186 | let url, max_depth 187 | try { 188 | ;[url, max_depth] = await parseInput(request) 189 | 190 | // eslint-disable-next-line @typescript-eslint/no-explicit-any 191 | } catch (error: any) { 192 | return new Response(JSON.stringify({ error: error.message }), { 193 | status: 400, 194 | headers: JSON_HEADERS, 195 | }) 196 | } 197 | 198 | request.tracer.addData({ original_url: url, max_depth: max_depth }) 199 | 200 | const [depth, new_url, response] = await unfurl(request, url, max_depth) 201 | if (response !== undefined) { 202 | return response 203 | } 204 | 205 | request.tracer.addData({ destination_url: new_url, actual_depth: depth }) 206 | return new Response( 207 | JSON.stringify({ destination: new_url, depth: depth }), 208 | { 209 | headers: JSON_HEADERS, 210 | }, 211 | ) 212 | }, 213 | } 214 | 215 | export default wrapModule(hcConfig, worker) 216 | -------------------------------------------------------------------------------- /serve-robots/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "serve-robots", 3 | "version": "1.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "serve-robots", 9 | "version": "1.0.0", 10 | "devDependencies": { 11 | "@cloudflare/workers-types": "^4.20240405.0", 12 | "prettier": "^3.2.5", 13 | "typescript": "^5.4.5", 14 | "wrangler": "^3.48.0" 15 | } 16 | }, 17 | "node_modules/@cloudflare/kv-asset-handler": { 18 | "version": "0.3.1", 19 | "resolved": "https://registry.npmjs.org/@cloudflare/kv-asset-handler/-/kv-asset-handler-0.3.1.tgz", 20 | "integrity": "sha512-lKN2XCfKCmpKb86a1tl4GIwsJYDy9TGuwjhDELLmpKygQhw8X2xR4dusgpC5Tg7q1pB96Eb0rBo81kxSILQMwA==", 21 | "dev": true, 22 | "dependencies": { 23 | "mime": "^3.0.0" 24 | } 25 | }, 26 | "node_modules/@cloudflare/workerd-darwin-64": { 27 | "version": "1.20240404.0", 28 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-darwin-64/-/workerd-darwin-64-1.20240404.0.tgz", 29 | "integrity": "sha512-rc/ov3I9GwgKRtUnkShNW3TIoZEPHzExrMRNlHq1VpXQRBSchHdMw8meMn54+oqgxW1AKLmPWj/c0A7EnYAsIw==", 30 | "cpu": [ 31 | "x64" 32 | ], 33 | "dev": true, 34 | "optional": true, 35 | "os": [ 36 | "darwin" 37 | ], 38 | "engines": { 39 | "node": ">=16" 40 | } 41 | }, 42 | "node_modules/@cloudflare/workerd-darwin-arm64": { 43 | "version": "1.20240404.0", 44 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-darwin-arm64/-/workerd-darwin-arm64-1.20240404.0.tgz", 45 | "integrity": "sha512-V9oPjeC2PYBCoAYnjbO2bsjT7PtzxfUHnh780FUi1r59Hwxd7FNlojwsIidA0nS/1WV5UKeJusIdrYlQbsketA==", 46 | "cpu": [ 47 | "arm64" 48 | ], 49 | "dev": true, 50 | "optional": true, 51 | "os": [ 52 | "darwin" 53 | ], 54 | "engines": { 55 | "node": ">=16" 56 | } 57 | }, 58 | "node_modules/@cloudflare/workerd-linux-64": { 59 | "version": "1.20240404.0", 60 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-linux-64/-/workerd-linux-64-1.20240404.0.tgz", 61 | "integrity": "sha512-ndO7q6G2X8uYd5byGFzow4SWPqINQcmJ7pKKATNa+9vh/YMO0of2ihPntnm9uv577l8nRiAwRkHbnsWoEI33qQ==", 62 | "cpu": [ 63 | "x64" 64 | ], 65 | "dev": true, 66 | "optional": true, 67 | "os": [ 68 | "linux" 69 | ], 70 | "engines": { 71 | "node": ">=16" 72 | } 73 | }, 74 | "node_modules/@cloudflare/workerd-linux-arm64": { 75 | "version": "1.20240404.0", 76 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-linux-arm64/-/workerd-linux-arm64-1.20240404.0.tgz", 77 | "integrity": "sha512-hto5pjKYFqFu2Rvxnh84TzgDwalBRXQSwOVHltcgqo48en9TJDCN48ZtLj2G7QTGUOMW88h+nqdbj8+P7S/GXQ==", 78 | "cpu": [ 79 | "arm64" 80 | ], 81 | "dev": true, 82 | "optional": true, 83 | "os": [ 84 | "linux" 85 | ], 86 | "engines": { 87 | "node": ">=16" 88 | } 89 | }, 90 | "node_modules/@cloudflare/workerd-windows-64": { 91 | "version": "1.20240404.0", 92 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-windows-64/-/workerd-windows-64-1.20240404.0.tgz", 93 | "integrity": "sha512-DpCLvNkOeFinKGJwv9qbyT7RLZ1168dhPx85IHSqAYVWZIszNSmNOkEDqklvoJoab01AqETrrEhwBdmjCA7qfA==", 94 | "cpu": [ 95 | "x64" 96 | ], 97 | "dev": true, 98 | "optional": true, 99 | "os": [ 100 | "win32" 101 | ], 102 | "engines": { 103 | "node": ">=16" 104 | } 105 | }, 106 | "node_modules/@cloudflare/workers-types": { 107 | "version": "4.20240405.0", 108 | "resolved": "https://registry.npmjs.org/@cloudflare/workers-types/-/workers-types-4.20240405.0.tgz", 109 | "integrity": "sha512-sEVOhyOgXUwfLkgHqbLZa/sfkSYrh7/zLmI6EZNibPaVPvAnAcItbNNl3SAlLyLKuwf8m4wAIAgu9meKWCvXjg==", 110 | "dev": true 111 | }, 112 | "node_modules/@cspotcode/source-map-support": { 113 | "version": "0.8.1", 114 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 115 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 116 | "dev": true, 117 | "dependencies": { 118 | "@jridgewell/trace-mapping": "0.3.9" 119 | }, 120 | "engines": { 121 | "node": ">=12" 122 | } 123 | }, 124 | "node_modules/@esbuild-plugins/node-globals-polyfill": { 125 | "version": "0.2.3", 126 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-globals-polyfill/-/node-globals-polyfill-0.2.3.tgz", 127 | "integrity": "sha512-r3MIryXDeXDOZh7ih1l/yE9ZLORCd5e8vWg02azWRGj5SPTuoh69A2AIyn0Z31V/kHBfZ4HgWJ+OK3GTTwLmnw==", 128 | "dev": true, 129 | "peerDependencies": { 130 | "esbuild": "*" 131 | } 132 | }, 133 | "node_modules/@esbuild-plugins/node-modules-polyfill": { 134 | "version": "0.2.2", 135 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-modules-polyfill/-/node-modules-polyfill-0.2.2.tgz", 136 | "integrity": "sha512-LXV7QsWJxRuMYvKbiznh+U1ilIop3g2TeKRzUxOG5X3YITc8JyyTa90BmLwqqv0YnX4v32CSlG+vsziZp9dMvA==", 137 | "dev": true, 138 | "dependencies": { 139 | "escape-string-regexp": "^4.0.0", 140 | "rollup-plugin-node-polyfills": "^0.2.1" 141 | }, 142 | "peerDependencies": { 143 | "esbuild": "*" 144 | } 145 | }, 146 | "node_modules/@esbuild/android-arm": { 147 | "version": "0.17.19", 148 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.19.tgz", 149 | "integrity": "sha512-rIKddzqhmav7MSmoFCmDIb6e2W57geRsM94gV2l38fzhXMwq7hZoClug9USI2pFRGL06f4IOPHHpFNOkWieR8A==", 150 | "cpu": [ 151 | "arm" 152 | ], 153 | "dev": true, 154 | "optional": true, 155 | "os": [ 156 | "android" 157 | ], 158 | "engines": { 159 | "node": ">=12" 160 | } 161 | }, 162 | "node_modules/@esbuild/android-arm64": { 163 | "version": "0.17.19", 164 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.19.tgz", 165 | "integrity": "sha512-KBMWvEZooR7+kzY0BtbTQn0OAYY7CsiydT63pVEaPtVYF0hXbUaOyZog37DKxK7NF3XacBJOpYT4adIJh+avxA==", 166 | "cpu": [ 167 | "arm64" 168 | ], 169 | "dev": true, 170 | "optional": true, 171 | "os": [ 172 | "android" 173 | ], 174 | "engines": { 175 | "node": ">=12" 176 | } 177 | }, 178 | "node_modules/@esbuild/android-x64": { 179 | "version": "0.17.19", 180 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.19.tgz", 181 | "integrity": "sha512-uUTTc4xGNDT7YSArp/zbtmbhO0uEEK9/ETW29Wk1thYUJBz3IVnvgEiEwEa9IeLyvnpKrWK64Utw2bgUmDveww==", 182 | "cpu": [ 183 | "x64" 184 | ], 185 | "dev": true, 186 | "optional": true, 187 | "os": [ 188 | "android" 189 | ], 190 | "engines": { 191 | "node": ">=12" 192 | } 193 | }, 194 | "node_modules/@esbuild/darwin-arm64": { 195 | "version": "0.17.19", 196 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.19.tgz", 197 | "integrity": "sha512-80wEoCfF/hFKM6WE1FyBHc9SfUblloAWx6FJkFWTWiCoht9Mc0ARGEM47e67W9rI09YoUxJL68WHfDRYEAvOhg==", 198 | "cpu": [ 199 | "arm64" 200 | ], 201 | "dev": true, 202 | "optional": true, 203 | "os": [ 204 | "darwin" 205 | ], 206 | "engines": { 207 | "node": ">=12" 208 | } 209 | }, 210 | "node_modules/@esbuild/darwin-x64": { 211 | "version": "0.17.19", 212 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.19.tgz", 213 | "integrity": "sha512-IJM4JJsLhRYr9xdtLytPLSH9k/oxR3boaUIYiHkAawtwNOXKE8KoU8tMvryogdcT8AU+Bflmh81Xn6Q0vTZbQw==", 214 | "cpu": [ 215 | "x64" 216 | ], 217 | "dev": true, 218 | "optional": true, 219 | "os": [ 220 | "darwin" 221 | ], 222 | "engines": { 223 | "node": ">=12" 224 | } 225 | }, 226 | "node_modules/@esbuild/freebsd-arm64": { 227 | "version": "0.17.19", 228 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.19.tgz", 229 | "integrity": "sha512-pBwbc7DufluUeGdjSU5Si+P3SoMF5DQ/F/UmTSb8HXO80ZEAJmrykPyzo1IfNbAoaqw48YRpv8shwd1NoI0jcQ==", 230 | "cpu": [ 231 | "arm64" 232 | ], 233 | "dev": true, 234 | "optional": true, 235 | "os": [ 236 | "freebsd" 237 | ], 238 | "engines": { 239 | "node": ">=12" 240 | } 241 | }, 242 | "node_modules/@esbuild/freebsd-x64": { 243 | "version": "0.17.19", 244 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.19.tgz", 245 | "integrity": "sha512-4lu+n8Wk0XlajEhbEffdy2xy53dpR06SlzvhGByyg36qJw6Kpfk7cp45DR/62aPH9mtJRmIyrXAS5UWBrJT6TQ==", 246 | "cpu": [ 247 | "x64" 248 | ], 249 | "dev": true, 250 | "optional": true, 251 | "os": [ 252 | "freebsd" 253 | ], 254 | "engines": { 255 | "node": ">=12" 256 | } 257 | }, 258 | "node_modules/@esbuild/linux-arm": { 259 | "version": "0.17.19", 260 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.19.tgz", 261 | "integrity": "sha512-cdmT3KxjlOQ/gZ2cjfrQOtmhG4HJs6hhvm3mWSRDPtZ/lP5oe8FWceS10JaSJC13GBd4eH/haHnqf7hhGNLerA==", 262 | "cpu": [ 263 | "arm" 264 | ], 265 | "dev": true, 266 | "optional": true, 267 | "os": [ 268 | "linux" 269 | ], 270 | "engines": { 271 | "node": ">=12" 272 | } 273 | }, 274 | "node_modules/@esbuild/linux-arm64": { 275 | "version": "0.17.19", 276 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.19.tgz", 277 | "integrity": "sha512-ct1Tg3WGwd3P+oZYqic+YZF4snNl2bsnMKRkb3ozHmnM0dGWuxcPTTntAF6bOP0Sp4x0PjSF+4uHQ1xvxfRKqg==", 278 | "cpu": [ 279 | "arm64" 280 | ], 281 | "dev": true, 282 | "optional": true, 283 | "os": [ 284 | "linux" 285 | ], 286 | "engines": { 287 | "node": ">=12" 288 | } 289 | }, 290 | "node_modules/@esbuild/linux-ia32": { 291 | "version": "0.17.19", 292 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.19.tgz", 293 | "integrity": "sha512-w4IRhSy1VbsNxHRQpeGCHEmibqdTUx61Vc38APcsRbuVgK0OPEnQ0YD39Brymn96mOx48Y2laBQGqgZ0j9w6SQ==", 294 | "cpu": [ 295 | "ia32" 296 | ], 297 | "dev": true, 298 | "optional": true, 299 | "os": [ 300 | "linux" 301 | ], 302 | "engines": { 303 | "node": ">=12" 304 | } 305 | }, 306 | "node_modules/@esbuild/linux-loong64": { 307 | "version": "0.17.19", 308 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.19.tgz", 309 | "integrity": "sha512-2iAngUbBPMq439a+z//gE+9WBldoMp1s5GWsUSgqHLzLJ9WoZLZhpwWuym0u0u/4XmZ3gpHmzV84PonE+9IIdQ==", 310 | "cpu": [ 311 | "loong64" 312 | ], 313 | "dev": true, 314 | "optional": true, 315 | "os": [ 316 | "linux" 317 | ], 318 | "engines": { 319 | "node": ">=12" 320 | } 321 | }, 322 | "node_modules/@esbuild/linux-mips64el": { 323 | "version": "0.17.19", 324 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.19.tgz", 325 | "integrity": "sha512-LKJltc4LVdMKHsrFe4MGNPp0hqDFA1Wpt3jE1gEyM3nKUvOiO//9PheZZHfYRfYl6AwdTH4aTcXSqBerX0ml4A==", 326 | "cpu": [ 327 | "mips64el" 328 | ], 329 | "dev": true, 330 | "optional": true, 331 | "os": [ 332 | "linux" 333 | ], 334 | "engines": { 335 | "node": ">=12" 336 | } 337 | }, 338 | "node_modules/@esbuild/linux-ppc64": { 339 | "version": "0.17.19", 340 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.19.tgz", 341 | "integrity": "sha512-/c/DGybs95WXNS8y3Ti/ytqETiW7EU44MEKuCAcpPto3YjQbyK3IQVKfF6nbghD7EcLUGl0NbiL5Rt5DMhn5tg==", 342 | "cpu": [ 343 | "ppc64" 344 | ], 345 | "dev": true, 346 | "optional": true, 347 | "os": [ 348 | "linux" 349 | ], 350 | "engines": { 351 | "node": ">=12" 352 | } 353 | }, 354 | "node_modules/@esbuild/linux-riscv64": { 355 | "version": "0.17.19", 356 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.19.tgz", 357 | "integrity": "sha512-FC3nUAWhvFoutlhAkgHf8f5HwFWUL6bYdvLc/TTuxKlvLi3+pPzdZiFKSWz/PF30TB1K19SuCxDTI5KcqASJqA==", 358 | "cpu": [ 359 | "riscv64" 360 | ], 361 | "dev": true, 362 | "optional": true, 363 | "os": [ 364 | "linux" 365 | ], 366 | "engines": { 367 | "node": ">=12" 368 | } 369 | }, 370 | "node_modules/@esbuild/linux-s390x": { 371 | "version": "0.17.19", 372 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.19.tgz", 373 | "integrity": "sha512-IbFsFbxMWLuKEbH+7sTkKzL6NJmG2vRyy6K7JJo55w+8xDk7RElYn6xvXtDW8HCfoKBFK69f3pgBJSUSQPr+4Q==", 374 | "cpu": [ 375 | "s390x" 376 | ], 377 | "dev": true, 378 | "optional": true, 379 | "os": [ 380 | "linux" 381 | ], 382 | "engines": { 383 | "node": ">=12" 384 | } 385 | }, 386 | "node_modules/@esbuild/linux-x64": { 387 | "version": "0.17.19", 388 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.19.tgz", 389 | "integrity": "sha512-68ngA9lg2H6zkZcyp22tsVt38mlhWde8l3eJLWkyLrp4HwMUr3c1s/M2t7+kHIhvMjglIBrFpncX1SzMckomGw==", 390 | "cpu": [ 391 | "x64" 392 | ], 393 | "dev": true, 394 | "optional": true, 395 | "os": [ 396 | "linux" 397 | ], 398 | "engines": { 399 | "node": ">=12" 400 | } 401 | }, 402 | "node_modules/@esbuild/netbsd-x64": { 403 | "version": "0.17.19", 404 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.19.tgz", 405 | "integrity": "sha512-CwFq42rXCR8TYIjIfpXCbRX0rp1jo6cPIUPSaWwzbVI4aOfX96OXY8M6KNmtPcg7QjYeDmN+DD0Wp3LaBOLf4Q==", 406 | "cpu": [ 407 | "x64" 408 | ], 409 | "dev": true, 410 | "optional": true, 411 | "os": [ 412 | "netbsd" 413 | ], 414 | "engines": { 415 | "node": ">=12" 416 | } 417 | }, 418 | "node_modules/@esbuild/openbsd-x64": { 419 | "version": "0.17.19", 420 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.19.tgz", 421 | "integrity": "sha512-cnq5brJYrSZ2CF6c35eCmviIN3k3RczmHz8eYaVlNasVqsNY+JKohZU5MKmaOI+KkllCdzOKKdPs762VCPC20g==", 422 | "cpu": [ 423 | "x64" 424 | ], 425 | "dev": true, 426 | "optional": true, 427 | "os": [ 428 | "openbsd" 429 | ], 430 | "engines": { 431 | "node": ">=12" 432 | } 433 | }, 434 | "node_modules/@esbuild/sunos-x64": { 435 | "version": "0.17.19", 436 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.19.tgz", 437 | "integrity": "sha512-vCRT7yP3zX+bKWFeP/zdS6SqdWB8OIpaRq/mbXQxTGHnIxspRtigpkUcDMlSCOejlHowLqII7K2JKevwyRP2rg==", 438 | "cpu": [ 439 | "x64" 440 | ], 441 | "dev": true, 442 | "optional": true, 443 | "os": [ 444 | "sunos" 445 | ], 446 | "engines": { 447 | "node": ">=12" 448 | } 449 | }, 450 | "node_modules/@esbuild/win32-arm64": { 451 | "version": "0.17.19", 452 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.19.tgz", 453 | "integrity": "sha512-yYx+8jwowUstVdorcMdNlzklLYhPxjniHWFKgRqH7IFlUEa0Umu3KuYplf1HUZZ422e3NU9F4LGb+4O0Kdcaag==", 454 | "cpu": [ 455 | "arm64" 456 | ], 457 | "dev": true, 458 | "optional": true, 459 | "os": [ 460 | "win32" 461 | ], 462 | "engines": { 463 | "node": ">=12" 464 | } 465 | }, 466 | "node_modules/@esbuild/win32-ia32": { 467 | "version": "0.17.19", 468 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.19.tgz", 469 | "integrity": "sha512-eggDKanJszUtCdlVs0RB+h35wNlb5v4TWEkq4vZcmVt5u/HiDZrTXe2bWFQUez3RgNHwx/x4sk5++4NSSicKkw==", 470 | "cpu": [ 471 | "ia32" 472 | ], 473 | "dev": true, 474 | "optional": true, 475 | "os": [ 476 | "win32" 477 | ], 478 | "engines": { 479 | "node": ">=12" 480 | } 481 | }, 482 | "node_modules/@esbuild/win32-x64": { 483 | "version": "0.17.19", 484 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.19.tgz", 485 | "integrity": "sha512-lAhycmKnVOuRYNtRtatQR1LPQf2oYCkRGkSFnseDAKPl8lu5SOsK/e1sXe5a0Pc5kHIHe6P2I/ilntNv2xf3cA==", 486 | "cpu": [ 487 | "x64" 488 | ], 489 | "dev": true, 490 | "optional": true, 491 | "os": [ 492 | "win32" 493 | ], 494 | "engines": { 495 | "node": ">=12" 496 | } 497 | }, 498 | "node_modules/@fastify/busboy": { 499 | "version": "2.1.1", 500 | "resolved": "https://registry.npmjs.org/@fastify/busboy/-/busboy-2.1.1.tgz", 501 | "integrity": "sha512-vBZP4NlzfOlerQTnba4aqZoMhE/a9HY7HRqoOPaETQcSQuWEIyZMHGfVu6w9wGtGK5fED5qRs2DteVCjOH60sA==", 502 | "dev": true, 503 | "engines": { 504 | "node": ">=14" 505 | } 506 | }, 507 | "node_modules/@jridgewell/resolve-uri": { 508 | "version": "3.1.2", 509 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 510 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 511 | "dev": true, 512 | "engines": { 513 | "node": ">=6.0.0" 514 | } 515 | }, 516 | "node_modules/@jridgewell/sourcemap-codec": { 517 | "version": "1.4.15", 518 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 519 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 520 | "dev": true 521 | }, 522 | "node_modules/@jridgewell/trace-mapping": { 523 | "version": "0.3.9", 524 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 525 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 526 | "dev": true, 527 | "dependencies": { 528 | "@jridgewell/resolve-uri": "^3.0.3", 529 | "@jridgewell/sourcemap-codec": "^1.4.10" 530 | } 531 | }, 532 | "node_modules/acorn": { 533 | "version": "8.11.3", 534 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 535 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 536 | "dev": true, 537 | "bin": { 538 | "acorn": "bin/acorn" 539 | }, 540 | "engines": { 541 | "node": ">=0.4.0" 542 | } 543 | }, 544 | "node_modules/acorn-walk": { 545 | "version": "8.3.2", 546 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.2.tgz", 547 | "integrity": "sha512-cjkyv4OtNCIeqhHrfS81QWXoCBPExR/J62oyEqepVw8WaQeSqpW2uhuLPh1m9eWhDuOo/jUXVTlifvesOWp/4A==", 548 | "dev": true, 549 | "engines": { 550 | "node": ">=0.4.0" 551 | } 552 | }, 553 | "node_modules/anymatch": { 554 | "version": "3.1.3", 555 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 556 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 557 | "dev": true, 558 | "dependencies": { 559 | "normalize-path": "^3.0.0", 560 | "picomatch": "^2.0.4" 561 | }, 562 | "engines": { 563 | "node": ">= 8" 564 | } 565 | }, 566 | "node_modules/as-table": { 567 | "version": "1.0.55", 568 | "resolved": "https://registry.npmjs.org/as-table/-/as-table-1.0.55.tgz", 569 | "integrity": "sha512-xvsWESUJn0JN421Xb9MQw6AsMHRCUknCe0Wjlxvjud80mU4E6hQf1A6NzQKcYNmYw62MfzEtXc+badstZP3JpQ==", 570 | "dev": true, 571 | "dependencies": { 572 | "printable-characters": "^1.0.42" 573 | } 574 | }, 575 | "node_modules/binary-extensions": { 576 | "version": "2.2.0", 577 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 578 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 579 | "dev": true, 580 | "engines": { 581 | "node": ">=8" 582 | } 583 | }, 584 | "node_modules/blake3-wasm": { 585 | "version": "2.1.5", 586 | "resolved": "https://registry.npmjs.org/blake3-wasm/-/blake3-wasm-2.1.5.tgz", 587 | "integrity": "sha512-F1+K8EbfOZE49dtoPtmxUQrpXaBIl3ICvasLh+nJta0xkz+9kF/7uet9fLnwKqhDrmj6g+6K3Tw9yQPUg2ka5g==", 588 | "dev": true 589 | }, 590 | "node_modules/braces": { 591 | "version": "3.0.2", 592 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 593 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 594 | "dev": true, 595 | "dependencies": { 596 | "fill-range": "^7.0.1" 597 | }, 598 | "engines": { 599 | "node": ">=8" 600 | } 601 | }, 602 | "node_modules/capnp-ts": { 603 | "version": "0.7.0", 604 | "resolved": "https://registry.npmjs.org/capnp-ts/-/capnp-ts-0.7.0.tgz", 605 | "integrity": "sha512-XKxXAC3HVPv7r674zP0VC3RTXz+/JKhfyw94ljvF80yynK6VkTnqE3jMuN8b3dUVmmc43TjyxjW4KTsmB3c86g==", 606 | "dev": true, 607 | "dependencies": { 608 | "debug": "^4.3.1", 609 | "tslib": "^2.2.0" 610 | } 611 | }, 612 | "node_modules/chokidar": { 613 | "version": "3.5.3", 614 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 615 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 616 | "dev": true, 617 | "funding": [ 618 | { 619 | "type": "individual", 620 | "url": "https://paulmillr.com/funding/" 621 | } 622 | ], 623 | "dependencies": { 624 | "anymatch": "~3.1.2", 625 | "braces": "~3.0.2", 626 | "glob-parent": "~5.1.2", 627 | "is-binary-path": "~2.1.0", 628 | "is-glob": "~4.0.1", 629 | "normalize-path": "~3.0.0", 630 | "readdirp": "~3.6.0" 631 | }, 632 | "engines": { 633 | "node": ">= 8.10.0" 634 | }, 635 | "optionalDependencies": { 636 | "fsevents": "~2.3.2" 637 | } 638 | }, 639 | "node_modules/cookie": { 640 | "version": "0.5.0", 641 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 642 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 643 | "dev": true, 644 | "engines": { 645 | "node": ">= 0.6" 646 | } 647 | }, 648 | "node_modules/data-uri-to-buffer": { 649 | "version": "2.0.2", 650 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-2.0.2.tgz", 651 | "integrity": "sha512-ND9qDTLc6diwj+Xe5cdAgVTbLVdXbtxTJRXRhli8Mowuaan+0EJOtdqJ0QCHNSSPyoXGx9HX2/VMnKeC34AChA==", 652 | "dev": true 653 | }, 654 | "node_modules/debug": { 655 | "version": "4.3.4", 656 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 657 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 658 | "dev": true, 659 | "dependencies": { 660 | "ms": "2.1.2" 661 | }, 662 | "engines": { 663 | "node": ">=6.0" 664 | }, 665 | "peerDependenciesMeta": { 666 | "supports-color": { 667 | "optional": true 668 | } 669 | } 670 | }, 671 | "node_modules/esbuild": { 672 | "version": "0.17.19", 673 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.19.tgz", 674 | "integrity": "sha512-XQ0jAPFkK/u3LcVRcvVHQcTIqD6E2H1fvZMA5dQPSOWb3suUbWbfbRf94pjc0bNzRYLfIrDRQXr7X+LHIm5oHw==", 675 | "dev": true, 676 | "hasInstallScript": true, 677 | "bin": { 678 | "esbuild": "bin/esbuild" 679 | }, 680 | "engines": { 681 | "node": ">=12" 682 | }, 683 | "optionalDependencies": { 684 | "@esbuild/android-arm": "0.17.19", 685 | "@esbuild/android-arm64": "0.17.19", 686 | "@esbuild/android-x64": "0.17.19", 687 | "@esbuild/darwin-arm64": "0.17.19", 688 | "@esbuild/darwin-x64": "0.17.19", 689 | "@esbuild/freebsd-arm64": "0.17.19", 690 | "@esbuild/freebsd-x64": "0.17.19", 691 | "@esbuild/linux-arm": "0.17.19", 692 | "@esbuild/linux-arm64": "0.17.19", 693 | "@esbuild/linux-ia32": "0.17.19", 694 | "@esbuild/linux-loong64": "0.17.19", 695 | "@esbuild/linux-mips64el": "0.17.19", 696 | "@esbuild/linux-ppc64": "0.17.19", 697 | "@esbuild/linux-riscv64": "0.17.19", 698 | "@esbuild/linux-s390x": "0.17.19", 699 | "@esbuild/linux-x64": "0.17.19", 700 | "@esbuild/netbsd-x64": "0.17.19", 701 | "@esbuild/openbsd-x64": "0.17.19", 702 | "@esbuild/sunos-x64": "0.17.19", 703 | "@esbuild/win32-arm64": "0.17.19", 704 | "@esbuild/win32-ia32": "0.17.19", 705 | "@esbuild/win32-x64": "0.17.19" 706 | } 707 | }, 708 | "node_modules/escape-string-regexp": { 709 | "version": "4.0.0", 710 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 711 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 712 | "dev": true, 713 | "engines": { 714 | "node": ">=10" 715 | }, 716 | "funding": { 717 | "url": "https://github.com/sponsors/sindresorhus" 718 | } 719 | }, 720 | "node_modules/estree-walker": { 721 | "version": "0.6.1", 722 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", 723 | "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", 724 | "dev": true 725 | }, 726 | "node_modules/exit-hook": { 727 | "version": "2.2.1", 728 | "resolved": "https://registry.npmjs.org/exit-hook/-/exit-hook-2.2.1.tgz", 729 | "integrity": "sha512-eNTPlAD67BmP31LDINZ3U7HSF8l57TxOY2PmBJ1shpCvpnxBF93mWCE8YHBnXs8qiUZJc9WDcWIeC3a2HIAMfw==", 730 | "dev": true, 731 | "engines": { 732 | "node": ">=6" 733 | }, 734 | "funding": { 735 | "url": "https://github.com/sponsors/sindresorhus" 736 | } 737 | }, 738 | "node_modules/fill-range": { 739 | "version": "7.0.1", 740 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 741 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 742 | "dev": true, 743 | "dependencies": { 744 | "to-regex-range": "^5.0.1" 745 | }, 746 | "engines": { 747 | "node": ">=8" 748 | } 749 | }, 750 | "node_modules/fsevents": { 751 | "version": "2.3.3", 752 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 753 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 754 | "dev": true, 755 | "hasInstallScript": true, 756 | "optional": true, 757 | "os": [ 758 | "darwin" 759 | ], 760 | "engines": { 761 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 762 | } 763 | }, 764 | "node_modules/function-bind": { 765 | "version": "1.1.2", 766 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 767 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 768 | "dev": true, 769 | "funding": { 770 | "url": "https://github.com/sponsors/ljharb" 771 | } 772 | }, 773 | "node_modules/get-source": { 774 | "version": "2.0.12", 775 | "resolved": "https://registry.npmjs.org/get-source/-/get-source-2.0.12.tgz", 776 | "integrity": "sha512-X5+4+iD+HoSeEED+uwrQ07BOQr0kEDFMVqqpBuI+RaZBpBpHCuXxo70bjar6f0b0u/DQJsJ7ssurpP0V60Az+w==", 777 | "dev": true, 778 | "dependencies": { 779 | "data-uri-to-buffer": "^2.0.0", 780 | "source-map": "^0.6.1" 781 | } 782 | }, 783 | "node_modules/glob-parent": { 784 | "version": "5.1.2", 785 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 786 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 787 | "dev": true, 788 | "dependencies": { 789 | "is-glob": "^4.0.1" 790 | }, 791 | "engines": { 792 | "node": ">= 6" 793 | } 794 | }, 795 | "node_modules/glob-to-regexp": { 796 | "version": "0.4.1", 797 | "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz", 798 | "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==", 799 | "dev": true 800 | }, 801 | "node_modules/hasown": { 802 | "version": "2.0.2", 803 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 804 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 805 | "dev": true, 806 | "dependencies": { 807 | "function-bind": "^1.1.2" 808 | }, 809 | "engines": { 810 | "node": ">= 0.4" 811 | } 812 | }, 813 | "node_modules/is-binary-path": { 814 | "version": "2.1.0", 815 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 816 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 817 | "dev": true, 818 | "dependencies": { 819 | "binary-extensions": "^2.0.0" 820 | }, 821 | "engines": { 822 | "node": ">=8" 823 | } 824 | }, 825 | "node_modules/is-core-module": { 826 | "version": "2.13.1", 827 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", 828 | "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", 829 | "dev": true, 830 | "dependencies": { 831 | "hasown": "^2.0.0" 832 | }, 833 | "funding": { 834 | "url": "https://github.com/sponsors/ljharb" 835 | } 836 | }, 837 | "node_modules/is-extglob": { 838 | "version": "2.1.1", 839 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 840 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 841 | "dev": true, 842 | "engines": { 843 | "node": ">=0.10.0" 844 | } 845 | }, 846 | "node_modules/is-glob": { 847 | "version": "4.0.3", 848 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 849 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 850 | "dev": true, 851 | "dependencies": { 852 | "is-extglob": "^2.1.1" 853 | }, 854 | "engines": { 855 | "node": ">=0.10.0" 856 | } 857 | }, 858 | "node_modules/is-number": { 859 | "version": "7.0.0", 860 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 861 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 862 | "dev": true, 863 | "engines": { 864 | "node": ">=0.12.0" 865 | } 866 | }, 867 | "node_modules/magic-string": { 868 | "version": "0.25.9", 869 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz", 870 | "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==", 871 | "dev": true, 872 | "dependencies": { 873 | "sourcemap-codec": "^1.4.8" 874 | } 875 | }, 876 | "node_modules/mime": { 877 | "version": "3.0.0", 878 | "resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz", 879 | "integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==", 880 | "dev": true, 881 | "bin": { 882 | "mime": "cli.js" 883 | }, 884 | "engines": { 885 | "node": ">=10.0.0" 886 | } 887 | }, 888 | "node_modules/miniflare": { 889 | "version": "3.20240404.0", 890 | "resolved": "https://registry.npmjs.org/miniflare/-/miniflare-3.20240404.0.tgz", 891 | "integrity": "sha512-+FOTcztPMW3akmucX4vE0PWMNvP4JBwl4s9ieA84fcOaDtTbtfU1rHXpcacj16klpUpvSnD6xd8Sjsn6SJXPfg==", 892 | "dev": true, 893 | "dependencies": { 894 | "@cspotcode/source-map-support": "0.8.1", 895 | "acorn": "^8.8.0", 896 | "acorn-walk": "^8.2.0", 897 | "capnp-ts": "^0.7.0", 898 | "exit-hook": "^2.2.1", 899 | "glob-to-regexp": "^0.4.1", 900 | "stoppable": "^1.1.0", 901 | "undici": "^5.28.2", 902 | "workerd": "1.20240404.0", 903 | "ws": "^8.11.0", 904 | "youch": "^3.2.2", 905 | "zod": "^3.20.6" 906 | }, 907 | "bin": { 908 | "miniflare": "bootstrap.js" 909 | }, 910 | "engines": { 911 | "node": ">=16.13" 912 | } 913 | }, 914 | "node_modules/ms": { 915 | "version": "2.1.2", 916 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 917 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 918 | "dev": true 919 | }, 920 | "node_modules/mustache": { 921 | "version": "4.2.0", 922 | "resolved": "https://registry.npmjs.org/mustache/-/mustache-4.2.0.tgz", 923 | "integrity": "sha512-71ippSywq5Yb7/tVYyGbkBggbU8H3u5Rz56fH60jGFgr8uHwxs+aSKeqmluIVzM0m0kB7xQjKS6qPfd0b2ZoqQ==", 924 | "dev": true, 925 | "bin": { 926 | "mustache": "bin/mustache" 927 | } 928 | }, 929 | "node_modules/nanoid": { 930 | "version": "3.3.6", 931 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz", 932 | "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==", 933 | "dev": true, 934 | "funding": [ 935 | { 936 | "type": "github", 937 | "url": "https://github.com/sponsors/ai" 938 | } 939 | ], 940 | "bin": { 941 | "nanoid": "bin/nanoid.cjs" 942 | }, 943 | "engines": { 944 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 945 | } 946 | }, 947 | "node_modules/node-forge": { 948 | "version": "1.3.1", 949 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", 950 | "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==", 951 | "dev": true, 952 | "engines": { 953 | "node": ">= 6.13.0" 954 | } 955 | }, 956 | "node_modules/normalize-path": { 957 | "version": "3.0.0", 958 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 959 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 960 | "dev": true, 961 | "engines": { 962 | "node": ">=0.10.0" 963 | } 964 | }, 965 | "node_modules/path-parse": { 966 | "version": "1.0.7", 967 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 968 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 969 | "dev": true 970 | }, 971 | "node_modules/path-to-regexp": { 972 | "version": "6.2.1", 973 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz", 974 | "integrity": "sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw==", 975 | "dev": true 976 | }, 977 | "node_modules/picomatch": { 978 | "version": "2.3.1", 979 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 980 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 981 | "dev": true, 982 | "engines": { 983 | "node": ">=8.6" 984 | }, 985 | "funding": { 986 | "url": "https://github.com/sponsors/jonschlinkert" 987 | } 988 | }, 989 | "node_modules/prettier": { 990 | "version": "3.2.5", 991 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.2.5.tgz", 992 | "integrity": "sha512-3/GWa9aOC0YeD7LUfvOG2NiDyhOWRvt1k+rcKhOuYnMY24iiCphgneUfJDyFXd6rZCAnuLBv6UeAULtrhT/F4A==", 993 | "dev": true, 994 | "bin": { 995 | "prettier": "bin/prettier.cjs" 996 | }, 997 | "engines": { 998 | "node": ">=14" 999 | }, 1000 | "funding": { 1001 | "url": "https://github.com/prettier/prettier?sponsor=1" 1002 | } 1003 | }, 1004 | "node_modules/printable-characters": { 1005 | "version": "1.0.42", 1006 | "resolved": "https://registry.npmjs.org/printable-characters/-/printable-characters-1.0.42.tgz", 1007 | "integrity": "sha512-dKp+C4iXWK4vVYZmYSd0KBH5F/h1HoZRsbJ82AVKRO3PEo8L4lBS/vLwhVtpwwuYcoIsVY+1JYKR268yn480uQ==", 1008 | "dev": true 1009 | }, 1010 | "node_modules/readdirp": { 1011 | "version": "3.6.0", 1012 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1013 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1014 | "dev": true, 1015 | "dependencies": { 1016 | "picomatch": "^2.2.1" 1017 | }, 1018 | "engines": { 1019 | "node": ">=8.10.0" 1020 | } 1021 | }, 1022 | "node_modules/resolve": { 1023 | "version": "1.22.8", 1024 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", 1025 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", 1026 | "dev": true, 1027 | "dependencies": { 1028 | "is-core-module": "^2.13.0", 1029 | "path-parse": "^1.0.7", 1030 | "supports-preserve-symlinks-flag": "^1.0.0" 1031 | }, 1032 | "bin": { 1033 | "resolve": "bin/resolve" 1034 | }, 1035 | "funding": { 1036 | "url": "https://github.com/sponsors/ljharb" 1037 | } 1038 | }, 1039 | "node_modules/resolve.exports": { 1040 | "version": "2.0.2", 1041 | "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.2.tgz", 1042 | "integrity": "sha512-X2UW6Nw3n/aMgDVy+0rSqgHlv39WZAlZrXCdnbyEiKm17DSqHX4MmQMaST3FbeWR5FTuRcUwYAziZajji0Y7mg==", 1043 | "dev": true, 1044 | "engines": { 1045 | "node": ">=10" 1046 | } 1047 | }, 1048 | "node_modules/rollup-plugin-inject": { 1049 | "version": "3.0.2", 1050 | "resolved": "https://registry.npmjs.org/rollup-plugin-inject/-/rollup-plugin-inject-3.0.2.tgz", 1051 | "integrity": "sha512-ptg9PQwzs3orn4jkgXJ74bfs5vYz1NCZlSQMBUA0wKcGp5i5pA1AO3fOUEte8enhGUC+iapTCzEWw2jEFFUO/w==", 1052 | "deprecated": "This package has been deprecated and is no longer maintained. Please use @rollup/plugin-inject.", 1053 | "dev": true, 1054 | "dependencies": { 1055 | "estree-walker": "^0.6.1", 1056 | "magic-string": "^0.25.3", 1057 | "rollup-pluginutils": "^2.8.1" 1058 | } 1059 | }, 1060 | "node_modules/rollup-plugin-node-polyfills": { 1061 | "version": "0.2.1", 1062 | "resolved": "https://registry.npmjs.org/rollup-plugin-node-polyfills/-/rollup-plugin-node-polyfills-0.2.1.tgz", 1063 | "integrity": "sha512-4kCrKPTJ6sK4/gLL/U5QzVT8cxJcofO0OU74tnB19F40cmuAKSzH5/siithxlofFEjwvw1YAhPmbvGNA6jEroA==", 1064 | "dev": true, 1065 | "dependencies": { 1066 | "rollup-plugin-inject": "^3.0.0" 1067 | } 1068 | }, 1069 | "node_modules/rollup-pluginutils": { 1070 | "version": "2.8.2", 1071 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", 1072 | "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", 1073 | "dev": true, 1074 | "dependencies": { 1075 | "estree-walker": "^0.6.1" 1076 | } 1077 | }, 1078 | "node_modules/selfsigned": { 1079 | "version": "2.1.1", 1080 | "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.1.1.tgz", 1081 | "integrity": "sha512-GSL3aowiF7wa/WtSFwnUrludWFoNhftq8bUkH9pkzjpN2XSPOAYEgg6e0sS9s0rZwgJzJiQRPU18A6clnoW5wQ==", 1082 | "dev": true, 1083 | "dependencies": { 1084 | "node-forge": "^1" 1085 | }, 1086 | "engines": { 1087 | "node": ">=10" 1088 | } 1089 | }, 1090 | "node_modules/source-map": { 1091 | "version": "0.6.1", 1092 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1093 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1094 | "dev": true, 1095 | "engines": { 1096 | "node": ">=0.10.0" 1097 | } 1098 | }, 1099 | "node_modules/sourcemap-codec": { 1100 | "version": "1.4.8", 1101 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 1102 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 1103 | "deprecated": "Please use @jridgewell/sourcemap-codec instead", 1104 | "dev": true 1105 | }, 1106 | "node_modules/stacktracey": { 1107 | "version": "2.1.8", 1108 | "resolved": "https://registry.npmjs.org/stacktracey/-/stacktracey-2.1.8.tgz", 1109 | "integrity": "sha512-Kpij9riA+UNg7TnphqjH7/CzctQ/owJGNbFkfEeve4Z4uxT5+JapVLFXcsurIfN34gnTWZNJ/f7NMG0E8JDzTw==", 1110 | "dev": true, 1111 | "dependencies": { 1112 | "as-table": "^1.0.36", 1113 | "get-source": "^2.0.12" 1114 | } 1115 | }, 1116 | "node_modules/stoppable": { 1117 | "version": "1.1.0", 1118 | "resolved": "https://registry.npmjs.org/stoppable/-/stoppable-1.1.0.tgz", 1119 | "integrity": "sha512-KXDYZ9dszj6bzvnEMRYvxgeTHU74QBFL54XKtP3nyMuJ81CFYtABZ3bAzL2EdFUaEwJOBOgENyFj3R7oTzDyyw==", 1120 | "dev": true, 1121 | "engines": { 1122 | "node": ">=4", 1123 | "npm": ">=6" 1124 | } 1125 | }, 1126 | "node_modules/supports-preserve-symlinks-flag": { 1127 | "version": "1.0.0", 1128 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1129 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1130 | "dev": true, 1131 | "engines": { 1132 | "node": ">= 0.4" 1133 | }, 1134 | "funding": { 1135 | "url": "https://github.com/sponsors/ljharb" 1136 | } 1137 | }, 1138 | "node_modules/to-regex-range": { 1139 | "version": "5.0.1", 1140 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1141 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1142 | "dev": true, 1143 | "dependencies": { 1144 | "is-number": "^7.0.0" 1145 | }, 1146 | "engines": { 1147 | "node": ">=8.0" 1148 | } 1149 | }, 1150 | "node_modules/tslib": { 1151 | "version": "2.6.2", 1152 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", 1153 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", 1154 | "dev": true 1155 | }, 1156 | "node_modules/typescript": { 1157 | "version": "5.4.5", 1158 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.4.5.tgz", 1159 | "integrity": "sha512-vcI4UpRgg81oIRUFwR0WSIHKt11nJ7SAVlYNIu+QpqeyXP+gpQJy/Z4+F0aGxSE4MqwjyXvW/TzgkLAx2AGHwQ==", 1160 | "dev": true, 1161 | "bin": { 1162 | "tsc": "bin/tsc", 1163 | "tsserver": "bin/tsserver" 1164 | }, 1165 | "engines": { 1166 | "node": ">=14.17" 1167 | } 1168 | }, 1169 | "node_modules/undici": { 1170 | "version": "5.28.4", 1171 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.28.4.tgz", 1172 | "integrity": "sha512-72RFADWFqKmUb2hmmvNODKL3p9hcB6Gt2DOQMis1SEBaV6a4MH8soBvzg+95CYhCKPFedut2JY9bMfrDl9D23g==", 1173 | "dev": true, 1174 | "dependencies": { 1175 | "@fastify/busboy": "^2.0.0" 1176 | }, 1177 | "engines": { 1178 | "node": ">=14.0" 1179 | } 1180 | }, 1181 | "node_modules/workerd": { 1182 | "version": "1.20240404.0", 1183 | "resolved": "https://registry.npmjs.org/workerd/-/workerd-1.20240404.0.tgz", 1184 | "integrity": "sha512-U4tfnvBcPMsv7pmRGuF0J5UnoZi6tbc64tXNfyijI74r6w6Vlb2+a6eibdQL8g0g46+4vjuTKME9G5RvSvdc8g==", 1185 | "dev": true, 1186 | "hasInstallScript": true, 1187 | "bin": { 1188 | "workerd": "bin/workerd" 1189 | }, 1190 | "engines": { 1191 | "node": ">=16" 1192 | }, 1193 | "optionalDependencies": { 1194 | "@cloudflare/workerd-darwin-64": "1.20240404.0", 1195 | "@cloudflare/workerd-darwin-arm64": "1.20240404.0", 1196 | "@cloudflare/workerd-linux-64": "1.20240404.0", 1197 | "@cloudflare/workerd-linux-arm64": "1.20240404.0", 1198 | "@cloudflare/workerd-windows-64": "1.20240404.0" 1199 | } 1200 | }, 1201 | "node_modules/wrangler": { 1202 | "version": "3.48.0", 1203 | "resolved": "https://registry.npmjs.org/wrangler/-/wrangler-3.48.0.tgz", 1204 | "integrity": "sha512-Wv7JS6FyX1j9HkaM6WL3fmTzBMAYc4hPSyZCuxuH55hkJDX/7ts+YAgsaN1U8rKoDrV3FVSgBfI9TyqP9iuM8Q==", 1205 | "dev": true, 1206 | "dependencies": { 1207 | "@cloudflare/kv-asset-handler": "0.3.1", 1208 | "@esbuild-plugins/node-globals-polyfill": "^0.2.3", 1209 | "@esbuild-plugins/node-modules-polyfill": "^0.2.2", 1210 | "blake3-wasm": "^2.1.5", 1211 | "chokidar": "^3.5.3", 1212 | "esbuild": "0.17.19", 1213 | "miniflare": "3.20240404.0", 1214 | "nanoid": "^3.3.3", 1215 | "path-to-regexp": "^6.2.0", 1216 | "resolve": "^1.22.8", 1217 | "resolve.exports": "^2.0.2", 1218 | "selfsigned": "^2.0.1", 1219 | "source-map": "0.6.1", 1220 | "xxhash-wasm": "^1.0.1" 1221 | }, 1222 | "bin": { 1223 | "wrangler": "bin/wrangler.js", 1224 | "wrangler2": "bin/wrangler.js" 1225 | }, 1226 | "engines": { 1227 | "node": ">=16.17.0" 1228 | }, 1229 | "optionalDependencies": { 1230 | "fsevents": "~2.3.2" 1231 | }, 1232 | "peerDependencies": { 1233 | "@cloudflare/workers-types": "^4.20240404.0" 1234 | }, 1235 | "peerDependenciesMeta": { 1236 | "@cloudflare/workers-types": { 1237 | "optional": true 1238 | } 1239 | } 1240 | }, 1241 | "node_modules/ws": { 1242 | "version": "8.16.0", 1243 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.16.0.tgz", 1244 | "integrity": "sha512-HS0c//TP7Ina87TfiPUz1rQzMhHrl/SG2guqRcTOIUYD2q8uhUdNHZYJUaQ8aTGPzCh+c6oawMKW35nFl1dxyQ==", 1245 | "dev": true, 1246 | "engines": { 1247 | "node": ">=10.0.0" 1248 | }, 1249 | "peerDependencies": { 1250 | "bufferutil": "^4.0.1", 1251 | "utf-8-validate": ">=5.0.2" 1252 | }, 1253 | "peerDependenciesMeta": { 1254 | "bufferutil": { 1255 | "optional": true 1256 | }, 1257 | "utf-8-validate": { 1258 | "optional": true 1259 | } 1260 | } 1261 | }, 1262 | "node_modules/xxhash-wasm": { 1263 | "version": "1.0.2", 1264 | "resolved": "https://registry.npmjs.org/xxhash-wasm/-/xxhash-wasm-1.0.2.tgz", 1265 | "integrity": "sha512-ibF0Or+FivM9lNrg+HGJfVX8WJqgo+kCLDc4vx6xMeTce7Aj+DLttKbxxRR/gNLSAelRc1omAPlJ77N/Jem07A==", 1266 | "dev": true 1267 | }, 1268 | "node_modules/youch": { 1269 | "version": "3.3.3", 1270 | "resolved": "https://registry.npmjs.org/youch/-/youch-3.3.3.tgz", 1271 | "integrity": "sha512-qSFXUk3UZBLfggAW3dJKg0BMblG5biqSF8M34E06o5CSsZtH92u9Hqmj2RzGiHDi64fhe83+4tENFP2DB6t6ZA==", 1272 | "dev": true, 1273 | "dependencies": { 1274 | "cookie": "^0.5.0", 1275 | "mustache": "^4.2.0", 1276 | "stacktracey": "^2.1.8" 1277 | } 1278 | }, 1279 | "node_modules/zod": { 1280 | "version": "3.22.4", 1281 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.22.4.tgz", 1282 | "integrity": "sha512-iC+8Io04lddc+mVqQ9AZ7OQ2MrUKGN+oIQyq1vemgt46jwCwLfhq7/pwnBnNXXXZb8VTVLKwp9EDkx+ryxIWmg==", 1283 | "dev": true, 1284 | "funding": { 1285 | "url": "https://github.com/sponsors/colinhacks" 1286 | } 1287 | } 1288 | } 1289 | } 1290 | -------------------------------------------------------------------------------- /report-uri/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "report-uri", 3 | "version": "1.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "report-uri", 9 | "version": "1.0.0", 10 | "license": "MIT", 11 | "devDependencies": { 12 | "@cloudflare/workers-types": "^4.20240405.0", 13 | "prettier": "^3.2.5", 14 | "typescript": "^5.4.5", 15 | "wrangler": "^3.48.0" 16 | } 17 | }, 18 | "node_modules/@cloudflare/kv-asset-handler": { 19 | "version": "0.3.1", 20 | "resolved": "https://registry.npmjs.org/@cloudflare/kv-asset-handler/-/kv-asset-handler-0.3.1.tgz", 21 | "integrity": "sha512-lKN2XCfKCmpKb86a1tl4GIwsJYDy9TGuwjhDELLmpKygQhw8X2xR4dusgpC5Tg7q1pB96Eb0rBo81kxSILQMwA==", 22 | "dev": true, 23 | "dependencies": { 24 | "mime": "^3.0.0" 25 | } 26 | }, 27 | "node_modules/@cloudflare/workerd-darwin-64": { 28 | "version": "1.20240404.0", 29 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-darwin-64/-/workerd-darwin-64-1.20240404.0.tgz", 30 | "integrity": "sha512-rc/ov3I9GwgKRtUnkShNW3TIoZEPHzExrMRNlHq1VpXQRBSchHdMw8meMn54+oqgxW1AKLmPWj/c0A7EnYAsIw==", 31 | "cpu": [ 32 | "x64" 33 | ], 34 | "dev": true, 35 | "optional": true, 36 | "os": [ 37 | "darwin" 38 | ], 39 | "engines": { 40 | "node": ">=16" 41 | } 42 | }, 43 | "node_modules/@cloudflare/workerd-darwin-arm64": { 44 | "version": "1.20240404.0", 45 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-darwin-arm64/-/workerd-darwin-arm64-1.20240404.0.tgz", 46 | "integrity": "sha512-V9oPjeC2PYBCoAYnjbO2bsjT7PtzxfUHnh780FUi1r59Hwxd7FNlojwsIidA0nS/1WV5UKeJusIdrYlQbsketA==", 47 | "cpu": [ 48 | "arm64" 49 | ], 50 | "dev": true, 51 | "optional": true, 52 | "os": [ 53 | "darwin" 54 | ], 55 | "engines": { 56 | "node": ">=16" 57 | } 58 | }, 59 | "node_modules/@cloudflare/workerd-linux-64": { 60 | "version": "1.20240404.0", 61 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-linux-64/-/workerd-linux-64-1.20240404.0.tgz", 62 | "integrity": "sha512-ndO7q6G2X8uYd5byGFzow4SWPqINQcmJ7pKKATNa+9vh/YMO0of2ihPntnm9uv577l8nRiAwRkHbnsWoEI33qQ==", 63 | "cpu": [ 64 | "x64" 65 | ], 66 | "dev": true, 67 | "optional": true, 68 | "os": [ 69 | "linux" 70 | ], 71 | "engines": { 72 | "node": ">=16" 73 | } 74 | }, 75 | "node_modules/@cloudflare/workerd-linux-arm64": { 76 | "version": "1.20240404.0", 77 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-linux-arm64/-/workerd-linux-arm64-1.20240404.0.tgz", 78 | "integrity": "sha512-hto5pjKYFqFu2Rvxnh84TzgDwalBRXQSwOVHltcgqo48en9TJDCN48ZtLj2G7QTGUOMW88h+nqdbj8+P7S/GXQ==", 79 | "cpu": [ 80 | "arm64" 81 | ], 82 | "dev": true, 83 | "optional": true, 84 | "os": [ 85 | "linux" 86 | ], 87 | "engines": { 88 | "node": ">=16" 89 | } 90 | }, 91 | "node_modules/@cloudflare/workerd-windows-64": { 92 | "version": "1.20240404.0", 93 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-windows-64/-/workerd-windows-64-1.20240404.0.tgz", 94 | "integrity": "sha512-DpCLvNkOeFinKGJwv9qbyT7RLZ1168dhPx85IHSqAYVWZIszNSmNOkEDqklvoJoab01AqETrrEhwBdmjCA7qfA==", 95 | "cpu": [ 96 | "x64" 97 | ], 98 | "dev": true, 99 | "optional": true, 100 | "os": [ 101 | "win32" 102 | ], 103 | "engines": { 104 | "node": ">=16" 105 | } 106 | }, 107 | "node_modules/@cloudflare/workers-types": { 108 | "version": "4.20240405.0", 109 | "resolved": "https://registry.npmjs.org/@cloudflare/workers-types/-/workers-types-4.20240405.0.tgz", 110 | "integrity": "sha512-sEVOhyOgXUwfLkgHqbLZa/sfkSYrh7/zLmI6EZNibPaVPvAnAcItbNNl3SAlLyLKuwf8m4wAIAgu9meKWCvXjg==", 111 | "dev": true 112 | }, 113 | "node_modules/@cspotcode/source-map-support": { 114 | "version": "0.8.1", 115 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 116 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 117 | "dev": true, 118 | "dependencies": { 119 | "@jridgewell/trace-mapping": "0.3.9" 120 | }, 121 | "engines": { 122 | "node": ">=12" 123 | } 124 | }, 125 | "node_modules/@esbuild-plugins/node-globals-polyfill": { 126 | "version": "0.2.3", 127 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-globals-polyfill/-/node-globals-polyfill-0.2.3.tgz", 128 | "integrity": "sha512-r3MIryXDeXDOZh7ih1l/yE9ZLORCd5e8vWg02azWRGj5SPTuoh69A2AIyn0Z31V/kHBfZ4HgWJ+OK3GTTwLmnw==", 129 | "dev": true, 130 | "peerDependencies": { 131 | "esbuild": "*" 132 | } 133 | }, 134 | "node_modules/@esbuild-plugins/node-modules-polyfill": { 135 | "version": "0.2.2", 136 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-modules-polyfill/-/node-modules-polyfill-0.2.2.tgz", 137 | "integrity": "sha512-LXV7QsWJxRuMYvKbiznh+U1ilIop3g2TeKRzUxOG5X3YITc8JyyTa90BmLwqqv0YnX4v32CSlG+vsziZp9dMvA==", 138 | "dev": true, 139 | "dependencies": { 140 | "escape-string-regexp": "^4.0.0", 141 | "rollup-plugin-node-polyfills": "^0.2.1" 142 | }, 143 | "peerDependencies": { 144 | "esbuild": "*" 145 | } 146 | }, 147 | "node_modules/@esbuild/android-arm": { 148 | "version": "0.17.19", 149 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.19.tgz", 150 | "integrity": "sha512-rIKddzqhmav7MSmoFCmDIb6e2W57geRsM94gV2l38fzhXMwq7hZoClug9USI2pFRGL06f4IOPHHpFNOkWieR8A==", 151 | "cpu": [ 152 | "arm" 153 | ], 154 | "dev": true, 155 | "optional": true, 156 | "os": [ 157 | "android" 158 | ], 159 | "engines": { 160 | "node": ">=12" 161 | } 162 | }, 163 | "node_modules/@esbuild/android-arm64": { 164 | "version": "0.17.19", 165 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.19.tgz", 166 | "integrity": "sha512-KBMWvEZooR7+kzY0BtbTQn0OAYY7CsiydT63pVEaPtVYF0hXbUaOyZog37DKxK7NF3XacBJOpYT4adIJh+avxA==", 167 | "cpu": [ 168 | "arm64" 169 | ], 170 | "dev": true, 171 | "optional": true, 172 | "os": [ 173 | "android" 174 | ], 175 | "engines": { 176 | "node": ">=12" 177 | } 178 | }, 179 | "node_modules/@esbuild/android-x64": { 180 | "version": "0.17.19", 181 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.19.tgz", 182 | "integrity": "sha512-uUTTc4xGNDT7YSArp/zbtmbhO0uEEK9/ETW29Wk1thYUJBz3IVnvgEiEwEa9IeLyvnpKrWK64Utw2bgUmDveww==", 183 | "cpu": [ 184 | "x64" 185 | ], 186 | "dev": true, 187 | "optional": true, 188 | "os": [ 189 | "android" 190 | ], 191 | "engines": { 192 | "node": ">=12" 193 | } 194 | }, 195 | "node_modules/@esbuild/darwin-arm64": { 196 | "version": "0.17.19", 197 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.19.tgz", 198 | "integrity": "sha512-80wEoCfF/hFKM6WE1FyBHc9SfUblloAWx6FJkFWTWiCoht9Mc0ARGEM47e67W9rI09YoUxJL68WHfDRYEAvOhg==", 199 | "cpu": [ 200 | "arm64" 201 | ], 202 | "dev": true, 203 | "optional": true, 204 | "os": [ 205 | "darwin" 206 | ], 207 | "engines": { 208 | "node": ">=12" 209 | } 210 | }, 211 | "node_modules/@esbuild/darwin-x64": { 212 | "version": "0.17.19", 213 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.19.tgz", 214 | "integrity": "sha512-IJM4JJsLhRYr9xdtLytPLSH9k/oxR3boaUIYiHkAawtwNOXKE8KoU8tMvryogdcT8AU+Bflmh81Xn6Q0vTZbQw==", 215 | "cpu": [ 216 | "x64" 217 | ], 218 | "dev": true, 219 | "optional": true, 220 | "os": [ 221 | "darwin" 222 | ], 223 | "engines": { 224 | "node": ">=12" 225 | } 226 | }, 227 | "node_modules/@esbuild/freebsd-arm64": { 228 | "version": "0.17.19", 229 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.19.tgz", 230 | "integrity": "sha512-pBwbc7DufluUeGdjSU5Si+P3SoMF5DQ/F/UmTSb8HXO80ZEAJmrykPyzo1IfNbAoaqw48YRpv8shwd1NoI0jcQ==", 231 | "cpu": [ 232 | "arm64" 233 | ], 234 | "dev": true, 235 | "optional": true, 236 | "os": [ 237 | "freebsd" 238 | ], 239 | "engines": { 240 | "node": ">=12" 241 | } 242 | }, 243 | "node_modules/@esbuild/freebsd-x64": { 244 | "version": "0.17.19", 245 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.19.tgz", 246 | "integrity": "sha512-4lu+n8Wk0XlajEhbEffdy2xy53dpR06SlzvhGByyg36qJw6Kpfk7cp45DR/62aPH9mtJRmIyrXAS5UWBrJT6TQ==", 247 | "cpu": [ 248 | "x64" 249 | ], 250 | "dev": true, 251 | "optional": true, 252 | "os": [ 253 | "freebsd" 254 | ], 255 | "engines": { 256 | "node": ">=12" 257 | } 258 | }, 259 | "node_modules/@esbuild/linux-arm": { 260 | "version": "0.17.19", 261 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.19.tgz", 262 | "integrity": "sha512-cdmT3KxjlOQ/gZ2cjfrQOtmhG4HJs6hhvm3mWSRDPtZ/lP5oe8FWceS10JaSJC13GBd4eH/haHnqf7hhGNLerA==", 263 | "cpu": [ 264 | "arm" 265 | ], 266 | "dev": true, 267 | "optional": true, 268 | "os": [ 269 | "linux" 270 | ], 271 | "engines": { 272 | "node": ">=12" 273 | } 274 | }, 275 | "node_modules/@esbuild/linux-arm64": { 276 | "version": "0.17.19", 277 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.19.tgz", 278 | "integrity": "sha512-ct1Tg3WGwd3P+oZYqic+YZF4snNl2bsnMKRkb3ozHmnM0dGWuxcPTTntAF6bOP0Sp4x0PjSF+4uHQ1xvxfRKqg==", 279 | "cpu": [ 280 | "arm64" 281 | ], 282 | "dev": true, 283 | "optional": true, 284 | "os": [ 285 | "linux" 286 | ], 287 | "engines": { 288 | "node": ">=12" 289 | } 290 | }, 291 | "node_modules/@esbuild/linux-ia32": { 292 | "version": "0.17.19", 293 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.19.tgz", 294 | "integrity": "sha512-w4IRhSy1VbsNxHRQpeGCHEmibqdTUx61Vc38APcsRbuVgK0OPEnQ0YD39Brymn96mOx48Y2laBQGqgZ0j9w6SQ==", 295 | "cpu": [ 296 | "ia32" 297 | ], 298 | "dev": true, 299 | "optional": true, 300 | "os": [ 301 | "linux" 302 | ], 303 | "engines": { 304 | "node": ">=12" 305 | } 306 | }, 307 | "node_modules/@esbuild/linux-loong64": { 308 | "version": "0.17.19", 309 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.19.tgz", 310 | "integrity": "sha512-2iAngUbBPMq439a+z//gE+9WBldoMp1s5GWsUSgqHLzLJ9WoZLZhpwWuym0u0u/4XmZ3gpHmzV84PonE+9IIdQ==", 311 | "cpu": [ 312 | "loong64" 313 | ], 314 | "dev": true, 315 | "optional": true, 316 | "os": [ 317 | "linux" 318 | ], 319 | "engines": { 320 | "node": ">=12" 321 | } 322 | }, 323 | "node_modules/@esbuild/linux-mips64el": { 324 | "version": "0.17.19", 325 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.19.tgz", 326 | "integrity": "sha512-LKJltc4LVdMKHsrFe4MGNPp0hqDFA1Wpt3jE1gEyM3nKUvOiO//9PheZZHfYRfYl6AwdTH4aTcXSqBerX0ml4A==", 327 | "cpu": [ 328 | "mips64el" 329 | ], 330 | "dev": true, 331 | "optional": true, 332 | "os": [ 333 | "linux" 334 | ], 335 | "engines": { 336 | "node": ">=12" 337 | } 338 | }, 339 | "node_modules/@esbuild/linux-ppc64": { 340 | "version": "0.17.19", 341 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.19.tgz", 342 | "integrity": "sha512-/c/DGybs95WXNS8y3Ti/ytqETiW7EU44MEKuCAcpPto3YjQbyK3IQVKfF6nbghD7EcLUGl0NbiL5Rt5DMhn5tg==", 343 | "cpu": [ 344 | "ppc64" 345 | ], 346 | "dev": true, 347 | "optional": true, 348 | "os": [ 349 | "linux" 350 | ], 351 | "engines": { 352 | "node": ">=12" 353 | } 354 | }, 355 | "node_modules/@esbuild/linux-riscv64": { 356 | "version": "0.17.19", 357 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.19.tgz", 358 | "integrity": "sha512-FC3nUAWhvFoutlhAkgHf8f5HwFWUL6bYdvLc/TTuxKlvLi3+pPzdZiFKSWz/PF30TB1K19SuCxDTI5KcqASJqA==", 359 | "cpu": [ 360 | "riscv64" 361 | ], 362 | "dev": true, 363 | "optional": true, 364 | "os": [ 365 | "linux" 366 | ], 367 | "engines": { 368 | "node": ">=12" 369 | } 370 | }, 371 | "node_modules/@esbuild/linux-s390x": { 372 | "version": "0.17.19", 373 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.19.tgz", 374 | "integrity": "sha512-IbFsFbxMWLuKEbH+7sTkKzL6NJmG2vRyy6K7JJo55w+8xDk7RElYn6xvXtDW8HCfoKBFK69f3pgBJSUSQPr+4Q==", 375 | "cpu": [ 376 | "s390x" 377 | ], 378 | "dev": true, 379 | "optional": true, 380 | "os": [ 381 | "linux" 382 | ], 383 | "engines": { 384 | "node": ">=12" 385 | } 386 | }, 387 | "node_modules/@esbuild/linux-x64": { 388 | "version": "0.17.19", 389 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.19.tgz", 390 | "integrity": "sha512-68ngA9lg2H6zkZcyp22tsVt38mlhWde8l3eJLWkyLrp4HwMUr3c1s/M2t7+kHIhvMjglIBrFpncX1SzMckomGw==", 391 | "cpu": [ 392 | "x64" 393 | ], 394 | "dev": true, 395 | "optional": true, 396 | "os": [ 397 | "linux" 398 | ], 399 | "engines": { 400 | "node": ">=12" 401 | } 402 | }, 403 | "node_modules/@esbuild/netbsd-x64": { 404 | "version": "0.17.19", 405 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.19.tgz", 406 | "integrity": "sha512-CwFq42rXCR8TYIjIfpXCbRX0rp1jo6cPIUPSaWwzbVI4aOfX96OXY8M6KNmtPcg7QjYeDmN+DD0Wp3LaBOLf4Q==", 407 | "cpu": [ 408 | "x64" 409 | ], 410 | "dev": true, 411 | "optional": true, 412 | "os": [ 413 | "netbsd" 414 | ], 415 | "engines": { 416 | "node": ">=12" 417 | } 418 | }, 419 | "node_modules/@esbuild/openbsd-x64": { 420 | "version": "0.17.19", 421 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.19.tgz", 422 | "integrity": "sha512-cnq5brJYrSZ2CF6c35eCmviIN3k3RczmHz8eYaVlNasVqsNY+JKohZU5MKmaOI+KkllCdzOKKdPs762VCPC20g==", 423 | "cpu": [ 424 | "x64" 425 | ], 426 | "dev": true, 427 | "optional": true, 428 | "os": [ 429 | "openbsd" 430 | ], 431 | "engines": { 432 | "node": ">=12" 433 | } 434 | }, 435 | "node_modules/@esbuild/sunos-x64": { 436 | "version": "0.17.19", 437 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.19.tgz", 438 | "integrity": "sha512-vCRT7yP3zX+bKWFeP/zdS6SqdWB8OIpaRq/mbXQxTGHnIxspRtigpkUcDMlSCOejlHowLqII7K2JKevwyRP2rg==", 439 | "cpu": [ 440 | "x64" 441 | ], 442 | "dev": true, 443 | "optional": true, 444 | "os": [ 445 | "sunos" 446 | ], 447 | "engines": { 448 | "node": ">=12" 449 | } 450 | }, 451 | "node_modules/@esbuild/win32-arm64": { 452 | "version": "0.17.19", 453 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.19.tgz", 454 | "integrity": "sha512-yYx+8jwowUstVdorcMdNlzklLYhPxjniHWFKgRqH7IFlUEa0Umu3KuYplf1HUZZ422e3NU9F4LGb+4O0Kdcaag==", 455 | "cpu": [ 456 | "arm64" 457 | ], 458 | "dev": true, 459 | "optional": true, 460 | "os": [ 461 | "win32" 462 | ], 463 | "engines": { 464 | "node": ">=12" 465 | } 466 | }, 467 | "node_modules/@esbuild/win32-ia32": { 468 | "version": "0.17.19", 469 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.19.tgz", 470 | "integrity": "sha512-eggDKanJszUtCdlVs0RB+h35wNlb5v4TWEkq4vZcmVt5u/HiDZrTXe2bWFQUez3RgNHwx/x4sk5++4NSSicKkw==", 471 | "cpu": [ 472 | "ia32" 473 | ], 474 | "dev": true, 475 | "optional": true, 476 | "os": [ 477 | "win32" 478 | ], 479 | "engines": { 480 | "node": ">=12" 481 | } 482 | }, 483 | "node_modules/@esbuild/win32-x64": { 484 | "version": "0.17.19", 485 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.19.tgz", 486 | "integrity": "sha512-lAhycmKnVOuRYNtRtatQR1LPQf2oYCkRGkSFnseDAKPl8lu5SOsK/e1sXe5a0Pc5kHIHe6P2I/ilntNv2xf3cA==", 487 | "cpu": [ 488 | "x64" 489 | ], 490 | "dev": true, 491 | "optional": true, 492 | "os": [ 493 | "win32" 494 | ], 495 | "engines": { 496 | "node": ">=12" 497 | } 498 | }, 499 | "node_modules/@fastify/busboy": { 500 | "version": "2.1.1", 501 | "resolved": "https://registry.npmjs.org/@fastify/busboy/-/busboy-2.1.1.tgz", 502 | "integrity": "sha512-vBZP4NlzfOlerQTnba4aqZoMhE/a9HY7HRqoOPaETQcSQuWEIyZMHGfVu6w9wGtGK5fED5qRs2DteVCjOH60sA==", 503 | "dev": true, 504 | "engines": { 505 | "node": ">=14" 506 | } 507 | }, 508 | "node_modules/@jridgewell/resolve-uri": { 509 | "version": "3.1.2", 510 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 511 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 512 | "dev": true, 513 | "engines": { 514 | "node": ">=6.0.0" 515 | } 516 | }, 517 | "node_modules/@jridgewell/sourcemap-codec": { 518 | "version": "1.4.15", 519 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 520 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 521 | "dev": true 522 | }, 523 | "node_modules/@jridgewell/trace-mapping": { 524 | "version": "0.3.9", 525 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 526 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 527 | "dev": true, 528 | "dependencies": { 529 | "@jridgewell/resolve-uri": "^3.0.3", 530 | "@jridgewell/sourcemap-codec": "^1.4.10" 531 | } 532 | }, 533 | "node_modules/@types/node": { 534 | "version": "20.12.7", 535 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.12.7.tgz", 536 | "integrity": "sha512-wq0cICSkRLVaf3UGLMGItu/PtdY7oaXaI/RVU+xliKVOtRna3PRY57ZDfztpDL0n11vfymMUnXv8QwYCO7L1wg==", 537 | "dev": true, 538 | "dependencies": { 539 | "undici-types": "~5.26.4" 540 | } 541 | }, 542 | "node_modules/@types/node-forge": { 543 | "version": "1.3.11", 544 | "resolved": "https://registry.npmjs.org/@types/node-forge/-/node-forge-1.3.11.tgz", 545 | "integrity": "sha512-FQx220y22OKNTqaByeBGqHWYz4cl94tpcxeFdvBo3wjG6XPBuZ0BNgNZRV5J5TFmmcsJ4IzsLkmGRiQbnYsBEQ==", 546 | "dev": true, 547 | "dependencies": { 548 | "@types/node": "*" 549 | } 550 | }, 551 | "node_modules/acorn": { 552 | "version": "8.11.3", 553 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 554 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 555 | "dev": true, 556 | "bin": { 557 | "acorn": "bin/acorn" 558 | }, 559 | "engines": { 560 | "node": ">=0.4.0" 561 | } 562 | }, 563 | "node_modules/acorn-walk": { 564 | "version": "8.3.2", 565 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.2.tgz", 566 | "integrity": "sha512-cjkyv4OtNCIeqhHrfS81QWXoCBPExR/J62oyEqepVw8WaQeSqpW2uhuLPh1m9eWhDuOo/jUXVTlifvesOWp/4A==", 567 | "dev": true, 568 | "engines": { 569 | "node": ">=0.4.0" 570 | } 571 | }, 572 | "node_modules/anymatch": { 573 | "version": "3.1.3", 574 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 575 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 576 | "dev": true, 577 | "dependencies": { 578 | "normalize-path": "^3.0.0", 579 | "picomatch": "^2.0.4" 580 | }, 581 | "engines": { 582 | "node": ">= 8" 583 | } 584 | }, 585 | "node_modules/as-table": { 586 | "version": "1.0.55", 587 | "resolved": "https://registry.npmjs.org/as-table/-/as-table-1.0.55.tgz", 588 | "integrity": "sha512-xvsWESUJn0JN421Xb9MQw6AsMHRCUknCe0Wjlxvjud80mU4E6hQf1A6NzQKcYNmYw62MfzEtXc+badstZP3JpQ==", 589 | "dev": true, 590 | "dependencies": { 591 | "printable-characters": "^1.0.42" 592 | } 593 | }, 594 | "node_modules/binary-extensions": { 595 | "version": "2.3.0", 596 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", 597 | "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", 598 | "dev": true, 599 | "engines": { 600 | "node": ">=8" 601 | }, 602 | "funding": { 603 | "url": "https://github.com/sponsors/sindresorhus" 604 | } 605 | }, 606 | "node_modules/blake3-wasm": { 607 | "version": "2.1.5", 608 | "resolved": "https://registry.npmjs.org/blake3-wasm/-/blake3-wasm-2.1.5.tgz", 609 | "integrity": "sha512-F1+K8EbfOZE49dtoPtmxUQrpXaBIl3ICvasLh+nJta0xkz+9kF/7uet9fLnwKqhDrmj6g+6K3Tw9yQPUg2ka5g==", 610 | "dev": true 611 | }, 612 | "node_modules/braces": { 613 | "version": "3.0.2", 614 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 615 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 616 | "dev": true, 617 | "dependencies": { 618 | "fill-range": "^7.0.1" 619 | }, 620 | "engines": { 621 | "node": ">=8" 622 | } 623 | }, 624 | "node_modules/capnp-ts": { 625 | "version": "0.7.0", 626 | "resolved": "https://registry.npmjs.org/capnp-ts/-/capnp-ts-0.7.0.tgz", 627 | "integrity": "sha512-XKxXAC3HVPv7r674zP0VC3RTXz+/JKhfyw94ljvF80yynK6VkTnqE3jMuN8b3dUVmmc43TjyxjW4KTsmB3c86g==", 628 | "dev": true, 629 | "dependencies": { 630 | "debug": "^4.3.1", 631 | "tslib": "^2.2.0" 632 | } 633 | }, 634 | "node_modules/chokidar": { 635 | "version": "3.6.0", 636 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", 637 | "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", 638 | "dev": true, 639 | "dependencies": { 640 | "anymatch": "~3.1.2", 641 | "braces": "~3.0.2", 642 | "glob-parent": "~5.1.2", 643 | "is-binary-path": "~2.1.0", 644 | "is-glob": "~4.0.1", 645 | "normalize-path": "~3.0.0", 646 | "readdirp": "~3.6.0" 647 | }, 648 | "engines": { 649 | "node": ">= 8.10.0" 650 | }, 651 | "funding": { 652 | "url": "https://paulmillr.com/funding/" 653 | }, 654 | "optionalDependencies": { 655 | "fsevents": "~2.3.2" 656 | } 657 | }, 658 | "node_modules/cookie": { 659 | "version": "0.5.0", 660 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 661 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 662 | "dev": true, 663 | "engines": { 664 | "node": ">= 0.6" 665 | } 666 | }, 667 | "node_modules/data-uri-to-buffer": { 668 | "version": "2.0.2", 669 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-2.0.2.tgz", 670 | "integrity": "sha512-ND9qDTLc6diwj+Xe5cdAgVTbLVdXbtxTJRXRhli8Mowuaan+0EJOtdqJ0QCHNSSPyoXGx9HX2/VMnKeC34AChA==", 671 | "dev": true 672 | }, 673 | "node_modules/debug": { 674 | "version": "4.3.4", 675 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 676 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 677 | "dev": true, 678 | "dependencies": { 679 | "ms": "2.1.2" 680 | }, 681 | "engines": { 682 | "node": ">=6.0" 683 | }, 684 | "peerDependenciesMeta": { 685 | "supports-color": { 686 | "optional": true 687 | } 688 | } 689 | }, 690 | "node_modules/esbuild": { 691 | "version": "0.17.19", 692 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.19.tgz", 693 | "integrity": "sha512-XQ0jAPFkK/u3LcVRcvVHQcTIqD6E2H1fvZMA5dQPSOWb3suUbWbfbRf94pjc0bNzRYLfIrDRQXr7X+LHIm5oHw==", 694 | "dev": true, 695 | "hasInstallScript": true, 696 | "bin": { 697 | "esbuild": "bin/esbuild" 698 | }, 699 | "engines": { 700 | "node": ">=12" 701 | }, 702 | "optionalDependencies": { 703 | "@esbuild/android-arm": "0.17.19", 704 | "@esbuild/android-arm64": "0.17.19", 705 | "@esbuild/android-x64": "0.17.19", 706 | "@esbuild/darwin-arm64": "0.17.19", 707 | "@esbuild/darwin-x64": "0.17.19", 708 | "@esbuild/freebsd-arm64": "0.17.19", 709 | "@esbuild/freebsd-x64": "0.17.19", 710 | "@esbuild/linux-arm": "0.17.19", 711 | "@esbuild/linux-arm64": "0.17.19", 712 | "@esbuild/linux-ia32": "0.17.19", 713 | "@esbuild/linux-loong64": "0.17.19", 714 | "@esbuild/linux-mips64el": "0.17.19", 715 | "@esbuild/linux-ppc64": "0.17.19", 716 | "@esbuild/linux-riscv64": "0.17.19", 717 | "@esbuild/linux-s390x": "0.17.19", 718 | "@esbuild/linux-x64": "0.17.19", 719 | "@esbuild/netbsd-x64": "0.17.19", 720 | "@esbuild/openbsd-x64": "0.17.19", 721 | "@esbuild/sunos-x64": "0.17.19", 722 | "@esbuild/win32-arm64": "0.17.19", 723 | "@esbuild/win32-ia32": "0.17.19", 724 | "@esbuild/win32-x64": "0.17.19" 725 | } 726 | }, 727 | "node_modules/escape-string-regexp": { 728 | "version": "4.0.0", 729 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 730 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 731 | "dev": true, 732 | "engines": { 733 | "node": ">=10" 734 | }, 735 | "funding": { 736 | "url": "https://github.com/sponsors/sindresorhus" 737 | } 738 | }, 739 | "node_modules/estree-walker": { 740 | "version": "0.6.1", 741 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", 742 | "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", 743 | "dev": true 744 | }, 745 | "node_modules/exit-hook": { 746 | "version": "2.2.1", 747 | "resolved": "https://registry.npmjs.org/exit-hook/-/exit-hook-2.2.1.tgz", 748 | "integrity": "sha512-eNTPlAD67BmP31LDINZ3U7HSF8l57TxOY2PmBJ1shpCvpnxBF93mWCE8YHBnXs8qiUZJc9WDcWIeC3a2HIAMfw==", 749 | "dev": true, 750 | "engines": { 751 | "node": ">=6" 752 | }, 753 | "funding": { 754 | "url": "https://github.com/sponsors/sindresorhus" 755 | } 756 | }, 757 | "node_modules/fill-range": { 758 | "version": "7.0.1", 759 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 760 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 761 | "dev": true, 762 | "dependencies": { 763 | "to-regex-range": "^5.0.1" 764 | }, 765 | "engines": { 766 | "node": ">=8" 767 | } 768 | }, 769 | "node_modules/fsevents": { 770 | "version": "2.3.3", 771 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 772 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 773 | "dev": true, 774 | "hasInstallScript": true, 775 | "optional": true, 776 | "os": [ 777 | "darwin" 778 | ], 779 | "engines": { 780 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 781 | } 782 | }, 783 | "node_modules/function-bind": { 784 | "version": "1.1.2", 785 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 786 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 787 | "dev": true, 788 | "funding": { 789 | "url": "https://github.com/sponsors/ljharb" 790 | } 791 | }, 792 | "node_modules/get-source": { 793 | "version": "2.0.12", 794 | "resolved": "https://registry.npmjs.org/get-source/-/get-source-2.0.12.tgz", 795 | "integrity": "sha512-X5+4+iD+HoSeEED+uwrQ07BOQr0kEDFMVqqpBuI+RaZBpBpHCuXxo70bjar6f0b0u/DQJsJ7ssurpP0V60Az+w==", 796 | "dev": true, 797 | "dependencies": { 798 | "data-uri-to-buffer": "^2.0.0", 799 | "source-map": "^0.6.1" 800 | } 801 | }, 802 | "node_modules/glob-parent": { 803 | "version": "5.1.2", 804 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 805 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 806 | "dev": true, 807 | "dependencies": { 808 | "is-glob": "^4.0.1" 809 | }, 810 | "engines": { 811 | "node": ">= 6" 812 | } 813 | }, 814 | "node_modules/glob-to-regexp": { 815 | "version": "0.4.1", 816 | "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz", 817 | "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==", 818 | "dev": true 819 | }, 820 | "node_modules/hasown": { 821 | "version": "2.0.2", 822 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 823 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 824 | "dev": true, 825 | "dependencies": { 826 | "function-bind": "^1.1.2" 827 | }, 828 | "engines": { 829 | "node": ">= 0.4" 830 | } 831 | }, 832 | "node_modules/is-binary-path": { 833 | "version": "2.1.0", 834 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 835 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 836 | "dev": true, 837 | "dependencies": { 838 | "binary-extensions": "^2.0.0" 839 | }, 840 | "engines": { 841 | "node": ">=8" 842 | } 843 | }, 844 | "node_modules/is-core-module": { 845 | "version": "2.13.1", 846 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", 847 | "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", 848 | "dev": true, 849 | "dependencies": { 850 | "hasown": "^2.0.0" 851 | }, 852 | "funding": { 853 | "url": "https://github.com/sponsors/ljharb" 854 | } 855 | }, 856 | "node_modules/is-extglob": { 857 | "version": "2.1.1", 858 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 859 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 860 | "dev": true, 861 | "engines": { 862 | "node": ">=0.10.0" 863 | } 864 | }, 865 | "node_modules/is-glob": { 866 | "version": "4.0.3", 867 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 868 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 869 | "dev": true, 870 | "dependencies": { 871 | "is-extglob": "^2.1.1" 872 | }, 873 | "engines": { 874 | "node": ">=0.10.0" 875 | } 876 | }, 877 | "node_modules/is-number": { 878 | "version": "7.0.0", 879 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 880 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 881 | "dev": true, 882 | "engines": { 883 | "node": ">=0.12.0" 884 | } 885 | }, 886 | "node_modules/magic-string": { 887 | "version": "0.25.9", 888 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz", 889 | "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==", 890 | "dev": true, 891 | "dependencies": { 892 | "sourcemap-codec": "^1.4.8" 893 | } 894 | }, 895 | "node_modules/mime": { 896 | "version": "3.0.0", 897 | "resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz", 898 | "integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==", 899 | "dev": true, 900 | "bin": { 901 | "mime": "cli.js" 902 | }, 903 | "engines": { 904 | "node": ">=10.0.0" 905 | } 906 | }, 907 | "node_modules/miniflare": { 908 | "version": "3.20240404.0", 909 | "resolved": "https://registry.npmjs.org/miniflare/-/miniflare-3.20240404.0.tgz", 910 | "integrity": "sha512-+FOTcztPMW3akmucX4vE0PWMNvP4JBwl4s9ieA84fcOaDtTbtfU1rHXpcacj16klpUpvSnD6xd8Sjsn6SJXPfg==", 911 | "dev": true, 912 | "dependencies": { 913 | "@cspotcode/source-map-support": "0.8.1", 914 | "acorn": "^8.8.0", 915 | "acorn-walk": "^8.2.0", 916 | "capnp-ts": "^0.7.0", 917 | "exit-hook": "^2.2.1", 918 | "glob-to-regexp": "^0.4.1", 919 | "stoppable": "^1.1.0", 920 | "undici": "^5.28.2", 921 | "workerd": "1.20240404.0", 922 | "ws": "^8.11.0", 923 | "youch": "^3.2.2", 924 | "zod": "^3.20.6" 925 | }, 926 | "bin": { 927 | "miniflare": "bootstrap.js" 928 | }, 929 | "engines": { 930 | "node": ">=16.13" 931 | } 932 | }, 933 | "node_modules/ms": { 934 | "version": "2.1.2", 935 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 936 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 937 | "dev": true 938 | }, 939 | "node_modules/mustache": { 940 | "version": "4.2.0", 941 | "resolved": "https://registry.npmjs.org/mustache/-/mustache-4.2.0.tgz", 942 | "integrity": "sha512-71ippSywq5Yb7/tVYyGbkBggbU8H3u5Rz56fH60jGFgr8uHwxs+aSKeqmluIVzM0m0kB7xQjKS6qPfd0b2ZoqQ==", 943 | "dev": true, 944 | "bin": { 945 | "mustache": "bin/mustache" 946 | } 947 | }, 948 | "node_modules/nanoid": { 949 | "version": "3.3.7", 950 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", 951 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", 952 | "dev": true, 953 | "funding": [ 954 | { 955 | "type": "github", 956 | "url": "https://github.com/sponsors/ai" 957 | } 958 | ], 959 | "bin": { 960 | "nanoid": "bin/nanoid.cjs" 961 | }, 962 | "engines": { 963 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 964 | } 965 | }, 966 | "node_modules/node-forge": { 967 | "version": "1.3.1", 968 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", 969 | "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==", 970 | "dev": true, 971 | "engines": { 972 | "node": ">= 6.13.0" 973 | } 974 | }, 975 | "node_modules/normalize-path": { 976 | "version": "3.0.0", 977 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 978 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 979 | "dev": true, 980 | "engines": { 981 | "node": ">=0.10.0" 982 | } 983 | }, 984 | "node_modules/path-parse": { 985 | "version": "1.0.7", 986 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 987 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 988 | "dev": true 989 | }, 990 | "node_modules/path-to-regexp": { 991 | "version": "6.2.2", 992 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.2.tgz", 993 | "integrity": "sha512-GQX3SSMokngb36+whdpRXE+3f9V8UzyAorlYvOGx87ufGHehNTn5lCxrKtLyZ4Yl/wEKnNnr98ZzOwwDZV5ogw==", 994 | "dev": true 995 | }, 996 | "node_modules/picomatch": { 997 | "version": "2.3.1", 998 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 999 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1000 | "dev": true, 1001 | "engines": { 1002 | "node": ">=8.6" 1003 | }, 1004 | "funding": { 1005 | "url": "https://github.com/sponsors/jonschlinkert" 1006 | } 1007 | }, 1008 | "node_modules/prettier": { 1009 | "version": "3.2.5", 1010 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.2.5.tgz", 1011 | "integrity": "sha512-3/GWa9aOC0YeD7LUfvOG2NiDyhOWRvt1k+rcKhOuYnMY24iiCphgneUfJDyFXd6rZCAnuLBv6UeAULtrhT/F4A==", 1012 | "dev": true, 1013 | "bin": { 1014 | "prettier": "bin/prettier.cjs" 1015 | }, 1016 | "engines": { 1017 | "node": ">=14" 1018 | }, 1019 | "funding": { 1020 | "url": "https://github.com/prettier/prettier?sponsor=1" 1021 | } 1022 | }, 1023 | "node_modules/printable-characters": { 1024 | "version": "1.0.42", 1025 | "resolved": "https://registry.npmjs.org/printable-characters/-/printable-characters-1.0.42.tgz", 1026 | "integrity": "sha512-dKp+C4iXWK4vVYZmYSd0KBH5F/h1HoZRsbJ82AVKRO3PEo8L4lBS/vLwhVtpwwuYcoIsVY+1JYKR268yn480uQ==", 1027 | "dev": true 1028 | }, 1029 | "node_modules/readdirp": { 1030 | "version": "3.6.0", 1031 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1032 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1033 | "dev": true, 1034 | "dependencies": { 1035 | "picomatch": "^2.2.1" 1036 | }, 1037 | "engines": { 1038 | "node": ">=8.10.0" 1039 | } 1040 | }, 1041 | "node_modules/resolve": { 1042 | "version": "1.22.8", 1043 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", 1044 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", 1045 | "dev": true, 1046 | "dependencies": { 1047 | "is-core-module": "^2.13.0", 1048 | "path-parse": "^1.0.7", 1049 | "supports-preserve-symlinks-flag": "^1.0.0" 1050 | }, 1051 | "bin": { 1052 | "resolve": "bin/resolve" 1053 | }, 1054 | "funding": { 1055 | "url": "https://github.com/sponsors/ljharb" 1056 | } 1057 | }, 1058 | "node_modules/resolve.exports": { 1059 | "version": "2.0.2", 1060 | "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.2.tgz", 1061 | "integrity": "sha512-X2UW6Nw3n/aMgDVy+0rSqgHlv39WZAlZrXCdnbyEiKm17DSqHX4MmQMaST3FbeWR5FTuRcUwYAziZajji0Y7mg==", 1062 | "dev": true, 1063 | "engines": { 1064 | "node": ">=10" 1065 | } 1066 | }, 1067 | "node_modules/rollup-plugin-inject": { 1068 | "version": "3.0.2", 1069 | "resolved": "https://registry.npmjs.org/rollup-plugin-inject/-/rollup-plugin-inject-3.0.2.tgz", 1070 | "integrity": "sha512-ptg9PQwzs3orn4jkgXJ74bfs5vYz1NCZlSQMBUA0wKcGp5i5pA1AO3fOUEte8enhGUC+iapTCzEWw2jEFFUO/w==", 1071 | "deprecated": "This package has been deprecated and is no longer maintained. Please use @rollup/plugin-inject.", 1072 | "dev": true, 1073 | "dependencies": { 1074 | "estree-walker": "^0.6.1", 1075 | "magic-string": "^0.25.3", 1076 | "rollup-pluginutils": "^2.8.1" 1077 | } 1078 | }, 1079 | "node_modules/rollup-plugin-node-polyfills": { 1080 | "version": "0.2.1", 1081 | "resolved": "https://registry.npmjs.org/rollup-plugin-node-polyfills/-/rollup-plugin-node-polyfills-0.2.1.tgz", 1082 | "integrity": "sha512-4kCrKPTJ6sK4/gLL/U5QzVT8cxJcofO0OU74tnB19F40cmuAKSzH5/siithxlofFEjwvw1YAhPmbvGNA6jEroA==", 1083 | "dev": true, 1084 | "dependencies": { 1085 | "rollup-plugin-inject": "^3.0.0" 1086 | } 1087 | }, 1088 | "node_modules/rollup-pluginutils": { 1089 | "version": "2.8.2", 1090 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", 1091 | "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", 1092 | "dev": true, 1093 | "dependencies": { 1094 | "estree-walker": "^0.6.1" 1095 | } 1096 | }, 1097 | "node_modules/selfsigned": { 1098 | "version": "2.4.1", 1099 | "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.4.1.tgz", 1100 | "integrity": "sha512-th5B4L2U+eGLq1TVh7zNRGBapioSORUeymIydxgFpwww9d2qyKvtuPU2jJuHvYAwwqi2Y596QBL3eEqcPEYL8Q==", 1101 | "dev": true, 1102 | "dependencies": { 1103 | "@types/node-forge": "^1.3.0", 1104 | "node-forge": "^1" 1105 | }, 1106 | "engines": { 1107 | "node": ">=10" 1108 | } 1109 | }, 1110 | "node_modules/source-map": { 1111 | "version": "0.6.1", 1112 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1113 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1114 | "dev": true, 1115 | "engines": { 1116 | "node": ">=0.10.0" 1117 | } 1118 | }, 1119 | "node_modules/sourcemap-codec": { 1120 | "version": "1.4.8", 1121 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 1122 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 1123 | "deprecated": "Please use @jridgewell/sourcemap-codec instead", 1124 | "dev": true 1125 | }, 1126 | "node_modules/stacktracey": { 1127 | "version": "2.1.8", 1128 | "resolved": "https://registry.npmjs.org/stacktracey/-/stacktracey-2.1.8.tgz", 1129 | "integrity": "sha512-Kpij9riA+UNg7TnphqjH7/CzctQ/owJGNbFkfEeve4Z4uxT5+JapVLFXcsurIfN34gnTWZNJ/f7NMG0E8JDzTw==", 1130 | "dev": true, 1131 | "dependencies": { 1132 | "as-table": "^1.0.36", 1133 | "get-source": "^2.0.12" 1134 | } 1135 | }, 1136 | "node_modules/stoppable": { 1137 | "version": "1.1.0", 1138 | "resolved": "https://registry.npmjs.org/stoppable/-/stoppable-1.1.0.tgz", 1139 | "integrity": "sha512-KXDYZ9dszj6bzvnEMRYvxgeTHU74QBFL54XKtP3nyMuJ81CFYtABZ3bAzL2EdFUaEwJOBOgENyFj3R7oTzDyyw==", 1140 | "dev": true, 1141 | "engines": { 1142 | "node": ">=4", 1143 | "npm": ">=6" 1144 | } 1145 | }, 1146 | "node_modules/supports-preserve-symlinks-flag": { 1147 | "version": "1.0.0", 1148 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1149 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1150 | "dev": true, 1151 | "engines": { 1152 | "node": ">= 0.4" 1153 | }, 1154 | "funding": { 1155 | "url": "https://github.com/sponsors/ljharb" 1156 | } 1157 | }, 1158 | "node_modules/to-regex-range": { 1159 | "version": "5.0.1", 1160 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1161 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1162 | "dev": true, 1163 | "dependencies": { 1164 | "is-number": "^7.0.0" 1165 | }, 1166 | "engines": { 1167 | "node": ">=8.0" 1168 | } 1169 | }, 1170 | "node_modules/tslib": { 1171 | "version": "2.6.2", 1172 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", 1173 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", 1174 | "dev": true 1175 | }, 1176 | "node_modules/typescript": { 1177 | "version": "5.4.5", 1178 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.4.5.tgz", 1179 | "integrity": "sha512-vcI4UpRgg81oIRUFwR0WSIHKt11nJ7SAVlYNIu+QpqeyXP+gpQJy/Z4+F0aGxSE4MqwjyXvW/TzgkLAx2AGHwQ==", 1180 | "dev": true, 1181 | "bin": { 1182 | "tsc": "bin/tsc", 1183 | "tsserver": "bin/tsserver" 1184 | }, 1185 | "engines": { 1186 | "node": ">=14.17" 1187 | } 1188 | }, 1189 | "node_modules/undici": { 1190 | "version": "5.28.4", 1191 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.28.4.tgz", 1192 | "integrity": "sha512-72RFADWFqKmUb2hmmvNODKL3p9hcB6Gt2DOQMis1SEBaV6a4MH8soBvzg+95CYhCKPFedut2JY9bMfrDl9D23g==", 1193 | "dev": true, 1194 | "dependencies": { 1195 | "@fastify/busboy": "^2.0.0" 1196 | }, 1197 | "engines": { 1198 | "node": ">=14.0" 1199 | } 1200 | }, 1201 | "node_modules/undici-types": { 1202 | "version": "5.26.5", 1203 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", 1204 | "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", 1205 | "dev": true 1206 | }, 1207 | "node_modules/workerd": { 1208 | "version": "1.20240404.0", 1209 | "resolved": "https://registry.npmjs.org/workerd/-/workerd-1.20240404.0.tgz", 1210 | "integrity": "sha512-U4tfnvBcPMsv7pmRGuF0J5UnoZi6tbc64tXNfyijI74r6w6Vlb2+a6eibdQL8g0g46+4vjuTKME9G5RvSvdc8g==", 1211 | "dev": true, 1212 | "hasInstallScript": true, 1213 | "bin": { 1214 | "workerd": "bin/workerd" 1215 | }, 1216 | "engines": { 1217 | "node": ">=16" 1218 | }, 1219 | "optionalDependencies": { 1220 | "@cloudflare/workerd-darwin-64": "1.20240404.0", 1221 | "@cloudflare/workerd-darwin-arm64": "1.20240404.0", 1222 | "@cloudflare/workerd-linux-64": "1.20240404.0", 1223 | "@cloudflare/workerd-linux-arm64": "1.20240404.0", 1224 | "@cloudflare/workerd-windows-64": "1.20240404.0" 1225 | } 1226 | }, 1227 | "node_modules/wrangler": { 1228 | "version": "3.48.0", 1229 | "resolved": "https://registry.npmjs.org/wrangler/-/wrangler-3.48.0.tgz", 1230 | "integrity": "sha512-Wv7JS6FyX1j9HkaM6WL3fmTzBMAYc4hPSyZCuxuH55hkJDX/7ts+YAgsaN1U8rKoDrV3FVSgBfI9TyqP9iuM8Q==", 1231 | "dev": true, 1232 | "dependencies": { 1233 | "@cloudflare/kv-asset-handler": "0.3.1", 1234 | "@esbuild-plugins/node-globals-polyfill": "^0.2.3", 1235 | "@esbuild-plugins/node-modules-polyfill": "^0.2.2", 1236 | "blake3-wasm": "^2.1.5", 1237 | "chokidar": "^3.5.3", 1238 | "esbuild": "0.17.19", 1239 | "miniflare": "3.20240404.0", 1240 | "nanoid": "^3.3.3", 1241 | "path-to-regexp": "^6.2.0", 1242 | "resolve": "^1.22.8", 1243 | "resolve.exports": "^2.0.2", 1244 | "selfsigned": "^2.0.1", 1245 | "source-map": "0.6.1", 1246 | "xxhash-wasm": "^1.0.1" 1247 | }, 1248 | "bin": { 1249 | "wrangler": "bin/wrangler.js", 1250 | "wrangler2": "bin/wrangler.js" 1251 | }, 1252 | "engines": { 1253 | "node": ">=16.17.0" 1254 | }, 1255 | "optionalDependencies": { 1256 | "fsevents": "~2.3.2" 1257 | }, 1258 | "peerDependencies": { 1259 | "@cloudflare/workers-types": "^4.20240404.0" 1260 | }, 1261 | "peerDependenciesMeta": { 1262 | "@cloudflare/workers-types": { 1263 | "optional": true 1264 | } 1265 | } 1266 | }, 1267 | "node_modules/ws": { 1268 | "version": "8.16.0", 1269 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.16.0.tgz", 1270 | "integrity": "sha512-HS0c//TP7Ina87TfiPUz1rQzMhHrl/SG2guqRcTOIUYD2q8uhUdNHZYJUaQ8aTGPzCh+c6oawMKW35nFl1dxyQ==", 1271 | "dev": true, 1272 | "engines": { 1273 | "node": ">=10.0.0" 1274 | }, 1275 | "peerDependencies": { 1276 | "bufferutil": "^4.0.1", 1277 | "utf-8-validate": ">=5.0.2" 1278 | }, 1279 | "peerDependenciesMeta": { 1280 | "bufferutil": { 1281 | "optional": true 1282 | }, 1283 | "utf-8-validate": { 1284 | "optional": true 1285 | } 1286 | } 1287 | }, 1288 | "node_modules/xxhash-wasm": { 1289 | "version": "1.0.2", 1290 | "resolved": "https://registry.npmjs.org/xxhash-wasm/-/xxhash-wasm-1.0.2.tgz", 1291 | "integrity": "sha512-ibF0Or+FivM9lNrg+HGJfVX8WJqgo+kCLDc4vx6xMeTce7Aj+DLttKbxxRR/gNLSAelRc1omAPlJ77N/Jem07A==", 1292 | "dev": true 1293 | }, 1294 | "node_modules/youch": { 1295 | "version": "3.3.3", 1296 | "resolved": "https://registry.npmjs.org/youch/-/youch-3.3.3.tgz", 1297 | "integrity": "sha512-qSFXUk3UZBLfggAW3dJKg0BMblG5biqSF8M34E06o5CSsZtH92u9Hqmj2RzGiHDi64fhe83+4tENFP2DB6t6ZA==", 1298 | "dev": true, 1299 | "dependencies": { 1300 | "cookie": "^0.5.0", 1301 | "mustache": "^4.2.0", 1302 | "stacktracey": "^2.1.8" 1303 | } 1304 | }, 1305 | "node_modules/zod": { 1306 | "version": "3.22.4", 1307 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.22.4.tgz", 1308 | "integrity": "sha512-iC+8Io04lddc+mVqQ9AZ7OQ2MrUKGN+oIQyq1vemgt46jwCwLfhq7/pwnBnNXXXZb8VTVLKwp9EDkx+ryxIWmg==", 1309 | "dev": true, 1310 | "funding": { 1311 | "url": "https://github.com/sponsors/colinhacks" 1312 | } 1313 | } 1314 | } 1315 | } 1316 | -------------------------------------------------------------------------------- /short-urls/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "short-urls", 3 | "version": "1.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "short-urls", 9 | "version": "1.0.0", 10 | "license": "MIT", 11 | "dependencies": { 12 | "@cloudflare/workers-honeycomb-logger": "^2.3.3" 13 | }, 14 | "devDependencies": { 15 | "@cloudflare/workers-types": "^4.20240405.0", 16 | "prettier": "^3.2.5", 17 | "typescript": "^5.4.5", 18 | "wrangler": "^3.48.0" 19 | } 20 | }, 21 | "node_modules/@cloudflare/kv-asset-handler": { 22 | "version": "0.3.1", 23 | "resolved": "https://registry.npmjs.org/@cloudflare/kv-asset-handler/-/kv-asset-handler-0.3.1.tgz", 24 | "integrity": "sha512-lKN2XCfKCmpKb86a1tl4GIwsJYDy9TGuwjhDELLmpKygQhw8X2xR4dusgpC5Tg7q1pB96Eb0rBo81kxSILQMwA==", 25 | "dev": true, 26 | "dependencies": { 27 | "mime": "^3.0.0" 28 | } 29 | }, 30 | "node_modules/@cloudflare/workerd-darwin-64": { 31 | "version": "1.20240404.0", 32 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-darwin-64/-/workerd-darwin-64-1.20240404.0.tgz", 33 | "integrity": "sha512-rc/ov3I9GwgKRtUnkShNW3TIoZEPHzExrMRNlHq1VpXQRBSchHdMw8meMn54+oqgxW1AKLmPWj/c0A7EnYAsIw==", 34 | "cpu": [ 35 | "x64" 36 | ], 37 | "dev": true, 38 | "optional": true, 39 | "os": [ 40 | "darwin" 41 | ], 42 | "engines": { 43 | "node": ">=16" 44 | } 45 | }, 46 | "node_modules/@cloudflare/workerd-darwin-arm64": { 47 | "version": "1.20240404.0", 48 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-darwin-arm64/-/workerd-darwin-arm64-1.20240404.0.tgz", 49 | "integrity": "sha512-V9oPjeC2PYBCoAYnjbO2bsjT7PtzxfUHnh780FUi1r59Hwxd7FNlojwsIidA0nS/1WV5UKeJusIdrYlQbsketA==", 50 | "cpu": [ 51 | "arm64" 52 | ], 53 | "dev": true, 54 | "optional": true, 55 | "os": [ 56 | "darwin" 57 | ], 58 | "engines": { 59 | "node": ">=16" 60 | } 61 | }, 62 | "node_modules/@cloudflare/workerd-linux-64": { 63 | "version": "1.20240404.0", 64 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-linux-64/-/workerd-linux-64-1.20240404.0.tgz", 65 | "integrity": "sha512-ndO7q6G2X8uYd5byGFzow4SWPqINQcmJ7pKKATNa+9vh/YMO0of2ihPntnm9uv577l8nRiAwRkHbnsWoEI33qQ==", 66 | "cpu": [ 67 | "x64" 68 | ], 69 | "dev": true, 70 | "optional": true, 71 | "os": [ 72 | "linux" 73 | ], 74 | "engines": { 75 | "node": ">=16" 76 | } 77 | }, 78 | "node_modules/@cloudflare/workerd-linux-arm64": { 79 | "version": "1.20240404.0", 80 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-linux-arm64/-/workerd-linux-arm64-1.20240404.0.tgz", 81 | "integrity": "sha512-hto5pjKYFqFu2Rvxnh84TzgDwalBRXQSwOVHltcgqo48en9TJDCN48ZtLj2G7QTGUOMW88h+nqdbj8+P7S/GXQ==", 82 | "cpu": [ 83 | "arm64" 84 | ], 85 | "dev": true, 86 | "optional": true, 87 | "os": [ 88 | "linux" 89 | ], 90 | "engines": { 91 | "node": ">=16" 92 | } 93 | }, 94 | "node_modules/@cloudflare/workerd-windows-64": { 95 | "version": "1.20240404.0", 96 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-windows-64/-/workerd-windows-64-1.20240404.0.tgz", 97 | "integrity": "sha512-DpCLvNkOeFinKGJwv9qbyT7RLZ1168dhPx85IHSqAYVWZIszNSmNOkEDqklvoJoab01AqETrrEhwBdmjCA7qfA==", 98 | "cpu": [ 99 | "x64" 100 | ], 101 | "dev": true, 102 | "optional": true, 103 | "os": [ 104 | "win32" 105 | ], 106 | "engines": { 107 | "node": ">=16" 108 | } 109 | }, 110 | "node_modules/@cloudflare/workers-honeycomb-logger": { 111 | "version": "2.3.3", 112 | "resolved": "https://registry.npmjs.org/@cloudflare/workers-honeycomb-logger/-/workers-honeycomb-logger-2.3.3.tgz", 113 | "integrity": "sha512-2HqQWZnBDSf41UWKz6zSMQlTuLb+P9LaqQXQEowMJIfzie3aEKk/bZLTfLzCRLOq9cn4Rhgawm8pha4rJpvS4Q==", 114 | "dependencies": { 115 | "@cloudflare/workers-types": "^3.2.0", 116 | "@types/uuid": "^8.3.0", 117 | "dotenv": "^9.0.2", 118 | "uuid": "^8.3.2" 119 | } 120 | }, 121 | "node_modules/@cloudflare/workers-honeycomb-logger/node_modules/@cloudflare/workers-types": { 122 | "version": "3.19.0", 123 | "resolved": "https://registry.npmjs.org/@cloudflare/workers-types/-/workers-types-3.19.0.tgz", 124 | "integrity": "sha512-0FRcsz7Ea3jT+gc5gKPIYciykm1bbAaTpygdzpCwGt0RL+V83zWnYN30NWDW4rIHj/FHtz+MIuBKS61C8l7AzQ==" 125 | }, 126 | "node_modules/@cloudflare/workers-types": { 127 | "version": "4.20240405.0", 128 | "resolved": "https://registry.npmjs.org/@cloudflare/workers-types/-/workers-types-4.20240405.0.tgz", 129 | "integrity": "sha512-sEVOhyOgXUwfLkgHqbLZa/sfkSYrh7/zLmI6EZNibPaVPvAnAcItbNNl3SAlLyLKuwf8m4wAIAgu9meKWCvXjg==", 130 | "dev": true 131 | }, 132 | "node_modules/@cspotcode/source-map-support": { 133 | "version": "0.8.1", 134 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 135 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 136 | "dev": true, 137 | "dependencies": { 138 | "@jridgewell/trace-mapping": "0.3.9" 139 | }, 140 | "engines": { 141 | "node": ">=12" 142 | } 143 | }, 144 | "node_modules/@esbuild-plugins/node-globals-polyfill": { 145 | "version": "0.2.3", 146 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-globals-polyfill/-/node-globals-polyfill-0.2.3.tgz", 147 | "integrity": "sha512-r3MIryXDeXDOZh7ih1l/yE9ZLORCd5e8vWg02azWRGj5SPTuoh69A2AIyn0Z31V/kHBfZ4HgWJ+OK3GTTwLmnw==", 148 | "dev": true, 149 | "peerDependencies": { 150 | "esbuild": "*" 151 | } 152 | }, 153 | "node_modules/@esbuild-plugins/node-modules-polyfill": { 154 | "version": "0.2.2", 155 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-modules-polyfill/-/node-modules-polyfill-0.2.2.tgz", 156 | "integrity": "sha512-LXV7QsWJxRuMYvKbiznh+U1ilIop3g2TeKRzUxOG5X3YITc8JyyTa90BmLwqqv0YnX4v32CSlG+vsziZp9dMvA==", 157 | "dev": true, 158 | "dependencies": { 159 | "escape-string-regexp": "^4.0.0", 160 | "rollup-plugin-node-polyfills": "^0.2.1" 161 | }, 162 | "peerDependencies": { 163 | "esbuild": "*" 164 | } 165 | }, 166 | "node_modules/@esbuild/android-arm": { 167 | "version": "0.17.19", 168 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.19.tgz", 169 | "integrity": "sha512-rIKddzqhmav7MSmoFCmDIb6e2W57geRsM94gV2l38fzhXMwq7hZoClug9USI2pFRGL06f4IOPHHpFNOkWieR8A==", 170 | "cpu": [ 171 | "arm" 172 | ], 173 | "dev": true, 174 | "optional": true, 175 | "os": [ 176 | "android" 177 | ], 178 | "engines": { 179 | "node": ">=12" 180 | } 181 | }, 182 | "node_modules/@esbuild/android-arm64": { 183 | "version": "0.17.19", 184 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.19.tgz", 185 | "integrity": "sha512-KBMWvEZooR7+kzY0BtbTQn0OAYY7CsiydT63pVEaPtVYF0hXbUaOyZog37DKxK7NF3XacBJOpYT4adIJh+avxA==", 186 | "cpu": [ 187 | "arm64" 188 | ], 189 | "dev": true, 190 | "optional": true, 191 | "os": [ 192 | "android" 193 | ], 194 | "engines": { 195 | "node": ">=12" 196 | } 197 | }, 198 | "node_modules/@esbuild/android-x64": { 199 | "version": "0.17.19", 200 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.19.tgz", 201 | "integrity": "sha512-uUTTc4xGNDT7YSArp/zbtmbhO0uEEK9/ETW29Wk1thYUJBz3IVnvgEiEwEa9IeLyvnpKrWK64Utw2bgUmDveww==", 202 | "cpu": [ 203 | "x64" 204 | ], 205 | "dev": true, 206 | "optional": true, 207 | "os": [ 208 | "android" 209 | ], 210 | "engines": { 211 | "node": ">=12" 212 | } 213 | }, 214 | "node_modules/@esbuild/darwin-arm64": { 215 | "version": "0.17.19", 216 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.19.tgz", 217 | "integrity": "sha512-80wEoCfF/hFKM6WE1FyBHc9SfUblloAWx6FJkFWTWiCoht9Mc0ARGEM47e67W9rI09YoUxJL68WHfDRYEAvOhg==", 218 | "cpu": [ 219 | "arm64" 220 | ], 221 | "dev": true, 222 | "optional": true, 223 | "os": [ 224 | "darwin" 225 | ], 226 | "engines": { 227 | "node": ">=12" 228 | } 229 | }, 230 | "node_modules/@esbuild/darwin-x64": { 231 | "version": "0.17.19", 232 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.19.tgz", 233 | "integrity": "sha512-IJM4JJsLhRYr9xdtLytPLSH9k/oxR3boaUIYiHkAawtwNOXKE8KoU8tMvryogdcT8AU+Bflmh81Xn6Q0vTZbQw==", 234 | "cpu": [ 235 | "x64" 236 | ], 237 | "dev": true, 238 | "optional": true, 239 | "os": [ 240 | "darwin" 241 | ], 242 | "engines": { 243 | "node": ">=12" 244 | } 245 | }, 246 | "node_modules/@esbuild/freebsd-arm64": { 247 | "version": "0.17.19", 248 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.19.tgz", 249 | "integrity": "sha512-pBwbc7DufluUeGdjSU5Si+P3SoMF5DQ/F/UmTSb8HXO80ZEAJmrykPyzo1IfNbAoaqw48YRpv8shwd1NoI0jcQ==", 250 | "cpu": [ 251 | "arm64" 252 | ], 253 | "dev": true, 254 | "optional": true, 255 | "os": [ 256 | "freebsd" 257 | ], 258 | "engines": { 259 | "node": ">=12" 260 | } 261 | }, 262 | "node_modules/@esbuild/freebsd-x64": { 263 | "version": "0.17.19", 264 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.19.tgz", 265 | "integrity": "sha512-4lu+n8Wk0XlajEhbEffdy2xy53dpR06SlzvhGByyg36qJw6Kpfk7cp45DR/62aPH9mtJRmIyrXAS5UWBrJT6TQ==", 266 | "cpu": [ 267 | "x64" 268 | ], 269 | "dev": true, 270 | "optional": true, 271 | "os": [ 272 | "freebsd" 273 | ], 274 | "engines": { 275 | "node": ">=12" 276 | } 277 | }, 278 | "node_modules/@esbuild/linux-arm": { 279 | "version": "0.17.19", 280 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.19.tgz", 281 | "integrity": "sha512-cdmT3KxjlOQ/gZ2cjfrQOtmhG4HJs6hhvm3mWSRDPtZ/lP5oe8FWceS10JaSJC13GBd4eH/haHnqf7hhGNLerA==", 282 | "cpu": [ 283 | "arm" 284 | ], 285 | "dev": true, 286 | "optional": true, 287 | "os": [ 288 | "linux" 289 | ], 290 | "engines": { 291 | "node": ">=12" 292 | } 293 | }, 294 | "node_modules/@esbuild/linux-arm64": { 295 | "version": "0.17.19", 296 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.19.tgz", 297 | "integrity": "sha512-ct1Tg3WGwd3P+oZYqic+YZF4snNl2bsnMKRkb3ozHmnM0dGWuxcPTTntAF6bOP0Sp4x0PjSF+4uHQ1xvxfRKqg==", 298 | "cpu": [ 299 | "arm64" 300 | ], 301 | "dev": true, 302 | "optional": true, 303 | "os": [ 304 | "linux" 305 | ], 306 | "engines": { 307 | "node": ">=12" 308 | } 309 | }, 310 | "node_modules/@esbuild/linux-ia32": { 311 | "version": "0.17.19", 312 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.19.tgz", 313 | "integrity": "sha512-w4IRhSy1VbsNxHRQpeGCHEmibqdTUx61Vc38APcsRbuVgK0OPEnQ0YD39Brymn96mOx48Y2laBQGqgZ0j9w6SQ==", 314 | "cpu": [ 315 | "ia32" 316 | ], 317 | "dev": true, 318 | "optional": true, 319 | "os": [ 320 | "linux" 321 | ], 322 | "engines": { 323 | "node": ">=12" 324 | } 325 | }, 326 | "node_modules/@esbuild/linux-loong64": { 327 | "version": "0.17.19", 328 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.19.tgz", 329 | "integrity": "sha512-2iAngUbBPMq439a+z//gE+9WBldoMp1s5GWsUSgqHLzLJ9WoZLZhpwWuym0u0u/4XmZ3gpHmzV84PonE+9IIdQ==", 330 | "cpu": [ 331 | "loong64" 332 | ], 333 | "dev": true, 334 | "optional": true, 335 | "os": [ 336 | "linux" 337 | ], 338 | "engines": { 339 | "node": ">=12" 340 | } 341 | }, 342 | "node_modules/@esbuild/linux-mips64el": { 343 | "version": "0.17.19", 344 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.19.tgz", 345 | "integrity": "sha512-LKJltc4LVdMKHsrFe4MGNPp0hqDFA1Wpt3jE1gEyM3nKUvOiO//9PheZZHfYRfYl6AwdTH4aTcXSqBerX0ml4A==", 346 | "cpu": [ 347 | "mips64el" 348 | ], 349 | "dev": true, 350 | "optional": true, 351 | "os": [ 352 | "linux" 353 | ], 354 | "engines": { 355 | "node": ">=12" 356 | } 357 | }, 358 | "node_modules/@esbuild/linux-ppc64": { 359 | "version": "0.17.19", 360 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.19.tgz", 361 | "integrity": "sha512-/c/DGybs95WXNS8y3Ti/ytqETiW7EU44MEKuCAcpPto3YjQbyK3IQVKfF6nbghD7EcLUGl0NbiL5Rt5DMhn5tg==", 362 | "cpu": [ 363 | "ppc64" 364 | ], 365 | "dev": true, 366 | "optional": true, 367 | "os": [ 368 | "linux" 369 | ], 370 | "engines": { 371 | "node": ">=12" 372 | } 373 | }, 374 | "node_modules/@esbuild/linux-riscv64": { 375 | "version": "0.17.19", 376 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.19.tgz", 377 | "integrity": "sha512-FC3nUAWhvFoutlhAkgHf8f5HwFWUL6bYdvLc/TTuxKlvLi3+pPzdZiFKSWz/PF30TB1K19SuCxDTI5KcqASJqA==", 378 | "cpu": [ 379 | "riscv64" 380 | ], 381 | "dev": true, 382 | "optional": true, 383 | "os": [ 384 | "linux" 385 | ], 386 | "engines": { 387 | "node": ">=12" 388 | } 389 | }, 390 | "node_modules/@esbuild/linux-s390x": { 391 | "version": "0.17.19", 392 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.19.tgz", 393 | "integrity": "sha512-IbFsFbxMWLuKEbH+7sTkKzL6NJmG2vRyy6K7JJo55w+8xDk7RElYn6xvXtDW8HCfoKBFK69f3pgBJSUSQPr+4Q==", 394 | "cpu": [ 395 | "s390x" 396 | ], 397 | "dev": true, 398 | "optional": true, 399 | "os": [ 400 | "linux" 401 | ], 402 | "engines": { 403 | "node": ">=12" 404 | } 405 | }, 406 | "node_modules/@esbuild/linux-x64": { 407 | "version": "0.17.19", 408 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.19.tgz", 409 | "integrity": "sha512-68ngA9lg2H6zkZcyp22tsVt38mlhWde8l3eJLWkyLrp4HwMUr3c1s/M2t7+kHIhvMjglIBrFpncX1SzMckomGw==", 410 | "cpu": [ 411 | "x64" 412 | ], 413 | "dev": true, 414 | "optional": true, 415 | "os": [ 416 | "linux" 417 | ], 418 | "engines": { 419 | "node": ">=12" 420 | } 421 | }, 422 | "node_modules/@esbuild/netbsd-x64": { 423 | "version": "0.17.19", 424 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.19.tgz", 425 | "integrity": "sha512-CwFq42rXCR8TYIjIfpXCbRX0rp1jo6cPIUPSaWwzbVI4aOfX96OXY8M6KNmtPcg7QjYeDmN+DD0Wp3LaBOLf4Q==", 426 | "cpu": [ 427 | "x64" 428 | ], 429 | "dev": true, 430 | "optional": true, 431 | "os": [ 432 | "netbsd" 433 | ], 434 | "engines": { 435 | "node": ">=12" 436 | } 437 | }, 438 | "node_modules/@esbuild/openbsd-x64": { 439 | "version": "0.17.19", 440 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.19.tgz", 441 | "integrity": "sha512-cnq5brJYrSZ2CF6c35eCmviIN3k3RczmHz8eYaVlNasVqsNY+JKohZU5MKmaOI+KkllCdzOKKdPs762VCPC20g==", 442 | "cpu": [ 443 | "x64" 444 | ], 445 | "dev": true, 446 | "optional": true, 447 | "os": [ 448 | "openbsd" 449 | ], 450 | "engines": { 451 | "node": ">=12" 452 | } 453 | }, 454 | "node_modules/@esbuild/sunos-x64": { 455 | "version": "0.17.19", 456 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.19.tgz", 457 | "integrity": "sha512-vCRT7yP3zX+bKWFeP/zdS6SqdWB8OIpaRq/mbXQxTGHnIxspRtigpkUcDMlSCOejlHowLqII7K2JKevwyRP2rg==", 458 | "cpu": [ 459 | "x64" 460 | ], 461 | "dev": true, 462 | "optional": true, 463 | "os": [ 464 | "sunos" 465 | ], 466 | "engines": { 467 | "node": ">=12" 468 | } 469 | }, 470 | "node_modules/@esbuild/win32-arm64": { 471 | "version": "0.17.19", 472 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.19.tgz", 473 | "integrity": "sha512-yYx+8jwowUstVdorcMdNlzklLYhPxjniHWFKgRqH7IFlUEa0Umu3KuYplf1HUZZ422e3NU9F4LGb+4O0Kdcaag==", 474 | "cpu": [ 475 | "arm64" 476 | ], 477 | "dev": true, 478 | "optional": true, 479 | "os": [ 480 | "win32" 481 | ], 482 | "engines": { 483 | "node": ">=12" 484 | } 485 | }, 486 | "node_modules/@esbuild/win32-ia32": { 487 | "version": "0.17.19", 488 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.19.tgz", 489 | "integrity": "sha512-eggDKanJszUtCdlVs0RB+h35wNlb5v4TWEkq4vZcmVt5u/HiDZrTXe2bWFQUez3RgNHwx/x4sk5++4NSSicKkw==", 490 | "cpu": [ 491 | "ia32" 492 | ], 493 | "dev": true, 494 | "optional": true, 495 | "os": [ 496 | "win32" 497 | ], 498 | "engines": { 499 | "node": ">=12" 500 | } 501 | }, 502 | "node_modules/@esbuild/win32-x64": { 503 | "version": "0.17.19", 504 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.19.tgz", 505 | "integrity": "sha512-lAhycmKnVOuRYNtRtatQR1LPQf2oYCkRGkSFnseDAKPl8lu5SOsK/e1sXe5a0Pc5kHIHe6P2I/ilntNv2xf3cA==", 506 | "cpu": [ 507 | "x64" 508 | ], 509 | "dev": true, 510 | "optional": true, 511 | "os": [ 512 | "win32" 513 | ], 514 | "engines": { 515 | "node": ">=12" 516 | } 517 | }, 518 | "node_modules/@fastify/busboy": { 519 | "version": "2.1.1", 520 | "resolved": "https://registry.npmjs.org/@fastify/busboy/-/busboy-2.1.1.tgz", 521 | "integrity": "sha512-vBZP4NlzfOlerQTnba4aqZoMhE/a9HY7HRqoOPaETQcSQuWEIyZMHGfVu6w9wGtGK5fED5qRs2DteVCjOH60sA==", 522 | "dev": true, 523 | "engines": { 524 | "node": ">=14" 525 | } 526 | }, 527 | "node_modules/@jridgewell/resolve-uri": { 528 | "version": "3.1.2", 529 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 530 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 531 | "dev": true, 532 | "engines": { 533 | "node": ">=6.0.0" 534 | } 535 | }, 536 | "node_modules/@jridgewell/sourcemap-codec": { 537 | "version": "1.4.15", 538 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 539 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 540 | "dev": true 541 | }, 542 | "node_modules/@jridgewell/trace-mapping": { 543 | "version": "0.3.9", 544 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 545 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 546 | "dev": true, 547 | "dependencies": { 548 | "@jridgewell/resolve-uri": "^3.0.3", 549 | "@jridgewell/sourcemap-codec": "^1.4.10" 550 | } 551 | }, 552 | "node_modules/@types/uuid": { 553 | "version": "8.3.4", 554 | "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-8.3.4.tgz", 555 | "integrity": "sha512-c/I8ZRb51j+pYGAu5CrFMRxqZ2ke4y2grEBO5AUjgSkSk+qT2Ea+OdWElz/OiMf5MNpn2b17kuVBwZLQJXzihw==" 556 | }, 557 | "node_modules/acorn": { 558 | "version": "8.11.3", 559 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 560 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 561 | "dev": true, 562 | "bin": { 563 | "acorn": "bin/acorn" 564 | }, 565 | "engines": { 566 | "node": ">=0.4.0" 567 | } 568 | }, 569 | "node_modules/acorn-walk": { 570 | "version": "8.3.2", 571 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.2.tgz", 572 | "integrity": "sha512-cjkyv4OtNCIeqhHrfS81QWXoCBPExR/J62oyEqepVw8WaQeSqpW2uhuLPh1m9eWhDuOo/jUXVTlifvesOWp/4A==", 573 | "dev": true, 574 | "engines": { 575 | "node": ">=0.4.0" 576 | } 577 | }, 578 | "node_modules/anymatch": { 579 | "version": "3.1.3", 580 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 581 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 582 | "dev": true, 583 | "dependencies": { 584 | "normalize-path": "^3.0.0", 585 | "picomatch": "^2.0.4" 586 | }, 587 | "engines": { 588 | "node": ">= 8" 589 | } 590 | }, 591 | "node_modules/as-table": { 592 | "version": "1.0.55", 593 | "resolved": "https://registry.npmjs.org/as-table/-/as-table-1.0.55.tgz", 594 | "integrity": "sha512-xvsWESUJn0JN421Xb9MQw6AsMHRCUknCe0Wjlxvjud80mU4E6hQf1A6NzQKcYNmYw62MfzEtXc+badstZP3JpQ==", 595 | "dev": true, 596 | "dependencies": { 597 | "printable-characters": "^1.0.42" 598 | } 599 | }, 600 | "node_modules/binary-extensions": { 601 | "version": "2.2.0", 602 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 603 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 604 | "dev": true, 605 | "engines": { 606 | "node": ">=8" 607 | } 608 | }, 609 | "node_modules/blake3-wasm": { 610 | "version": "2.1.5", 611 | "resolved": "https://registry.npmjs.org/blake3-wasm/-/blake3-wasm-2.1.5.tgz", 612 | "integrity": "sha512-F1+K8EbfOZE49dtoPtmxUQrpXaBIl3ICvasLh+nJta0xkz+9kF/7uet9fLnwKqhDrmj6g+6K3Tw9yQPUg2ka5g==", 613 | "dev": true 614 | }, 615 | "node_modules/braces": { 616 | "version": "3.0.2", 617 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 618 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 619 | "dev": true, 620 | "dependencies": { 621 | "fill-range": "^7.0.1" 622 | }, 623 | "engines": { 624 | "node": ">=8" 625 | } 626 | }, 627 | "node_modules/capnp-ts": { 628 | "version": "0.7.0", 629 | "resolved": "https://registry.npmjs.org/capnp-ts/-/capnp-ts-0.7.0.tgz", 630 | "integrity": "sha512-XKxXAC3HVPv7r674zP0VC3RTXz+/JKhfyw94ljvF80yynK6VkTnqE3jMuN8b3dUVmmc43TjyxjW4KTsmB3c86g==", 631 | "dev": true, 632 | "dependencies": { 633 | "debug": "^4.3.1", 634 | "tslib": "^2.2.0" 635 | } 636 | }, 637 | "node_modules/chokidar": { 638 | "version": "3.5.3", 639 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 640 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 641 | "dev": true, 642 | "funding": [ 643 | { 644 | "type": "individual", 645 | "url": "https://paulmillr.com/funding/" 646 | } 647 | ], 648 | "dependencies": { 649 | "anymatch": "~3.1.2", 650 | "braces": "~3.0.2", 651 | "glob-parent": "~5.1.2", 652 | "is-binary-path": "~2.1.0", 653 | "is-glob": "~4.0.1", 654 | "normalize-path": "~3.0.0", 655 | "readdirp": "~3.6.0" 656 | }, 657 | "engines": { 658 | "node": ">= 8.10.0" 659 | }, 660 | "optionalDependencies": { 661 | "fsevents": "~2.3.2" 662 | } 663 | }, 664 | "node_modules/cookie": { 665 | "version": "0.5.0", 666 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 667 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 668 | "dev": true, 669 | "engines": { 670 | "node": ">= 0.6" 671 | } 672 | }, 673 | "node_modules/data-uri-to-buffer": { 674 | "version": "2.0.2", 675 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-2.0.2.tgz", 676 | "integrity": "sha512-ND9qDTLc6diwj+Xe5cdAgVTbLVdXbtxTJRXRhli8Mowuaan+0EJOtdqJ0QCHNSSPyoXGx9HX2/VMnKeC34AChA==", 677 | "dev": true 678 | }, 679 | "node_modules/debug": { 680 | "version": "4.3.4", 681 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 682 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 683 | "dev": true, 684 | "dependencies": { 685 | "ms": "2.1.2" 686 | }, 687 | "engines": { 688 | "node": ">=6.0" 689 | }, 690 | "peerDependenciesMeta": { 691 | "supports-color": { 692 | "optional": true 693 | } 694 | } 695 | }, 696 | "node_modules/dotenv": { 697 | "version": "9.0.2", 698 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-9.0.2.tgz", 699 | "integrity": "sha512-I9OvvrHp4pIARv4+x9iuewrWycX6CcZtoAu1XrzPxc5UygMJXJZYmBsynku8IkrJwgypE5DGNjDPmPRhDCptUg==", 700 | "engines": { 701 | "node": ">=10" 702 | } 703 | }, 704 | "node_modules/esbuild": { 705 | "version": "0.17.19", 706 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.19.tgz", 707 | "integrity": "sha512-XQ0jAPFkK/u3LcVRcvVHQcTIqD6E2H1fvZMA5dQPSOWb3suUbWbfbRf94pjc0bNzRYLfIrDRQXr7X+LHIm5oHw==", 708 | "dev": true, 709 | "hasInstallScript": true, 710 | "bin": { 711 | "esbuild": "bin/esbuild" 712 | }, 713 | "engines": { 714 | "node": ">=12" 715 | }, 716 | "optionalDependencies": { 717 | "@esbuild/android-arm": "0.17.19", 718 | "@esbuild/android-arm64": "0.17.19", 719 | "@esbuild/android-x64": "0.17.19", 720 | "@esbuild/darwin-arm64": "0.17.19", 721 | "@esbuild/darwin-x64": "0.17.19", 722 | "@esbuild/freebsd-arm64": "0.17.19", 723 | "@esbuild/freebsd-x64": "0.17.19", 724 | "@esbuild/linux-arm": "0.17.19", 725 | "@esbuild/linux-arm64": "0.17.19", 726 | "@esbuild/linux-ia32": "0.17.19", 727 | "@esbuild/linux-loong64": "0.17.19", 728 | "@esbuild/linux-mips64el": "0.17.19", 729 | "@esbuild/linux-ppc64": "0.17.19", 730 | "@esbuild/linux-riscv64": "0.17.19", 731 | "@esbuild/linux-s390x": "0.17.19", 732 | "@esbuild/linux-x64": "0.17.19", 733 | "@esbuild/netbsd-x64": "0.17.19", 734 | "@esbuild/openbsd-x64": "0.17.19", 735 | "@esbuild/sunos-x64": "0.17.19", 736 | "@esbuild/win32-arm64": "0.17.19", 737 | "@esbuild/win32-ia32": "0.17.19", 738 | "@esbuild/win32-x64": "0.17.19" 739 | } 740 | }, 741 | "node_modules/escape-string-regexp": { 742 | "version": "4.0.0", 743 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 744 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 745 | "dev": true, 746 | "engines": { 747 | "node": ">=10" 748 | }, 749 | "funding": { 750 | "url": "https://github.com/sponsors/sindresorhus" 751 | } 752 | }, 753 | "node_modules/estree-walker": { 754 | "version": "0.6.1", 755 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", 756 | "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", 757 | "dev": true 758 | }, 759 | "node_modules/exit-hook": { 760 | "version": "2.2.1", 761 | "resolved": "https://registry.npmjs.org/exit-hook/-/exit-hook-2.2.1.tgz", 762 | "integrity": "sha512-eNTPlAD67BmP31LDINZ3U7HSF8l57TxOY2PmBJ1shpCvpnxBF93mWCE8YHBnXs8qiUZJc9WDcWIeC3a2HIAMfw==", 763 | "dev": true, 764 | "engines": { 765 | "node": ">=6" 766 | }, 767 | "funding": { 768 | "url": "https://github.com/sponsors/sindresorhus" 769 | } 770 | }, 771 | "node_modules/fill-range": { 772 | "version": "7.0.1", 773 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 774 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 775 | "dev": true, 776 | "dependencies": { 777 | "to-regex-range": "^5.0.1" 778 | }, 779 | "engines": { 780 | "node": ">=8" 781 | } 782 | }, 783 | "node_modules/fsevents": { 784 | "version": "2.3.3", 785 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 786 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 787 | "dev": true, 788 | "hasInstallScript": true, 789 | "optional": true, 790 | "os": [ 791 | "darwin" 792 | ], 793 | "engines": { 794 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 795 | } 796 | }, 797 | "node_modules/function-bind": { 798 | "version": "1.1.2", 799 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 800 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 801 | "dev": true, 802 | "funding": { 803 | "url": "https://github.com/sponsors/ljharb" 804 | } 805 | }, 806 | "node_modules/get-source": { 807 | "version": "2.0.12", 808 | "resolved": "https://registry.npmjs.org/get-source/-/get-source-2.0.12.tgz", 809 | "integrity": "sha512-X5+4+iD+HoSeEED+uwrQ07BOQr0kEDFMVqqpBuI+RaZBpBpHCuXxo70bjar6f0b0u/DQJsJ7ssurpP0V60Az+w==", 810 | "dev": true, 811 | "dependencies": { 812 | "data-uri-to-buffer": "^2.0.0", 813 | "source-map": "^0.6.1" 814 | } 815 | }, 816 | "node_modules/glob-parent": { 817 | "version": "5.1.2", 818 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 819 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 820 | "dev": true, 821 | "dependencies": { 822 | "is-glob": "^4.0.1" 823 | }, 824 | "engines": { 825 | "node": ">= 6" 826 | } 827 | }, 828 | "node_modules/glob-to-regexp": { 829 | "version": "0.4.1", 830 | "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz", 831 | "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==", 832 | "dev": true 833 | }, 834 | "node_modules/hasown": { 835 | "version": "2.0.2", 836 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 837 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 838 | "dev": true, 839 | "dependencies": { 840 | "function-bind": "^1.1.2" 841 | }, 842 | "engines": { 843 | "node": ">= 0.4" 844 | } 845 | }, 846 | "node_modules/is-binary-path": { 847 | "version": "2.1.0", 848 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 849 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 850 | "dev": true, 851 | "dependencies": { 852 | "binary-extensions": "^2.0.0" 853 | }, 854 | "engines": { 855 | "node": ">=8" 856 | } 857 | }, 858 | "node_modules/is-core-module": { 859 | "version": "2.13.1", 860 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", 861 | "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", 862 | "dev": true, 863 | "dependencies": { 864 | "hasown": "^2.0.0" 865 | }, 866 | "funding": { 867 | "url": "https://github.com/sponsors/ljharb" 868 | } 869 | }, 870 | "node_modules/is-extglob": { 871 | "version": "2.1.1", 872 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 873 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 874 | "dev": true, 875 | "engines": { 876 | "node": ">=0.10.0" 877 | } 878 | }, 879 | "node_modules/is-glob": { 880 | "version": "4.0.3", 881 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 882 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 883 | "dev": true, 884 | "dependencies": { 885 | "is-extglob": "^2.1.1" 886 | }, 887 | "engines": { 888 | "node": ">=0.10.0" 889 | } 890 | }, 891 | "node_modules/is-number": { 892 | "version": "7.0.0", 893 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 894 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 895 | "dev": true, 896 | "engines": { 897 | "node": ">=0.12.0" 898 | } 899 | }, 900 | "node_modules/magic-string": { 901 | "version": "0.25.9", 902 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz", 903 | "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==", 904 | "dev": true, 905 | "dependencies": { 906 | "sourcemap-codec": "^1.4.8" 907 | } 908 | }, 909 | "node_modules/mime": { 910 | "version": "3.0.0", 911 | "resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz", 912 | "integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==", 913 | "dev": true, 914 | "bin": { 915 | "mime": "cli.js" 916 | }, 917 | "engines": { 918 | "node": ">=10.0.0" 919 | } 920 | }, 921 | "node_modules/miniflare": { 922 | "version": "3.20240404.0", 923 | "resolved": "https://registry.npmjs.org/miniflare/-/miniflare-3.20240404.0.tgz", 924 | "integrity": "sha512-+FOTcztPMW3akmucX4vE0PWMNvP4JBwl4s9ieA84fcOaDtTbtfU1rHXpcacj16klpUpvSnD6xd8Sjsn6SJXPfg==", 925 | "dev": true, 926 | "dependencies": { 927 | "@cspotcode/source-map-support": "0.8.1", 928 | "acorn": "^8.8.0", 929 | "acorn-walk": "^8.2.0", 930 | "capnp-ts": "^0.7.0", 931 | "exit-hook": "^2.2.1", 932 | "glob-to-regexp": "^0.4.1", 933 | "stoppable": "^1.1.0", 934 | "undici": "^5.28.2", 935 | "workerd": "1.20240404.0", 936 | "ws": "^8.11.0", 937 | "youch": "^3.2.2", 938 | "zod": "^3.20.6" 939 | }, 940 | "bin": { 941 | "miniflare": "bootstrap.js" 942 | }, 943 | "engines": { 944 | "node": ">=16.13" 945 | } 946 | }, 947 | "node_modules/ms": { 948 | "version": "2.1.2", 949 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 950 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 951 | "dev": true 952 | }, 953 | "node_modules/mustache": { 954 | "version": "4.2.0", 955 | "resolved": "https://registry.npmjs.org/mustache/-/mustache-4.2.0.tgz", 956 | "integrity": "sha512-71ippSywq5Yb7/tVYyGbkBggbU8H3u5Rz56fH60jGFgr8uHwxs+aSKeqmluIVzM0m0kB7xQjKS6qPfd0b2ZoqQ==", 957 | "dev": true, 958 | "bin": { 959 | "mustache": "bin/mustache" 960 | } 961 | }, 962 | "node_modules/nanoid": { 963 | "version": "3.3.6", 964 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz", 965 | "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==", 966 | "dev": true, 967 | "funding": [ 968 | { 969 | "type": "github", 970 | "url": "https://github.com/sponsors/ai" 971 | } 972 | ], 973 | "bin": { 974 | "nanoid": "bin/nanoid.cjs" 975 | }, 976 | "engines": { 977 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 978 | } 979 | }, 980 | "node_modules/node-forge": { 981 | "version": "1.3.1", 982 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", 983 | "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==", 984 | "dev": true, 985 | "engines": { 986 | "node": ">= 6.13.0" 987 | } 988 | }, 989 | "node_modules/normalize-path": { 990 | "version": "3.0.0", 991 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 992 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 993 | "dev": true, 994 | "engines": { 995 | "node": ">=0.10.0" 996 | } 997 | }, 998 | "node_modules/path-parse": { 999 | "version": "1.0.7", 1000 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1001 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1002 | "dev": true 1003 | }, 1004 | "node_modules/path-to-regexp": { 1005 | "version": "6.2.1", 1006 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz", 1007 | "integrity": "sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw==", 1008 | "dev": true 1009 | }, 1010 | "node_modules/picomatch": { 1011 | "version": "2.3.1", 1012 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1013 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1014 | "dev": true, 1015 | "engines": { 1016 | "node": ">=8.6" 1017 | }, 1018 | "funding": { 1019 | "url": "https://github.com/sponsors/jonschlinkert" 1020 | } 1021 | }, 1022 | "node_modules/prettier": { 1023 | "version": "3.2.5", 1024 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.2.5.tgz", 1025 | "integrity": "sha512-3/GWa9aOC0YeD7LUfvOG2NiDyhOWRvt1k+rcKhOuYnMY24iiCphgneUfJDyFXd6rZCAnuLBv6UeAULtrhT/F4A==", 1026 | "dev": true, 1027 | "bin": { 1028 | "prettier": "bin/prettier.cjs" 1029 | }, 1030 | "engines": { 1031 | "node": ">=14" 1032 | }, 1033 | "funding": { 1034 | "url": "https://github.com/prettier/prettier?sponsor=1" 1035 | } 1036 | }, 1037 | "node_modules/printable-characters": { 1038 | "version": "1.0.42", 1039 | "resolved": "https://registry.npmjs.org/printable-characters/-/printable-characters-1.0.42.tgz", 1040 | "integrity": "sha512-dKp+C4iXWK4vVYZmYSd0KBH5F/h1HoZRsbJ82AVKRO3PEo8L4lBS/vLwhVtpwwuYcoIsVY+1JYKR268yn480uQ==", 1041 | "dev": true 1042 | }, 1043 | "node_modules/readdirp": { 1044 | "version": "3.6.0", 1045 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1046 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1047 | "dev": true, 1048 | "dependencies": { 1049 | "picomatch": "^2.2.1" 1050 | }, 1051 | "engines": { 1052 | "node": ">=8.10.0" 1053 | } 1054 | }, 1055 | "node_modules/resolve": { 1056 | "version": "1.22.8", 1057 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", 1058 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", 1059 | "dev": true, 1060 | "dependencies": { 1061 | "is-core-module": "^2.13.0", 1062 | "path-parse": "^1.0.7", 1063 | "supports-preserve-symlinks-flag": "^1.0.0" 1064 | }, 1065 | "bin": { 1066 | "resolve": "bin/resolve" 1067 | }, 1068 | "funding": { 1069 | "url": "https://github.com/sponsors/ljharb" 1070 | } 1071 | }, 1072 | "node_modules/resolve.exports": { 1073 | "version": "2.0.2", 1074 | "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.2.tgz", 1075 | "integrity": "sha512-X2UW6Nw3n/aMgDVy+0rSqgHlv39WZAlZrXCdnbyEiKm17DSqHX4MmQMaST3FbeWR5FTuRcUwYAziZajji0Y7mg==", 1076 | "dev": true, 1077 | "engines": { 1078 | "node": ">=10" 1079 | } 1080 | }, 1081 | "node_modules/rollup-plugin-inject": { 1082 | "version": "3.0.2", 1083 | "resolved": "https://registry.npmjs.org/rollup-plugin-inject/-/rollup-plugin-inject-3.0.2.tgz", 1084 | "integrity": "sha512-ptg9PQwzs3orn4jkgXJ74bfs5vYz1NCZlSQMBUA0wKcGp5i5pA1AO3fOUEte8enhGUC+iapTCzEWw2jEFFUO/w==", 1085 | "deprecated": "This package has been deprecated and is no longer maintained. Please use @rollup/plugin-inject.", 1086 | "dev": true, 1087 | "dependencies": { 1088 | "estree-walker": "^0.6.1", 1089 | "magic-string": "^0.25.3", 1090 | "rollup-pluginutils": "^2.8.1" 1091 | } 1092 | }, 1093 | "node_modules/rollup-plugin-node-polyfills": { 1094 | "version": "0.2.1", 1095 | "resolved": "https://registry.npmjs.org/rollup-plugin-node-polyfills/-/rollup-plugin-node-polyfills-0.2.1.tgz", 1096 | "integrity": "sha512-4kCrKPTJ6sK4/gLL/U5QzVT8cxJcofO0OU74tnB19F40cmuAKSzH5/siithxlofFEjwvw1YAhPmbvGNA6jEroA==", 1097 | "dev": true, 1098 | "dependencies": { 1099 | "rollup-plugin-inject": "^3.0.0" 1100 | } 1101 | }, 1102 | "node_modules/rollup-pluginutils": { 1103 | "version": "2.8.2", 1104 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", 1105 | "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", 1106 | "dev": true, 1107 | "dependencies": { 1108 | "estree-walker": "^0.6.1" 1109 | } 1110 | }, 1111 | "node_modules/selfsigned": { 1112 | "version": "2.1.1", 1113 | "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.1.1.tgz", 1114 | "integrity": "sha512-GSL3aowiF7wa/WtSFwnUrludWFoNhftq8bUkH9pkzjpN2XSPOAYEgg6e0sS9s0rZwgJzJiQRPU18A6clnoW5wQ==", 1115 | "dev": true, 1116 | "dependencies": { 1117 | "node-forge": "^1" 1118 | }, 1119 | "engines": { 1120 | "node": ">=10" 1121 | } 1122 | }, 1123 | "node_modules/source-map": { 1124 | "version": "0.6.1", 1125 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1126 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1127 | "dev": true, 1128 | "engines": { 1129 | "node": ">=0.10.0" 1130 | } 1131 | }, 1132 | "node_modules/sourcemap-codec": { 1133 | "version": "1.4.8", 1134 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 1135 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 1136 | "deprecated": "Please use @jridgewell/sourcemap-codec instead", 1137 | "dev": true 1138 | }, 1139 | "node_modules/stacktracey": { 1140 | "version": "2.1.8", 1141 | "resolved": "https://registry.npmjs.org/stacktracey/-/stacktracey-2.1.8.tgz", 1142 | "integrity": "sha512-Kpij9riA+UNg7TnphqjH7/CzctQ/owJGNbFkfEeve4Z4uxT5+JapVLFXcsurIfN34gnTWZNJ/f7NMG0E8JDzTw==", 1143 | "dev": true, 1144 | "dependencies": { 1145 | "as-table": "^1.0.36", 1146 | "get-source": "^2.0.12" 1147 | } 1148 | }, 1149 | "node_modules/stoppable": { 1150 | "version": "1.1.0", 1151 | "resolved": "https://registry.npmjs.org/stoppable/-/stoppable-1.1.0.tgz", 1152 | "integrity": "sha512-KXDYZ9dszj6bzvnEMRYvxgeTHU74QBFL54XKtP3nyMuJ81CFYtABZ3bAzL2EdFUaEwJOBOgENyFj3R7oTzDyyw==", 1153 | "dev": true, 1154 | "engines": { 1155 | "node": ">=4", 1156 | "npm": ">=6" 1157 | } 1158 | }, 1159 | "node_modules/supports-preserve-symlinks-flag": { 1160 | "version": "1.0.0", 1161 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1162 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1163 | "dev": true, 1164 | "engines": { 1165 | "node": ">= 0.4" 1166 | }, 1167 | "funding": { 1168 | "url": "https://github.com/sponsors/ljharb" 1169 | } 1170 | }, 1171 | "node_modules/to-regex-range": { 1172 | "version": "5.0.1", 1173 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1174 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1175 | "dev": true, 1176 | "dependencies": { 1177 | "is-number": "^7.0.0" 1178 | }, 1179 | "engines": { 1180 | "node": ">=8.0" 1181 | } 1182 | }, 1183 | "node_modules/tslib": { 1184 | "version": "2.6.2", 1185 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", 1186 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", 1187 | "dev": true 1188 | }, 1189 | "node_modules/typescript": { 1190 | "version": "5.4.5", 1191 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.4.5.tgz", 1192 | "integrity": "sha512-vcI4UpRgg81oIRUFwR0WSIHKt11nJ7SAVlYNIu+QpqeyXP+gpQJy/Z4+F0aGxSE4MqwjyXvW/TzgkLAx2AGHwQ==", 1193 | "dev": true, 1194 | "bin": { 1195 | "tsc": "bin/tsc", 1196 | "tsserver": "bin/tsserver" 1197 | }, 1198 | "engines": { 1199 | "node": ">=14.17" 1200 | } 1201 | }, 1202 | "node_modules/undici": { 1203 | "version": "5.28.4", 1204 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.28.4.tgz", 1205 | "integrity": "sha512-72RFADWFqKmUb2hmmvNODKL3p9hcB6Gt2DOQMis1SEBaV6a4MH8soBvzg+95CYhCKPFedut2JY9bMfrDl9D23g==", 1206 | "dev": true, 1207 | "dependencies": { 1208 | "@fastify/busboy": "^2.0.0" 1209 | }, 1210 | "engines": { 1211 | "node": ">=14.0" 1212 | } 1213 | }, 1214 | "node_modules/uuid": { 1215 | "version": "8.3.2", 1216 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 1217 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", 1218 | "bin": { 1219 | "uuid": "dist/bin/uuid" 1220 | } 1221 | }, 1222 | "node_modules/workerd": { 1223 | "version": "1.20240404.0", 1224 | "resolved": "https://registry.npmjs.org/workerd/-/workerd-1.20240404.0.tgz", 1225 | "integrity": "sha512-U4tfnvBcPMsv7pmRGuF0J5UnoZi6tbc64tXNfyijI74r6w6Vlb2+a6eibdQL8g0g46+4vjuTKME9G5RvSvdc8g==", 1226 | "dev": true, 1227 | "hasInstallScript": true, 1228 | "bin": { 1229 | "workerd": "bin/workerd" 1230 | }, 1231 | "engines": { 1232 | "node": ">=16" 1233 | }, 1234 | "optionalDependencies": { 1235 | "@cloudflare/workerd-darwin-64": "1.20240404.0", 1236 | "@cloudflare/workerd-darwin-arm64": "1.20240404.0", 1237 | "@cloudflare/workerd-linux-64": "1.20240404.0", 1238 | "@cloudflare/workerd-linux-arm64": "1.20240404.0", 1239 | "@cloudflare/workerd-windows-64": "1.20240404.0" 1240 | } 1241 | }, 1242 | "node_modules/wrangler": { 1243 | "version": "3.48.0", 1244 | "resolved": "https://registry.npmjs.org/wrangler/-/wrangler-3.48.0.tgz", 1245 | "integrity": "sha512-Wv7JS6FyX1j9HkaM6WL3fmTzBMAYc4hPSyZCuxuH55hkJDX/7ts+YAgsaN1U8rKoDrV3FVSgBfI9TyqP9iuM8Q==", 1246 | "dev": true, 1247 | "dependencies": { 1248 | "@cloudflare/kv-asset-handler": "0.3.1", 1249 | "@esbuild-plugins/node-globals-polyfill": "^0.2.3", 1250 | "@esbuild-plugins/node-modules-polyfill": "^0.2.2", 1251 | "blake3-wasm": "^2.1.5", 1252 | "chokidar": "^3.5.3", 1253 | "esbuild": "0.17.19", 1254 | "miniflare": "3.20240404.0", 1255 | "nanoid": "^3.3.3", 1256 | "path-to-regexp": "^6.2.0", 1257 | "resolve": "^1.22.8", 1258 | "resolve.exports": "^2.0.2", 1259 | "selfsigned": "^2.0.1", 1260 | "source-map": "0.6.1", 1261 | "xxhash-wasm": "^1.0.1" 1262 | }, 1263 | "bin": { 1264 | "wrangler": "bin/wrangler.js", 1265 | "wrangler2": "bin/wrangler.js" 1266 | }, 1267 | "engines": { 1268 | "node": ">=16.17.0" 1269 | }, 1270 | "optionalDependencies": { 1271 | "fsevents": "~2.3.2" 1272 | }, 1273 | "peerDependencies": { 1274 | "@cloudflare/workers-types": "^4.20240404.0" 1275 | }, 1276 | "peerDependenciesMeta": { 1277 | "@cloudflare/workers-types": { 1278 | "optional": true 1279 | } 1280 | } 1281 | }, 1282 | "node_modules/ws": { 1283 | "version": "8.16.0", 1284 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.16.0.tgz", 1285 | "integrity": "sha512-HS0c//TP7Ina87TfiPUz1rQzMhHrl/SG2guqRcTOIUYD2q8uhUdNHZYJUaQ8aTGPzCh+c6oawMKW35nFl1dxyQ==", 1286 | "dev": true, 1287 | "engines": { 1288 | "node": ">=10.0.0" 1289 | }, 1290 | "peerDependencies": { 1291 | "bufferutil": "^4.0.1", 1292 | "utf-8-validate": ">=5.0.2" 1293 | }, 1294 | "peerDependenciesMeta": { 1295 | "bufferutil": { 1296 | "optional": true 1297 | }, 1298 | "utf-8-validate": { 1299 | "optional": true 1300 | } 1301 | } 1302 | }, 1303 | "node_modules/xxhash-wasm": { 1304 | "version": "1.0.2", 1305 | "resolved": "https://registry.npmjs.org/xxhash-wasm/-/xxhash-wasm-1.0.2.tgz", 1306 | "integrity": "sha512-ibF0Or+FivM9lNrg+HGJfVX8WJqgo+kCLDc4vx6xMeTce7Aj+DLttKbxxRR/gNLSAelRc1omAPlJ77N/Jem07A==", 1307 | "dev": true 1308 | }, 1309 | "node_modules/youch": { 1310 | "version": "3.3.3", 1311 | "resolved": "https://registry.npmjs.org/youch/-/youch-3.3.3.tgz", 1312 | "integrity": "sha512-qSFXUk3UZBLfggAW3dJKg0BMblG5biqSF8M34E06o5CSsZtH92u9Hqmj2RzGiHDi64fhe83+4tENFP2DB6t6ZA==", 1313 | "dev": true, 1314 | "dependencies": { 1315 | "cookie": "^0.5.0", 1316 | "mustache": "^4.2.0", 1317 | "stacktracey": "^2.1.8" 1318 | } 1319 | }, 1320 | "node_modules/zod": { 1321 | "version": "3.22.4", 1322 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.22.4.tgz", 1323 | "integrity": "sha512-iC+8Io04lddc+mVqQ9AZ7OQ2MrUKGN+oIQyq1vemgt46jwCwLfhq7/pwnBnNXXXZb8VTVLKwp9EDkx+ryxIWmg==", 1324 | "dev": true, 1325 | "funding": { 1326 | "url": "https://github.com/sponsors/colinhacks" 1327 | } 1328 | } 1329 | } 1330 | } 1331 | --------------------------------------------------------------------------------