├── .devcontainer ├── Dockerfile ├── devcontainer.json └── setup.sh ├── .github └── workflows │ └── codeql-analysis.yml ├── .gitignore ├── .nvmrc ├── package-lock.json ├── package.json ├── readme.md ├── src ├── cryptoHelper.ts └── index.ts ├── tsconfig.json └── wrangler.toml /.devcontainer/Dockerfile: -------------------------------------------------------------------------------- 1 | FROM node:18-bullseye 2 | 3 | WORKDIR /home/ 4 | 5 | COPY . . 6 | 7 | RUN bash ./setup.sh -------------------------------------------------------------------------------- /.devcontainer/devcontainer.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "Node.js & Wrangler", 3 | "extensions": [ 4 | "cschleiden.vscode-github-actions", 5 | "vscode-icons-team.vscode-icons", 6 | "visualstudioexptteam.vscodeintellicode" 7 | ], 8 | "dockerFile": "Dockerfile" 9 | } -------------------------------------------------------------------------------- /.devcontainer/setup.sh: -------------------------------------------------------------------------------- 1 | ## update and install some things we should probably have 2 | apt-get update 3 | apt-get install -y \ 4 | curl \ 5 | git \ 6 | gnupg2 \ 7 | jq \ 8 | nano \ 9 | htop \ 10 | sudo 11 | 12 | # set-up and install yarn 13 | curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - 14 | echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list 15 | apt-get update && apt-get install yarn -y 16 | npm install -g wrangler 17 | -------------------------------------------------------------------------------- /.github/workflows/codeql-analysis.yml: -------------------------------------------------------------------------------- 1 | # For most projects, this workflow file will not need changing; you simply need 2 | # to commit it to your repository. 3 | # 4 | # You may wish to alter this file to override the set of languages analyzed, 5 | # or to provide custom queries or build logic. 6 | # 7 | # ******** NOTE ******** 8 | # We have attempted to detect the languages in your repository. Please check 9 | # the `language` matrix defined below to confirm you have the correct set of 10 | # supported CodeQL languages. 11 | # 12 | name: "CodeQL" 13 | 14 | on: 15 | push: 16 | branches: [ "master" ] 17 | pull_request: 18 | # The branches below must be a subset of the branches above 19 | branches: [ "master" ] 20 | schedule: 21 | - cron: '30 17 * * 3' 22 | 23 | jobs: 24 | analyze: 25 | name: Analyze 26 | runs-on: ubuntu-latest 27 | permissions: 28 | actions: read 29 | contents: read 30 | security-events: write 31 | 32 | strategy: 33 | fail-fast: false 34 | matrix: 35 | language: [ 'javascript' ] 36 | # CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python', 'ruby' ] 37 | # Learn more about CodeQL language support at https://aka.ms/codeql-docs/language-support 38 | 39 | steps: 40 | - name: Checkout repository 41 | uses: actions/checkout@v3 42 | 43 | # Initializes the CodeQL tools for scanning. 44 | - name: Initialize CodeQL 45 | uses: github/codeql-action/init@v2 46 | with: 47 | languages: ${{ matrix.language }} 48 | # If you wish to specify custom queries, you can do so here or in a config file. 49 | # By default, queries listed here will override any specified in a config file. 50 | # Prefix the list here with "+" to use these queries and those in the config file. 51 | 52 | # Details on CodeQL's query packs refer to : https://docs.github.com/en/code-security/code-scanning/automatically-scanning-your-code-for-vulnerabilities-and-errors/configuring-code-scanning#using-queries-in-ql-packs 53 | # queries: security-extended,security-and-quality 54 | 55 | 56 | # Autobuild attempts to build any compiled languages (C/C++, C#, or Java). 57 | # If this step fails, then you should remove it and run the build manually (see below) 58 | - name: Autobuild 59 | uses: github/codeql-action/autobuild@v2 60 | 61 | # ℹ️ Command-line programs to run using the OS shell. 62 | # 📚 See https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsrun 63 | 64 | # If the Autobuild fails above, remove it and uncomment the following three lines. 65 | # modify them (or add more) to build your code if your project, please refer to the EXAMPLE below for guidance. 66 | 67 | # - run: | 68 | # echo "Run, Build Application using script" 69 | # ./location_of_script_within_repo/buildscript.sh 70 | 71 | - name: Perform CodeQL Analysis 72 | uses: github/codeql-action/analyze@v2 73 | with: 74 | category: "/language:${{matrix.language}}" 75 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | ### JetBrains template 2 | # Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio, WebStorm and Rider 3 | # Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839 4 | 5 | # User-specific stuff 6 | .idea 7 | 8 | # Gradle and Maven with auto-import 9 | # When using Gradle or Maven with auto-import, you should exclude module files, 10 | # since they will be recreated, and may cause churn. Uncomment if using 11 | # auto-import. 12 | # .idea/artifacts 13 | # .idea/compiler.xml 14 | # .idea/jarRepositories.xml 15 | # .idea/modules.xml 16 | # .idea/*.iml 17 | # .idea/modules 18 | # *.iml 19 | # *.ipr 20 | 21 | # CMake 22 | cmake-build-*/ 23 | 24 | # Mongo Explorer plugin 25 | .idea/**/mongoSettings.xml 26 | 27 | # File-based project format 28 | *.iws 29 | 30 | # IntelliJ 31 | out/ 32 | 33 | # mpeltonen/sbt-idea plugin 34 | .idea_modules/ 35 | 36 | # JIRA plugin 37 | atlassian-ide-plugin.xml 38 | 39 | # Cursive Clojure plugin 40 | .idea/replstate.xml 41 | 42 | # Crashlytics plugin (for Android Studio and IntelliJ) 43 | com_crashlytics_export_strings.xml 44 | crashlytics.properties 45 | crashlytics-build.properties 46 | fabric.properties 47 | 48 | # Editor-based Rest Client 49 | .idea/httpRequests 50 | 51 | # Android studio 3.1+ serialized cache file 52 | .idea/caches/build_file_checksums.ser 53 | 54 | ### Node template 55 | # Logs 56 | logs 57 | *.log 58 | npm-debug.log* 59 | yarn-debug.log* 60 | yarn-error.log* 61 | lerna-debug.log* 62 | 63 | # Diagnostic reports (https://nodejs.org/api/report.html) 64 | report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json 65 | 66 | # Runtime data 67 | pids 68 | *.pid 69 | *.seed 70 | *.pid.lock 71 | 72 | # Directory for instrumented libs generated by jscoverage/JSCover 73 | lib-cov 74 | 75 | # Coverage directory used by tools like istanbul 76 | coverage 77 | *.lcov 78 | 79 | # nyc test coverage 80 | .nyc_output 81 | 82 | # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) 83 | .grunt 84 | 85 | # Bower dependency directory (https://bower.io/) 86 | bower_components 87 | 88 | # node-waf configuration 89 | .lock-wscript 90 | 91 | # Compiled binary addons (https://nodejs.org/api/addons.html) 92 | build/Release 93 | 94 | # Dependency directories 95 | node_modules/ 96 | jspm_packages/ 97 | 98 | # Snowpack dependency directory (https://snowpack.dev/) 99 | web_modules/ 100 | 101 | # TypeScript cache 102 | *.tsbuildinfo 103 | 104 | # Optional npm cache directory 105 | .npm 106 | 107 | # Optional eslint cache 108 | .eslintcache 109 | 110 | # Microbundle cache 111 | .rpt2_cache/ 112 | .rts2_cache_cjs/ 113 | .rts2_cache_es/ 114 | .rts2_cache_umd/ 115 | 116 | # Optional REPL history 117 | .node_repl_history 118 | 119 | # Output of 'npm pack' 120 | *.tgz 121 | 122 | # Yarn Integrity file 123 | .yarn-integrity 124 | 125 | # dotenv environment variables file 126 | .env 127 | .env.test 128 | 129 | # parcel-bundler cache (https://parceljs.org/) 130 | .cache 131 | .parcel-cache 132 | 133 | # Next.js build output 134 | .next 135 | out 136 | 137 | # Nuxt.js build / generate output 138 | .nuxt 139 | dist 140 | 141 | # Gatsby files 142 | .cache/ 143 | # Comment in the public line in if your project uses Gatsby and not Next.js 144 | # https://nextjs.org/blog/next-9-1#public-directory-support 145 | # public 146 | 147 | # vuepress build output 148 | .vuepress/dist 149 | 150 | # Serverless directories 151 | .serverless/ 152 | 153 | # FuseBox cache 154 | .fusebox/ 155 | 156 | # DynamoDB Local files 157 | .dynamodb/ 158 | 159 | # TernJS port file 160 | .tern-port 161 | 162 | # Stores VSCode versions used for testing VSCode extensions 163 | .vscode-test 164 | 165 | # yarn v2 166 | .yarn/cache 167 | .yarn/unplugged 168 | .yarn/build-state.yml 169 | .yarn/install-state.gz 170 | .pnp.* 171 | 172 | ### macOS template 173 | # General 174 | .DS_Store 175 | .AppleDouble 176 | .LSOverride 177 | 178 | # Icon must end with two \r 179 | Icon 180 | 181 | # Thumbnails 182 | ._* 183 | 184 | # Files that might appear in the root of a volume 185 | .DocumentRevisions-V100 186 | .fseventsd 187 | .Spotlight-V100 188 | .TemporaryItems 189 | .Trashes 190 | .VolumeIcon.icns 191 | .com.apple.timemachine.donotpresent 192 | 193 | # Directories potentially created on remote AFP share 194 | .AppleDB 195 | .AppleDesktop 196 | Network Trash Folder 197 | Temporary Items 198 | .apdisk 199 | 200 | -------------------------------------------------------------------------------- /.nvmrc: -------------------------------------------------------------------------------- 1 | v18.9.0 -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "session-authentication-worker", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "session-authentication-worker", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "devDependencies": { 12 | "@cloudflare/workers-types": "^3.16.0", 13 | "@types/cookie": "^0.5.1", 14 | "typescript": "^4.8.3", 15 | "wrangler": "^2.0.29" 16 | } 17 | }, 18 | "node_modules/@cloudflare/kv-asset-handler": { 19 | "version": "0.2.0", 20 | "resolved": "https://registry.npmjs.org/@cloudflare/kv-asset-handler/-/kv-asset-handler-0.2.0.tgz", 21 | "integrity": "sha512-MVbXLbTcAotOPUj0pAMhVtJ+3/kFkwJqc5qNOleOZTv6QkZZABDMS21dSrSlVswEHwrpWC03e4fWytjqKvuE2A==", 22 | "dev": true, 23 | "dependencies": { 24 | "mime": "^3.0.0" 25 | } 26 | }, 27 | "node_modules/@cloudflare/workers-types": { 28 | "version": "3.16.0", 29 | "resolved": "https://registry.npmjs.org/@cloudflare/workers-types/-/workers-types-3.16.0.tgz", 30 | "integrity": "sha512-gaBUSaKS65mN3iKZEgichbXYEmAa/pXkc5Gbt+1BptYphdGkj09ggdsiE4w8g0F/uI1g36QaTKrzVnBAWMipvQ==", 31 | "dev": true 32 | }, 33 | "node_modules/@esbuild-plugins/node-globals-polyfill": { 34 | "version": "0.1.1", 35 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-globals-polyfill/-/node-globals-polyfill-0.1.1.tgz", 36 | "integrity": "sha512-MR0oAA+mlnJWrt1RQVQ+4VYuRJW/P2YmRTv1AsplObyvuBMnPHiizUF95HHYiSsMGLhyGtWufaq2XQg6+iurBg==", 37 | "dev": true, 38 | "peerDependencies": { 39 | "esbuild": "*" 40 | } 41 | }, 42 | "node_modules/@esbuild-plugins/node-modules-polyfill": { 43 | "version": "0.1.4", 44 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-modules-polyfill/-/node-modules-polyfill-0.1.4.tgz", 45 | "integrity": "sha512-uZbcXi0zbmKC/050p3gJnne5Qdzw8vkXIv+c2BW0Lsc1ji1SkrxbKPUy5Efr0blbTu1SL8w4eyfpnSdPg3G0Qg==", 46 | "dev": true, 47 | "dependencies": { 48 | "escape-string-regexp": "^4.0.0", 49 | "rollup-plugin-node-polyfills": "^0.2.1" 50 | }, 51 | "peerDependencies": { 52 | "esbuild": "*" 53 | } 54 | }, 55 | "node_modules/@iarna/toml": { 56 | "version": "2.2.5", 57 | "resolved": "https://registry.npmjs.org/@iarna/toml/-/toml-2.2.5.tgz", 58 | "integrity": "sha512-trnsAYxU3xnS1gPHPyU961coFyLkh4gAD/0zQ5mymY4yOZ+CYvsPqUbOFSw0aDM4y0tV7tiFxL/1XfXPNC6IPg==", 59 | "dev": true 60 | }, 61 | "node_modules/@miniflare/cache": { 62 | "version": "2.9.0", 63 | "resolved": "https://registry.npmjs.org/@miniflare/cache/-/cache-2.9.0.tgz", 64 | "integrity": "sha512-lriPxUEva9TJ01vU9P7pI60s3SsFnb4apWkNwZ+D7CRqyXPipSbapY8BWI2FUIwkEG7xap6UhzeTS76NettCXQ==", 65 | "dev": true, 66 | "dependencies": { 67 | "@miniflare/core": "2.9.0", 68 | "@miniflare/shared": "2.9.0", 69 | "http-cache-semantics": "^4.1.0", 70 | "undici": "5.9.1" 71 | }, 72 | "engines": { 73 | "node": ">=16.13" 74 | } 75 | }, 76 | "node_modules/@miniflare/cli-parser": { 77 | "version": "2.9.0", 78 | "resolved": "https://registry.npmjs.org/@miniflare/cli-parser/-/cli-parser-2.9.0.tgz", 79 | "integrity": "sha512-gu8Z7NWNcYw6514/yOvajaj3GmebRucx+EEt3p1vKirO+gvFgKAt/puyUN3p7u8ZZmLuLF/B+wVnH3lj8BWKlg==", 80 | "dev": true, 81 | "dependencies": { 82 | "@miniflare/shared": "2.9.0", 83 | "kleur": "^4.1.4" 84 | }, 85 | "engines": { 86 | "node": ">=16.13" 87 | } 88 | }, 89 | "node_modules/@miniflare/core": { 90 | "version": "2.9.0", 91 | "resolved": "https://registry.npmjs.org/@miniflare/core/-/core-2.9.0.tgz", 92 | "integrity": "sha512-QqSwF6oHvgrFvN5lnrLc6EEagFlZWW+UMU8QdrE8305cNGHrIOxKCA2nte4PVFZUVw/Ts13a0tVhUk3a2fAyxQ==", 93 | "dev": true, 94 | "dependencies": { 95 | "@iarna/toml": "^2.2.5", 96 | "@miniflare/queues": "2.9.0", 97 | "@miniflare/shared": "2.9.0", 98 | "@miniflare/watcher": "2.9.0", 99 | "busboy": "^1.6.0", 100 | "dotenv": "^10.0.0", 101 | "kleur": "^4.1.4", 102 | "set-cookie-parser": "^2.4.8", 103 | "undici": "5.9.1", 104 | "urlpattern-polyfill": "^4.0.3" 105 | }, 106 | "engines": { 107 | "node": ">=16.13" 108 | } 109 | }, 110 | "node_modules/@miniflare/d1": { 111 | "version": "2.9.0", 112 | "resolved": "https://registry.npmjs.org/@miniflare/d1/-/d1-2.9.0.tgz", 113 | "integrity": "sha512-swK9nzxw1SvVh/4cH3bRR1SBuHQU/YsB8WvuHojxufmgviAD1xhms3XO3rkpAzfKoGM5Oy6DovMe0xUXV/GS0w==", 114 | "dev": true, 115 | "dependencies": { 116 | "@miniflare/core": "2.9.0", 117 | "@miniflare/shared": "2.9.0" 118 | }, 119 | "engines": { 120 | "node": ">=16.7" 121 | } 122 | }, 123 | "node_modules/@miniflare/durable-objects": { 124 | "version": "2.9.0", 125 | "resolved": "https://registry.npmjs.org/@miniflare/durable-objects/-/durable-objects-2.9.0.tgz", 126 | "integrity": "sha512-7uTvfEUXS7xqwrsWOwWrFUuKc4EiMpVkAWPeYGLB/0TJaJ6N+sZMpYYymdW79TQwPIDfgtpfkIy93MRydqpnrw==", 127 | "dev": true, 128 | "dependencies": { 129 | "@miniflare/core": "2.9.0", 130 | "@miniflare/shared": "2.9.0", 131 | "@miniflare/storage-memory": "2.9.0", 132 | "undici": "5.9.1" 133 | }, 134 | "engines": { 135 | "node": ">=16.13" 136 | } 137 | }, 138 | "node_modules/@miniflare/html-rewriter": { 139 | "version": "2.9.0", 140 | "resolved": "https://registry.npmjs.org/@miniflare/html-rewriter/-/html-rewriter-2.9.0.tgz", 141 | "integrity": "sha512-K5OB70PtkMo7M+tU46s/cX/j/qtjD9AlJ0hecYswrxVsfrT/YWyrCQJevmShFfJ92h7jPNigbeC3Od3JiVb6QA==", 142 | "dev": true, 143 | "dependencies": { 144 | "@miniflare/core": "2.9.0", 145 | "@miniflare/shared": "2.9.0", 146 | "html-rewriter-wasm": "^0.4.1", 147 | "undici": "5.9.1" 148 | }, 149 | "engines": { 150 | "node": ">=16.13" 151 | } 152 | }, 153 | "node_modules/@miniflare/http-server": { 154 | "version": "2.9.0", 155 | "resolved": "https://registry.npmjs.org/@miniflare/http-server/-/http-server-2.9.0.tgz", 156 | "integrity": "sha512-IVJMkFfMpecq9WiCTvATEKhMuKPK9fMs2E6zmgexaefr3u1VlNtj2QxBxoPUXkT9xMJQlT5sSKstlRR1XKDz9Q==", 157 | "dev": true, 158 | "dependencies": { 159 | "@miniflare/core": "2.9.0", 160 | "@miniflare/shared": "2.9.0", 161 | "@miniflare/web-sockets": "2.9.0", 162 | "kleur": "^4.1.4", 163 | "selfsigned": "^2.0.0", 164 | "undici": "5.9.1", 165 | "ws": "^8.2.2", 166 | "youch": "^2.2.2" 167 | }, 168 | "engines": { 169 | "node": ">=16.13" 170 | } 171 | }, 172 | "node_modules/@miniflare/kv": { 173 | "version": "2.9.0", 174 | "resolved": "https://registry.npmjs.org/@miniflare/kv/-/kv-2.9.0.tgz", 175 | "integrity": "sha512-EqG51okY5rDtgjYs2Ny6j6IUVdTlJzDjwBKBIuW+wOV9NsAAzEchKVdYAXc8CyxvkggpYX481HydTD2OzK3INQ==", 176 | "dev": true, 177 | "dependencies": { 178 | "@miniflare/shared": "2.9.0" 179 | }, 180 | "engines": { 181 | "node": ">=16.13" 182 | } 183 | }, 184 | "node_modules/@miniflare/queues": { 185 | "version": "2.9.0", 186 | "resolved": "https://registry.npmjs.org/@miniflare/queues/-/queues-2.9.0.tgz", 187 | "integrity": "sha512-cAHWIlLF57rxQaJl19AzXw1k0SOM/uLTlx8r2PylHajZ/RRSs7CkCox3oKA6E5zKyfyxk2M64bmsAFZ9RCA0gw==", 188 | "dev": true, 189 | "dependencies": { 190 | "@miniflare/shared": "2.9.0" 191 | }, 192 | "engines": { 193 | "node": ">=16.7" 194 | } 195 | }, 196 | "node_modules/@miniflare/r2": { 197 | "version": "2.9.0", 198 | "resolved": "https://registry.npmjs.org/@miniflare/r2/-/r2-2.9.0.tgz", 199 | "integrity": "sha512-aMFWxxciAE3YsVok2OLy3A7hP5+2j/NaK7txmadgoe1CA8HYZyNuvv7v6bn8HKM5gWnJdT8sk4yEbMbBQ7Jv/A==", 200 | "dev": true, 201 | "dependencies": { 202 | "@miniflare/shared": "2.9.0", 203 | "undici": "5.9.1" 204 | }, 205 | "engines": { 206 | "node": ">=16.13" 207 | } 208 | }, 209 | "node_modules/@miniflare/runner-vm": { 210 | "version": "2.9.0", 211 | "resolved": "https://registry.npmjs.org/@miniflare/runner-vm/-/runner-vm-2.9.0.tgz", 212 | "integrity": "sha512-vewP+Fy7Czb261GmB9x/YtQkoDs/QP9B5LbP0YfJ35bI2C2j940eJLm8JP72IHV7ILtWNOqMc3Ure8uAbpf9NQ==", 213 | "dev": true, 214 | "dependencies": { 215 | "@miniflare/shared": "2.9.0" 216 | }, 217 | "engines": { 218 | "node": ">=16.13" 219 | } 220 | }, 221 | "node_modules/@miniflare/scheduler": { 222 | "version": "2.9.0", 223 | "resolved": "https://registry.npmjs.org/@miniflare/scheduler/-/scheduler-2.9.0.tgz", 224 | "integrity": "sha512-eodSCGkJYi4Z+Imbx/bNScDfDSt5HOypVSYjbFHj+hA2aNOdkGw6a1b6mzwx49jJD3GadIkonZAKD0S114yWMA==", 225 | "dev": true, 226 | "dependencies": { 227 | "@miniflare/core": "2.9.0", 228 | "@miniflare/shared": "2.9.0", 229 | "cron-schedule": "^3.0.4" 230 | }, 231 | "engines": { 232 | "node": ">=16.13" 233 | } 234 | }, 235 | "node_modules/@miniflare/shared": { 236 | "version": "2.9.0", 237 | "resolved": "https://registry.npmjs.org/@miniflare/shared/-/shared-2.9.0.tgz", 238 | "integrity": "sha512-5Ew/Ph0cHDQqKvOlmN70kz+qZW0hdgE9fQBStKLY3vDYhnBEhopbCUChSS+FCcL7WtxVJJVE7iB6J09NQTnQ/A==", 239 | "dev": true, 240 | "dependencies": { 241 | "@types/better-sqlite3": "^7.6.0", 242 | "kleur": "^4.1.4", 243 | "npx-import": "^1.1.3", 244 | "picomatch": "^2.3.1" 245 | }, 246 | "engines": { 247 | "node": ">=16.13" 248 | } 249 | }, 250 | "node_modules/@miniflare/sites": { 251 | "version": "2.9.0", 252 | "resolved": "https://registry.npmjs.org/@miniflare/sites/-/sites-2.9.0.tgz", 253 | "integrity": "sha512-+tWf7znxSQqXWGzPup8Xqkl8EmLmx+HaLC+UBtWPNnaJZrsjbbVxKwHpmGIdm+wZasEGfQk/82R21gUs9wdZnw==", 254 | "dev": true, 255 | "dependencies": { 256 | "@miniflare/kv": "2.9.0", 257 | "@miniflare/shared": "2.9.0", 258 | "@miniflare/storage-file": "2.9.0" 259 | }, 260 | "engines": { 261 | "node": ">=16.13" 262 | } 263 | }, 264 | "node_modules/@miniflare/storage-file": { 265 | "version": "2.9.0", 266 | "resolved": "https://registry.npmjs.org/@miniflare/storage-file/-/storage-file-2.9.0.tgz", 267 | "integrity": "sha512-HZHtHfJaLoDzQFddoIMcDGgAJ3/Nee98gwUYusQam7rj9pbEXnWmk54dzjzsDlkQpB/3MBFQNbtN5Bj1NIt0pg==", 268 | "dev": true, 269 | "dependencies": { 270 | "@miniflare/shared": "2.9.0", 271 | "@miniflare/storage-memory": "2.9.0" 272 | }, 273 | "engines": { 274 | "node": ">=16.13" 275 | } 276 | }, 277 | "node_modules/@miniflare/storage-memory": { 278 | "version": "2.9.0", 279 | "resolved": "https://registry.npmjs.org/@miniflare/storage-memory/-/storage-memory-2.9.0.tgz", 280 | "integrity": "sha512-p2yrr0omQhv6teDbdzhdBKzoQAFmUBMLEx+PtrO7CJHX15ICD08/pFAFAp96IcljNwZZDchU20Z3AcbldMj6Tw==", 281 | "dev": true, 282 | "dependencies": { 283 | "@miniflare/shared": "2.9.0" 284 | }, 285 | "engines": { 286 | "node": ">=16.13" 287 | } 288 | }, 289 | "node_modules/@miniflare/watcher": { 290 | "version": "2.9.0", 291 | "resolved": "https://registry.npmjs.org/@miniflare/watcher/-/watcher-2.9.0.tgz", 292 | "integrity": "sha512-Yqz8Q1He/2chebXvmCft8sMamuUiDQ4FIn0bwiF0+GBP2vvGCmy6SejXZY4ZD4REluPqQSis3CLKcIOWlHnIsw==", 293 | "dev": true, 294 | "dependencies": { 295 | "@miniflare/shared": "2.9.0" 296 | }, 297 | "engines": { 298 | "node": ">=16.13" 299 | } 300 | }, 301 | "node_modules/@miniflare/web-sockets": { 302 | "version": "2.9.0", 303 | "resolved": "https://registry.npmjs.org/@miniflare/web-sockets/-/web-sockets-2.9.0.tgz", 304 | "integrity": "sha512-Nob9e84m78qeQCka6OQf/JdNOmMkKCkX+i3rg+TYKSSITiMVuyzWp3vz3Ma184lAZiLg44lxBF4ZzENEdi99Kg==", 305 | "dev": true, 306 | "dependencies": { 307 | "@miniflare/core": "2.9.0", 308 | "@miniflare/shared": "2.9.0", 309 | "undici": "5.9.1", 310 | "ws": "^8.2.2" 311 | }, 312 | "engines": { 313 | "node": ">=16.13" 314 | } 315 | }, 316 | "node_modules/@types/better-sqlite3": { 317 | "version": "7.6.0", 318 | "resolved": "https://registry.npmjs.org/@types/better-sqlite3/-/better-sqlite3-7.6.0.tgz", 319 | "integrity": "sha512-rnSP9vY+fVsF3iJja5yRGBJV63PNBiezJlYrCkqUmQWFoB16cxAHwOkjsAYEu317miOfKaJpa65cbp0P4XJ/jw==", 320 | "dev": true, 321 | "dependencies": { 322 | "@types/node": "*" 323 | } 324 | }, 325 | "node_modules/@types/cookie": { 326 | "version": "0.5.1", 327 | "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.5.1.tgz", 328 | "integrity": "sha512-COUnqfB2+ckwXXSFInsFdOAWQzCCx+a5hq2ruyj+Vjund94RJQd4LG2u9hnvJrTgunKAaax7ancBYlDrNYxA0g==", 329 | "dev": true 330 | }, 331 | "node_modules/@types/node": { 332 | "version": "18.7.18", 333 | "resolved": "https://registry.npmjs.org/@types/node/-/node-18.7.18.tgz", 334 | "integrity": "sha512-m+6nTEOadJZuTPkKR/SYK3A2d7FZrgElol9UP1Kae90VVU4a6mxnPuLiIW1m4Cq4gZ/nWb9GrdVXJCoCazDAbg==", 335 | "dev": true 336 | }, 337 | "node_modules/@types/stack-trace": { 338 | "version": "0.0.29", 339 | "resolved": "https://registry.npmjs.org/@types/stack-trace/-/stack-trace-0.0.29.tgz", 340 | "integrity": "sha512-TgfOX+mGY/NyNxJLIbDWrO9DjGoVSW9+aB8H2yy1fy32jsvxijhmyJI9fDFgvz3YP4lvJaq9DzdR/M1bOgVc9g==", 341 | "dev": true 342 | }, 343 | "node_modules/anymatch": { 344 | "version": "3.1.2", 345 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 346 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 347 | "dev": true, 348 | "dependencies": { 349 | "normalize-path": "^3.0.0", 350 | "picomatch": "^2.0.4" 351 | }, 352 | "engines": { 353 | "node": ">= 8" 354 | } 355 | }, 356 | "node_modules/binary-extensions": { 357 | "version": "2.2.0", 358 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 359 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 360 | "dev": true, 361 | "engines": { 362 | "node": ">=8" 363 | } 364 | }, 365 | "node_modules/blake3-wasm": { 366 | "version": "2.1.5", 367 | "resolved": "https://registry.npmjs.org/blake3-wasm/-/blake3-wasm-2.1.5.tgz", 368 | "integrity": "sha512-F1+K8EbfOZE49dtoPtmxUQrpXaBIl3ICvasLh+nJta0xkz+9kF/7uet9fLnwKqhDrmj6g+6K3Tw9yQPUg2ka5g==", 369 | "dev": true 370 | }, 371 | "node_modules/braces": { 372 | "version": "3.0.2", 373 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 374 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 375 | "dev": true, 376 | "dependencies": { 377 | "fill-range": "^7.0.1" 378 | }, 379 | "engines": { 380 | "node": ">=8" 381 | } 382 | }, 383 | "node_modules/buffer-from": { 384 | "version": "1.1.2", 385 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 386 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 387 | "dev": true 388 | }, 389 | "node_modules/builtins": { 390 | "version": "5.0.1", 391 | "resolved": "https://registry.npmjs.org/builtins/-/builtins-5.0.1.tgz", 392 | "integrity": "sha512-qwVpFEHNfhYJIzNRBvd2C1kyo6jz3ZSMPyyuR47OPdiKWlbYnZNyDWuyR175qDnAJLiCo5fBBqPb3RiXgWlkOQ==", 393 | "dev": true, 394 | "dependencies": { 395 | "semver": "^7.0.0" 396 | } 397 | }, 398 | "node_modules/busboy": { 399 | "version": "1.6.0", 400 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", 401 | "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", 402 | "dev": true, 403 | "dependencies": { 404 | "streamsearch": "^1.1.0" 405 | }, 406 | "engines": { 407 | "node": ">=10.16.0" 408 | } 409 | }, 410 | "node_modules/chokidar": { 411 | "version": "3.5.3", 412 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 413 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 414 | "dev": true, 415 | "funding": [ 416 | { 417 | "type": "individual", 418 | "url": "https://paulmillr.com/funding/" 419 | } 420 | ], 421 | "dependencies": { 422 | "anymatch": "~3.1.2", 423 | "braces": "~3.0.2", 424 | "glob-parent": "~5.1.2", 425 | "is-binary-path": "~2.1.0", 426 | "is-glob": "~4.0.1", 427 | "normalize-path": "~3.0.0", 428 | "readdirp": "~3.6.0" 429 | }, 430 | "engines": { 431 | "node": ">= 8.10.0" 432 | }, 433 | "optionalDependencies": { 434 | "fsevents": "~2.3.2" 435 | } 436 | }, 437 | "node_modules/cookie": { 438 | "version": "0.4.2", 439 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz", 440 | "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==", 441 | "dev": true, 442 | "engines": { 443 | "node": ">= 0.6" 444 | } 445 | }, 446 | "node_modules/cron-schedule": { 447 | "version": "3.0.6", 448 | "resolved": "https://registry.npmjs.org/cron-schedule/-/cron-schedule-3.0.6.tgz", 449 | "integrity": "sha512-izfGgKyzzIyLaeb1EtZ3KbglkS6AKp9cv7LxmiyoOu+fXfol1tQDC0Cof0enVZGNtudTHW+3lfuW9ZkLQss4Wg==", 450 | "dev": true 451 | }, 452 | "node_modules/cross-spawn": { 453 | "version": "7.0.3", 454 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 455 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 456 | "dev": true, 457 | "dependencies": { 458 | "path-key": "^3.1.0", 459 | "shebang-command": "^2.0.0", 460 | "which": "^2.0.1" 461 | }, 462 | "engines": { 463 | "node": ">= 8" 464 | } 465 | }, 466 | "node_modules/dotenv": { 467 | "version": "10.0.0", 468 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-10.0.0.tgz", 469 | "integrity": "sha512-rlBi9d8jpv9Sf1klPjNfFAuWDjKLwTIJJ/VxtoTwIR6hnZxcEOQCZg2oIL3MWBYw5GpUDKOEnND7LXTbIpQ03Q==", 470 | "dev": true, 471 | "engines": { 472 | "node": ">=10" 473 | } 474 | }, 475 | "node_modules/esbuild": { 476 | "version": "0.14.51", 477 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.14.51.tgz", 478 | "integrity": "sha512-+CvnDitD7Q5sT7F+FM65sWkF8wJRf+j9fPcprxYV4j+ohmzVj2W7caUqH2s5kCaCJAfcAICjSlKhDCcvDpU7nw==", 479 | "dev": true, 480 | "hasInstallScript": true, 481 | "bin": { 482 | "esbuild": "bin/esbuild" 483 | }, 484 | "engines": { 485 | "node": ">=12" 486 | }, 487 | "optionalDependencies": { 488 | "esbuild-android-64": "0.14.51", 489 | "esbuild-android-arm64": "0.14.51", 490 | "esbuild-darwin-64": "0.14.51", 491 | "esbuild-darwin-arm64": "0.14.51", 492 | "esbuild-freebsd-64": "0.14.51", 493 | "esbuild-freebsd-arm64": "0.14.51", 494 | "esbuild-linux-32": "0.14.51", 495 | "esbuild-linux-64": "0.14.51", 496 | "esbuild-linux-arm": "0.14.51", 497 | "esbuild-linux-arm64": "0.14.51", 498 | "esbuild-linux-mips64le": "0.14.51", 499 | "esbuild-linux-ppc64le": "0.14.51", 500 | "esbuild-linux-riscv64": "0.14.51", 501 | "esbuild-linux-s390x": "0.14.51", 502 | "esbuild-netbsd-64": "0.14.51", 503 | "esbuild-openbsd-64": "0.14.51", 504 | "esbuild-sunos-64": "0.14.51", 505 | "esbuild-windows-32": "0.14.51", 506 | "esbuild-windows-64": "0.14.51", 507 | "esbuild-windows-arm64": "0.14.51" 508 | } 509 | }, 510 | "node_modules/esbuild-android-64": { 511 | "version": "0.14.51", 512 | "resolved": "https://registry.npmjs.org/esbuild-android-64/-/esbuild-android-64-0.14.51.tgz", 513 | "integrity": "sha512-6FOuKTHnC86dtrKDmdSj2CkcKF8PnqkaIXqvgydqfJmqBazCPdw+relrMlhGjkvVdiiGV70rpdnyFmA65ekBCQ==", 514 | "cpu": [ 515 | "x64" 516 | ], 517 | "dev": true, 518 | "optional": true, 519 | "os": [ 520 | "android" 521 | ], 522 | "engines": { 523 | "node": ">=12" 524 | } 525 | }, 526 | "node_modules/esbuild-android-arm64": { 527 | "version": "0.14.51", 528 | "resolved": "https://registry.npmjs.org/esbuild-android-arm64/-/esbuild-android-arm64-0.14.51.tgz", 529 | "integrity": "sha512-vBtp//5VVkZWmYYvHsqBRCMMi1MzKuMIn5XDScmnykMTu9+TD9v0NMEDqQxvtFToeYmojdo5UCV2vzMQWJcJ4A==", 530 | "cpu": [ 531 | "arm64" 532 | ], 533 | "dev": true, 534 | "optional": true, 535 | "os": [ 536 | "android" 537 | ], 538 | "engines": { 539 | "node": ">=12" 540 | } 541 | }, 542 | "node_modules/esbuild-darwin-64": { 543 | "version": "0.14.51", 544 | "resolved": "https://registry.npmjs.org/esbuild-darwin-64/-/esbuild-darwin-64-0.14.51.tgz", 545 | "integrity": "sha512-YFmXPIOvuagDcwCejMRtCDjgPfnDu+bNeh5FU2Ryi68ADDVlWEpbtpAbrtf/lvFTWPexbgyKgzppNgsmLPr8PA==", 546 | "cpu": [ 547 | "x64" 548 | ], 549 | "dev": true, 550 | "optional": true, 551 | "os": [ 552 | "darwin" 553 | ], 554 | "engines": { 555 | "node": ">=12" 556 | } 557 | }, 558 | "node_modules/esbuild-darwin-arm64": { 559 | "version": "0.14.51", 560 | "resolved": "https://registry.npmjs.org/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.14.51.tgz", 561 | "integrity": "sha512-juYD0QnSKwAMfzwKdIF6YbueXzS6N7y4GXPDeDkApz/1RzlT42mvX9jgNmyOlWKN7YzQAYbcUEJmZJYQGdf2ow==", 562 | "cpu": [ 563 | "arm64" 564 | ], 565 | "dev": true, 566 | "optional": true, 567 | "os": [ 568 | "darwin" 569 | ], 570 | "engines": { 571 | "node": ">=12" 572 | } 573 | }, 574 | "node_modules/esbuild-freebsd-64": { 575 | "version": "0.14.51", 576 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-64/-/esbuild-freebsd-64-0.14.51.tgz", 577 | "integrity": "sha512-cLEI/aXjb6vo5O2Y8rvVSQ7smgLldwYY5xMxqh/dQGfWO+R1NJOFsiax3IS4Ng300SVp7Gz3czxT6d6qf2cw0g==", 578 | "cpu": [ 579 | "x64" 580 | ], 581 | "dev": true, 582 | "optional": true, 583 | "os": [ 584 | "freebsd" 585 | ], 586 | "engines": { 587 | "node": ">=12" 588 | } 589 | }, 590 | "node_modules/esbuild-freebsd-arm64": { 591 | "version": "0.14.51", 592 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.14.51.tgz", 593 | "integrity": "sha512-TcWVw/rCL2F+jUgRkgLa3qltd5gzKjIMGhkVybkjk6PJadYInPtgtUBp1/hG+mxyigaT7ib+od1Xb84b+L+1Mg==", 594 | "cpu": [ 595 | "arm64" 596 | ], 597 | "dev": true, 598 | "optional": true, 599 | "os": [ 600 | "freebsd" 601 | ], 602 | "engines": { 603 | "node": ">=12" 604 | } 605 | }, 606 | "node_modules/esbuild-linux-32": { 607 | "version": "0.14.51", 608 | "resolved": "https://registry.npmjs.org/esbuild-linux-32/-/esbuild-linux-32-0.14.51.tgz", 609 | "integrity": "sha512-RFqpyC5ChyWrjx8Xj2K0EC1aN0A37H6OJfmUXIASEqJoHcntuV3j2Efr9RNmUhMfNE6yEj2VpYuDteZLGDMr0w==", 610 | "cpu": [ 611 | "ia32" 612 | ], 613 | "dev": true, 614 | "optional": true, 615 | "os": [ 616 | "linux" 617 | ], 618 | "engines": { 619 | "node": ">=12" 620 | } 621 | }, 622 | "node_modules/esbuild-linux-64": { 623 | "version": "0.14.51", 624 | "resolved": "https://registry.npmjs.org/esbuild-linux-64/-/esbuild-linux-64-0.14.51.tgz", 625 | "integrity": "sha512-dxjhrqo5i7Rq6DXwz5v+MEHVs9VNFItJmHBe1CxROWNf4miOGoQhqSG8StStbDkQ1Mtobg6ng+4fwByOhoQoeA==", 626 | "cpu": [ 627 | "x64" 628 | ], 629 | "dev": true, 630 | "optional": true, 631 | "os": [ 632 | "linux" 633 | ], 634 | "engines": { 635 | "node": ">=12" 636 | } 637 | }, 638 | "node_modules/esbuild-linux-arm": { 639 | "version": "0.14.51", 640 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm/-/esbuild-linux-arm-0.14.51.tgz", 641 | "integrity": "sha512-LsJynDxYF6Neg7ZC7748yweCDD+N8ByCv22/7IAZglIEniEkqdF4HCaa49JNDLw1UQGlYuhOB8ZT/MmcSWzcWg==", 642 | "cpu": [ 643 | "arm" 644 | ], 645 | "dev": true, 646 | "optional": true, 647 | "os": [ 648 | "linux" 649 | ], 650 | "engines": { 651 | "node": ">=12" 652 | } 653 | }, 654 | "node_modules/esbuild-linux-arm64": { 655 | "version": "0.14.51", 656 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm64/-/esbuild-linux-arm64-0.14.51.tgz", 657 | "integrity": "sha512-D9rFxGutoqQX3xJPxqd6o+kvYKeIbM0ifW2y0bgKk5HPgQQOo2k9/2Vpto3ybGYaFPCE5qTGtqQta9PoP6ZEzw==", 658 | "cpu": [ 659 | "arm64" 660 | ], 661 | "dev": true, 662 | "optional": true, 663 | "os": [ 664 | "linux" 665 | ], 666 | "engines": { 667 | "node": ">=12" 668 | } 669 | }, 670 | "node_modules/esbuild-linux-mips64le": { 671 | "version": "0.14.51", 672 | "resolved": "https://registry.npmjs.org/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.14.51.tgz", 673 | "integrity": "sha512-vS54wQjy4IinLSlb5EIlLoln8buh1yDgliP4CuEHumrPk4PvvP4kTRIG4SzMXm6t19N0rIfT4bNdAxzJLg2k6A==", 674 | "cpu": [ 675 | "mips64el" 676 | ], 677 | "dev": true, 678 | "optional": true, 679 | "os": [ 680 | "linux" 681 | ], 682 | "engines": { 683 | "node": ">=12" 684 | } 685 | }, 686 | "node_modules/esbuild-linux-ppc64le": { 687 | "version": "0.14.51", 688 | "resolved": "https://registry.npmjs.org/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.14.51.tgz", 689 | "integrity": "sha512-xcdd62Y3VfGoyphNP/aIV9LP+RzFw5M5Z7ja+zdpQHHvokJM7d0rlDRMN+iSSwvUymQkqZO+G/xjb4/75du8BQ==", 690 | "cpu": [ 691 | "ppc64" 692 | ], 693 | "dev": true, 694 | "optional": true, 695 | "os": [ 696 | "linux" 697 | ], 698 | "engines": { 699 | "node": ">=12" 700 | } 701 | }, 702 | "node_modules/esbuild-linux-riscv64": { 703 | "version": "0.14.51", 704 | "resolved": "https://registry.npmjs.org/esbuild-linux-riscv64/-/esbuild-linux-riscv64-0.14.51.tgz", 705 | "integrity": "sha512-syXHGak9wkAnFz0gMmRBoy44JV0rp4kVCEA36P5MCeZcxFq8+fllBC2t6sKI23w3qd8Vwo9pTADCgjTSf3L3rA==", 706 | "cpu": [ 707 | "riscv64" 708 | ], 709 | "dev": true, 710 | "optional": true, 711 | "os": [ 712 | "linux" 713 | ], 714 | "engines": { 715 | "node": ">=12" 716 | } 717 | }, 718 | "node_modules/esbuild-linux-s390x": { 719 | "version": "0.14.51", 720 | "resolved": "https://registry.npmjs.org/esbuild-linux-s390x/-/esbuild-linux-s390x-0.14.51.tgz", 721 | "integrity": "sha512-kFAJY3dv+Wq8o28K/C7xkZk/X34rgTwhknSsElIqoEo8armCOjMJ6NsMxm48KaWY2h2RUYGtQmr+RGuUPKBhyw==", 722 | "cpu": [ 723 | "s390x" 724 | ], 725 | "dev": true, 726 | "optional": true, 727 | "os": [ 728 | "linux" 729 | ], 730 | "engines": { 731 | "node": ">=12" 732 | } 733 | }, 734 | "node_modules/esbuild-netbsd-64": { 735 | "version": "0.14.51", 736 | "resolved": "https://registry.npmjs.org/esbuild-netbsd-64/-/esbuild-netbsd-64-0.14.51.tgz", 737 | "integrity": "sha512-ZZBI7qrR1FevdPBVHz/1GSk1x5GDL/iy42Zy8+neEm/HA7ma+hH/bwPEjeHXKWUDvM36CZpSL/fn1/y9/Hb+1A==", 738 | "cpu": [ 739 | "x64" 740 | ], 741 | "dev": true, 742 | "optional": true, 743 | "os": [ 744 | "netbsd" 745 | ], 746 | "engines": { 747 | "node": ">=12" 748 | } 749 | }, 750 | "node_modules/esbuild-openbsd-64": { 751 | "version": "0.14.51", 752 | "resolved": "https://registry.npmjs.org/esbuild-openbsd-64/-/esbuild-openbsd-64-0.14.51.tgz", 753 | "integrity": "sha512-7R1/p39M+LSVQVgDVlcY1KKm6kFKjERSX1lipMG51NPcspJD1tmiZSmmBXoY5jhHIu6JL1QkFDTx94gMYK6vfA==", 754 | "cpu": [ 755 | "x64" 756 | ], 757 | "dev": true, 758 | "optional": true, 759 | "os": [ 760 | "openbsd" 761 | ], 762 | "engines": { 763 | "node": ">=12" 764 | } 765 | }, 766 | "node_modules/esbuild-sunos-64": { 767 | "version": "0.14.51", 768 | "resolved": "https://registry.npmjs.org/esbuild-sunos-64/-/esbuild-sunos-64-0.14.51.tgz", 769 | "integrity": "sha512-HoHaCswHxLEYN8eBTtyO0bFEWvA3Kdb++hSQ/lLG7TyKF69TeSG0RNoBRAs45x/oCeWaTDntEZlYwAfQlhEtJA==", 770 | "cpu": [ 771 | "x64" 772 | ], 773 | "dev": true, 774 | "optional": true, 775 | "os": [ 776 | "sunos" 777 | ], 778 | "engines": { 779 | "node": ">=12" 780 | } 781 | }, 782 | "node_modules/esbuild-windows-32": { 783 | "version": "0.14.51", 784 | "resolved": "https://registry.npmjs.org/esbuild-windows-32/-/esbuild-windows-32-0.14.51.tgz", 785 | "integrity": "sha512-4rtwSAM35A07CBt1/X8RWieDj3ZUHQqUOaEo5ZBs69rt5WAFjP4aqCIobdqOy4FdhYw1yF8Z0xFBTyc9lgPtEg==", 786 | "cpu": [ 787 | "ia32" 788 | ], 789 | "dev": true, 790 | "optional": true, 791 | "os": [ 792 | "win32" 793 | ], 794 | "engines": { 795 | "node": ">=12" 796 | } 797 | }, 798 | "node_modules/esbuild-windows-64": { 799 | "version": "0.14.51", 800 | "resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.14.51.tgz", 801 | "integrity": "sha512-HoN/5HGRXJpWODprGCgKbdMvrC3A2gqvzewu2eECRw2sYxOUoh2TV1tS+G7bHNapPGI79woQJGV6pFH7GH7qnA==", 802 | "cpu": [ 803 | "x64" 804 | ], 805 | "dev": true, 806 | "optional": true, 807 | "os": [ 808 | "win32" 809 | ], 810 | "engines": { 811 | "node": ">=12" 812 | } 813 | }, 814 | "node_modules/esbuild-windows-arm64": { 815 | "version": "0.14.51", 816 | "resolved": "https://registry.npmjs.org/esbuild-windows-arm64/-/esbuild-windows-arm64-0.14.51.tgz", 817 | "integrity": "sha512-JQDqPjuOH7o+BsKMSddMfmVJXrnYZxXDHsoLHc0xgmAZkOOCflRmC43q31pk79F9xuyWY45jDBPolb5ZgGOf9g==", 818 | "cpu": [ 819 | "arm64" 820 | ], 821 | "dev": true, 822 | "optional": true, 823 | "os": [ 824 | "win32" 825 | ], 826 | "engines": { 827 | "node": ">=12" 828 | } 829 | }, 830 | "node_modules/escape-string-regexp": { 831 | "version": "4.0.0", 832 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 833 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 834 | "dev": true, 835 | "engines": { 836 | "node": ">=10" 837 | }, 838 | "funding": { 839 | "url": "https://github.com/sponsors/sindresorhus" 840 | } 841 | }, 842 | "node_modules/estree-walker": { 843 | "version": "0.6.1", 844 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", 845 | "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", 846 | "dev": true 847 | }, 848 | "node_modules/execa": { 849 | "version": "6.1.0", 850 | "resolved": "https://registry.npmjs.org/execa/-/execa-6.1.0.tgz", 851 | "integrity": "sha512-QVWlX2e50heYJcCPG0iWtf8r0xjEYfz/OYLGDYH+IyjWezzPNxz63qNFOu0l4YftGWuizFVZHHs8PrLU5p2IDA==", 852 | "dev": true, 853 | "dependencies": { 854 | "cross-spawn": "^7.0.3", 855 | "get-stream": "^6.0.1", 856 | "human-signals": "^3.0.1", 857 | "is-stream": "^3.0.0", 858 | "merge-stream": "^2.0.0", 859 | "npm-run-path": "^5.1.0", 860 | "onetime": "^6.0.0", 861 | "signal-exit": "^3.0.7", 862 | "strip-final-newline": "^3.0.0" 863 | }, 864 | "engines": { 865 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 866 | }, 867 | "funding": { 868 | "url": "https://github.com/sindresorhus/execa?sponsor=1" 869 | } 870 | }, 871 | "node_modules/fill-range": { 872 | "version": "7.0.1", 873 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 874 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 875 | "dev": true, 876 | "dependencies": { 877 | "to-regex-range": "^5.0.1" 878 | }, 879 | "engines": { 880 | "node": ">=8" 881 | } 882 | }, 883 | "node_modules/fsevents": { 884 | "version": "2.3.2", 885 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 886 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 887 | "dev": true, 888 | "hasInstallScript": true, 889 | "optional": true, 890 | "os": [ 891 | "darwin" 892 | ], 893 | "engines": { 894 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 895 | } 896 | }, 897 | "node_modules/get-stream": { 898 | "version": "6.0.1", 899 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 900 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 901 | "dev": true, 902 | "engines": { 903 | "node": ">=10" 904 | }, 905 | "funding": { 906 | "url": "https://github.com/sponsors/sindresorhus" 907 | } 908 | }, 909 | "node_modules/glob-parent": { 910 | "version": "5.1.2", 911 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 912 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 913 | "dev": true, 914 | "dependencies": { 915 | "is-glob": "^4.0.1" 916 | }, 917 | "engines": { 918 | "node": ">= 6" 919 | } 920 | }, 921 | "node_modules/html-rewriter-wasm": { 922 | "version": "0.4.1", 923 | "resolved": "https://registry.npmjs.org/html-rewriter-wasm/-/html-rewriter-wasm-0.4.1.tgz", 924 | "integrity": "sha512-lNovG8CMCCmcVB1Q7xggMSf7tqPCijZXaH4gL6iE8BFghdQCbaY5Met9i1x2Ex8m/cZHDUtXK9H6/znKamRP8Q==", 925 | "dev": true 926 | }, 927 | "node_modules/http-cache-semantics": { 928 | "version": "4.1.0", 929 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 930 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==", 931 | "dev": true 932 | }, 933 | "node_modules/human-signals": { 934 | "version": "3.0.1", 935 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-3.0.1.tgz", 936 | "integrity": "sha512-rQLskxnM/5OCldHo+wNXbpVgDn5A17CUoKX+7Sokwaknlq7CdSnphy0W39GU8dw59XiCXmFXDg4fRuckQRKewQ==", 937 | "dev": true, 938 | "engines": { 939 | "node": ">=12.20.0" 940 | } 941 | }, 942 | "node_modules/is-binary-path": { 943 | "version": "2.1.0", 944 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 945 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 946 | "dev": true, 947 | "dependencies": { 948 | "binary-extensions": "^2.0.0" 949 | }, 950 | "engines": { 951 | "node": ">=8" 952 | } 953 | }, 954 | "node_modules/is-extglob": { 955 | "version": "2.1.1", 956 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 957 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 958 | "dev": true, 959 | "engines": { 960 | "node": ">=0.10.0" 961 | } 962 | }, 963 | "node_modules/is-glob": { 964 | "version": "4.0.3", 965 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 966 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 967 | "dev": true, 968 | "dependencies": { 969 | "is-extglob": "^2.1.1" 970 | }, 971 | "engines": { 972 | "node": ">=0.10.0" 973 | } 974 | }, 975 | "node_modules/is-number": { 976 | "version": "7.0.0", 977 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 978 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 979 | "dev": true, 980 | "engines": { 981 | "node": ">=0.12.0" 982 | } 983 | }, 984 | "node_modules/is-stream": { 985 | "version": "3.0.0", 986 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-3.0.0.tgz", 987 | "integrity": "sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==", 988 | "dev": true, 989 | "engines": { 990 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 991 | }, 992 | "funding": { 993 | "url": "https://github.com/sponsors/sindresorhus" 994 | } 995 | }, 996 | "node_modules/isexe": { 997 | "version": "2.0.0", 998 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 999 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1000 | "dev": true 1001 | }, 1002 | "node_modules/kleur": { 1003 | "version": "4.1.5", 1004 | "resolved": "https://registry.npmjs.org/kleur/-/kleur-4.1.5.tgz", 1005 | "integrity": "sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ==", 1006 | "dev": true, 1007 | "engines": { 1008 | "node": ">=6" 1009 | } 1010 | }, 1011 | "node_modules/lru-cache": { 1012 | "version": "6.0.0", 1013 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1014 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1015 | "dev": true, 1016 | "dependencies": { 1017 | "yallist": "^4.0.0" 1018 | }, 1019 | "engines": { 1020 | "node": ">=10" 1021 | } 1022 | }, 1023 | "node_modules/magic-string": { 1024 | "version": "0.25.9", 1025 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz", 1026 | "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==", 1027 | "dev": true, 1028 | "dependencies": { 1029 | "sourcemap-codec": "^1.4.8" 1030 | } 1031 | }, 1032 | "node_modules/merge-stream": { 1033 | "version": "2.0.0", 1034 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 1035 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 1036 | "dev": true 1037 | }, 1038 | "node_modules/mime": { 1039 | "version": "3.0.0", 1040 | "resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz", 1041 | "integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==", 1042 | "dev": true, 1043 | "bin": { 1044 | "mime": "cli.js" 1045 | }, 1046 | "engines": { 1047 | "node": ">=10.0.0" 1048 | } 1049 | }, 1050 | "node_modules/mimic-fn": { 1051 | "version": "4.0.0", 1052 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", 1053 | "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==", 1054 | "dev": true, 1055 | "engines": { 1056 | "node": ">=12" 1057 | }, 1058 | "funding": { 1059 | "url": "https://github.com/sponsors/sindresorhus" 1060 | } 1061 | }, 1062 | "node_modules/miniflare": { 1063 | "version": "2.9.0", 1064 | "resolved": "https://registry.npmjs.org/miniflare/-/miniflare-2.9.0.tgz", 1065 | "integrity": "sha512-HBGQ5Jj6sMU1B1hX6G3ML46ThtUvu1nvxgXjDDmhp2RhWKYj0XvcohW/nPPL/MTP1gpvfT880De9EHmobVsDsw==", 1066 | "dev": true, 1067 | "dependencies": { 1068 | "@miniflare/cache": "2.9.0", 1069 | "@miniflare/cli-parser": "2.9.0", 1070 | "@miniflare/core": "2.9.0", 1071 | "@miniflare/d1": "2.9.0", 1072 | "@miniflare/durable-objects": "2.9.0", 1073 | "@miniflare/html-rewriter": "2.9.0", 1074 | "@miniflare/http-server": "2.9.0", 1075 | "@miniflare/kv": "2.9.0", 1076 | "@miniflare/queues": "2.9.0", 1077 | "@miniflare/r2": "2.9.0", 1078 | "@miniflare/runner-vm": "2.9.0", 1079 | "@miniflare/scheduler": "2.9.0", 1080 | "@miniflare/shared": "2.9.0", 1081 | "@miniflare/sites": "2.9.0", 1082 | "@miniflare/storage-file": "2.9.0", 1083 | "@miniflare/storage-memory": "2.9.0", 1084 | "@miniflare/web-sockets": "2.9.0", 1085 | "kleur": "^4.1.4", 1086 | "semiver": "^1.1.0", 1087 | "source-map-support": "^0.5.20", 1088 | "undici": "5.9.1" 1089 | }, 1090 | "bin": { 1091 | "miniflare": "bootstrap.js" 1092 | }, 1093 | "engines": { 1094 | "node": ">=16.13" 1095 | }, 1096 | "peerDependencies": { 1097 | "@miniflare/storage-redis": "2.9.0", 1098 | "cron-schedule": "^3.0.4", 1099 | "ioredis": "^4.27.9" 1100 | }, 1101 | "peerDependenciesMeta": { 1102 | "@miniflare/storage-redis": { 1103 | "optional": true 1104 | }, 1105 | "cron-schedule": { 1106 | "optional": true 1107 | }, 1108 | "ioredis": { 1109 | "optional": true 1110 | } 1111 | } 1112 | }, 1113 | "node_modules/mustache": { 1114 | "version": "4.2.0", 1115 | "resolved": "https://registry.npmjs.org/mustache/-/mustache-4.2.0.tgz", 1116 | "integrity": "sha512-71ippSywq5Yb7/tVYyGbkBggbU8H3u5Rz56fH60jGFgr8uHwxs+aSKeqmluIVzM0m0kB7xQjKS6qPfd0b2ZoqQ==", 1117 | "dev": true, 1118 | "bin": { 1119 | "mustache": "bin/mustache" 1120 | } 1121 | }, 1122 | "node_modules/nanoid": { 1123 | "version": "3.3.4", 1124 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.4.tgz", 1125 | "integrity": "sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==", 1126 | "dev": true, 1127 | "bin": { 1128 | "nanoid": "bin/nanoid.cjs" 1129 | }, 1130 | "engines": { 1131 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1132 | } 1133 | }, 1134 | "node_modules/node-forge": { 1135 | "version": "1.3.1", 1136 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", 1137 | "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==", 1138 | "dev": true, 1139 | "engines": { 1140 | "node": ">= 6.13.0" 1141 | } 1142 | }, 1143 | "node_modules/normalize-path": { 1144 | "version": "3.0.0", 1145 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1146 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1147 | "dev": true, 1148 | "engines": { 1149 | "node": ">=0.10.0" 1150 | } 1151 | }, 1152 | "node_modules/npm-run-path": { 1153 | "version": "5.1.0", 1154 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.1.0.tgz", 1155 | "integrity": "sha512-sJOdmRGrY2sjNTRMbSvluQqg+8X7ZK61yvzBEIDhz4f8z1TZFYABsqjjCBd/0PUNE9M6QDgHJXQkGUEm7Q+l9Q==", 1156 | "dev": true, 1157 | "dependencies": { 1158 | "path-key": "^4.0.0" 1159 | }, 1160 | "engines": { 1161 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 1162 | }, 1163 | "funding": { 1164 | "url": "https://github.com/sponsors/sindresorhus" 1165 | } 1166 | }, 1167 | "node_modules/npm-run-path/node_modules/path-key": { 1168 | "version": "4.0.0", 1169 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-4.0.0.tgz", 1170 | "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==", 1171 | "dev": true, 1172 | "engines": { 1173 | "node": ">=12" 1174 | }, 1175 | "funding": { 1176 | "url": "https://github.com/sponsors/sindresorhus" 1177 | } 1178 | }, 1179 | "node_modules/npx-import": { 1180 | "version": "1.1.3", 1181 | "resolved": "https://registry.npmjs.org/npx-import/-/npx-import-1.1.3.tgz", 1182 | "integrity": "sha512-zy6249FJ81OtPsvz2y0+rgis31EN5wbdwBG2umtEh65W/4onYArHuoUSZ+W+T7BQYK7YF+h9G4CuGPusMCcLOw==", 1183 | "dev": true, 1184 | "dependencies": { 1185 | "execa": "^6.1.0", 1186 | "parse-package-name": "^1.0.0", 1187 | "semver": "^7.3.7", 1188 | "validate-npm-package-name": "^4.0.0" 1189 | } 1190 | }, 1191 | "node_modules/onetime": { 1192 | "version": "6.0.0", 1193 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz", 1194 | "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==", 1195 | "dev": true, 1196 | "dependencies": { 1197 | "mimic-fn": "^4.0.0" 1198 | }, 1199 | "engines": { 1200 | "node": ">=12" 1201 | }, 1202 | "funding": { 1203 | "url": "https://github.com/sponsors/sindresorhus" 1204 | } 1205 | }, 1206 | "node_modules/parse-package-name": { 1207 | "version": "1.0.0", 1208 | "resolved": "https://registry.npmjs.org/parse-package-name/-/parse-package-name-1.0.0.tgz", 1209 | "integrity": "sha512-kBeTUtcj+SkyfaW4+KBe0HtsloBJ/mKTPoxpVdA57GZiPerREsUWJOhVj9anXweFiJkm5y8FG1sxFZkZ0SN6wg==", 1210 | "dev": true 1211 | }, 1212 | "node_modules/path-key": { 1213 | "version": "3.1.1", 1214 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1215 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1216 | "dev": true, 1217 | "engines": { 1218 | "node": ">=8" 1219 | } 1220 | }, 1221 | "node_modules/path-to-regexp": { 1222 | "version": "6.2.1", 1223 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz", 1224 | "integrity": "sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw==", 1225 | "dev": true 1226 | }, 1227 | "node_modules/picomatch": { 1228 | "version": "2.3.1", 1229 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1230 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1231 | "dev": true, 1232 | "engines": { 1233 | "node": ">=8.6" 1234 | }, 1235 | "funding": { 1236 | "url": "https://github.com/sponsors/jonschlinkert" 1237 | } 1238 | }, 1239 | "node_modules/readdirp": { 1240 | "version": "3.6.0", 1241 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1242 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1243 | "dev": true, 1244 | "dependencies": { 1245 | "picomatch": "^2.2.1" 1246 | }, 1247 | "engines": { 1248 | "node": ">=8.10.0" 1249 | } 1250 | }, 1251 | "node_modules/rollup-plugin-inject": { 1252 | "version": "3.0.2", 1253 | "resolved": "https://registry.npmjs.org/rollup-plugin-inject/-/rollup-plugin-inject-3.0.2.tgz", 1254 | "integrity": "sha512-ptg9PQwzs3orn4jkgXJ74bfs5vYz1NCZlSQMBUA0wKcGp5i5pA1AO3fOUEte8enhGUC+iapTCzEWw2jEFFUO/w==", 1255 | "deprecated": "This package has been deprecated and is no longer maintained. Please use @rollup/plugin-inject.", 1256 | "dev": true, 1257 | "dependencies": { 1258 | "estree-walker": "^0.6.1", 1259 | "magic-string": "^0.25.3", 1260 | "rollup-pluginutils": "^2.8.1" 1261 | } 1262 | }, 1263 | "node_modules/rollup-plugin-node-polyfills": { 1264 | "version": "0.2.1", 1265 | "resolved": "https://registry.npmjs.org/rollup-plugin-node-polyfills/-/rollup-plugin-node-polyfills-0.2.1.tgz", 1266 | "integrity": "sha512-4kCrKPTJ6sK4/gLL/U5QzVT8cxJcofO0OU74tnB19F40cmuAKSzH5/siithxlofFEjwvw1YAhPmbvGNA6jEroA==", 1267 | "dev": true, 1268 | "dependencies": { 1269 | "rollup-plugin-inject": "^3.0.0" 1270 | } 1271 | }, 1272 | "node_modules/rollup-pluginutils": { 1273 | "version": "2.8.2", 1274 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", 1275 | "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", 1276 | "dev": true, 1277 | "dependencies": { 1278 | "estree-walker": "^0.6.1" 1279 | } 1280 | }, 1281 | "node_modules/selfsigned": { 1282 | "version": "2.1.1", 1283 | "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.1.1.tgz", 1284 | "integrity": "sha512-GSL3aowiF7wa/WtSFwnUrludWFoNhftq8bUkH9pkzjpN2XSPOAYEgg6e0sS9s0rZwgJzJiQRPU18A6clnoW5wQ==", 1285 | "dev": true, 1286 | "dependencies": { 1287 | "node-forge": "^1" 1288 | }, 1289 | "engines": { 1290 | "node": ">=10" 1291 | } 1292 | }, 1293 | "node_modules/semiver": { 1294 | "version": "1.1.0", 1295 | "resolved": "https://registry.npmjs.org/semiver/-/semiver-1.1.0.tgz", 1296 | "integrity": "sha512-QNI2ChmuioGC1/xjyYwyZYADILWyW6AmS1UH6gDj/SFUUUS4MBAWs/7mxnkRPc/F4iHezDP+O8t0dO8WHiEOdg==", 1297 | "dev": true, 1298 | "engines": { 1299 | "node": ">=6" 1300 | } 1301 | }, 1302 | "node_modules/semver": { 1303 | "version": "7.3.7", 1304 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz", 1305 | "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==", 1306 | "dev": true, 1307 | "dependencies": { 1308 | "lru-cache": "^6.0.0" 1309 | }, 1310 | "bin": { 1311 | "semver": "bin/semver.js" 1312 | }, 1313 | "engines": { 1314 | "node": ">=10" 1315 | } 1316 | }, 1317 | "node_modules/set-cookie-parser": { 1318 | "version": "2.5.1", 1319 | "resolved": "https://registry.npmjs.org/set-cookie-parser/-/set-cookie-parser-2.5.1.tgz", 1320 | "integrity": "sha512-1jeBGaKNGdEq4FgIrORu/N570dwoPYio8lSoYLWmX7sQ//0JY08Xh9o5pBcgmHQ/MbsYp/aZnOe1s1lIsbLprQ==", 1321 | "dev": true 1322 | }, 1323 | "node_modules/shebang-command": { 1324 | "version": "2.0.0", 1325 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1326 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1327 | "dev": true, 1328 | "dependencies": { 1329 | "shebang-regex": "^3.0.0" 1330 | }, 1331 | "engines": { 1332 | "node": ">=8" 1333 | } 1334 | }, 1335 | "node_modules/shebang-regex": { 1336 | "version": "3.0.0", 1337 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1338 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1339 | "dev": true, 1340 | "engines": { 1341 | "node": ">=8" 1342 | } 1343 | }, 1344 | "node_modules/signal-exit": { 1345 | "version": "3.0.7", 1346 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 1347 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 1348 | "dev": true 1349 | }, 1350 | "node_modules/source-map": { 1351 | "version": "0.7.4", 1352 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", 1353 | "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", 1354 | "dev": true, 1355 | "engines": { 1356 | "node": ">= 8" 1357 | } 1358 | }, 1359 | "node_modules/source-map-support": { 1360 | "version": "0.5.21", 1361 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 1362 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 1363 | "dev": true, 1364 | "dependencies": { 1365 | "buffer-from": "^1.0.0", 1366 | "source-map": "^0.6.0" 1367 | } 1368 | }, 1369 | "node_modules/source-map-support/node_modules/source-map": { 1370 | "version": "0.6.1", 1371 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1372 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1373 | "dev": true, 1374 | "engines": { 1375 | "node": ">=0.10.0" 1376 | } 1377 | }, 1378 | "node_modules/sourcemap-codec": { 1379 | "version": "1.4.8", 1380 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 1381 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 1382 | "dev": true 1383 | }, 1384 | "node_modules/stack-trace": { 1385 | "version": "0.0.10", 1386 | "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz", 1387 | "integrity": "sha512-KGzahc7puUKkzyMt+IqAep+TVNbKP+k2Lmwhub39m1AsTSkaDutx56aDCo+HLDzf/D26BIHTJWNiTG1KAJiQCg==", 1388 | "dev": true, 1389 | "engines": { 1390 | "node": "*" 1391 | } 1392 | }, 1393 | "node_modules/streamsearch": { 1394 | "version": "1.1.0", 1395 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", 1396 | "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", 1397 | "dev": true, 1398 | "engines": { 1399 | "node": ">=10.0.0" 1400 | } 1401 | }, 1402 | "node_modules/strip-final-newline": { 1403 | "version": "3.0.0", 1404 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-3.0.0.tgz", 1405 | "integrity": "sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==", 1406 | "dev": true, 1407 | "engines": { 1408 | "node": ">=12" 1409 | }, 1410 | "funding": { 1411 | "url": "https://github.com/sponsors/sindresorhus" 1412 | } 1413 | }, 1414 | "node_modules/to-regex-range": { 1415 | "version": "5.0.1", 1416 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1417 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1418 | "dev": true, 1419 | "dependencies": { 1420 | "is-number": "^7.0.0" 1421 | }, 1422 | "engines": { 1423 | "node": ">=8.0" 1424 | } 1425 | }, 1426 | "node_modules/typescript": { 1427 | "version": "4.8.3", 1428 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.8.3.tgz", 1429 | "integrity": "sha512-goMHfm00nWPa8UvR/CPSvykqf6dVV8x/dp0c5mFTMTIu0u0FlGWRioyy7Nn0PGAdHxpJZnuO/ut+PpQ8UiHAig==", 1430 | "dev": true, 1431 | "bin": { 1432 | "tsc": "bin/tsc", 1433 | "tsserver": "bin/tsserver" 1434 | }, 1435 | "engines": { 1436 | "node": ">=4.2.0" 1437 | } 1438 | }, 1439 | "node_modules/undici": { 1440 | "version": "5.9.1", 1441 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.9.1.tgz", 1442 | "integrity": "sha512-6fB3a+SNnWEm4CJbgo0/CWR8RGcOCQP68SF4X0mxtYTq2VNN8T88NYrWVBAeSX+zb7bny2dx2iYhP3XHi00omg==", 1443 | "dev": true, 1444 | "engines": { 1445 | "node": ">=12.18" 1446 | } 1447 | }, 1448 | "node_modules/urlpattern-polyfill": { 1449 | "version": "4.0.3", 1450 | "resolved": "https://registry.npmjs.org/urlpattern-polyfill/-/urlpattern-polyfill-4.0.3.tgz", 1451 | "integrity": "sha512-DOE84vZT2fEcl9gqCUTcnAw5ZY5Id55ikUcziSUntuEFL3pRvavg5kwDmTEUJkeCHInTlV/HexFomgYnzO5kdQ==", 1452 | "dev": true 1453 | }, 1454 | "node_modules/validate-npm-package-name": { 1455 | "version": "4.0.0", 1456 | "resolved": "https://registry.npmjs.org/validate-npm-package-name/-/validate-npm-package-name-4.0.0.tgz", 1457 | "integrity": "sha512-mzR0L8ZDktZjpX4OB46KT+56MAhl4EIazWP/+G/HPGuvfdaqg4YsCdtOm6U9+LOFyYDoh4dpnpxZRB9MQQns5Q==", 1458 | "dev": true, 1459 | "dependencies": { 1460 | "builtins": "^5.0.0" 1461 | }, 1462 | "engines": { 1463 | "node": "^12.13.0 || ^14.15.0 || >=16.0.0" 1464 | } 1465 | }, 1466 | "node_modules/which": { 1467 | "version": "2.0.2", 1468 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1469 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1470 | "dev": true, 1471 | "dependencies": { 1472 | "isexe": "^2.0.0" 1473 | }, 1474 | "bin": { 1475 | "node-which": "bin/node-which" 1476 | }, 1477 | "engines": { 1478 | "node": ">= 8" 1479 | } 1480 | }, 1481 | "node_modules/wrangler": { 1482 | "version": "2.0.29", 1483 | "resolved": "https://registry.npmjs.org/wrangler/-/wrangler-2.0.29.tgz", 1484 | "integrity": "sha512-Z9W48pRpo87qO2WLMU24TFLL5Oq2WUwzqlwVDFrnSpBT+7GRrkAceepKU8V+aOXxLqyUaEzaSVHT3KVPyXh8KQ==", 1485 | "dev": true, 1486 | "dependencies": { 1487 | "@cloudflare/kv-asset-handler": "^0.2.0", 1488 | "@esbuild-plugins/node-globals-polyfill": "^0.1.1", 1489 | "@esbuild-plugins/node-modules-polyfill": "^0.1.4", 1490 | "blake3-wasm": "^2.1.5", 1491 | "chokidar": "^3.5.3", 1492 | "esbuild": "0.14.51", 1493 | "miniflare": "^2.7.1", 1494 | "nanoid": "^3.3.3", 1495 | "path-to-regexp": "^6.2.0", 1496 | "selfsigned": "^2.0.1", 1497 | "source-map": "^0.7.4", 1498 | "xxhash-wasm": "^1.0.1" 1499 | }, 1500 | "bin": { 1501 | "wrangler": "bin/wrangler.js", 1502 | "wrangler2": "bin/wrangler.js" 1503 | }, 1504 | "engines": { 1505 | "node": ">=16.13.0" 1506 | }, 1507 | "optionalDependencies": { 1508 | "fsevents": "~2.3.2" 1509 | } 1510 | }, 1511 | "node_modules/ws": { 1512 | "version": "8.8.1", 1513 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.8.1.tgz", 1514 | "integrity": "sha512-bGy2JzvzkPowEJV++hF07hAD6niYSr0JzBNo/J29WsB57A2r7Wlc1UFcTR9IzrPvuNVO4B8LGqF8qcpsVOhJCA==", 1515 | "dev": true, 1516 | "engines": { 1517 | "node": ">=10.0.0" 1518 | }, 1519 | "peerDependencies": { 1520 | "bufferutil": "^4.0.1", 1521 | "utf-8-validate": "^5.0.2" 1522 | }, 1523 | "peerDependenciesMeta": { 1524 | "bufferutil": { 1525 | "optional": true 1526 | }, 1527 | "utf-8-validate": { 1528 | "optional": true 1529 | } 1530 | } 1531 | }, 1532 | "node_modules/xxhash-wasm": { 1533 | "version": "1.0.1", 1534 | "resolved": "https://registry.npmjs.org/xxhash-wasm/-/xxhash-wasm-1.0.1.tgz", 1535 | "integrity": "sha512-Lc9CTvDrH2vRoiaUzz25q7lRaviMhz90pkx6YxR9EPYtF99yOJnv2cB+CQ0hp/TLoqrUsk8z/W2EN31T568Azw==", 1536 | "dev": true 1537 | }, 1538 | "node_modules/yallist": { 1539 | "version": "4.0.0", 1540 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1541 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1542 | "dev": true 1543 | }, 1544 | "node_modules/youch": { 1545 | "version": "2.2.2", 1546 | "resolved": "https://registry.npmjs.org/youch/-/youch-2.2.2.tgz", 1547 | "integrity": "sha512-/FaCeG3GkuJwaMR34GHVg0l8jCbafZLHiFowSjqLlqhC6OMyf2tPJBu8UirF7/NI9X/R5ai4QfEKUCOxMAGxZQ==", 1548 | "dev": true, 1549 | "dependencies": { 1550 | "@types/stack-trace": "0.0.29", 1551 | "cookie": "^0.4.1", 1552 | "mustache": "^4.2.0", 1553 | "stack-trace": "0.0.10" 1554 | } 1555 | } 1556 | }, 1557 | "dependencies": { 1558 | "@cloudflare/kv-asset-handler": { 1559 | "version": "0.2.0", 1560 | "resolved": "https://registry.npmjs.org/@cloudflare/kv-asset-handler/-/kv-asset-handler-0.2.0.tgz", 1561 | "integrity": "sha512-MVbXLbTcAotOPUj0pAMhVtJ+3/kFkwJqc5qNOleOZTv6QkZZABDMS21dSrSlVswEHwrpWC03e4fWytjqKvuE2A==", 1562 | "dev": true, 1563 | "requires": { 1564 | "mime": "^3.0.0" 1565 | } 1566 | }, 1567 | "@cloudflare/workers-types": { 1568 | "version": "3.16.0", 1569 | "resolved": "https://registry.npmjs.org/@cloudflare/workers-types/-/workers-types-3.16.0.tgz", 1570 | "integrity": "sha512-gaBUSaKS65mN3iKZEgichbXYEmAa/pXkc5Gbt+1BptYphdGkj09ggdsiE4w8g0F/uI1g36QaTKrzVnBAWMipvQ==", 1571 | "dev": true 1572 | }, 1573 | "@esbuild-plugins/node-globals-polyfill": { 1574 | "version": "0.1.1", 1575 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-globals-polyfill/-/node-globals-polyfill-0.1.1.tgz", 1576 | "integrity": "sha512-MR0oAA+mlnJWrt1RQVQ+4VYuRJW/P2YmRTv1AsplObyvuBMnPHiizUF95HHYiSsMGLhyGtWufaq2XQg6+iurBg==", 1577 | "dev": true, 1578 | "requires": {} 1579 | }, 1580 | "@esbuild-plugins/node-modules-polyfill": { 1581 | "version": "0.1.4", 1582 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-modules-polyfill/-/node-modules-polyfill-0.1.4.tgz", 1583 | "integrity": "sha512-uZbcXi0zbmKC/050p3gJnne5Qdzw8vkXIv+c2BW0Lsc1ji1SkrxbKPUy5Efr0blbTu1SL8w4eyfpnSdPg3G0Qg==", 1584 | "dev": true, 1585 | "requires": { 1586 | "escape-string-regexp": "^4.0.0", 1587 | "rollup-plugin-node-polyfills": "^0.2.1" 1588 | } 1589 | }, 1590 | "@iarna/toml": { 1591 | "version": "2.2.5", 1592 | "resolved": "https://registry.npmjs.org/@iarna/toml/-/toml-2.2.5.tgz", 1593 | "integrity": "sha512-trnsAYxU3xnS1gPHPyU961coFyLkh4gAD/0zQ5mymY4yOZ+CYvsPqUbOFSw0aDM4y0tV7tiFxL/1XfXPNC6IPg==", 1594 | "dev": true 1595 | }, 1596 | "@miniflare/cache": { 1597 | "version": "2.9.0", 1598 | "resolved": "https://registry.npmjs.org/@miniflare/cache/-/cache-2.9.0.tgz", 1599 | "integrity": "sha512-lriPxUEva9TJ01vU9P7pI60s3SsFnb4apWkNwZ+D7CRqyXPipSbapY8BWI2FUIwkEG7xap6UhzeTS76NettCXQ==", 1600 | "dev": true, 1601 | "requires": { 1602 | "@miniflare/core": "2.9.0", 1603 | "@miniflare/shared": "2.9.0", 1604 | "http-cache-semantics": "^4.1.0", 1605 | "undici": "5.9.1" 1606 | } 1607 | }, 1608 | "@miniflare/cli-parser": { 1609 | "version": "2.9.0", 1610 | "resolved": "https://registry.npmjs.org/@miniflare/cli-parser/-/cli-parser-2.9.0.tgz", 1611 | "integrity": "sha512-gu8Z7NWNcYw6514/yOvajaj3GmebRucx+EEt3p1vKirO+gvFgKAt/puyUN3p7u8ZZmLuLF/B+wVnH3lj8BWKlg==", 1612 | "dev": true, 1613 | "requires": { 1614 | "@miniflare/shared": "2.9.0", 1615 | "kleur": "^4.1.4" 1616 | } 1617 | }, 1618 | "@miniflare/core": { 1619 | "version": "2.9.0", 1620 | "resolved": "https://registry.npmjs.org/@miniflare/core/-/core-2.9.0.tgz", 1621 | "integrity": "sha512-QqSwF6oHvgrFvN5lnrLc6EEagFlZWW+UMU8QdrE8305cNGHrIOxKCA2nte4PVFZUVw/Ts13a0tVhUk3a2fAyxQ==", 1622 | "dev": true, 1623 | "requires": { 1624 | "@iarna/toml": "^2.2.5", 1625 | "@miniflare/queues": "2.9.0", 1626 | "@miniflare/shared": "2.9.0", 1627 | "@miniflare/watcher": "2.9.0", 1628 | "busboy": "^1.6.0", 1629 | "dotenv": "^10.0.0", 1630 | "kleur": "^4.1.4", 1631 | "set-cookie-parser": "^2.4.8", 1632 | "undici": "5.9.1", 1633 | "urlpattern-polyfill": "^4.0.3" 1634 | } 1635 | }, 1636 | "@miniflare/d1": { 1637 | "version": "2.9.0", 1638 | "resolved": "https://registry.npmjs.org/@miniflare/d1/-/d1-2.9.0.tgz", 1639 | "integrity": "sha512-swK9nzxw1SvVh/4cH3bRR1SBuHQU/YsB8WvuHojxufmgviAD1xhms3XO3rkpAzfKoGM5Oy6DovMe0xUXV/GS0w==", 1640 | "dev": true, 1641 | "requires": { 1642 | "@miniflare/core": "2.9.0", 1643 | "@miniflare/shared": "2.9.0" 1644 | } 1645 | }, 1646 | "@miniflare/durable-objects": { 1647 | "version": "2.9.0", 1648 | "resolved": "https://registry.npmjs.org/@miniflare/durable-objects/-/durable-objects-2.9.0.tgz", 1649 | "integrity": "sha512-7uTvfEUXS7xqwrsWOwWrFUuKc4EiMpVkAWPeYGLB/0TJaJ6N+sZMpYYymdW79TQwPIDfgtpfkIy93MRydqpnrw==", 1650 | "dev": true, 1651 | "requires": { 1652 | "@miniflare/core": "2.9.0", 1653 | "@miniflare/shared": "2.9.0", 1654 | "@miniflare/storage-memory": "2.9.0", 1655 | "undici": "5.9.1" 1656 | } 1657 | }, 1658 | "@miniflare/html-rewriter": { 1659 | "version": "2.9.0", 1660 | "resolved": "https://registry.npmjs.org/@miniflare/html-rewriter/-/html-rewriter-2.9.0.tgz", 1661 | "integrity": "sha512-K5OB70PtkMo7M+tU46s/cX/j/qtjD9AlJ0hecYswrxVsfrT/YWyrCQJevmShFfJ92h7jPNigbeC3Od3JiVb6QA==", 1662 | "dev": true, 1663 | "requires": { 1664 | "@miniflare/core": "2.9.0", 1665 | "@miniflare/shared": "2.9.0", 1666 | "html-rewriter-wasm": "^0.4.1", 1667 | "undici": "5.9.1" 1668 | } 1669 | }, 1670 | "@miniflare/http-server": { 1671 | "version": "2.9.0", 1672 | "resolved": "https://registry.npmjs.org/@miniflare/http-server/-/http-server-2.9.0.tgz", 1673 | "integrity": "sha512-IVJMkFfMpecq9WiCTvATEKhMuKPK9fMs2E6zmgexaefr3u1VlNtj2QxBxoPUXkT9xMJQlT5sSKstlRR1XKDz9Q==", 1674 | "dev": true, 1675 | "requires": { 1676 | "@miniflare/core": "2.9.0", 1677 | "@miniflare/shared": "2.9.0", 1678 | "@miniflare/web-sockets": "2.9.0", 1679 | "kleur": "^4.1.4", 1680 | "selfsigned": "^2.0.0", 1681 | "undici": "5.9.1", 1682 | "ws": "^8.2.2", 1683 | "youch": "^2.2.2" 1684 | } 1685 | }, 1686 | "@miniflare/kv": { 1687 | "version": "2.9.0", 1688 | "resolved": "https://registry.npmjs.org/@miniflare/kv/-/kv-2.9.0.tgz", 1689 | "integrity": "sha512-EqG51okY5rDtgjYs2Ny6j6IUVdTlJzDjwBKBIuW+wOV9NsAAzEchKVdYAXc8CyxvkggpYX481HydTD2OzK3INQ==", 1690 | "dev": true, 1691 | "requires": { 1692 | "@miniflare/shared": "2.9.0" 1693 | } 1694 | }, 1695 | "@miniflare/queues": { 1696 | "version": "2.9.0", 1697 | "resolved": "https://registry.npmjs.org/@miniflare/queues/-/queues-2.9.0.tgz", 1698 | "integrity": "sha512-cAHWIlLF57rxQaJl19AzXw1k0SOM/uLTlx8r2PylHajZ/RRSs7CkCox3oKA6E5zKyfyxk2M64bmsAFZ9RCA0gw==", 1699 | "dev": true, 1700 | "requires": { 1701 | "@miniflare/shared": "2.9.0" 1702 | } 1703 | }, 1704 | "@miniflare/r2": { 1705 | "version": "2.9.0", 1706 | "resolved": "https://registry.npmjs.org/@miniflare/r2/-/r2-2.9.0.tgz", 1707 | "integrity": "sha512-aMFWxxciAE3YsVok2OLy3A7hP5+2j/NaK7txmadgoe1CA8HYZyNuvv7v6bn8HKM5gWnJdT8sk4yEbMbBQ7Jv/A==", 1708 | "dev": true, 1709 | "requires": { 1710 | "@miniflare/shared": "2.9.0", 1711 | "undici": "5.9.1" 1712 | } 1713 | }, 1714 | "@miniflare/runner-vm": { 1715 | "version": "2.9.0", 1716 | "resolved": "https://registry.npmjs.org/@miniflare/runner-vm/-/runner-vm-2.9.0.tgz", 1717 | "integrity": "sha512-vewP+Fy7Czb261GmB9x/YtQkoDs/QP9B5LbP0YfJ35bI2C2j940eJLm8JP72IHV7ILtWNOqMc3Ure8uAbpf9NQ==", 1718 | "dev": true, 1719 | "requires": { 1720 | "@miniflare/shared": "2.9.0" 1721 | } 1722 | }, 1723 | "@miniflare/scheduler": { 1724 | "version": "2.9.0", 1725 | "resolved": "https://registry.npmjs.org/@miniflare/scheduler/-/scheduler-2.9.0.tgz", 1726 | "integrity": "sha512-eodSCGkJYi4Z+Imbx/bNScDfDSt5HOypVSYjbFHj+hA2aNOdkGw6a1b6mzwx49jJD3GadIkonZAKD0S114yWMA==", 1727 | "dev": true, 1728 | "requires": { 1729 | "@miniflare/core": "2.9.0", 1730 | "@miniflare/shared": "2.9.0", 1731 | "cron-schedule": "^3.0.4" 1732 | } 1733 | }, 1734 | "@miniflare/shared": { 1735 | "version": "2.9.0", 1736 | "resolved": "https://registry.npmjs.org/@miniflare/shared/-/shared-2.9.0.tgz", 1737 | "integrity": "sha512-5Ew/Ph0cHDQqKvOlmN70kz+qZW0hdgE9fQBStKLY3vDYhnBEhopbCUChSS+FCcL7WtxVJJVE7iB6J09NQTnQ/A==", 1738 | "dev": true, 1739 | "requires": { 1740 | "@types/better-sqlite3": "^7.6.0", 1741 | "kleur": "^4.1.4", 1742 | "npx-import": "^1.1.3", 1743 | "picomatch": "^2.3.1" 1744 | } 1745 | }, 1746 | "@miniflare/sites": { 1747 | "version": "2.9.0", 1748 | "resolved": "https://registry.npmjs.org/@miniflare/sites/-/sites-2.9.0.tgz", 1749 | "integrity": "sha512-+tWf7znxSQqXWGzPup8Xqkl8EmLmx+HaLC+UBtWPNnaJZrsjbbVxKwHpmGIdm+wZasEGfQk/82R21gUs9wdZnw==", 1750 | "dev": true, 1751 | "requires": { 1752 | "@miniflare/kv": "2.9.0", 1753 | "@miniflare/shared": "2.9.0", 1754 | "@miniflare/storage-file": "2.9.0" 1755 | } 1756 | }, 1757 | "@miniflare/storage-file": { 1758 | "version": "2.9.0", 1759 | "resolved": "https://registry.npmjs.org/@miniflare/storage-file/-/storage-file-2.9.0.tgz", 1760 | "integrity": "sha512-HZHtHfJaLoDzQFddoIMcDGgAJ3/Nee98gwUYusQam7rj9pbEXnWmk54dzjzsDlkQpB/3MBFQNbtN5Bj1NIt0pg==", 1761 | "dev": true, 1762 | "requires": { 1763 | "@miniflare/shared": "2.9.0", 1764 | "@miniflare/storage-memory": "2.9.0" 1765 | } 1766 | }, 1767 | "@miniflare/storage-memory": { 1768 | "version": "2.9.0", 1769 | "resolved": "https://registry.npmjs.org/@miniflare/storage-memory/-/storage-memory-2.9.0.tgz", 1770 | "integrity": "sha512-p2yrr0omQhv6teDbdzhdBKzoQAFmUBMLEx+PtrO7CJHX15ICD08/pFAFAp96IcljNwZZDchU20Z3AcbldMj6Tw==", 1771 | "dev": true, 1772 | "requires": { 1773 | "@miniflare/shared": "2.9.0" 1774 | } 1775 | }, 1776 | "@miniflare/watcher": { 1777 | "version": "2.9.0", 1778 | "resolved": "https://registry.npmjs.org/@miniflare/watcher/-/watcher-2.9.0.tgz", 1779 | "integrity": "sha512-Yqz8Q1He/2chebXvmCft8sMamuUiDQ4FIn0bwiF0+GBP2vvGCmy6SejXZY4ZD4REluPqQSis3CLKcIOWlHnIsw==", 1780 | "dev": true, 1781 | "requires": { 1782 | "@miniflare/shared": "2.9.0" 1783 | } 1784 | }, 1785 | "@miniflare/web-sockets": { 1786 | "version": "2.9.0", 1787 | "resolved": "https://registry.npmjs.org/@miniflare/web-sockets/-/web-sockets-2.9.0.tgz", 1788 | "integrity": "sha512-Nob9e84m78qeQCka6OQf/JdNOmMkKCkX+i3rg+TYKSSITiMVuyzWp3vz3Ma184lAZiLg44lxBF4ZzENEdi99Kg==", 1789 | "dev": true, 1790 | "requires": { 1791 | "@miniflare/core": "2.9.0", 1792 | "@miniflare/shared": "2.9.0", 1793 | "undici": "5.9.1", 1794 | "ws": "^8.2.2" 1795 | } 1796 | }, 1797 | "@types/better-sqlite3": { 1798 | "version": "7.6.0", 1799 | "resolved": "https://registry.npmjs.org/@types/better-sqlite3/-/better-sqlite3-7.6.0.tgz", 1800 | "integrity": "sha512-rnSP9vY+fVsF3iJja5yRGBJV63PNBiezJlYrCkqUmQWFoB16cxAHwOkjsAYEu317miOfKaJpa65cbp0P4XJ/jw==", 1801 | "dev": true, 1802 | "requires": { 1803 | "@types/node": "*" 1804 | } 1805 | }, 1806 | "@types/cookie": { 1807 | "version": "0.5.1", 1808 | "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.5.1.tgz", 1809 | "integrity": "sha512-COUnqfB2+ckwXXSFInsFdOAWQzCCx+a5hq2ruyj+Vjund94RJQd4LG2u9hnvJrTgunKAaax7ancBYlDrNYxA0g==", 1810 | "dev": true 1811 | }, 1812 | "@types/node": { 1813 | "version": "18.7.18", 1814 | "resolved": "https://registry.npmjs.org/@types/node/-/node-18.7.18.tgz", 1815 | "integrity": "sha512-m+6nTEOadJZuTPkKR/SYK3A2d7FZrgElol9UP1Kae90VVU4a6mxnPuLiIW1m4Cq4gZ/nWb9GrdVXJCoCazDAbg==", 1816 | "dev": true 1817 | }, 1818 | "@types/stack-trace": { 1819 | "version": "0.0.29", 1820 | "resolved": "https://registry.npmjs.org/@types/stack-trace/-/stack-trace-0.0.29.tgz", 1821 | "integrity": "sha512-TgfOX+mGY/NyNxJLIbDWrO9DjGoVSW9+aB8H2yy1fy32jsvxijhmyJI9fDFgvz3YP4lvJaq9DzdR/M1bOgVc9g==", 1822 | "dev": true 1823 | }, 1824 | "anymatch": { 1825 | "version": "3.1.2", 1826 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 1827 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 1828 | "dev": true, 1829 | "requires": { 1830 | "normalize-path": "^3.0.0", 1831 | "picomatch": "^2.0.4" 1832 | } 1833 | }, 1834 | "binary-extensions": { 1835 | "version": "2.2.0", 1836 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 1837 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 1838 | "dev": true 1839 | }, 1840 | "blake3-wasm": { 1841 | "version": "2.1.5", 1842 | "resolved": "https://registry.npmjs.org/blake3-wasm/-/blake3-wasm-2.1.5.tgz", 1843 | "integrity": "sha512-F1+K8EbfOZE49dtoPtmxUQrpXaBIl3ICvasLh+nJta0xkz+9kF/7uet9fLnwKqhDrmj6g+6K3Tw9yQPUg2ka5g==", 1844 | "dev": true 1845 | }, 1846 | "braces": { 1847 | "version": "3.0.2", 1848 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1849 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1850 | "dev": true, 1851 | "requires": { 1852 | "fill-range": "^7.0.1" 1853 | } 1854 | }, 1855 | "buffer-from": { 1856 | "version": "1.1.2", 1857 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 1858 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 1859 | "dev": true 1860 | }, 1861 | "builtins": { 1862 | "version": "5.0.1", 1863 | "resolved": "https://registry.npmjs.org/builtins/-/builtins-5.0.1.tgz", 1864 | "integrity": "sha512-qwVpFEHNfhYJIzNRBvd2C1kyo6jz3ZSMPyyuR47OPdiKWlbYnZNyDWuyR175qDnAJLiCo5fBBqPb3RiXgWlkOQ==", 1865 | "dev": true, 1866 | "requires": { 1867 | "semver": "^7.0.0" 1868 | } 1869 | }, 1870 | "busboy": { 1871 | "version": "1.6.0", 1872 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", 1873 | "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", 1874 | "dev": true, 1875 | "requires": { 1876 | "streamsearch": "^1.1.0" 1877 | } 1878 | }, 1879 | "chokidar": { 1880 | "version": "3.5.3", 1881 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 1882 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 1883 | "dev": true, 1884 | "requires": { 1885 | "anymatch": "~3.1.2", 1886 | "braces": "~3.0.2", 1887 | "fsevents": "~2.3.2", 1888 | "glob-parent": "~5.1.2", 1889 | "is-binary-path": "~2.1.0", 1890 | "is-glob": "~4.0.1", 1891 | "normalize-path": "~3.0.0", 1892 | "readdirp": "~3.6.0" 1893 | } 1894 | }, 1895 | "cookie": { 1896 | "version": "0.4.2", 1897 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz", 1898 | "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==", 1899 | "dev": true 1900 | }, 1901 | "cron-schedule": { 1902 | "version": "3.0.6", 1903 | "resolved": "https://registry.npmjs.org/cron-schedule/-/cron-schedule-3.0.6.tgz", 1904 | "integrity": "sha512-izfGgKyzzIyLaeb1EtZ3KbglkS6AKp9cv7LxmiyoOu+fXfol1tQDC0Cof0enVZGNtudTHW+3lfuW9ZkLQss4Wg==", 1905 | "dev": true 1906 | }, 1907 | "cross-spawn": { 1908 | "version": "7.0.3", 1909 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1910 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1911 | "dev": true, 1912 | "requires": { 1913 | "path-key": "^3.1.0", 1914 | "shebang-command": "^2.0.0", 1915 | "which": "^2.0.1" 1916 | } 1917 | }, 1918 | "dotenv": { 1919 | "version": "10.0.0", 1920 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-10.0.0.tgz", 1921 | "integrity": "sha512-rlBi9d8jpv9Sf1klPjNfFAuWDjKLwTIJJ/VxtoTwIR6hnZxcEOQCZg2oIL3MWBYw5GpUDKOEnND7LXTbIpQ03Q==", 1922 | "dev": true 1923 | }, 1924 | "esbuild": { 1925 | "version": "0.14.51", 1926 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.14.51.tgz", 1927 | "integrity": "sha512-+CvnDitD7Q5sT7F+FM65sWkF8wJRf+j9fPcprxYV4j+ohmzVj2W7caUqH2s5kCaCJAfcAICjSlKhDCcvDpU7nw==", 1928 | "dev": true, 1929 | "requires": { 1930 | "esbuild-android-64": "0.14.51", 1931 | "esbuild-android-arm64": "0.14.51", 1932 | "esbuild-darwin-64": "0.14.51", 1933 | "esbuild-darwin-arm64": "0.14.51", 1934 | "esbuild-freebsd-64": "0.14.51", 1935 | "esbuild-freebsd-arm64": "0.14.51", 1936 | "esbuild-linux-32": "0.14.51", 1937 | "esbuild-linux-64": "0.14.51", 1938 | "esbuild-linux-arm": "0.14.51", 1939 | "esbuild-linux-arm64": "0.14.51", 1940 | "esbuild-linux-mips64le": "0.14.51", 1941 | "esbuild-linux-ppc64le": "0.14.51", 1942 | "esbuild-linux-riscv64": "0.14.51", 1943 | "esbuild-linux-s390x": "0.14.51", 1944 | "esbuild-netbsd-64": "0.14.51", 1945 | "esbuild-openbsd-64": "0.14.51", 1946 | "esbuild-sunos-64": "0.14.51", 1947 | "esbuild-windows-32": "0.14.51", 1948 | "esbuild-windows-64": "0.14.51", 1949 | "esbuild-windows-arm64": "0.14.51" 1950 | } 1951 | }, 1952 | "esbuild-android-64": { 1953 | "version": "0.14.51", 1954 | "resolved": "https://registry.npmjs.org/esbuild-android-64/-/esbuild-android-64-0.14.51.tgz", 1955 | "integrity": "sha512-6FOuKTHnC86dtrKDmdSj2CkcKF8PnqkaIXqvgydqfJmqBazCPdw+relrMlhGjkvVdiiGV70rpdnyFmA65ekBCQ==", 1956 | "dev": true, 1957 | "optional": true 1958 | }, 1959 | "esbuild-android-arm64": { 1960 | "version": "0.14.51", 1961 | "resolved": "https://registry.npmjs.org/esbuild-android-arm64/-/esbuild-android-arm64-0.14.51.tgz", 1962 | "integrity": "sha512-vBtp//5VVkZWmYYvHsqBRCMMi1MzKuMIn5XDScmnykMTu9+TD9v0NMEDqQxvtFToeYmojdo5UCV2vzMQWJcJ4A==", 1963 | "dev": true, 1964 | "optional": true 1965 | }, 1966 | "esbuild-darwin-64": { 1967 | "version": "0.14.51", 1968 | "resolved": "https://registry.npmjs.org/esbuild-darwin-64/-/esbuild-darwin-64-0.14.51.tgz", 1969 | "integrity": "sha512-YFmXPIOvuagDcwCejMRtCDjgPfnDu+bNeh5FU2Ryi68ADDVlWEpbtpAbrtf/lvFTWPexbgyKgzppNgsmLPr8PA==", 1970 | "dev": true, 1971 | "optional": true 1972 | }, 1973 | "esbuild-darwin-arm64": { 1974 | "version": "0.14.51", 1975 | "resolved": "https://registry.npmjs.org/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.14.51.tgz", 1976 | "integrity": "sha512-juYD0QnSKwAMfzwKdIF6YbueXzS6N7y4GXPDeDkApz/1RzlT42mvX9jgNmyOlWKN7YzQAYbcUEJmZJYQGdf2ow==", 1977 | "dev": true, 1978 | "optional": true 1979 | }, 1980 | "esbuild-freebsd-64": { 1981 | "version": "0.14.51", 1982 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-64/-/esbuild-freebsd-64-0.14.51.tgz", 1983 | "integrity": "sha512-cLEI/aXjb6vo5O2Y8rvVSQ7smgLldwYY5xMxqh/dQGfWO+R1NJOFsiax3IS4Ng300SVp7Gz3czxT6d6qf2cw0g==", 1984 | "dev": true, 1985 | "optional": true 1986 | }, 1987 | "esbuild-freebsd-arm64": { 1988 | "version": "0.14.51", 1989 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.14.51.tgz", 1990 | "integrity": "sha512-TcWVw/rCL2F+jUgRkgLa3qltd5gzKjIMGhkVybkjk6PJadYInPtgtUBp1/hG+mxyigaT7ib+od1Xb84b+L+1Mg==", 1991 | "dev": true, 1992 | "optional": true 1993 | }, 1994 | "esbuild-linux-32": { 1995 | "version": "0.14.51", 1996 | "resolved": "https://registry.npmjs.org/esbuild-linux-32/-/esbuild-linux-32-0.14.51.tgz", 1997 | "integrity": "sha512-RFqpyC5ChyWrjx8Xj2K0EC1aN0A37H6OJfmUXIASEqJoHcntuV3j2Efr9RNmUhMfNE6yEj2VpYuDteZLGDMr0w==", 1998 | "dev": true, 1999 | "optional": true 2000 | }, 2001 | "esbuild-linux-64": { 2002 | "version": "0.14.51", 2003 | "resolved": "https://registry.npmjs.org/esbuild-linux-64/-/esbuild-linux-64-0.14.51.tgz", 2004 | "integrity": "sha512-dxjhrqo5i7Rq6DXwz5v+MEHVs9VNFItJmHBe1CxROWNf4miOGoQhqSG8StStbDkQ1Mtobg6ng+4fwByOhoQoeA==", 2005 | "dev": true, 2006 | "optional": true 2007 | }, 2008 | "esbuild-linux-arm": { 2009 | "version": "0.14.51", 2010 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm/-/esbuild-linux-arm-0.14.51.tgz", 2011 | "integrity": "sha512-LsJynDxYF6Neg7ZC7748yweCDD+N8ByCv22/7IAZglIEniEkqdF4HCaa49JNDLw1UQGlYuhOB8ZT/MmcSWzcWg==", 2012 | "dev": true, 2013 | "optional": true 2014 | }, 2015 | "esbuild-linux-arm64": { 2016 | "version": "0.14.51", 2017 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm64/-/esbuild-linux-arm64-0.14.51.tgz", 2018 | "integrity": "sha512-D9rFxGutoqQX3xJPxqd6o+kvYKeIbM0ifW2y0bgKk5HPgQQOo2k9/2Vpto3ybGYaFPCE5qTGtqQta9PoP6ZEzw==", 2019 | "dev": true, 2020 | "optional": true 2021 | }, 2022 | "esbuild-linux-mips64le": { 2023 | "version": "0.14.51", 2024 | "resolved": "https://registry.npmjs.org/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.14.51.tgz", 2025 | "integrity": "sha512-vS54wQjy4IinLSlb5EIlLoln8buh1yDgliP4CuEHumrPk4PvvP4kTRIG4SzMXm6t19N0rIfT4bNdAxzJLg2k6A==", 2026 | "dev": true, 2027 | "optional": true 2028 | }, 2029 | "esbuild-linux-ppc64le": { 2030 | "version": "0.14.51", 2031 | "resolved": "https://registry.npmjs.org/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.14.51.tgz", 2032 | "integrity": "sha512-xcdd62Y3VfGoyphNP/aIV9LP+RzFw5M5Z7ja+zdpQHHvokJM7d0rlDRMN+iSSwvUymQkqZO+G/xjb4/75du8BQ==", 2033 | "dev": true, 2034 | "optional": true 2035 | }, 2036 | "esbuild-linux-riscv64": { 2037 | "version": "0.14.51", 2038 | "resolved": "https://registry.npmjs.org/esbuild-linux-riscv64/-/esbuild-linux-riscv64-0.14.51.tgz", 2039 | "integrity": "sha512-syXHGak9wkAnFz0gMmRBoy44JV0rp4kVCEA36P5MCeZcxFq8+fllBC2t6sKI23w3qd8Vwo9pTADCgjTSf3L3rA==", 2040 | "dev": true, 2041 | "optional": true 2042 | }, 2043 | "esbuild-linux-s390x": { 2044 | "version": "0.14.51", 2045 | "resolved": "https://registry.npmjs.org/esbuild-linux-s390x/-/esbuild-linux-s390x-0.14.51.tgz", 2046 | "integrity": "sha512-kFAJY3dv+Wq8o28K/C7xkZk/X34rgTwhknSsElIqoEo8armCOjMJ6NsMxm48KaWY2h2RUYGtQmr+RGuUPKBhyw==", 2047 | "dev": true, 2048 | "optional": true 2049 | }, 2050 | "esbuild-netbsd-64": { 2051 | "version": "0.14.51", 2052 | "resolved": "https://registry.npmjs.org/esbuild-netbsd-64/-/esbuild-netbsd-64-0.14.51.tgz", 2053 | "integrity": "sha512-ZZBI7qrR1FevdPBVHz/1GSk1x5GDL/iy42Zy8+neEm/HA7ma+hH/bwPEjeHXKWUDvM36CZpSL/fn1/y9/Hb+1A==", 2054 | "dev": true, 2055 | "optional": true 2056 | }, 2057 | "esbuild-openbsd-64": { 2058 | "version": "0.14.51", 2059 | "resolved": "https://registry.npmjs.org/esbuild-openbsd-64/-/esbuild-openbsd-64-0.14.51.tgz", 2060 | "integrity": "sha512-7R1/p39M+LSVQVgDVlcY1KKm6kFKjERSX1lipMG51NPcspJD1tmiZSmmBXoY5jhHIu6JL1QkFDTx94gMYK6vfA==", 2061 | "dev": true, 2062 | "optional": true 2063 | }, 2064 | "esbuild-sunos-64": { 2065 | "version": "0.14.51", 2066 | "resolved": "https://registry.npmjs.org/esbuild-sunos-64/-/esbuild-sunos-64-0.14.51.tgz", 2067 | "integrity": "sha512-HoHaCswHxLEYN8eBTtyO0bFEWvA3Kdb++hSQ/lLG7TyKF69TeSG0RNoBRAs45x/oCeWaTDntEZlYwAfQlhEtJA==", 2068 | "dev": true, 2069 | "optional": true 2070 | }, 2071 | "esbuild-windows-32": { 2072 | "version": "0.14.51", 2073 | "resolved": "https://registry.npmjs.org/esbuild-windows-32/-/esbuild-windows-32-0.14.51.tgz", 2074 | "integrity": "sha512-4rtwSAM35A07CBt1/X8RWieDj3ZUHQqUOaEo5ZBs69rt5WAFjP4aqCIobdqOy4FdhYw1yF8Z0xFBTyc9lgPtEg==", 2075 | "dev": true, 2076 | "optional": true 2077 | }, 2078 | "esbuild-windows-64": { 2079 | "version": "0.14.51", 2080 | "resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.14.51.tgz", 2081 | "integrity": "sha512-HoN/5HGRXJpWODprGCgKbdMvrC3A2gqvzewu2eECRw2sYxOUoh2TV1tS+G7bHNapPGI79woQJGV6pFH7GH7qnA==", 2082 | "dev": true, 2083 | "optional": true 2084 | }, 2085 | "esbuild-windows-arm64": { 2086 | "version": "0.14.51", 2087 | "resolved": "https://registry.npmjs.org/esbuild-windows-arm64/-/esbuild-windows-arm64-0.14.51.tgz", 2088 | "integrity": "sha512-JQDqPjuOH7o+BsKMSddMfmVJXrnYZxXDHsoLHc0xgmAZkOOCflRmC43q31pk79F9xuyWY45jDBPolb5ZgGOf9g==", 2089 | "dev": true, 2090 | "optional": true 2091 | }, 2092 | "escape-string-regexp": { 2093 | "version": "4.0.0", 2094 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2095 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2096 | "dev": true 2097 | }, 2098 | "estree-walker": { 2099 | "version": "0.6.1", 2100 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", 2101 | "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", 2102 | "dev": true 2103 | }, 2104 | "execa": { 2105 | "version": "6.1.0", 2106 | "resolved": "https://registry.npmjs.org/execa/-/execa-6.1.0.tgz", 2107 | "integrity": "sha512-QVWlX2e50heYJcCPG0iWtf8r0xjEYfz/OYLGDYH+IyjWezzPNxz63qNFOu0l4YftGWuizFVZHHs8PrLU5p2IDA==", 2108 | "dev": true, 2109 | "requires": { 2110 | "cross-spawn": "^7.0.3", 2111 | "get-stream": "^6.0.1", 2112 | "human-signals": "^3.0.1", 2113 | "is-stream": "^3.0.0", 2114 | "merge-stream": "^2.0.0", 2115 | "npm-run-path": "^5.1.0", 2116 | "onetime": "^6.0.0", 2117 | "signal-exit": "^3.0.7", 2118 | "strip-final-newline": "^3.0.0" 2119 | } 2120 | }, 2121 | "fill-range": { 2122 | "version": "7.0.1", 2123 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2124 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2125 | "dev": true, 2126 | "requires": { 2127 | "to-regex-range": "^5.0.1" 2128 | } 2129 | }, 2130 | "fsevents": { 2131 | "version": "2.3.2", 2132 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2133 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2134 | "dev": true, 2135 | "optional": true 2136 | }, 2137 | "get-stream": { 2138 | "version": "6.0.1", 2139 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 2140 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 2141 | "dev": true 2142 | }, 2143 | "glob-parent": { 2144 | "version": "5.1.2", 2145 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2146 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2147 | "dev": true, 2148 | "requires": { 2149 | "is-glob": "^4.0.1" 2150 | } 2151 | }, 2152 | "html-rewriter-wasm": { 2153 | "version": "0.4.1", 2154 | "resolved": "https://registry.npmjs.org/html-rewriter-wasm/-/html-rewriter-wasm-0.4.1.tgz", 2155 | "integrity": "sha512-lNovG8CMCCmcVB1Q7xggMSf7tqPCijZXaH4gL6iE8BFghdQCbaY5Met9i1x2Ex8m/cZHDUtXK9H6/znKamRP8Q==", 2156 | "dev": true 2157 | }, 2158 | "http-cache-semantics": { 2159 | "version": "4.1.0", 2160 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 2161 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==", 2162 | "dev": true 2163 | }, 2164 | "human-signals": { 2165 | "version": "3.0.1", 2166 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-3.0.1.tgz", 2167 | "integrity": "sha512-rQLskxnM/5OCldHo+wNXbpVgDn5A17CUoKX+7Sokwaknlq7CdSnphy0W39GU8dw59XiCXmFXDg4fRuckQRKewQ==", 2168 | "dev": true 2169 | }, 2170 | "is-binary-path": { 2171 | "version": "2.1.0", 2172 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2173 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2174 | "dev": true, 2175 | "requires": { 2176 | "binary-extensions": "^2.0.0" 2177 | } 2178 | }, 2179 | "is-extglob": { 2180 | "version": "2.1.1", 2181 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2182 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2183 | "dev": true 2184 | }, 2185 | "is-glob": { 2186 | "version": "4.0.3", 2187 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2188 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2189 | "dev": true, 2190 | "requires": { 2191 | "is-extglob": "^2.1.1" 2192 | } 2193 | }, 2194 | "is-number": { 2195 | "version": "7.0.0", 2196 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2197 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2198 | "dev": true 2199 | }, 2200 | "is-stream": { 2201 | "version": "3.0.0", 2202 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-3.0.0.tgz", 2203 | "integrity": "sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==", 2204 | "dev": true 2205 | }, 2206 | "isexe": { 2207 | "version": "2.0.0", 2208 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2209 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2210 | "dev": true 2211 | }, 2212 | "kleur": { 2213 | "version": "4.1.5", 2214 | "resolved": "https://registry.npmjs.org/kleur/-/kleur-4.1.5.tgz", 2215 | "integrity": "sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ==", 2216 | "dev": true 2217 | }, 2218 | "lru-cache": { 2219 | "version": "6.0.0", 2220 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2221 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2222 | "dev": true, 2223 | "requires": { 2224 | "yallist": "^4.0.0" 2225 | } 2226 | }, 2227 | "magic-string": { 2228 | "version": "0.25.9", 2229 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz", 2230 | "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==", 2231 | "dev": true, 2232 | "requires": { 2233 | "sourcemap-codec": "^1.4.8" 2234 | } 2235 | }, 2236 | "merge-stream": { 2237 | "version": "2.0.0", 2238 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 2239 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 2240 | "dev": true 2241 | }, 2242 | "mime": { 2243 | "version": "3.0.0", 2244 | "resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz", 2245 | "integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==", 2246 | "dev": true 2247 | }, 2248 | "mimic-fn": { 2249 | "version": "4.0.0", 2250 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", 2251 | "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==", 2252 | "dev": true 2253 | }, 2254 | "miniflare": { 2255 | "version": "2.9.0", 2256 | "resolved": "https://registry.npmjs.org/miniflare/-/miniflare-2.9.0.tgz", 2257 | "integrity": "sha512-HBGQ5Jj6sMU1B1hX6G3ML46ThtUvu1nvxgXjDDmhp2RhWKYj0XvcohW/nPPL/MTP1gpvfT880De9EHmobVsDsw==", 2258 | "dev": true, 2259 | "requires": { 2260 | "@miniflare/cache": "2.9.0", 2261 | "@miniflare/cli-parser": "2.9.0", 2262 | "@miniflare/core": "2.9.0", 2263 | "@miniflare/d1": "2.9.0", 2264 | "@miniflare/durable-objects": "2.9.0", 2265 | "@miniflare/html-rewriter": "2.9.0", 2266 | "@miniflare/http-server": "2.9.0", 2267 | "@miniflare/kv": "2.9.0", 2268 | "@miniflare/queues": "2.9.0", 2269 | "@miniflare/r2": "2.9.0", 2270 | "@miniflare/runner-vm": "2.9.0", 2271 | "@miniflare/scheduler": "2.9.0", 2272 | "@miniflare/shared": "2.9.0", 2273 | "@miniflare/sites": "2.9.0", 2274 | "@miniflare/storage-file": "2.9.0", 2275 | "@miniflare/storage-memory": "2.9.0", 2276 | "@miniflare/web-sockets": "2.9.0", 2277 | "kleur": "^4.1.4", 2278 | "semiver": "^1.1.0", 2279 | "source-map-support": "^0.5.20", 2280 | "undici": "5.9.1" 2281 | } 2282 | }, 2283 | "mustache": { 2284 | "version": "4.2.0", 2285 | "resolved": "https://registry.npmjs.org/mustache/-/mustache-4.2.0.tgz", 2286 | "integrity": "sha512-71ippSywq5Yb7/tVYyGbkBggbU8H3u5Rz56fH60jGFgr8uHwxs+aSKeqmluIVzM0m0kB7xQjKS6qPfd0b2ZoqQ==", 2287 | "dev": true 2288 | }, 2289 | "nanoid": { 2290 | "version": "3.3.4", 2291 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.4.tgz", 2292 | "integrity": "sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==", 2293 | "dev": true 2294 | }, 2295 | "node-forge": { 2296 | "version": "1.3.1", 2297 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", 2298 | "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==", 2299 | "dev": true 2300 | }, 2301 | "normalize-path": { 2302 | "version": "3.0.0", 2303 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2304 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2305 | "dev": true 2306 | }, 2307 | "npm-run-path": { 2308 | "version": "5.1.0", 2309 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.1.0.tgz", 2310 | "integrity": "sha512-sJOdmRGrY2sjNTRMbSvluQqg+8X7ZK61yvzBEIDhz4f8z1TZFYABsqjjCBd/0PUNE9M6QDgHJXQkGUEm7Q+l9Q==", 2311 | "dev": true, 2312 | "requires": { 2313 | "path-key": "^4.0.0" 2314 | }, 2315 | "dependencies": { 2316 | "path-key": { 2317 | "version": "4.0.0", 2318 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-4.0.0.tgz", 2319 | "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==", 2320 | "dev": true 2321 | } 2322 | } 2323 | }, 2324 | "npx-import": { 2325 | "version": "1.1.3", 2326 | "resolved": "https://registry.npmjs.org/npx-import/-/npx-import-1.1.3.tgz", 2327 | "integrity": "sha512-zy6249FJ81OtPsvz2y0+rgis31EN5wbdwBG2umtEh65W/4onYArHuoUSZ+W+T7BQYK7YF+h9G4CuGPusMCcLOw==", 2328 | "dev": true, 2329 | "requires": { 2330 | "execa": "^6.1.0", 2331 | "parse-package-name": "^1.0.0", 2332 | "semver": "^7.3.7", 2333 | "validate-npm-package-name": "^4.0.0" 2334 | } 2335 | }, 2336 | "onetime": { 2337 | "version": "6.0.0", 2338 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz", 2339 | "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==", 2340 | "dev": true, 2341 | "requires": { 2342 | "mimic-fn": "^4.0.0" 2343 | } 2344 | }, 2345 | "parse-package-name": { 2346 | "version": "1.0.0", 2347 | "resolved": "https://registry.npmjs.org/parse-package-name/-/parse-package-name-1.0.0.tgz", 2348 | "integrity": "sha512-kBeTUtcj+SkyfaW4+KBe0HtsloBJ/mKTPoxpVdA57GZiPerREsUWJOhVj9anXweFiJkm5y8FG1sxFZkZ0SN6wg==", 2349 | "dev": true 2350 | }, 2351 | "path-key": { 2352 | "version": "3.1.1", 2353 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2354 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2355 | "dev": true 2356 | }, 2357 | "path-to-regexp": { 2358 | "version": "6.2.1", 2359 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz", 2360 | "integrity": "sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw==", 2361 | "dev": true 2362 | }, 2363 | "picomatch": { 2364 | "version": "2.3.1", 2365 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2366 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2367 | "dev": true 2368 | }, 2369 | "readdirp": { 2370 | "version": "3.6.0", 2371 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2372 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2373 | "dev": true, 2374 | "requires": { 2375 | "picomatch": "^2.2.1" 2376 | } 2377 | }, 2378 | "rollup-plugin-inject": { 2379 | "version": "3.0.2", 2380 | "resolved": "https://registry.npmjs.org/rollup-plugin-inject/-/rollup-plugin-inject-3.0.2.tgz", 2381 | "integrity": "sha512-ptg9PQwzs3orn4jkgXJ74bfs5vYz1NCZlSQMBUA0wKcGp5i5pA1AO3fOUEte8enhGUC+iapTCzEWw2jEFFUO/w==", 2382 | "dev": true, 2383 | "requires": { 2384 | "estree-walker": "^0.6.1", 2385 | "magic-string": "^0.25.3", 2386 | "rollup-pluginutils": "^2.8.1" 2387 | } 2388 | }, 2389 | "rollup-plugin-node-polyfills": { 2390 | "version": "0.2.1", 2391 | "resolved": "https://registry.npmjs.org/rollup-plugin-node-polyfills/-/rollup-plugin-node-polyfills-0.2.1.tgz", 2392 | "integrity": "sha512-4kCrKPTJ6sK4/gLL/U5QzVT8cxJcofO0OU74tnB19F40cmuAKSzH5/siithxlofFEjwvw1YAhPmbvGNA6jEroA==", 2393 | "dev": true, 2394 | "requires": { 2395 | "rollup-plugin-inject": "^3.0.0" 2396 | } 2397 | }, 2398 | "rollup-pluginutils": { 2399 | "version": "2.8.2", 2400 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", 2401 | "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", 2402 | "dev": true, 2403 | "requires": { 2404 | "estree-walker": "^0.6.1" 2405 | } 2406 | }, 2407 | "selfsigned": { 2408 | "version": "2.1.1", 2409 | "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.1.1.tgz", 2410 | "integrity": "sha512-GSL3aowiF7wa/WtSFwnUrludWFoNhftq8bUkH9pkzjpN2XSPOAYEgg6e0sS9s0rZwgJzJiQRPU18A6clnoW5wQ==", 2411 | "dev": true, 2412 | "requires": { 2413 | "node-forge": "^1" 2414 | } 2415 | }, 2416 | "semiver": { 2417 | "version": "1.1.0", 2418 | "resolved": "https://registry.npmjs.org/semiver/-/semiver-1.1.0.tgz", 2419 | "integrity": "sha512-QNI2ChmuioGC1/xjyYwyZYADILWyW6AmS1UH6gDj/SFUUUS4MBAWs/7mxnkRPc/F4iHezDP+O8t0dO8WHiEOdg==", 2420 | "dev": true 2421 | }, 2422 | "semver": { 2423 | "version": "7.3.7", 2424 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz", 2425 | "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==", 2426 | "dev": true, 2427 | "requires": { 2428 | "lru-cache": "^6.0.0" 2429 | } 2430 | }, 2431 | "set-cookie-parser": { 2432 | "version": "2.5.1", 2433 | "resolved": "https://registry.npmjs.org/set-cookie-parser/-/set-cookie-parser-2.5.1.tgz", 2434 | "integrity": "sha512-1jeBGaKNGdEq4FgIrORu/N570dwoPYio8lSoYLWmX7sQ//0JY08Xh9o5pBcgmHQ/MbsYp/aZnOe1s1lIsbLprQ==", 2435 | "dev": true 2436 | }, 2437 | "shebang-command": { 2438 | "version": "2.0.0", 2439 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2440 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2441 | "dev": true, 2442 | "requires": { 2443 | "shebang-regex": "^3.0.0" 2444 | } 2445 | }, 2446 | "shebang-regex": { 2447 | "version": "3.0.0", 2448 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2449 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2450 | "dev": true 2451 | }, 2452 | "signal-exit": { 2453 | "version": "3.0.7", 2454 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 2455 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 2456 | "dev": true 2457 | }, 2458 | "source-map": { 2459 | "version": "0.7.4", 2460 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", 2461 | "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", 2462 | "dev": true 2463 | }, 2464 | "source-map-support": { 2465 | "version": "0.5.21", 2466 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 2467 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 2468 | "dev": true, 2469 | "requires": { 2470 | "buffer-from": "^1.0.0", 2471 | "source-map": "^0.6.0" 2472 | }, 2473 | "dependencies": { 2474 | "source-map": { 2475 | "version": "0.6.1", 2476 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2477 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2478 | "dev": true 2479 | } 2480 | } 2481 | }, 2482 | "sourcemap-codec": { 2483 | "version": "1.4.8", 2484 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 2485 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 2486 | "dev": true 2487 | }, 2488 | "stack-trace": { 2489 | "version": "0.0.10", 2490 | "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz", 2491 | "integrity": "sha512-KGzahc7puUKkzyMt+IqAep+TVNbKP+k2Lmwhub39m1AsTSkaDutx56aDCo+HLDzf/D26BIHTJWNiTG1KAJiQCg==", 2492 | "dev": true 2493 | }, 2494 | "streamsearch": { 2495 | "version": "1.1.0", 2496 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", 2497 | "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", 2498 | "dev": true 2499 | }, 2500 | "strip-final-newline": { 2501 | "version": "3.0.0", 2502 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-3.0.0.tgz", 2503 | "integrity": "sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==", 2504 | "dev": true 2505 | }, 2506 | "to-regex-range": { 2507 | "version": "5.0.1", 2508 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2509 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2510 | "dev": true, 2511 | "requires": { 2512 | "is-number": "^7.0.0" 2513 | } 2514 | }, 2515 | "typescript": { 2516 | "version": "4.8.3", 2517 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.8.3.tgz", 2518 | "integrity": "sha512-goMHfm00nWPa8UvR/CPSvykqf6dVV8x/dp0c5mFTMTIu0u0FlGWRioyy7Nn0PGAdHxpJZnuO/ut+PpQ8UiHAig==", 2519 | "dev": true 2520 | }, 2521 | "undici": { 2522 | "version": "5.9.1", 2523 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.9.1.tgz", 2524 | "integrity": "sha512-6fB3a+SNnWEm4CJbgo0/CWR8RGcOCQP68SF4X0mxtYTq2VNN8T88NYrWVBAeSX+zb7bny2dx2iYhP3XHi00omg==", 2525 | "dev": true 2526 | }, 2527 | "urlpattern-polyfill": { 2528 | "version": "4.0.3", 2529 | "resolved": "https://registry.npmjs.org/urlpattern-polyfill/-/urlpattern-polyfill-4.0.3.tgz", 2530 | "integrity": "sha512-DOE84vZT2fEcl9gqCUTcnAw5ZY5Id55ikUcziSUntuEFL3pRvavg5kwDmTEUJkeCHInTlV/HexFomgYnzO5kdQ==", 2531 | "dev": true 2532 | }, 2533 | "validate-npm-package-name": { 2534 | "version": "4.0.0", 2535 | "resolved": "https://registry.npmjs.org/validate-npm-package-name/-/validate-npm-package-name-4.0.0.tgz", 2536 | "integrity": "sha512-mzR0L8ZDktZjpX4OB46KT+56MAhl4EIazWP/+G/HPGuvfdaqg4YsCdtOm6U9+LOFyYDoh4dpnpxZRB9MQQns5Q==", 2537 | "dev": true, 2538 | "requires": { 2539 | "builtins": "^5.0.0" 2540 | } 2541 | }, 2542 | "which": { 2543 | "version": "2.0.2", 2544 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2545 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2546 | "dev": true, 2547 | "requires": { 2548 | "isexe": "^2.0.0" 2549 | } 2550 | }, 2551 | "wrangler": { 2552 | "version": "2.0.29", 2553 | "resolved": "https://registry.npmjs.org/wrangler/-/wrangler-2.0.29.tgz", 2554 | "integrity": "sha512-Z9W48pRpo87qO2WLMU24TFLL5Oq2WUwzqlwVDFrnSpBT+7GRrkAceepKU8V+aOXxLqyUaEzaSVHT3KVPyXh8KQ==", 2555 | "dev": true, 2556 | "requires": { 2557 | "@cloudflare/kv-asset-handler": "^0.2.0", 2558 | "@esbuild-plugins/node-globals-polyfill": "^0.1.1", 2559 | "@esbuild-plugins/node-modules-polyfill": "^0.1.4", 2560 | "blake3-wasm": "^2.1.5", 2561 | "chokidar": "^3.5.3", 2562 | "esbuild": "0.14.51", 2563 | "fsevents": "~2.3.2", 2564 | "miniflare": "^2.7.1", 2565 | "nanoid": "^3.3.3", 2566 | "path-to-regexp": "^6.2.0", 2567 | "selfsigned": "^2.0.1", 2568 | "source-map": "^0.7.4", 2569 | "xxhash-wasm": "^1.0.1" 2570 | } 2571 | }, 2572 | "ws": { 2573 | "version": "8.8.1", 2574 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.8.1.tgz", 2575 | "integrity": "sha512-bGy2JzvzkPowEJV++hF07hAD6niYSr0JzBNo/J29WsB57A2r7Wlc1UFcTR9IzrPvuNVO4B8LGqF8qcpsVOhJCA==", 2576 | "dev": true, 2577 | "requires": {} 2578 | }, 2579 | "xxhash-wasm": { 2580 | "version": "1.0.1", 2581 | "resolved": "https://registry.npmjs.org/xxhash-wasm/-/xxhash-wasm-1.0.1.tgz", 2582 | "integrity": "sha512-Lc9CTvDrH2vRoiaUzz25q7lRaviMhz90pkx6YxR9EPYtF99yOJnv2cB+CQ0hp/TLoqrUsk8z/W2EN31T568Azw==", 2583 | "dev": true 2584 | }, 2585 | "yallist": { 2586 | "version": "4.0.0", 2587 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2588 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2589 | "dev": true 2590 | }, 2591 | "youch": { 2592 | "version": "2.2.2", 2593 | "resolved": "https://registry.npmjs.org/youch/-/youch-2.2.2.tgz", 2594 | "integrity": "sha512-/FaCeG3GkuJwaMR34GHVg0l8jCbafZLHiFowSjqLlqhC6OMyf2tPJBu8UirF7/NI9X/R5ai4QfEKUCOxMAGxZQ==", 2595 | "dev": true, 2596 | "requires": { 2597 | "@types/stack-trace": "0.0.29", 2598 | "cookie": "^0.4.1", 2599 | "mustache": "^4.2.0", 2600 | "stack-trace": "0.0.10" 2601 | } 2602 | } 2603 | } 2604 | } 2605 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "session-authentication-worker", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "keywords": [], 10 | "author": "", 11 | "license": "ISC", 12 | "devDependencies": { 13 | "@cloudflare/workers-types": "^3.16.0", 14 | "@types/cookie": "^0.5.1", 15 | "typescript": "^4.8.3", 16 | "wrangler": "^2.0.29" 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /readme.md: -------------------------------------------------------------------------------- 1 | [![CodeQL](https://github.com/beykansen/session-authentication-worker/actions/workflows/codeql-analysis.yml/badge.svg)](https://github.com/beykansen/session-authentication-worker/actions/workflows/codeql-analysis.yml) 2 | [![Codespaces Prebuilds](https://github.com/beykansen/session-authentication-worker/actions/workflows/codespaces/create_codespaces_prebuilds/badge.svg)](https://github.com/beykansen/session-authentication-worker/actions/workflows/codespaces/create_codespaces_prebuilds) 3 | 4 | # Cloudflare Session Authentication Worker 5 | 6 | This worker uses both cookie and basic authentication by creating a `__session` cookie and encrypts with `AES-CBC` after initial login via basic authentication. 7 | While the cookie is valid, the annoying browser basic authentication popup won't be triggered again even you close browser or device like in normal session based authentications. 8 | 9 | Also, you can visit `https://{WORKER_URL}/logout` page for manually logout and deleting cookie. 10 | 11 | :warning: **Use with caution**. This worker is not meant to be replaced your trusted authentication mechanism. It just may be useful for non-critical back office applications or dashboards. 12 | 13 | #### How to use: 14 | 15 | 1. Change worker `name` in `wrangler.toml` according to your worker. 16 | 2. Create environment variables that you see below. 17 | 3. Type `wranger publish` from your favorite terminal. 18 | 4. (Optional) Change cookie `MAX_AGE`, name and basic authentication `REALM` in `src/index.ts`. 19 | 20 | ##### Create These Environment Variables via Cloudflare Dashboard: 21 | 22 | 1. `USERNAME`: for admin username 23 | 2. `PASSWORD`: for admin password 24 | 3. `SECRET_KEY`: for cookie encryption. 25 | 26 | ##### Guides: 27 | 28 | - [Get Started To Workers](https://developers.cloudflare.com/workers/get-started/guide/) 29 | - [Creating environment variables](https://developers.cloudflare.com/workers/platform/environment-variables/#:~:text=Add%20environment%20variables%20by%20logging,Add%20variable%20under%20Environment%20Variables.) 30 | -------------------------------------------------------------------------------- /src/cryptoHelper.ts: -------------------------------------------------------------------------------- 1 | import {Env} from "./index"; 2 | 3 | const algorithm = 'AES-CBC'; 4 | 5 | export type HashResult = { 6 | hash: string 7 | iv: string 8 | } 9 | 10 | export const encrypt = async (env: Env, text: string): Promise => { 11 | const key = await generateImportKey(env); 12 | 13 | const iv = crypto.getRandomValues(new Uint8Array(16)); 14 | const buffer = await crypto.subtle.encrypt( 15 | { 16 | name: algorithm, 17 | iv: iv, 18 | }, 19 | key, 20 | stringToBuffer(text), 21 | ); 22 | 23 | return { 24 | hash: bufferToBase64String(buffer), 25 | iv: bufferToBase64String(iv) 26 | } 27 | }; 28 | 29 | export const decrypt = async (env: Env, hashResult: HashResult) : Promise => { 30 | const key = await generateImportKey(env); 31 | const buffer = await crypto.subtle.decrypt( 32 | {name: algorithm, iv: base64StringToBuffer(hashResult.iv)}, 33 | key, 34 | base64StringToBuffer(hashResult.hash), 35 | ); 36 | 37 | return atob(bufferToBase64String(buffer)) 38 | }; 39 | 40 | 41 | const stringToBuffer = (content: string): ArrayBuffer => { 42 | return new TextEncoder().encode(content) 43 | } 44 | 45 | export const bufferToString = (buffer: ArrayBuffer): string => { 46 | return new TextDecoder().decode(buffer).normalize(); 47 | } 48 | 49 | export const base64StringToBuffer = (content: string): ArrayBuffer => { 50 | return Uint8Array.from(atob(content), character => character.charCodeAt(0)); 51 | } 52 | 53 | const bufferToBase64String = (buffer: ArrayBuffer): string => { 54 | return btoa(String.fromCharCode(...new Uint8Array(buffer))) 55 | } 56 | 57 | const generateImportKey = (env: Env) => { 58 | const secretKey = (env as any).SECRET_KEY 59 | if (!secretKey) 60 | throw new Error("secretKey not found") 61 | return crypto.subtle.importKey( 62 | "raw", //can be "jwk" or "raw" 63 | stringToBuffer(secretKey), 64 | { //this is the algorithm options 65 | name: algorithm, 66 | }, 67 | false, //whether the key is extractable (i.e. can be used in exportKey) 68 | ["encrypt", "decrypt"] //can be "encrypt", "decrypt", "wrapKey", or "unwrapKey" 69 | ) 70 | } 71 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | export interface Env { 2 | } 3 | 4 | import {parse, serialize} from 'cookie'; 5 | import {encrypt, decrypt, base64StringToBuffer, bufferToString} from "./cryptoHelper"; 6 | 7 | const REALM = "Password Protected Area" 8 | const COOKIE_NAME = '__session'; 9 | const COOKIE_DEFAULT_MAX_AGE = 60 * 60 * 24 * 30; // 1 month 10 | 11 | 12 | class WorkerError extends Error { 13 | constructor(public statusCode: number, message: string) { 14 | super(message); 15 | this.name = "WorkerError"; 16 | } 17 | } 18 | 19 | 20 | const handle = async (request: Request, 21 | env: Env, 22 | ctx: ExecutionContext): Promise => { 23 | 24 | const {protocol, pathname} = new URL(request.url); 25 | if ('https:' !== protocol || 'https' !== request.headers.get('x-forwarded-proto')) { 26 | return createCustomResponse(204) 27 | } 28 | 29 | if (pathname === '/favicon.ico' || pathname === '/robots.txt') { 30 | return createCustomResponse(204) 31 | } 32 | 33 | if (pathname === '/logout') { 34 | return logout() 35 | } 36 | 37 | if (await getSessionCookie(request, env)) { 38 | console.log("logging via cookie...") 39 | return await loginViaCookie(request, env) 40 | } 41 | 42 | if (request.headers.has('Authorization')) { 43 | console.log("logging via authorization header...") 44 | return await loginViaBasicAuth(request, env) 45 | } 46 | 47 | throw new WorkerError(401, "You need to login!") 48 | } 49 | 50 | const logout = (): Response => { 51 | return withDeletingCookies(createCustomResponse(401, 'Logged out!')) 52 | } 53 | 54 | const loginViaCookie = async (request: Request, env: Env,): Promise => { 55 | const cookie = (await getSessionCookie(request, env))!!.split(":") 56 | const user = cookie[0] 57 | const pass = cookie[1] 58 | return await login(request, env, user!!, pass!!) 59 | } 60 | 61 | const loginViaBasicAuth = async (request: Request, env: Env,): Promise => { 62 | const authorization = request.headers.get('Authorization'); 63 | const [scheme, encoded] = authorization!!.split(' '); 64 | 65 | if (!encoded || scheme !== 'Basic') { 66 | throw new WorkerError(400, 'Malformed authorization header.') 67 | } 68 | const {user, pass} = decodeAuthorizationHeader(encoded); 69 | return await login(request, env, user!!, pass!!) 70 | } 71 | 72 | const decodeAuthorizationHeader = (encoded: string) => { 73 | const decoded = bufferToString(base64StringToBuffer(encoded)) 74 | const index = decoded.indexOf(':'); 75 | // The user & password are split by the first colon and MUST NOT contain control characters. 76 | // @see https://tools.ietf.org/html/rfc5234#appendix-B.1 (=> "CTL = %x00-1F / %x7F") 77 | if (index === -1 || /[\0-\x1F\x7F]/.test(decoded)) { 78 | throw new WorkerError(400, 'Invalid authorization value.') 79 | } 80 | 81 | return { 82 | user: decoded.substring(0, index), 83 | pass: decoded.substring(index + 1), 84 | }; 85 | } 86 | 87 | const login = async (request: Request, env: Env, user: string, pass: string): Promise => { 88 | const adminUsername = (env as any).USERNAME 89 | const adminPassword = (env as any).PASSWORD 90 | if (!adminPassword || !adminPassword) { 91 | throw new WorkerError(500, "admin username and/or password not exist in environment variables.") 92 | } 93 | 94 | if (adminUsername === user && adminPassword === pass) { 95 | console.log("Logged in successfully!") 96 | return await withCreatingCookies(env, user, pass, await fetch(request)) 97 | } 98 | throw new WorkerError(401, "Invalid Credentials!") 99 | } 100 | 101 | const withCreatingCookies = async (env: Env, user: string, password: string, response: Response): Promise => { 102 | const newResponse = new Response(response.body, response); 103 | newResponse.headers.append("Set-Cookie", await serializeForCreatingCookie(env, user, password)) 104 | return newResponse 105 | } 106 | 107 | const withDeletingCookies = (response: Response): Response => { 108 | const newResponse = new Response(response.body, response); 109 | newResponse.headers.append("Set-Cookie", serializeForDeletingCookie()) 110 | return newResponse 111 | } 112 | 113 | const serializeForCreatingCookie = async (env: Env, user: string, password: string): Promise => { 114 | const value = await encrypt(env, `${user}:${password}`) 115 | return serialize(COOKIE_NAME, JSON.stringify(value), { 116 | httpOnly: true, 117 | maxAge: COOKIE_DEFAULT_MAX_AGE, 118 | secure: true 119 | }) 120 | } 121 | 122 | const serializeForDeletingCookie = (): string => { 123 | return serialize(COOKIE_NAME, "", { 124 | httpOnly: true, 125 | maxAge: -1, 126 | secure: true 127 | }) 128 | } 129 | 130 | const getSessionCookie = async (request: Request, env: Env): Promise => { 131 | const cookie = parse(request.headers.get('Cookie') || '')[COOKIE_NAME] 132 | if (!cookie) 133 | return null 134 | return await decrypt(env, JSON.parse(cookie)) 135 | } 136 | 137 | const createCustomResponse = (statusCode: number, body?: string): Response => { 138 | const headers: Record = { 139 | 'Content-Type': 'text/plain;charset=UTF-8', 140 | 'Cache-Control': 'no-store', 141 | 'Content-Length': body?.length, 142 | } 143 | return new Response(body, { 144 | status: statusCode, 145 | headers: headers!! 146 | }); 147 | } 148 | 149 | export default { 150 | async fetch( 151 | request: Request, 152 | env: Env, 153 | ctx: ExecutionContext 154 | ): Promise { 155 | try { 156 | return await handle(request, env, ctx); 157 | } catch (e) { 158 | console.error((e as Error).message) 159 | if (e instanceof WorkerError) { 160 | if (e.statusCode >= 500) 161 | throw e; 162 | 163 | const response = withDeletingCookies(createCustomResponse(e.statusCode, e.message)) 164 | if (e.statusCode === 401) 165 | response.headers.append("WWW-Authenticate", `Basic realm="${REALM}", charset="UTF-8"`) 166 | return response 167 | }else if (e instanceof SyntaxError) { 168 | // for handling cookie schema changes 169 | return withDeletingCookies(createCustomResponse(500, "An unexpected error has occurred! Please try again later.")) 170 | } 171 | throw e; 172 | } 173 | }, 174 | } 175 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | /* Visit https://aka.ms/tsconfig.json to read more about this file */ 4 | 5 | /* Projects */ 6 | // "incremental": true, /* Enable incremental compilation */ 7 | // "composite": true, /* Enable constraints that allow a TypeScript project to be used with project references. */ 8 | // "tsBuildInfoFile": "./", /* Specify the folder for .tsbuildinfo incremental compilation files. */ 9 | // "disableSourceOfProjectReferenceRedirect": true, /* Disable preferring source files instead of declaration files when referencing composite projects */ 10 | // "disableSolutionSearching": true, /* Opt a project out of multi-project reference checking when editing. */ 11 | // "disableReferencedProjectLoad": true, /* Reduce the number of projects loaded automatically by TypeScript. */ 12 | 13 | /* Language and Environment */ 14 | "target": "es2021" /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */, 15 | "lib": [ 16 | "es2021" 17 | ] /* Specify a set of bundled library declaration files that describe the target runtime environment. */, 18 | "jsx": "react" /* Specify what JSX code is generated. */, 19 | // "experimentalDecorators": true, /* Enable experimental support for TC39 stage 2 draft decorators. */ 20 | // "emitDecoratorMetadata": true, /* Emit design-type metadata for decorated declarations in source files. */ 21 | // "jsxFactory": "", /* Specify the JSX factory function used when targeting React JSX emit, e.g. 'React.createElement' or 'h' */ 22 | // "jsxFragmentFactory": "", /* Specify the JSX Fragment reference used for fragments when targeting React JSX emit e.g. 'React.Fragment' or 'Fragment'. */ 23 | // "jsxImportSource": "", /* Specify module specifier used to import the JSX factory functions when using `jsx: react-jsx*`.` */ 24 | // "reactNamespace": "", /* Specify the object invoked for `createElement`. This only applies when targeting `react` JSX emit. */ 25 | // "noLib": true, /* Disable including any library files, including the default lib.d.ts. */ 26 | // "useDefineForClassFields": true, /* Emit ECMAScript-standard-compliant class fields. */ 27 | 28 | /* Modules */ 29 | "module": "es2022" /* Specify what module code is generated. */, 30 | // "rootDir": "./", /* Specify the root folder within your source files. */ 31 | "moduleResolution": "node" /* Specify how TypeScript looks up a file from a given module specifier. */, 32 | // "baseUrl": "./", /* Specify the base directory to resolve non-relative module names. */ 33 | // "paths": {}, /* Specify a set of entries that re-map imports to additional lookup locations. */ 34 | // "rootDirs": [], /* Allow multiple folders to be treated as one when resolving modules. */ 35 | // "typeRoots": [], /* Specify multiple folders that act like `./node_modules/@types`. */ 36 | "types": [ 37 | "@cloudflare/workers-types" 38 | ] /* Specify type package names to be included without being referenced in a source file. */, 39 | // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ 40 | "resolveJsonModule": true /* Enable importing .json files */, 41 | // "noResolve": true, /* Disallow `import`s, `require`s or ``s from expanding the number of files TypeScript should add to a project. */ 42 | 43 | /* JavaScript Support */ 44 | "allowJs": true /* Allow JavaScript files to be a part of your program. Use the `checkJS` option to get errors from these files. */, 45 | "checkJs": false /* Enable error reporting in type-checked JavaScript files. */, 46 | // "maxNodeModuleJsDepth": 1, /* Specify the maximum folder depth used for checking JavaScript files from `node_modules`. Only applicable with `allowJs`. */ 47 | 48 | /* Emit */ 49 | // "declaration": true, /* Generate .d.ts files from TypeScript and JavaScript files in your project. */ 50 | // "declarationMap": true, /* Create sourcemaps for d.ts files. */ 51 | // "emitDeclarationOnly": true, /* Only output d.ts files and not JavaScript files. */ 52 | // "sourceMap": true, /* Create source map files for emitted JavaScript files. */ 53 | // "outFile": "./", /* Specify a file that bundles all outputs into one JavaScript file. If `declaration` is true, also designates a file that bundles all .d.ts output. */ 54 | // "outDir": "./", /* Specify an output folder for all emitted files. */ 55 | // "removeComments": true, /* Disable emitting comments. */ 56 | "noEmit": true /* Disable emitting files from a compilation. */, 57 | // "importHelpers": true, /* Allow importing helper functions from tslib once per project, instead of including them per-file. */ 58 | // "importsNotUsedAsValues": "remove", /* Specify emit/checking behavior for imports that are only used for types */ 59 | // "downlevelIteration": true, /* Emit more compliant, but verbose and less performant JavaScript for iteration. */ 60 | // "sourceRoot": "", /* Specify the root path for debuggers to find the reference source code. */ 61 | // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ 62 | // "inlineSourceMap": true, /* Include sourcemap files inside the emitted JavaScript. */ 63 | // "inlineSources": true, /* Include source code in the sourcemaps inside the emitted JavaScript. */ 64 | // "emitBOM": true, /* Emit a UTF-8 Byte Order Mark (BOM) in the beginning of output files. */ 65 | // "newLine": "crlf", /* Set the newline character for emitting files. */ 66 | // "stripInternal": true, /* Disable emitting declarations that have `@internal` in their JSDoc comments. */ 67 | // "noEmitHelpers": true, /* Disable generating custom helper functions like `__extends` in compiled output. */ 68 | // "noEmitOnError": true, /* Disable emitting files if any type checking errors are reported. */ 69 | // "preserveConstEnums": true, /* Disable erasing `const enum` declarations in generated code. */ 70 | // "declarationDir": "./", /* Specify the output directory for generated declaration files. */ 71 | // "preserveValueImports": true, /* Preserve unused imported values in the JavaScript output that would otherwise be removed. */ 72 | 73 | /* Interop Constraints */ 74 | "isolatedModules": true /* Ensure that each file can be safely transpiled without relying on other imports. */, 75 | "allowSyntheticDefaultImports": true /* Allow 'import x from y' when a module doesn't have a default export. */, 76 | // "esModuleInterop": true /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables `allowSyntheticDefaultImports` for type compatibility. */, 77 | // "preserveSymlinks": true, /* Disable resolving symlinks to their realpath. This correlates to the same flag in node. */ 78 | "forceConsistentCasingInFileNames": true /* Ensure that casing is correct in imports. */, 79 | 80 | /* Type Checking */ 81 | "strict": true /* Enable all strict type-checking options. */, 82 | // "noImplicitAny": true, /* Enable error reporting for expressions and declarations with an implied `any` type.. */ 83 | // "strictNullChecks": true, /* When type checking, take into account `null` and `undefined`. */ 84 | // "strictFunctionTypes": true, /* When assigning functions, check to ensure parameters and the return values are subtype-compatible. */ 85 | // "strictBindCallApply": true, /* Check that the arguments for `bind`, `call`, and `apply` methods match the original function. */ 86 | // "strictPropertyInitialization": true, /* Check for class properties that are declared but not set in the constructor. */ 87 | // "noImplicitThis": true, /* Enable error reporting when `this` is given the type `any`. */ 88 | // "useUnknownInCatchVariables": true, /* Type catch clause variables as 'unknown' instead of 'any'. */ 89 | // "alwaysStrict": true, /* Ensure 'use strict' is always emitted. */ 90 | // "noUnusedLocals": true, /* Enable error reporting when a local variables aren't read. */ 91 | // "noUnusedParameters": true, /* Raise an error when a function parameter isn't read */ 92 | // "exactOptionalPropertyTypes": true, /* Interpret optional property types as written, rather than adding 'undefined'. */ 93 | // "noImplicitReturns": true, /* Enable error reporting for codepaths that do not explicitly return in a function. */ 94 | // "noFallthroughCasesInSwitch": true, /* Enable error reporting for fallthrough cases in switch statements. */ 95 | // "noUncheckedIndexedAccess": true, /* Include 'undefined' in index signature results */ 96 | // "noImplicitOverride": true, /* Ensure overriding members in derived classes are marked with an override modifier. */ 97 | // "noPropertyAccessFromIndexSignature": true, /* Enforces using indexed accessors for keys declared using an indexed type */ 98 | // "allowUnusedLabels": true, /* Disable error reporting for unused labels. */ 99 | // "allowUnreachableCode": true, /* Disable error reporting for unreachable code. */ 100 | 101 | /* Completeness */ 102 | // "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */ 103 | "skipLibCheck": true /* Skip type checking all .d.ts files. */ 104 | } 105 | } 106 | -------------------------------------------------------------------------------- /wrangler.toml: -------------------------------------------------------------------------------- 1 | name = "session-authentication-worker" 2 | main = "src/index.ts" 3 | compatibility_date = "2022-09-21" 4 | --------------------------------------------------------------------------------