├── .editorconfig ├── .gitignore ├── .prettierrc ├── README.md ├── package-lock.json ├── package.json ├── src └── index.ts ├── tsconfig.json └── wrangler.toml /.editorconfig: -------------------------------------------------------------------------------- 1 | # http://editorconfig.org 2 | root = true 3 | 4 | [*] 5 | indent_style = tab 6 | tab_width = 2 7 | end_of_line = lf 8 | charset = utf-8 9 | trim_trailing_whitespace = true 10 | insert_final_newline = true 11 | 12 | [*.yml] 13 | indent_style = space 14 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | 3 | logs 4 | _.log 5 | npm-debug.log_ 6 | yarn-debug.log* 7 | yarn-error.log* 8 | lerna-debug.log* 9 | .pnpm-debug.log* 10 | 11 | # Diagnostic reports (https://nodejs.org/api/report.html) 12 | 13 | report.[0-9]_.[0-9]_.[0-9]_.[0-9]_.json 14 | 15 | # Runtime data 16 | 17 | pids 18 | _.pid 19 | _.seed 20 | \*.pid.lock 21 | 22 | # Directory for instrumented libs generated by jscoverage/JSCover 23 | 24 | lib-cov 25 | 26 | # Coverage directory used by tools like istanbul 27 | 28 | coverage 29 | \*.lcov 30 | 31 | # nyc test coverage 32 | 33 | .nyc_output 34 | 35 | # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) 36 | 37 | .grunt 38 | 39 | # Bower dependency directory (https://bower.io/) 40 | 41 | bower_components 42 | 43 | # node-waf configuration 44 | 45 | .lock-wscript 46 | 47 | # Compiled binary addons (https://nodejs.org/api/addons.html) 48 | 49 | build/Release 50 | 51 | # Dependency directories 52 | 53 | node_modules/ 54 | jspm_packages/ 55 | 56 | # Snowpack dependency directory (https://snowpack.dev/) 57 | 58 | web_modules/ 59 | 60 | # TypeScript cache 61 | 62 | \*.tsbuildinfo 63 | 64 | # Optional npm cache directory 65 | 66 | .npm 67 | 68 | # Optional eslint cache 69 | 70 | .eslintcache 71 | 72 | # Optional stylelint cache 73 | 74 | .stylelintcache 75 | 76 | # Microbundle cache 77 | 78 | .rpt2_cache/ 79 | .rts2_cache_cjs/ 80 | .rts2_cache_es/ 81 | .rts2_cache_umd/ 82 | 83 | # Optional REPL history 84 | 85 | .node_repl_history 86 | 87 | # Output of 'npm pack' 88 | 89 | \*.tgz 90 | 91 | # Yarn Integrity file 92 | 93 | .yarn-integrity 94 | 95 | # dotenv environment variable files 96 | 97 | .env 98 | .env.development.local 99 | .env.test.local 100 | .env.production.local 101 | .env.local 102 | 103 | # parcel-bundler cache (https://parceljs.org/) 104 | 105 | .cache 106 | .parcel-cache 107 | 108 | # Next.js build output 109 | 110 | .next 111 | out 112 | 113 | # Nuxt.js build / generate output 114 | 115 | .nuxt 116 | dist 117 | 118 | # Gatsby files 119 | 120 | .cache/ 121 | 122 | # Comment in the public line in if your project uses Gatsby and not Next.js 123 | 124 | # https://nextjs.org/blog/next-9-1#public-directory-support 125 | 126 | # public 127 | 128 | # vuepress build output 129 | 130 | .vuepress/dist 131 | 132 | # vuepress v2.x temp and cache directory 133 | 134 | .temp 135 | .cache 136 | 137 | # Docusaurus cache and generated files 138 | 139 | .docusaurus 140 | 141 | # Serverless directories 142 | 143 | .serverless/ 144 | 145 | # FuseBox cache 146 | 147 | .fusebox/ 148 | 149 | # DynamoDB Local files 150 | 151 | .dynamodb/ 152 | 153 | # TernJS port file 154 | 155 | .tern-port 156 | 157 | # Stores VSCode versions used for testing VSCode extensions 158 | 159 | .vscode-test 160 | 161 | # yarn v2 162 | 163 | .yarn/cache 164 | .yarn/unplugged 165 | .yarn/build-state.yml 166 | .yarn/install-state.gz 167 | .pnp.\* 168 | 169 | # wrangler project 170 | 171 | .dev.vars 172 | .wrangler/ 173 | -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "printWidth": 140, 3 | "singleQuote": true, 4 | "semi": true, 5 | "useTabs": true 6 | } 7 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # SDXL Worker 2 | 3 | Small [Workers AI](https://developers.cloudflare.com/workers-ai/) demo using Stable Diffusion XL to generate and store images. 4 | 5 | Visiting e.g. `/?prompt=small black cat` will generate the image and store it in R2 under a directory labelled after the prompt. 6 | 7 | ![](https://up.erisa.uk/firefox_PJTTY9Jhpc.png) 8 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "sdxl", 3 | "version": "0.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "sdxl", 9 | "version": "0.0.0", 10 | "devDependencies": { 11 | "@cloudflare/workers-types": "^4.20240502.0", 12 | "typescript": "^5.3.3", 13 | "wrangler": "^3.55.0" 14 | } 15 | }, 16 | "node_modules/@cloudflare/kv-asset-handler": { 17 | "version": "0.3.2", 18 | "resolved": "https://registry.npmjs.org/@cloudflare/kv-asset-handler/-/kv-asset-handler-0.3.2.tgz", 19 | "integrity": "sha512-EeEjMobfuJrwoctj7FA1y1KEbM0+Q1xSjobIEyie9k4haVEBB7vkDvsasw1pM3rO39mL2akxIAzLMUAtrMHZhA==", 20 | "dev": true, 21 | "dependencies": { 22 | "mime": "^3.0.0" 23 | }, 24 | "engines": { 25 | "node": ">=16.13" 26 | } 27 | }, 28 | "node_modules/@cloudflare/workerd-darwin-64": { 29 | "version": "1.20240419.0", 30 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-darwin-64/-/workerd-darwin-64-1.20240419.0.tgz", 31 | "integrity": "sha512-PGVe9sYWULHfvGhN0IZh8MsskNG/ufnBSqPbgFCxJHCTrVXLPuC35EoVaforyqjKRwj3U35XMyGo9KHcGnTeHQ==", 32 | "cpu": [ 33 | "x64" 34 | ], 35 | "dev": true, 36 | "optional": true, 37 | "os": [ 38 | "darwin" 39 | ], 40 | "engines": { 41 | "node": ">=16" 42 | } 43 | }, 44 | "node_modules/@cloudflare/workerd-darwin-arm64": { 45 | "version": "1.20240419.0", 46 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-darwin-arm64/-/workerd-darwin-arm64-1.20240419.0.tgz", 47 | "integrity": "sha512-z4etQSPiD5Gcjs962LiC7ZdmXnN6SGof5KrYoFiSI9X9kUvpuGH/lnjVVPd+NnVNeDU2kzmcAIgyZjkjTaqVXQ==", 48 | "cpu": [ 49 | "arm64" 50 | ], 51 | "dev": true, 52 | "optional": true, 53 | "os": [ 54 | "darwin" 55 | ], 56 | "engines": { 57 | "node": ">=16" 58 | } 59 | }, 60 | "node_modules/@cloudflare/workerd-linux-64": { 61 | "version": "1.20240419.0", 62 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-linux-64/-/workerd-linux-64-1.20240419.0.tgz", 63 | "integrity": "sha512-lBwhg0j3sYTFMsEb4bOClbVje8nqrYOu0H3feQlX+Eks94JIhWPkf8ywK4at/BUc1comPMhCgzDHwc2OMPUGgg==", 64 | "cpu": [ 65 | "x64" 66 | ], 67 | "dev": true, 68 | "optional": true, 69 | "os": [ 70 | "linux" 71 | ], 72 | "engines": { 73 | "node": ">=16" 74 | } 75 | }, 76 | "node_modules/@cloudflare/workerd-linux-arm64": { 77 | "version": "1.20240419.0", 78 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-linux-arm64/-/workerd-linux-arm64-1.20240419.0.tgz", 79 | "integrity": "sha512-ZMY6wwWkxL+WPq8ydOp/irSYjAnMhBz1OC1+4z+OANtDs2beaZODmq7LEB3hb5WUAaTPY7DIjZh3DfDfty0nYg==", 80 | "cpu": [ 81 | "arm64" 82 | ], 83 | "dev": true, 84 | "optional": true, 85 | "os": [ 86 | "linux" 87 | ], 88 | "engines": { 89 | "node": ">=16" 90 | } 91 | }, 92 | "node_modules/@cloudflare/workerd-windows-64": { 93 | "version": "1.20240419.0", 94 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-windows-64/-/workerd-windows-64-1.20240419.0.tgz", 95 | "integrity": "sha512-YJjgaJN2yGTkV7Cr4K3i8N4dUwVQTclT3Pr3NpRZCcLjTszwlE53++XXDnHMKGXBbSguIizaVbmcU2EtmIXyeQ==", 96 | "cpu": [ 97 | "x64" 98 | ], 99 | "dev": true, 100 | "optional": true, 101 | "os": [ 102 | "win32" 103 | ], 104 | "engines": { 105 | "node": ">=16" 106 | } 107 | }, 108 | "node_modules/@cloudflare/workers-types": { 109 | "version": "4.20240502.0", 110 | "resolved": "https://registry.npmjs.org/@cloudflare/workers-types/-/workers-types-4.20240502.0.tgz", 111 | "integrity": "sha512-OB1jIyPOzyOcuZFHWhsQnkRLN6u8+jmU9X3T4KZlGgn3Ivw8pBiswhLOp+yFeChR3Y4/5+V0hPFRko5SReordg==", 112 | "dev": true 113 | }, 114 | "node_modules/@cspotcode/source-map-support": { 115 | "version": "0.8.1", 116 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 117 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 118 | "dev": true, 119 | "dependencies": { 120 | "@jridgewell/trace-mapping": "0.3.9" 121 | }, 122 | "engines": { 123 | "node": ">=12" 124 | } 125 | }, 126 | "node_modules/@esbuild-plugins/node-globals-polyfill": { 127 | "version": "0.2.3", 128 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-globals-polyfill/-/node-globals-polyfill-0.2.3.tgz", 129 | "integrity": "sha512-r3MIryXDeXDOZh7ih1l/yE9ZLORCd5e8vWg02azWRGj5SPTuoh69A2AIyn0Z31V/kHBfZ4HgWJ+OK3GTTwLmnw==", 130 | "dev": true, 131 | "peerDependencies": { 132 | "esbuild": "*" 133 | } 134 | }, 135 | "node_modules/@esbuild-plugins/node-modules-polyfill": { 136 | "version": "0.2.2", 137 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-modules-polyfill/-/node-modules-polyfill-0.2.2.tgz", 138 | "integrity": "sha512-LXV7QsWJxRuMYvKbiznh+U1ilIop3g2TeKRzUxOG5X3YITc8JyyTa90BmLwqqv0YnX4v32CSlG+vsziZp9dMvA==", 139 | "dev": true, 140 | "dependencies": { 141 | "escape-string-regexp": "^4.0.0", 142 | "rollup-plugin-node-polyfills": "^0.2.1" 143 | }, 144 | "peerDependencies": { 145 | "esbuild": "*" 146 | } 147 | }, 148 | "node_modules/@esbuild/android-arm": { 149 | "version": "0.17.19", 150 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.19.tgz", 151 | "integrity": "sha512-rIKddzqhmav7MSmoFCmDIb6e2W57geRsM94gV2l38fzhXMwq7hZoClug9USI2pFRGL06f4IOPHHpFNOkWieR8A==", 152 | "cpu": [ 153 | "arm" 154 | ], 155 | "dev": true, 156 | "optional": true, 157 | "os": [ 158 | "android" 159 | ], 160 | "engines": { 161 | "node": ">=12" 162 | } 163 | }, 164 | "node_modules/@esbuild/android-arm64": { 165 | "version": "0.17.19", 166 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.19.tgz", 167 | "integrity": "sha512-KBMWvEZooR7+kzY0BtbTQn0OAYY7CsiydT63pVEaPtVYF0hXbUaOyZog37DKxK7NF3XacBJOpYT4adIJh+avxA==", 168 | "cpu": [ 169 | "arm64" 170 | ], 171 | "dev": true, 172 | "optional": true, 173 | "os": [ 174 | "android" 175 | ], 176 | "engines": { 177 | "node": ">=12" 178 | } 179 | }, 180 | "node_modules/@esbuild/android-x64": { 181 | "version": "0.17.19", 182 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.19.tgz", 183 | "integrity": "sha512-uUTTc4xGNDT7YSArp/zbtmbhO0uEEK9/ETW29Wk1thYUJBz3IVnvgEiEwEa9IeLyvnpKrWK64Utw2bgUmDveww==", 184 | "cpu": [ 185 | "x64" 186 | ], 187 | "dev": true, 188 | "optional": true, 189 | "os": [ 190 | "android" 191 | ], 192 | "engines": { 193 | "node": ">=12" 194 | } 195 | }, 196 | "node_modules/@esbuild/darwin-arm64": { 197 | "version": "0.17.19", 198 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.19.tgz", 199 | "integrity": "sha512-80wEoCfF/hFKM6WE1FyBHc9SfUblloAWx6FJkFWTWiCoht9Mc0ARGEM47e67W9rI09YoUxJL68WHfDRYEAvOhg==", 200 | "cpu": [ 201 | "arm64" 202 | ], 203 | "dev": true, 204 | "optional": true, 205 | "os": [ 206 | "darwin" 207 | ], 208 | "engines": { 209 | "node": ">=12" 210 | } 211 | }, 212 | "node_modules/@esbuild/darwin-x64": { 213 | "version": "0.17.19", 214 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.19.tgz", 215 | "integrity": "sha512-IJM4JJsLhRYr9xdtLytPLSH9k/oxR3boaUIYiHkAawtwNOXKE8KoU8tMvryogdcT8AU+Bflmh81Xn6Q0vTZbQw==", 216 | "cpu": [ 217 | "x64" 218 | ], 219 | "dev": true, 220 | "optional": true, 221 | "os": [ 222 | "darwin" 223 | ], 224 | "engines": { 225 | "node": ">=12" 226 | } 227 | }, 228 | "node_modules/@esbuild/freebsd-arm64": { 229 | "version": "0.17.19", 230 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.19.tgz", 231 | "integrity": "sha512-pBwbc7DufluUeGdjSU5Si+P3SoMF5DQ/F/UmTSb8HXO80ZEAJmrykPyzo1IfNbAoaqw48YRpv8shwd1NoI0jcQ==", 232 | "cpu": [ 233 | "arm64" 234 | ], 235 | "dev": true, 236 | "optional": true, 237 | "os": [ 238 | "freebsd" 239 | ], 240 | "engines": { 241 | "node": ">=12" 242 | } 243 | }, 244 | "node_modules/@esbuild/freebsd-x64": { 245 | "version": "0.17.19", 246 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.19.tgz", 247 | "integrity": "sha512-4lu+n8Wk0XlajEhbEffdy2xy53dpR06SlzvhGByyg36qJw6Kpfk7cp45DR/62aPH9mtJRmIyrXAS5UWBrJT6TQ==", 248 | "cpu": [ 249 | "x64" 250 | ], 251 | "dev": true, 252 | "optional": true, 253 | "os": [ 254 | "freebsd" 255 | ], 256 | "engines": { 257 | "node": ">=12" 258 | } 259 | }, 260 | "node_modules/@esbuild/linux-arm": { 261 | "version": "0.17.19", 262 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.19.tgz", 263 | "integrity": "sha512-cdmT3KxjlOQ/gZ2cjfrQOtmhG4HJs6hhvm3mWSRDPtZ/lP5oe8FWceS10JaSJC13GBd4eH/haHnqf7hhGNLerA==", 264 | "cpu": [ 265 | "arm" 266 | ], 267 | "dev": true, 268 | "optional": true, 269 | "os": [ 270 | "linux" 271 | ], 272 | "engines": { 273 | "node": ">=12" 274 | } 275 | }, 276 | "node_modules/@esbuild/linux-arm64": { 277 | "version": "0.17.19", 278 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.19.tgz", 279 | "integrity": "sha512-ct1Tg3WGwd3P+oZYqic+YZF4snNl2bsnMKRkb3ozHmnM0dGWuxcPTTntAF6bOP0Sp4x0PjSF+4uHQ1xvxfRKqg==", 280 | "cpu": [ 281 | "arm64" 282 | ], 283 | "dev": true, 284 | "optional": true, 285 | "os": [ 286 | "linux" 287 | ], 288 | "engines": { 289 | "node": ">=12" 290 | } 291 | }, 292 | "node_modules/@esbuild/linux-ia32": { 293 | "version": "0.17.19", 294 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.19.tgz", 295 | "integrity": "sha512-w4IRhSy1VbsNxHRQpeGCHEmibqdTUx61Vc38APcsRbuVgK0OPEnQ0YD39Brymn96mOx48Y2laBQGqgZ0j9w6SQ==", 296 | "cpu": [ 297 | "ia32" 298 | ], 299 | "dev": true, 300 | "optional": true, 301 | "os": [ 302 | "linux" 303 | ], 304 | "engines": { 305 | "node": ">=12" 306 | } 307 | }, 308 | "node_modules/@esbuild/linux-loong64": { 309 | "version": "0.17.19", 310 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.19.tgz", 311 | "integrity": "sha512-2iAngUbBPMq439a+z//gE+9WBldoMp1s5GWsUSgqHLzLJ9WoZLZhpwWuym0u0u/4XmZ3gpHmzV84PonE+9IIdQ==", 312 | "cpu": [ 313 | "loong64" 314 | ], 315 | "dev": true, 316 | "optional": true, 317 | "os": [ 318 | "linux" 319 | ], 320 | "engines": { 321 | "node": ">=12" 322 | } 323 | }, 324 | "node_modules/@esbuild/linux-mips64el": { 325 | "version": "0.17.19", 326 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.19.tgz", 327 | "integrity": "sha512-LKJltc4LVdMKHsrFe4MGNPp0hqDFA1Wpt3jE1gEyM3nKUvOiO//9PheZZHfYRfYl6AwdTH4aTcXSqBerX0ml4A==", 328 | "cpu": [ 329 | "mips64el" 330 | ], 331 | "dev": true, 332 | "optional": true, 333 | "os": [ 334 | "linux" 335 | ], 336 | "engines": { 337 | "node": ">=12" 338 | } 339 | }, 340 | "node_modules/@esbuild/linux-ppc64": { 341 | "version": "0.17.19", 342 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.19.tgz", 343 | "integrity": "sha512-/c/DGybs95WXNS8y3Ti/ytqETiW7EU44MEKuCAcpPto3YjQbyK3IQVKfF6nbghD7EcLUGl0NbiL5Rt5DMhn5tg==", 344 | "cpu": [ 345 | "ppc64" 346 | ], 347 | "dev": true, 348 | "optional": true, 349 | "os": [ 350 | "linux" 351 | ], 352 | "engines": { 353 | "node": ">=12" 354 | } 355 | }, 356 | "node_modules/@esbuild/linux-riscv64": { 357 | "version": "0.17.19", 358 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.19.tgz", 359 | "integrity": "sha512-FC3nUAWhvFoutlhAkgHf8f5HwFWUL6bYdvLc/TTuxKlvLi3+pPzdZiFKSWz/PF30TB1K19SuCxDTI5KcqASJqA==", 360 | "cpu": [ 361 | "riscv64" 362 | ], 363 | "dev": true, 364 | "optional": true, 365 | "os": [ 366 | "linux" 367 | ], 368 | "engines": { 369 | "node": ">=12" 370 | } 371 | }, 372 | "node_modules/@esbuild/linux-s390x": { 373 | "version": "0.17.19", 374 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.19.tgz", 375 | "integrity": "sha512-IbFsFbxMWLuKEbH+7sTkKzL6NJmG2vRyy6K7JJo55w+8xDk7RElYn6xvXtDW8HCfoKBFK69f3pgBJSUSQPr+4Q==", 376 | "cpu": [ 377 | "s390x" 378 | ], 379 | "dev": true, 380 | "optional": true, 381 | "os": [ 382 | "linux" 383 | ], 384 | "engines": { 385 | "node": ">=12" 386 | } 387 | }, 388 | "node_modules/@esbuild/linux-x64": { 389 | "version": "0.17.19", 390 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.19.tgz", 391 | "integrity": "sha512-68ngA9lg2H6zkZcyp22tsVt38mlhWde8l3eJLWkyLrp4HwMUr3c1s/M2t7+kHIhvMjglIBrFpncX1SzMckomGw==", 392 | "cpu": [ 393 | "x64" 394 | ], 395 | "dev": true, 396 | "optional": true, 397 | "os": [ 398 | "linux" 399 | ], 400 | "engines": { 401 | "node": ">=12" 402 | } 403 | }, 404 | "node_modules/@esbuild/netbsd-x64": { 405 | "version": "0.17.19", 406 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.19.tgz", 407 | "integrity": "sha512-CwFq42rXCR8TYIjIfpXCbRX0rp1jo6cPIUPSaWwzbVI4aOfX96OXY8M6KNmtPcg7QjYeDmN+DD0Wp3LaBOLf4Q==", 408 | "cpu": [ 409 | "x64" 410 | ], 411 | "dev": true, 412 | "optional": true, 413 | "os": [ 414 | "netbsd" 415 | ], 416 | "engines": { 417 | "node": ">=12" 418 | } 419 | }, 420 | "node_modules/@esbuild/openbsd-x64": { 421 | "version": "0.17.19", 422 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.19.tgz", 423 | "integrity": "sha512-cnq5brJYrSZ2CF6c35eCmviIN3k3RczmHz8eYaVlNasVqsNY+JKohZU5MKmaOI+KkllCdzOKKdPs762VCPC20g==", 424 | "cpu": [ 425 | "x64" 426 | ], 427 | "dev": true, 428 | "optional": true, 429 | "os": [ 430 | "openbsd" 431 | ], 432 | "engines": { 433 | "node": ">=12" 434 | } 435 | }, 436 | "node_modules/@esbuild/sunos-x64": { 437 | "version": "0.17.19", 438 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.19.tgz", 439 | "integrity": "sha512-vCRT7yP3zX+bKWFeP/zdS6SqdWB8OIpaRq/mbXQxTGHnIxspRtigpkUcDMlSCOejlHowLqII7K2JKevwyRP2rg==", 440 | "cpu": [ 441 | "x64" 442 | ], 443 | "dev": true, 444 | "optional": true, 445 | "os": [ 446 | "sunos" 447 | ], 448 | "engines": { 449 | "node": ">=12" 450 | } 451 | }, 452 | "node_modules/@esbuild/win32-arm64": { 453 | "version": "0.17.19", 454 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.19.tgz", 455 | "integrity": "sha512-yYx+8jwowUstVdorcMdNlzklLYhPxjniHWFKgRqH7IFlUEa0Umu3KuYplf1HUZZ422e3NU9F4LGb+4O0Kdcaag==", 456 | "cpu": [ 457 | "arm64" 458 | ], 459 | "dev": true, 460 | "optional": true, 461 | "os": [ 462 | "win32" 463 | ], 464 | "engines": { 465 | "node": ">=12" 466 | } 467 | }, 468 | "node_modules/@esbuild/win32-ia32": { 469 | "version": "0.17.19", 470 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.19.tgz", 471 | "integrity": "sha512-eggDKanJszUtCdlVs0RB+h35wNlb5v4TWEkq4vZcmVt5u/HiDZrTXe2bWFQUez3RgNHwx/x4sk5++4NSSicKkw==", 472 | "cpu": [ 473 | "ia32" 474 | ], 475 | "dev": true, 476 | "optional": true, 477 | "os": [ 478 | "win32" 479 | ], 480 | "engines": { 481 | "node": ">=12" 482 | } 483 | }, 484 | "node_modules/@esbuild/win32-x64": { 485 | "version": "0.17.19", 486 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.19.tgz", 487 | "integrity": "sha512-lAhycmKnVOuRYNtRtatQR1LPQf2oYCkRGkSFnseDAKPl8lu5SOsK/e1sXe5a0Pc5kHIHe6P2I/ilntNv2xf3cA==", 488 | "cpu": [ 489 | "x64" 490 | ], 491 | "dev": true, 492 | "optional": true, 493 | "os": [ 494 | "win32" 495 | ], 496 | "engines": { 497 | "node": ">=12" 498 | } 499 | }, 500 | "node_modules/@fastify/busboy": { 501 | "version": "2.1.1", 502 | "resolved": "https://registry.npmjs.org/@fastify/busboy/-/busboy-2.1.1.tgz", 503 | "integrity": "sha512-vBZP4NlzfOlerQTnba4aqZoMhE/a9HY7HRqoOPaETQcSQuWEIyZMHGfVu6w9wGtGK5fED5qRs2DteVCjOH60sA==", 504 | "dev": true, 505 | "engines": { 506 | "node": ">=14" 507 | } 508 | }, 509 | "node_modules/@jridgewell/resolve-uri": { 510 | "version": "3.1.2", 511 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 512 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 513 | "dev": true, 514 | "engines": { 515 | "node": ">=6.0.0" 516 | } 517 | }, 518 | "node_modules/@jridgewell/sourcemap-codec": { 519 | "version": "1.4.15", 520 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 521 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 522 | "dev": true 523 | }, 524 | "node_modules/@jridgewell/trace-mapping": { 525 | "version": "0.3.9", 526 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 527 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 528 | "dev": true, 529 | "dependencies": { 530 | "@jridgewell/resolve-uri": "^3.0.3", 531 | "@jridgewell/sourcemap-codec": "^1.4.10" 532 | } 533 | }, 534 | "node_modules/@types/node": { 535 | "version": "20.9.0", 536 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.9.0.tgz", 537 | "integrity": "sha512-nekiGu2NDb1BcVofVcEKMIwzlx4NjHlcjhoxxKBNLtz15Y1z7MYf549DFvkHSId02Ax6kGwWntIBPC3l/JZcmw==", 538 | "dev": true, 539 | "dependencies": { 540 | "undici-types": "~5.26.4" 541 | } 542 | }, 543 | "node_modules/@types/node-forge": { 544 | "version": "1.3.9", 545 | "resolved": "https://registry.npmjs.org/@types/node-forge/-/node-forge-1.3.9.tgz", 546 | "integrity": "sha512-meK88cx/sTalPSLSoCzkiUB4VPIFHmxtXm5FaaqRDqBX2i/Sy8bJ4odsan0b20RBjPh06dAQ+OTTdnyQyhJZyQ==", 547 | "dev": true, 548 | "dependencies": { 549 | "@types/node": "*" 550 | } 551 | }, 552 | "node_modules/acorn": { 553 | "version": "8.11.3", 554 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 555 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 556 | "dev": true, 557 | "bin": { 558 | "acorn": "bin/acorn" 559 | }, 560 | "engines": { 561 | "node": ">=0.4.0" 562 | } 563 | }, 564 | "node_modules/acorn-walk": { 565 | "version": "8.3.2", 566 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.2.tgz", 567 | "integrity": "sha512-cjkyv4OtNCIeqhHrfS81QWXoCBPExR/J62oyEqepVw8WaQeSqpW2uhuLPh1m9eWhDuOo/jUXVTlifvesOWp/4A==", 568 | "dev": true, 569 | "engines": { 570 | "node": ">=0.4.0" 571 | } 572 | }, 573 | "node_modules/anymatch": { 574 | "version": "3.1.3", 575 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 576 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 577 | "dev": true, 578 | "dependencies": { 579 | "normalize-path": "^3.0.0", 580 | "picomatch": "^2.0.4" 581 | }, 582 | "engines": { 583 | "node": ">= 8" 584 | } 585 | }, 586 | "node_modules/as-table": { 587 | "version": "1.0.55", 588 | "resolved": "https://registry.npmjs.org/as-table/-/as-table-1.0.55.tgz", 589 | "integrity": "sha512-xvsWESUJn0JN421Xb9MQw6AsMHRCUknCe0Wjlxvjud80mU4E6hQf1A6NzQKcYNmYw62MfzEtXc+badstZP3JpQ==", 590 | "dev": true, 591 | "dependencies": { 592 | "printable-characters": "^1.0.42" 593 | } 594 | }, 595 | "node_modules/binary-extensions": { 596 | "version": "2.2.0", 597 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 598 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 599 | "dev": true, 600 | "engines": { 601 | "node": ">=8" 602 | } 603 | }, 604 | "node_modules/blake3-wasm": { 605 | "version": "2.1.5", 606 | "resolved": "https://registry.npmjs.org/blake3-wasm/-/blake3-wasm-2.1.5.tgz", 607 | "integrity": "sha512-F1+K8EbfOZE49dtoPtmxUQrpXaBIl3ICvasLh+nJta0xkz+9kF/7uet9fLnwKqhDrmj6g+6K3Tw9yQPUg2ka5g==", 608 | "dev": true 609 | }, 610 | "node_modules/braces": { 611 | "version": "3.0.3", 612 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 613 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 614 | "dev": true, 615 | "dependencies": { 616 | "fill-range": "^7.1.1" 617 | }, 618 | "engines": { 619 | "node": ">=8" 620 | } 621 | }, 622 | "node_modules/capnp-ts": { 623 | "version": "0.7.0", 624 | "resolved": "https://registry.npmjs.org/capnp-ts/-/capnp-ts-0.7.0.tgz", 625 | "integrity": "sha512-XKxXAC3HVPv7r674zP0VC3RTXz+/JKhfyw94ljvF80yynK6VkTnqE3jMuN8b3dUVmmc43TjyxjW4KTsmB3c86g==", 626 | "dev": true, 627 | "dependencies": { 628 | "debug": "^4.3.1", 629 | "tslib": "^2.2.0" 630 | } 631 | }, 632 | "node_modules/chokidar": { 633 | "version": "3.5.3", 634 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 635 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 636 | "dev": true, 637 | "funding": [ 638 | { 639 | "type": "individual", 640 | "url": "https://paulmillr.com/funding/" 641 | } 642 | ], 643 | "dependencies": { 644 | "anymatch": "~3.1.2", 645 | "braces": "~3.0.2", 646 | "glob-parent": "~5.1.2", 647 | "is-binary-path": "~2.1.0", 648 | "is-glob": "~4.0.1", 649 | "normalize-path": "~3.0.0", 650 | "readdirp": "~3.6.0" 651 | }, 652 | "engines": { 653 | "node": ">= 8.10.0" 654 | }, 655 | "optionalDependencies": { 656 | "fsevents": "~2.3.2" 657 | } 658 | }, 659 | "node_modules/cookie": { 660 | "version": "0.5.0", 661 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 662 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 663 | "dev": true, 664 | "engines": { 665 | "node": ">= 0.6" 666 | } 667 | }, 668 | "node_modules/data-uri-to-buffer": { 669 | "version": "2.0.2", 670 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-2.0.2.tgz", 671 | "integrity": "sha512-ND9qDTLc6diwj+Xe5cdAgVTbLVdXbtxTJRXRhli8Mowuaan+0EJOtdqJ0QCHNSSPyoXGx9HX2/VMnKeC34AChA==", 672 | "dev": true 673 | }, 674 | "node_modules/debug": { 675 | "version": "4.3.4", 676 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 677 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 678 | "dev": true, 679 | "dependencies": { 680 | "ms": "2.1.2" 681 | }, 682 | "engines": { 683 | "node": ">=6.0" 684 | }, 685 | "peerDependenciesMeta": { 686 | "supports-color": { 687 | "optional": true 688 | } 689 | } 690 | }, 691 | "node_modules/esbuild": { 692 | "version": "0.17.19", 693 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.19.tgz", 694 | "integrity": "sha512-XQ0jAPFkK/u3LcVRcvVHQcTIqD6E2H1fvZMA5dQPSOWb3suUbWbfbRf94pjc0bNzRYLfIrDRQXr7X+LHIm5oHw==", 695 | "dev": true, 696 | "hasInstallScript": true, 697 | "bin": { 698 | "esbuild": "bin/esbuild" 699 | }, 700 | "engines": { 701 | "node": ">=12" 702 | }, 703 | "optionalDependencies": { 704 | "@esbuild/android-arm": "0.17.19", 705 | "@esbuild/android-arm64": "0.17.19", 706 | "@esbuild/android-x64": "0.17.19", 707 | "@esbuild/darwin-arm64": "0.17.19", 708 | "@esbuild/darwin-x64": "0.17.19", 709 | "@esbuild/freebsd-arm64": "0.17.19", 710 | "@esbuild/freebsd-x64": "0.17.19", 711 | "@esbuild/linux-arm": "0.17.19", 712 | "@esbuild/linux-arm64": "0.17.19", 713 | "@esbuild/linux-ia32": "0.17.19", 714 | "@esbuild/linux-loong64": "0.17.19", 715 | "@esbuild/linux-mips64el": "0.17.19", 716 | "@esbuild/linux-ppc64": "0.17.19", 717 | "@esbuild/linux-riscv64": "0.17.19", 718 | "@esbuild/linux-s390x": "0.17.19", 719 | "@esbuild/linux-x64": "0.17.19", 720 | "@esbuild/netbsd-x64": "0.17.19", 721 | "@esbuild/openbsd-x64": "0.17.19", 722 | "@esbuild/sunos-x64": "0.17.19", 723 | "@esbuild/win32-arm64": "0.17.19", 724 | "@esbuild/win32-ia32": "0.17.19", 725 | "@esbuild/win32-x64": "0.17.19" 726 | } 727 | }, 728 | "node_modules/escape-string-regexp": { 729 | "version": "4.0.0", 730 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 731 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 732 | "dev": true, 733 | "engines": { 734 | "node": ">=10" 735 | }, 736 | "funding": { 737 | "url": "https://github.com/sponsors/sindresorhus" 738 | } 739 | }, 740 | "node_modules/estree-walker": { 741 | "version": "0.6.1", 742 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", 743 | "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", 744 | "dev": true 745 | }, 746 | "node_modules/exit-hook": { 747 | "version": "2.2.1", 748 | "resolved": "https://registry.npmjs.org/exit-hook/-/exit-hook-2.2.1.tgz", 749 | "integrity": "sha512-eNTPlAD67BmP31LDINZ3U7HSF8l57TxOY2PmBJ1shpCvpnxBF93mWCE8YHBnXs8qiUZJc9WDcWIeC3a2HIAMfw==", 750 | "dev": true, 751 | "engines": { 752 | "node": ">=6" 753 | }, 754 | "funding": { 755 | "url": "https://github.com/sponsors/sindresorhus" 756 | } 757 | }, 758 | "node_modules/fill-range": { 759 | "version": "7.1.1", 760 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 761 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 762 | "dev": true, 763 | "dependencies": { 764 | "to-regex-range": "^5.0.1" 765 | }, 766 | "engines": { 767 | "node": ">=8" 768 | } 769 | }, 770 | "node_modules/fsevents": { 771 | "version": "2.3.3", 772 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 773 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 774 | "dev": true, 775 | "hasInstallScript": true, 776 | "optional": true, 777 | "os": [ 778 | "darwin" 779 | ], 780 | "engines": { 781 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 782 | } 783 | }, 784 | "node_modules/function-bind": { 785 | "version": "1.1.2", 786 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 787 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 788 | "dev": true, 789 | "funding": { 790 | "url": "https://github.com/sponsors/ljharb" 791 | } 792 | }, 793 | "node_modules/get-source": { 794 | "version": "2.0.12", 795 | "resolved": "https://registry.npmjs.org/get-source/-/get-source-2.0.12.tgz", 796 | "integrity": "sha512-X5+4+iD+HoSeEED+uwrQ07BOQr0kEDFMVqqpBuI+RaZBpBpHCuXxo70bjar6f0b0u/DQJsJ7ssurpP0V60Az+w==", 797 | "dev": true, 798 | "dependencies": { 799 | "data-uri-to-buffer": "^2.0.0", 800 | "source-map": "^0.6.1" 801 | } 802 | }, 803 | "node_modules/glob-parent": { 804 | "version": "5.1.2", 805 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 806 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 807 | "dev": true, 808 | "dependencies": { 809 | "is-glob": "^4.0.1" 810 | }, 811 | "engines": { 812 | "node": ">= 6" 813 | } 814 | }, 815 | "node_modules/glob-to-regexp": { 816 | "version": "0.4.1", 817 | "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz", 818 | "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==", 819 | "dev": true 820 | }, 821 | "node_modules/hasown": { 822 | "version": "2.0.0", 823 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.0.tgz", 824 | "integrity": "sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA==", 825 | "dev": true, 826 | "dependencies": { 827 | "function-bind": "^1.1.2" 828 | }, 829 | "engines": { 830 | "node": ">= 0.4" 831 | } 832 | }, 833 | "node_modules/is-binary-path": { 834 | "version": "2.1.0", 835 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 836 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 837 | "dev": true, 838 | "dependencies": { 839 | "binary-extensions": "^2.0.0" 840 | }, 841 | "engines": { 842 | "node": ">=8" 843 | } 844 | }, 845 | "node_modules/is-core-module": { 846 | "version": "2.13.1", 847 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", 848 | "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", 849 | "dev": true, 850 | "dependencies": { 851 | "hasown": "^2.0.0" 852 | }, 853 | "funding": { 854 | "url": "https://github.com/sponsors/ljharb" 855 | } 856 | }, 857 | "node_modules/is-extglob": { 858 | "version": "2.1.1", 859 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 860 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 861 | "dev": true, 862 | "engines": { 863 | "node": ">=0.10.0" 864 | } 865 | }, 866 | "node_modules/is-glob": { 867 | "version": "4.0.3", 868 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 869 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 870 | "dev": true, 871 | "dependencies": { 872 | "is-extglob": "^2.1.1" 873 | }, 874 | "engines": { 875 | "node": ">=0.10.0" 876 | } 877 | }, 878 | "node_modules/is-number": { 879 | "version": "7.0.0", 880 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 881 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 882 | "dev": true, 883 | "engines": { 884 | "node": ">=0.12.0" 885 | } 886 | }, 887 | "node_modules/magic-string": { 888 | "version": "0.25.9", 889 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz", 890 | "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==", 891 | "dev": true, 892 | "dependencies": { 893 | "sourcemap-codec": "^1.4.8" 894 | } 895 | }, 896 | "node_modules/mime": { 897 | "version": "3.0.0", 898 | "resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz", 899 | "integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==", 900 | "dev": true, 901 | "bin": { 902 | "mime": "cli.js" 903 | }, 904 | "engines": { 905 | "node": ">=10.0.0" 906 | } 907 | }, 908 | "node_modules/miniflare": { 909 | "version": "3.20240419.1", 910 | "resolved": "https://registry.npmjs.org/miniflare/-/miniflare-3.20240419.1.tgz", 911 | "integrity": "sha512-Q9n0W07uUD/u0c/b03E4iogeXOAMjZnE3P7B5Yi8sPaZAx6TYWwjurGBja+Pg2yILN2iMaliEobfVyAKss33cA==", 912 | "dev": true, 913 | "dependencies": { 914 | "@cspotcode/source-map-support": "0.8.1", 915 | "acorn": "^8.8.0", 916 | "acorn-walk": "^8.2.0", 917 | "capnp-ts": "^0.7.0", 918 | "exit-hook": "^2.2.1", 919 | "glob-to-regexp": "^0.4.1", 920 | "stoppable": "^1.1.0", 921 | "undici": "^5.28.2", 922 | "workerd": "1.20240419.0", 923 | "ws": "^8.11.0", 924 | "youch": "^3.2.2", 925 | "zod": "^3.20.6" 926 | }, 927 | "bin": { 928 | "miniflare": "bootstrap.js" 929 | }, 930 | "engines": { 931 | "node": ">=16.13" 932 | } 933 | }, 934 | "node_modules/ms": { 935 | "version": "2.1.2", 936 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 937 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 938 | "dev": true 939 | }, 940 | "node_modules/mustache": { 941 | "version": "4.2.0", 942 | "resolved": "https://registry.npmjs.org/mustache/-/mustache-4.2.0.tgz", 943 | "integrity": "sha512-71ippSywq5Yb7/tVYyGbkBggbU8H3u5Rz56fH60jGFgr8uHwxs+aSKeqmluIVzM0m0kB7xQjKS6qPfd0b2ZoqQ==", 944 | "dev": true, 945 | "bin": { 946 | "mustache": "bin/mustache" 947 | } 948 | }, 949 | "node_modules/nanoid": { 950 | "version": "3.3.7", 951 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", 952 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", 953 | "dev": true, 954 | "funding": [ 955 | { 956 | "type": "github", 957 | "url": "https://github.com/sponsors/ai" 958 | } 959 | ], 960 | "bin": { 961 | "nanoid": "bin/nanoid.cjs" 962 | }, 963 | "engines": { 964 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 965 | } 966 | }, 967 | "node_modules/node-forge": { 968 | "version": "1.3.1", 969 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", 970 | "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==", 971 | "dev": true, 972 | "engines": { 973 | "node": ">= 6.13.0" 974 | } 975 | }, 976 | "node_modules/normalize-path": { 977 | "version": "3.0.0", 978 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 979 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 980 | "dev": true, 981 | "engines": { 982 | "node": ">=0.10.0" 983 | } 984 | }, 985 | "node_modules/path-parse": { 986 | "version": "1.0.7", 987 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 988 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 989 | "dev": true 990 | }, 991 | "node_modules/path-to-regexp": { 992 | "version": "6.2.1", 993 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz", 994 | "integrity": "sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw==", 995 | "dev": true 996 | }, 997 | "node_modules/picomatch": { 998 | "version": "2.3.1", 999 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1000 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1001 | "dev": true, 1002 | "engines": { 1003 | "node": ">=8.6" 1004 | }, 1005 | "funding": { 1006 | "url": "https://github.com/sponsors/jonschlinkert" 1007 | } 1008 | }, 1009 | "node_modules/printable-characters": { 1010 | "version": "1.0.42", 1011 | "resolved": "https://registry.npmjs.org/printable-characters/-/printable-characters-1.0.42.tgz", 1012 | "integrity": "sha512-dKp+C4iXWK4vVYZmYSd0KBH5F/h1HoZRsbJ82AVKRO3PEo8L4lBS/vLwhVtpwwuYcoIsVY+1JYKR268yn480uQ==", 1013 | "dev": true 1014 | }, 1015 | "node_modules/readdirp": { 1016 | "version": "3.6.0", 1017 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1018 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1019 | "dev": true, 1020 | "dependencies": { 1021 | "picomatch": "^2.2.1" 1022 | }, 1023 | "engines": { 1024 | "node": ">=8.10.0" 1025 | } 1026 | }, 1027 | "node_modules/resolve": { 1028 | "version": "1.22.8", 1029 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", 1030 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", 1031 | "dev": true, 1032 | "dependencies": { 1033 | "is-core-module": "^2.13.0", 1034 | "path-parse": "^1.0.7", 1035 | "supports-preserve-symlinks-flag": "^1.0.0" 1036 | }, 1037 | "bin": { 1038 | "resolve": "bin/resolve" 1039 | }, 1040 | "funding": { 1041 | "url": "https://github.com/sponsors/ljharb" 1042 | } 1043 | }, 1044 | "node_modules/resolve.exports": { 1045 | "version": "2.0.2", 1046 | "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.2.tgz", 1047 | "integrity": "sha512-X2UW6Nw3n/aMgDVy+0rSqgHlv39WZAlZrXCdnbyEiKm17DSqHX4MmQMaST3FbeWR5FTuRcUwYAziZajji0Y7mg==", 1048 | "dev": true, 1049 | "engines": { 1050 | "node": ">=10" 1051 | } 1052 | }, 1053 | "node_modules/rollup-plugin-inject": { 1054 | "version": "3.0.2", 1055 | "resolved": "https://registry.npmjs.org/rollup-plugin-inject/-/rollup-plugin-inject-3.0.2.tgz", 1056 | "integrity": "sha512-ptg9PQwzs3orn4jkgXJ74bfs5vYz1NCZlSQMBUA0wKcGp5i5pA1AO3fOUEte8enhGUC+iapTCzEWw2jEFFUO/w==", 1057 | "deprecated": "This package has been deprecated and is no longer maintained. Please use @rollup/plugin-inject.", 1058 | "dev": true, 1059 | "dependencies": { 1060 | "estree-walker": "^0.6.1", 1061 | "magic-string": "^0.25.3", 1062 | "rollup-pluginutils": "^2.8.1" 1063 | } 1064 | }, 1065 | "node_modules/rollup-plugin-node-polyfills": { 1066 | "version": "0.2.1", 1067 | "resolved": "https://registry.npmjs.org/rollup-plugin-node-polyfills/-/rollup-plugin-node-polyfills-0.2.1.tgz", 1068 | "integrity": "sha512-4kCrKPTJ6sK4/gLL/U5QzVT8cxJcofO0OU74tnB19F40cmuAKSzH5/siithxlofFEjwvw1YAhPmbvGNA6jEroA==", 1069 | "dev": true, 1070 | "dependencies": { 1071 | "rollup-plugin-inject": "^3.0.0" 1072 | } 1073 | }, 1074 | "node_modules/rollup-pluginutils": { 1075 | "version": "2.8.2", 1076 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", 1077 | "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", 1078 | "dev": true, 1079 | "dependencies": { 1080 | "estree-walker": "^0.6.1" 1081 | } 1082 | }, 1083 | "node_modules/selfsigned": { 1084 | "version": "2.4.1", 1085 | "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.4.1.tgz", 1086 | "integrity": "sha512-th5B4L2U+eGLq1TVh7zNRGBapioSORUeymIydxgFpwww9d2qyKvtuPU2jJuHvYAwwqi2Y596QBL3eEqcPEYL8Q==", 1087 | "dev": true, 1088 | "dependencies": { 1089 | "@types/node-forge": "^1.3.0", 1090 | "node-forge": "^1" 1091 | }, 1092 | "engines": { 1093 | "node": ">=10" 1094 | } 1095 | }, 1096 | "node_modules/source-map": { 1097 | "version": "0.6.1", 1098 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1099 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1100 | "dev": true, 1101 | "engines": { 1102 | "node": ">=0.10.0" 1103 | } 1104 | }, 1105 | "node_modules/sourcemap-codec": { 1106 | "version": "1.4.8", 1107 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 1108 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 1109 | "deprecated": "Please use @jridgewell/sourcemap-codec instead", 1110 | "dev": true 1111 | }, 1112 | "node_modules/stacktracey": { 1113 | "version": "2.1.8", 1114 | "resolved": "https://registry.npmjs.org/stacktracey/-/stacktracey-2.1.8.tgz", 1115 | "integrity": "sha512-Kpij9riA+UNg7TnphqjH7/CzctQ/owJGNbFkfEeve4Z4uxT5+JapVLFXcsurIfN34gnTWZNJ/f7NMG0E8JDzTw==", 1116 | "dev": true, 1117 | "dependencies": { 1118 | "as-table": "^1.0.36", 1119 | "get-source": "^2.0.12" 1120 | } 1121 | }, 1122 | "node_modules/stoppable": { 1123 | "version": "1.1.0", 1124 | "resolved": "https://registry.npmjs.org/stoppable/-/stoppable-1.1.0.tgz", 1125 | "integrity": "sha512-KXDYZ9dszj6bzvnEMRYvxgeTHU74QBFL54XKtP3nyMuJ81CFYtABZ3bAzL2EdFUaEwJOBOgENyFj3R7oTzDyyw==", 1126 | "dev": true, 1127 | "engines": { 1128 | "node": ">=4", 1129 | "npm": ">=6" 1130 | } 1131 | }, 1132 | "node_modules/supports-preserve-symlinks-flag": { 1133 | "version": "1.0.0", 1134 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1135 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1136 | "dev": true, 1137 | "engines": { 1138 | "node": ">= 0.4" 1139 | }, 1140 | "funding": { 1141 | "url": "https://github.com/sponsors/ljharb" 1142 | } 1143 | }, 1144 | "node_modules/to-regex-range": { 1145 | "version": "5.0.1", 1146 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1147 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1148 | "dev": true, 1149 | "dependencies": { 1150 | "is-number": "^7.0.0" 1151 | }, 1152 | "engines": { 1153 | "node": ">=8.0" 1154 | } 1155 | }, 1156 | "node_modules/tslib": { 1157 | "version": "2.6.2", 1158 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", 1159 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", 1160 | "dev": true 1161 | }, 1162 | "node_modules/typescript": { 1163 | "version": "5.3.3", 1164 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz", 1165 | "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==", 1166 | "dev": true, 1167 | "bin": { 1168 | "tsc": "bin/tsc", 1169 | "tsserver": "bin/tsserver" 1170 | }, 1171 | "engines": { 1172 | "node": ">=14.17" 1173 | } 1174 | }, 1175 | "node_modules/undici": { 1176 | "version": "5.28.4", 1177 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.28.4.tgz", 1178 | "integrity": "sha512-72RFADWFqKmUb2hmmvNODKL3p9hcB6Gt2DOQMis1SEBaV6a4MH8soBvzg+95CYhCKPFedut2JY9bMfrDl9D23g==", 1179 | "dev": true, 1180 | "dependencies": { 1181 | "@fastify/busboy": "^2.0.0" 1182 | }, 1183 | "engines": { 1184 | "node": ">=14.0" 1185 | } 1186 | }, 1187 | "node_modules/undici-types": { 1188 | "version": "5.26.5", 1189 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", 1190 | "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", 1191 | "dev": true 1192 | }, 1193 | "node_modules/workerd": { 1194 | "version": "1.20240419.0", 1195 | "resolved": "https://registry.npmjs.org/workerd/-/workerd-1.20240419.0.tgz", 1196 | "integrity": "sha512-9yV98KpkQgG+bdEsKEW8i1AYZgxns6NVSfdOVEB2Ue1pTMtIEYfUyqUE+O2amisRrfaC3Pw4EvjtTmVaoetfeg==", 1197 | "dev": true, 1198 | "hasInstallScript": true, 1199 | "bin": { 1200 | "workerd": "bin/workerd" 1201 | }, 1202 | "engines": { 1203 | "node": ">=16" 1204 | }, 1205 | "optionalDependencies": { 1206 | "@cloudflare/workerd-darwin-64": "1.20240419.0", 1207 | "@cloudflare/workerd-darwin-arm64": "1.20240419.0", 1208 | "@cloudflare/workerd-linux-64": "1.20240419.0", 1209 | "@cloudflare/workerd-linux-arm64": "1.20240419.0", 1210 | "@cloudflare/workerd-windows-64": "1.20240419.0" 1211 | } 1212 | }, 1213 | "node_modules/wrangler": { 1214 | "version": "3.55.0", 1215 | "resolved": "https://registry.npmjs.org/wrangler/-/wrangler-3.55.0.tgz", 1216 | "integrity": "sha512-VhtCioKxOdVqkHa8jQ6C6bX3by2Ko0uM0DKzrA+6lBZvfDUlGDWSOPiG+1fOHBHj2JTVBntxWCztXP6L+Udr8w==", 1217 | "dev": true, 1218 | "dependencies": { 1219 | "@cloudflare/kv-asset-handler": "0.3.2", 1220 | "@esbuild-plugins/node-globals-polyfill": "^0.2.3", 1221 | "@esbuild-plugins/node-modules-polyfill": "^0.2.2", 1222 | "blake3-wasm": "^2.1.5", 1223 | "chokidar": "^3.5.3", 1224 | "esbuild": "0.17.19", 1225 | "miniflare": "3.20240419.1", 1226 | "nanoid": "^3.3.3", 1227 | "path-to-regexp": "^6.2.0", 1228 | "resolve": "^1.22.8", 1229 | "resolve.exports": "^2.0.2", 1230 | "selfsigned": "^2.0.1", 1231 | "source-map": "0.6.1", 1232 | "xxhash-wasm": "^1.0.1" 1233 | }, 1234 | "bin": { 1235 | "wrangler": "bin/wrangler.js", 1236 | "wrangler2": "bin/wrangler.js" 1237 | }, 1238 | "engines": { 1239 | "node": ">=16.17.0" 1240 | }, 1241 | "optionalDependencies": { 1242 | "fsevents": "~2.3.2" 1243 | }, 1244 | "peerDependencies": { 1245 | "@cloudflare/workers-types": "^4.20240419.0" 1246 | }, 1247 | "peerDependenciesMeta": { 1248 | "@cloudflare/workers-types": { 1249 | "optional": true 1250 | } 1251 | } 1252 | }, 1253 | "node_modules/ws": { 1254 | "version": "8.17.1", 1255 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.17.1.tgz", 1256 | "integrity": "sha512-6XQFvXTkbfUOZOKKILFG1PDK2NDQs4azKQl26T0YS5CxqWLgXajbPZ+h4gZekJyRqFU8pvnbAbbs/3TgRPy+GQ==", 1257 | "dev": true, 1258 | "engines": { 1259 | "node": ">=10.0.0" 1260 | }, 1261 | "peerDependencies": { 1262 | "bufferutil": "^4.0.1", 1263 | "utf-8-validate": ">=5.0.2" 1264 | }, 1265 | "peerDependenciesMeta": { 1266 | "bufferutil": { 1267 | "optional": true 1268 | }, 1269 | "utf-8-validate": { 1270 | "optional": true 1271 | } 1272 | } 1273 | }, 1274 | "node_modules/xxhash-wasm": { 1275 | "version": "1.0.2", 1276 | "resolved": "https://registry.npmjs.org/xxhash-wasm/-/xxhash-wasm-1.0.2.tgz", 1277 | "integrity": "sha512-ibF0Or+FivM9lNrg+HGJfVX8WJqgo+kCLDc4vx6xMeTce7Aj+DLttKbxxRR/gNLSAelRc1omAPlJ77N/Jem07A==", 1278 | "dev": true 1279 | }, 1280 | "node_modules/youch": { 1281 | "version": "3.3.3", 1282 | "resolved": "https://registry.npmjs.org/youch/-/youch-3.3.3.tgz", 1283 | "integrity": "sha512-qSFXUk3UZBLfggAW3dJKg0BMblG5biqSF8M34E06o5CSsZtH92u9Hqmj2RzGiHDi64fhe83+4tENFP2DB6t6ZA==", 1284 | "dev": true, 1285 | "dependencies": { 1286 | "cookie": "^0.5.0", 1287 | "mustache": "^4.2.0", 1288 | "stacktracey": "^2.1.8" 1289 | } 1290 | }, 1291 | "node_modules/zod": { 1292 | "version": "3.23.8", 1293 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.23.8.tgz", 1294 | "integrity": "sha512-XBx9AXhXktjUqnepgTiE5flcKIYWi/rme0Eaj+5Y0lftuGBq+jyRu/md4WnuxqgP1ubdpNCsYEYPxrzVHD8d6g==", 1295 | "dev": true, 1296 | "funding": { 1297 | "url": "https://github.com/sponsors/colinhacks" 1298 | } 1299 | } 1300 | } 1301 | } 1302 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "sdxl", 3 | "version": "0.0.0", 4 | "private": true, 5 | "scripts": { 6 | "deploy": "wrangler deploy", 7 | "dev": "wrangler dev", 8 | "start": "wrangler dev" 9 | }, 10 | "devDependencies": { 11 | "@cloudflare/workers-types": "^4.20240502.0", 12 | "typescript": "^5.3.3", 13 | "wrangler": "^3.55.0" 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | export interface Env { 2 | AI: Ai; 3 | R2: R2Bucket; 4 | } 5 | 6 | export default { 7 | async fetch(request: Request, env: Env, ctx: ExecutionContext) { 8 | const ai = env.AI; 9 | const url = new URL(request.url); 10 | const params = url.searchParams; 11 | 12 | const inputs = { 13 | prompt: params.get('prompt') ?? 'small black cat', 14 | }; 15 | 16 | let response: Uint8Array = new Uint8Array(); 17 | 18 | try { 19 | response = await ai.run('@cf/stabilityai/stable-diffusion-xl-base-1.0', inputs); 20 | } catch (e) { 21 | if (e instanceof Error) { 22 | return new Response(e.name + '\n' + e.message + '\n' + e.stack, { status: 500 }); 23 | } 24 | } 25 | 26 | ctx.waitUntil(env.R2.put((params.get('prompt') ?? 'small black cat') + '/' + request.headers.get('cf-ray') + '.png', response)); 27 | 28 | return new Response(response, { 29 | headers: { 30 | 'content-type': 'image/png', 31 | }, 32 | }); 33 | }, 34 | }; 35 | -------------------------------------------------------------------------------- /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": ["es2021"] /* Specify a set of bundled library declaration files that describe the target runtime environment. */, 16 | "jsx": "react" /* Specify what JSX code is generated. */, 17 | // "experimentalDecorators": true, /* Enable experimental support for TC39 stage 2 draft decorators. */ 18 | // "emitDecoratorMetadata": true, /* Emit design-type metadata for decorated declarations in source files. */ 19 | // "jsxFactory": "", /* Specify the JSX factory function used when targeting React JSX emit, e.g. 'React.createElement' or 'h' */ 20 | // "jsxFragmentFactory": "", /* Specify the JSX Fragment reference used for fragments when targeting React JSX emit e.g. 'React.Fragment' or 'Fragment'. */ 21 | // "jsxImportSource": "", /* Specify module specifier used to import the JSX factory functions when using `jsx: react-jsx*`.` */ 22 | // "reactNamespace": "", /* Specify the object invoked for `createElement`. This only applies when targeting `react` JSX emit. */ 23 | // "noLib": true, /* Disable including any library files, including the default lib.d.ts. */ 24 | // "useDefineForClassFields": true, /* Emit ECMAScript-standard-compliant class fields. */ 25 | 26 | /* Modules */ 27 | "module": "es2022" /* Specify what module code is generated. */, 28 | // "rootDir": "./", /* Specify the root folder within your source files. */ 29 | "moduleResolution": "node" /* Specify how TypeScript looks up a file from a given module specifier. */, 30 | // "baseUrl": "./", /* Specify the base directory to resolve non-relative module names. */ 31 | // "paths": {}, /* Specify a set of entries that re-map imports to additional lookup locations. */ 32 | // "rootDirs": [], /* Allow multiple folders to be treated as one when resolving modules. */ 33 | // "typeRoots": [], /* Specify multiple folders that act like `./node_modules/@types`. */ 34 | "types": ["@cloudflare/workers-types/experimental"] /* Specify type package names to be included without being referenced in a source file. */, 35 | // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ 36 | "resolveJsonModule": true /* Enable importing .json files */, 37 | // "noResolve": true, /* Disallow `import`s, `require`s or ``s from expanding the number of files TypeScript should add to a project. */ 38 | 39 | /* JavaScript Support */ 40 | "allowJs": true /* Allow JavaScript files to be a part of your program. Use the `checkJS` option to get errors from these files. */, 41 | "checkJs": false /* Enable error reporting in type-checked JavaScript files. */, 42 | // "maxNodeModuleJsDepth": 1, /* Specify the maximum folder depth used for checking JavaScript files from `node_modules`. Only applicable with `allowJs`. */ 43 | 44 | /* Emit */ 45 | // "declaration": true, /* Generate .d.ts files from TypeScript and JavaScript files in your project. */ 46 | // "declarationMap": true, /* Create sourcemaps for d.ts files. */ 47 | // "emitDeclarationOnly": true, /* Only output d.ts files and not JavaScript files. */ 48 | // "sourceMap": true, /* Create source map files for emitted JavaScript files. */ 49 | // "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. */ 50 | // "outDir": "./", /* Specify an output folder for all emitted files. */ 51 | // "removeComments": true, /* Disable emitting comments. */ 52 | "noEmit": true /* Disable emitting files from a compilation. */, 53 | // "importHelpers": true, /* Allow importing helper functions from tslib once per project, instead of including them per-file. */ 54 | // "importsNotUsedAsValues": "remove", /* Specify emit/checking behavior for imports that are only used for types */ 55 | // "downlevelIteration": true, /* Emit more compliant, but verbose and less performant JavaScript for iteration. */ 56 | // "sourceRoot": "", /* Specify the root path for debuggers to find the reference source code. */ 57 | // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ 58 | // "inlineSourceMap": true, /* Include sourcemap files inside the emitted JavaScript. */ 59 | // "inlineSources": true, /* Include source code in the sourcemaps inside the emitted JavaScript. */ 60 | // "emitBOM": true, /* Emit a UTF-8 Byte Order Mark (BOM) in the beginning of output files. */ 61 | // "newLine": "crlf", /* Set the newline character for emitting files. */ 62 | // "stripInternal": true, /* Disable emitting declarations that have `@internal` in their JSDoc comments. */ 63 | // "noEmitHelpers": true, /* Disable generating custom helper functions like `__extends` in compiled output. */ 64 | // "noEmitOnError": true, /* Disable emitting files if any type checking errors are reported. */ 65 | // "preserveConstEnums": true, /* Disable erasing `const enum` declarations in generated code. */ 66 | // "declarationDir": "./", /* Specify the output directory for generated declaration files. */ 67 | // "preserveValueImports": true, /* Preserve unused imported values in the JavaScript output that would otherwise be removed. */ 68 | 69 | /* Interop Constraints */ 70 | "isolatedModules": true /* Ensure that each file can be safely transpiled without relying on other imports. */, 71 | "allowSyntheticDefaultImports": true /* Allow 'import x from y' when a module doesn't have a default export. */, 72 | // "esModuleInterop": true /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables `allowSyntheticDefaultImports` for type compatibility. */, 73 | // "preserveSymlinks": true, /* Disable resolving symlinks to their realpath. This correlates to the same flag in node. */ 74 | "forceConsistentCasingInFileNames": true /* Ensure that casing is correct in imports. */, 75 | 76 | /* Type Checking */ 77 | "strict": true /* Enable all strict type-checking options. */, 78 | // "noImplicitAny": true, /* Enable error reporting for expressions and declarations with an implied `any` type.. */ 79 | // "strictNullChecks": true, /* When type checking, take into account `null` and `undefined`. */ 80 | // "strictFunctionTypes": true, /* When assigning functions, check to ensure parameters and the return values are subtype-compatible. */ 81 | // "strictBindCallApply": true, /* Check that the arguments for `bind`, `call`, and `apply` methods match the original function. */ 82 | // "strictPropertyInitialization": true, /* Check for class properties that are declared but not set in the constructor. */ 83 | // "noImplicitThis": true, /* Enable error reporting when `this` is given the type `any`. */ 84 | // "useUnknownInCatchVariables": true, /* Type catch clause variables as 'unknown' instead of 'any'. */ 85 | // "alwaysStrict": true, /* Ensure 'use strict' is always emitted. */ 86 | // "noUnusedLocals": true, /* Enable error reporting when a local variables aren't read. */ 87 | // "noUnusedParameters": true, /* Raise an error when a function parameter isn't read */ 88 | // "exactOptionalPropertyTypes": true, /* Interpret optional property types as written, rather than adding 'undefined'. */ 89 | // "noImplicitReturns": true, /* Enable error reporting for codepaths that do not explicitly return in a function. */ 90 | // "noFallthroughCasesInSwitch": true, /* Enable error reporting for fallthrough cases in switch statements. */ 91 | // "noUncheckedIndexedAccess": true, /* Include 'undefined' in index signature results */ 92 | // "noImplicitOverride": true, /* Ensure overriding members in derived classes are marked with an override modifier. */ 93 | // "noPropertyAccessFromIndexSignature": true, /* Enforces using indexed accessors for keys declared using an indexed type */ 94 | // "allowUnusedLabels": true, /* Disable error reporting for unused labels. */ 95 | // "allowUnreachableCode": true, /* Disable error reporting for unreachable code. */ 96 | 97 | /* Completeness */ 98 | // "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */ 99 | "skipLibCheck": true /* Skip type checking all .d.ts files. */ 100 | } 101 | } 102 | -------------------------------------------------------------------------------- /wrangler.toml: -------------------------------------------------------------------------------- 1 | name = "sdxl" 2 | main = "src/index.ts" 3 | compatibility_date = "2023-10-30" 4 | 5 | [ai] 6 | binding = "AI" # i.e. available in your Worker on env.AI 7 | 8 | [[r2_buckets]] 9 | binding = "R2" 10 | bucket_name = "sdxl" 11 | preview_bucket_name = "sdxl" 12 | --------------------------------------------------------------------------------