├── .gitignore ├── GitHub-Starred-Notify ├── .editorconfig ├── .prettierrc ├── package-lock.json ├── package.json ├── src │ └── worker.ts ├── tsconfig.json └── wrangler.toml ├── LICENSE ├── README.md ├── index.js ├── main.gs └── package-lock.json /.gitignore: -------------------------------------------------------------------------------- 1 | .wrangler/ 2 | dist/ 3 | node_modules/ 4 | -------------------------------------------------------------------------------- /GitHub-Starred-Notify/.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 | -------------------------------------------------------------------------------- /GitHub-Starred-Notify/.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "printWidth": 140, 3 | "singleQuote": true, 4 | "semi": true, 5 | "useTabs": true 6 | } 7 | -------------------------------------------------------------------------------- /GitHub-Starred-Notify/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "GitHub-Starred-Notify", 3 | "version": "0.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "GitHub-Starred-Notify", 9 | "version": "0.0.0", 10 | "devDependencies": { 11 | "@cloudflare/workers-types": "^4.20230419.0", 12 | "typescript": "^5.0.4", 13 | "wrangler": "^3.0.0" 14 | } 15 | }, 16 | "node_modules/@cloudflare/kv-asset-handler": { 17 | "version": "0.2.0", 18 | "resolved": "https://registry.npmjs.org/@cloudflare/kv-asset-handler/-/kv-asset-handler-0.2.0.tgz", 19 | "integrity": "sha512-MVbXLbTcAotOPUj0pAMhVtJ+3/kFkwJqc5qNOleOZTv6QkZZABDMS21dSrSlVswEHwrpWC03e4fWytjqKvuE2A==", 20 | "dev": true, 21 | "dependencies": { 22 | "mime": "^3.0.0" 23 | } 24 | }, 25 | "node_modules/@cloudflare/workerd-darwin-64": { 26 | "version": "1.20230710.0", 27 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-darwin-64/-/workerd-darwin-64-1.20230710.0.tgz", 28 | "integrity": "sha512-TDEgTfzTkveW+U0qtg9/60PXbl2klnEso0oio501zAnY2SOC1x7M0qb8UkhvjHFUVpwdykUzTPWPIWFBcF1ibA==", 29 | "cpu": [ 30 | "x64" 31 | ], 32 | "dev": true, 33 | "optional": true, 34 | "os": [ 35 | "darwin" 36 | ], 37 | "engines": { 38 | "node": ">=16" 39 | } 40 | }, 41 | "node_modules/@cloudflare/workerd-darwin-arm64": { 42 | "version": "1.20230710.0", 43 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-darwin-arm64/-/workerd-darwin-arm64-1.20230710.0.tgz", 44 | "integrity": "sha512-dxBwnKcj7TiM1JGiODg0LASa25A9P0XLeMkmF8YCECZoq+3QLH/uY4Vbm1xeEy8iXUZrt/uYN72bBE83vY4HIQ==", 45 | "cpu": [ 46 | "arm64" 47 | ], 48 | "dev": true, 49 | "optional": true, 50 | "os": [ 51 | "darwin" 52 | ], 53 | "engines": { 54 | "node": ">=16" 55 | } 56 | }, 57 | "node_modules/@cloudflare/workerd-linux-64": { 58 | "version": "1.20230710.0", 59 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-linux-64/-/workerd-linux-64-1.20230710.0.tgz", 60 | "integrity": "sha512-WrKZwL76i51jQLFpSxklpRSm2s8T9Xf6tVzQaiLTtpguKZSF/CTAyjjEOVfS7FXk+Te8lyAJAFQnj5QHoJ3pzA==", 61 | "cpu": [ 62 | "x64" 63 | ], 64 | "dev": true, 65 | "optional": true, 66 | "os": [ 67 | "linux" 68 | ], 69 | "engines": { 70 | "node": ">=16" 71 | } 72 | }, 73 | "node_modules/@cloudflare/workerd-linux-arm64": { 74 | "version": "1.20230710.0", 75 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-linux-arm64/-/workerd-linux-arm64-1.20230710.0.tgz", 76 | "integrity": "sha512-eWdbOoqFqQ4m1/Wwy2dRDaOVXjOmWGjwBliU8pvm2m9RjfRTdfik7z6E3vOkalxqJDHiJ0f8SUykKz2oM1lD0A==", 77 | "cpu": [ 78 | "arm64" 79 | ], 80 | "dev": true, 81 | "optional": true, 82 | "os": [ 83 | "linux" 84 | ], 85 | "engines": { 86 | "node": ">=16" 87 | } 88 | }, 89 | "node_modules/@cloudflare/workerd-windows-64": { 90 | "version": "1.20230710.0", 91 | "resolved": "https://registry.npmjs.org/@cloudflare/workerd-windows-64/-/workerd-windows-64-1.20230710.0.tgz", 92 | "integrity": "sha512-P5ihH98Pb72HrsVsvb/HCSezvAvEtPeVQVBKgIclNE9e0fkA4zX9QMzBBFvLy3yr0YLf4r7MO2tNnt7JFnheGA==", 93 | "cpu": [ 94 | "x64" 95 | ], 96 | "dev": true, 97 | "optional": true, 98 | "os": [ 99 | "win32" 100 | ], 101 | "engines": { 102 | "node": ">=16" 103 | } 104 | }, 105 | "node_modules/@cloudflare/workers-types": { 106 | "version": "4.20230710.0", 107 | "resolved": "https://registry.npmjs.org/@cloudflare/workers-types/-/workers-types-4.20230710.0.tgz", 108 | "integrity": "sha512-bq0QMM51KyqTL/lIFUToT2AZfulO7pqwQvdZhjPMbxlIJADDNYeFd+GEQ6YGiGl5G/xxVEkpEql59sYlSfzYIg==", 109 | "dev": true 110 | }, 111 | "node_modules/@esbuild-plugins/node-globals-polyfill": { 112 | "version": "0.1.1", 113 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-globals-polyfill/-/node-globals-polyfill-0.1.1.tgz", 114 | "integrity": "sha512-MR0oAA+mlnJWrt1RQVQ+4VYuRJW/P2YmRTv1AsplObyvuBMnPHiizUF95HHYiSsMGLhyGtWufaq2XQg6+iurBg==", 115 | "dev": true, 116 | "peerDependencies": { 117 | "esbuild": "*" 118 | } 119 | }, 120 | "node_modules/@esbuild-plugins/node-modules-polyfill": { 121 | "version": "0.1.4", 122 | "resolved": "https://registry.npmjs.org/@esbuild-plugins/node-modules-polyfill/-/node-modules-polyfill-0.1.4.tgz", 123 | "integrity": "sha512-uZbcXi0zbmKC/050p3gJnne5Qdzw8vkXIv+c2BW0Lsc1ji1SkrxbKPUy5Efr0blbTu1SL8w4eyfpnSdPg3G0Qg==", 124 | "dev": true, 125 | "dependencies": { 126 | "escape-string-regexp": "^4.0.0", 127 | "rollup-plugin-node-polyfills": "^0.2.1" 128 | }, 129 | "peerDependencies": { 130 | "esbuild": "*" 131 | } 132 | }, 133 | "node_modules/@esbuild/android-arm": { 134 | "version": "0.16.3", 135 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.16.3.tgz", 136 | "integrity": "sha512-mueuEoh+s1eRbSJqq9KNBQwI4QhQV6sRXIfTyLXSHGMpyew61rOK4qY21uKbXl1iBoMb0AdL1deWFCQVlN2qHA==", 137 | "cpu": [ 138 | "arm" 139 | ], 140 | "dev": true, 141 | "optional": true, 142 | "os": [ 143 | "android" 144 | ], 145 | "engines": { 146 | "node": ">=12" 147 | } 148 | }, 149 | "node_modules/@esbuild/android-arm64": { 150 | "version": "0.16.3", 151 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.16.3.tgz", 152 | "integrity": "sha512-RolFVeinkeraDvN/OoRf1F/lP0KUfGNb5jxy/vkIMeRRChkrX/HTYN6TYZosRJs3a1+8wqpxAo5PI5hFmxyPRg==", 153 | "cpu": [ 154 | "arm64" 155 | ], 156 | "dev": true, 157 | "optional": true, 158 | "os": [ 159 | "android" 160 | ], 161 | "engines": { 162 | "node": ">=12" 163 | } 164 | }, 165 | "node_modules/@esbuild/android-x64": { 166 | "version": "0.16.3", 167 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.16.3.tgz", 168 | "integrity": "sha512-SFpTUcIT1bIJuCCBMCQWq1bL2gPTjWoLZdjmIhjdcQHaUfV41OQfho6Ici5uvvkMmZRXIUGpM3GxysP/EU7ifQ==", 169 | "cpu": [ 170 | "x64" 171 | ], 172 | "dev": true, 173 | "optional": true, 174 | "os": [ 175 | "android" 176 | ], 177 | "engines": { 178 | "node": ">=12" 179 | } 180 | }, 181 | "node_modules/@esbuild/darwin-arm64": { 182 | "version": "0.16.3", 183 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.16.3.tgz", 184 | "integrity": "sha512-DO8WykMyB+N9mIDfI/Hug70Dk1KipavlGAecxS3jDUwAbTpDXj0Lcwzw9svkhxfpCagDmpaTMgxWK8/C/XcXvw==", 185 | "cpu": [ 186 | "arm64" 187 | ], 188 | "dev": true, 189 | "optional": true, 190 | "os": [ 191 | "darwin" 192 | ], 193 | "engines": { 194 | "node": ">=12" 195 | } 196 | }, 197 | "node_modules/@esbuild/darwin-x64": { 198 | "version": "0.16.3", 199 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.16.3.tgz", 200 | "integrity": "sha512-uEqZQ2omc6BvWqdCiyZ5+XmxuHEi1SPzpVxXCSSV2+Sh7sbXbpeNhHIeFrIpRjAs0lI1FmA1iIOxFozKBhKgRQ==", 201 | "cpu": [ 202 | "x64" 203 | ], 204 | "dev": true, 205 | "optional": true, 206 | "os": [ 207 | "darwin" 208 | ], 209 | "engines": { 210 | "node": ">=12" 211 | } 212 | }, 213 | "node_modules/@esbuild/freebsd-arm64": { 214 | "version": "0.16.3", 215 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.16.3.tgz", 216 | "integrity": "sha512-nJansp3sSXakNkOD5i5mIz2Is/HjzIhFs49b1tjrPrpCmwgBmH9SSzhC/Z1UqlkivqMYkhfPwMw1dGFUuwmXhw==", 217 | "cpu": [ 218 | "arm64" 219 | ], 220 | "dev": true, 221 | "optional": true, 222 | "os": [ 223 | "freebsd" 224 | ], 225 | "engines": { 226 | "node": ">=12" 227 | } 228 | }, 229 | "node_modules/@esbuild/freebsd-x64": { 230 | "version": "0.16.3", 231 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.16.3.tgz", 232 | "integrity": "sha512-TfoDzLw+QHfc4a8aKtGSQ96Wa+6eimljjkq9HKR0rHlU83vw8aldMOUSJTUDxbcUdcgnJzPaX8/vGWm7vyV7ug==", 233 | "cpu": [ 234 | "x64" 235 | ], 236 | "dev": true, 237 | "optional": true, 238 | "os": [ 239 | "freebsd" 240 | ], 241 | "engines": { 242 | "node": ">=12" 243 | } 244 | }, 245 | "node_modules/@esbuild/linux-arm": { 246 | "version": "0.16.3", 247 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.16.3.tgz", 248 | "integrity": "sha512-VwswmSYwVAAq6LysV59Fyqk3UIjbhuc6wb3vEcJ7HEJUtFuLK9uXWuFoH1lulEbE4+5GjtHi3MHX+w1gNHdOWQ==", 249 | "cpu": [ 250 | "arm" 251 | ], 252 | "dev": true, 253 | "optional": true, 254 | "os": [ 255 | "linux" 256 | ], 257 | "engines": { 258 | "node": ">=12" 259 | } 260 | }, 261 | "node_modules/@esbuild/linux-arm64": { 262 | "version": "0.16.3", 263 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.16.3.tgz", 264 | "integrity": "sha512-7I3RlsnxEFCHVZNBLb2w7unamgZ5sVwO0/ikE2GaYvYuUQs9Qte/w7TqWcXHtCwxvZx/2+F97ndiUQAWs47ZfQ==", 265 | "cpu": [ 266 | "arm64" 267 | ], 268 | "dev": true, 269 | "optional": true, 270 | "os": [ 271 | "linux" 272 | ], 273 | "engines": { 274 | "node": ">=12" 275 | } 276 | }, 277 | "node_modules/@esbuild/linux-ia32": { 278 | "version": "0.16.3", 279 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.16.3.tgz", 280 | "integrity": "sha512-X8FDDxM9cqda2rJE+iblQhIMYY49LfvW4kaEjoFbTTQ4Go8G96Smj2w3BRTwA8IHGoi9dPOPGAX63dhuv19UqA==", 281 | "cpu": [ 282 | "ia32" 283 | ], 284 | "dev": true, 285 | "optional": true, 286 | "os": [ 287 | "linux" 288 | ], 289 | "engines": { 290 | "node": ">=12" 291 | } 292 | }, 293 | "node_modules/@esbuild/linux-loong64": { 294 | "version": "0.16.3", 295 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.16.3.tgz", 296 | "integrity": "sha512-hIbeejCOyO0X9ujfIIOKjBjNAs9XD/YdJ9JXAy1lHA+8UXuOqbFe4ErMCqMr8dhlMGBuvcQYGF7+kO7waj2KHw==", 297 | "cpu": [ 298 | "loong64" 299 | ], 300 | "dev": true, 301 | "optional": true, 302 | "os": [ 303 | "linux" 304 | ], 305 | "engines": { 306 | "node": ">=12" 307 | } 308 | }, 309 | "node_modules/@esbuild/linux-mips64el": { 310 | "version": "0.16.3", 311 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.16.3.tgz", 312 | "integrity": "sha512-znFRzICT/V8VZQMt6rjb21MtAVJv/3dmKRMlohlShrbVXdBuOdDrGb+C2cZGQAR8RFyRe7HS6klmHq103WpmVw==", 313 | "cpu": [ 314 | "mips64el" 315 | ], 316 | "dev": true, 317 | "optional": true, 318 | "os": [ 319 | "linux" 320 | ], 321 | "engines": { 322 | "node": ">=12" 323 | } 324 | }, 325 | "node_modules/@esbuild/linux-ppc64": { 326 | "version": "0.16.3", 327 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.16.3.tgz", 328 | "integrity": "sha512-EV7LuEybxhXrVTDpbqWF2yehYRNz5e5p+u3oQUS2+ZFpknyi1NXxr8URk4ykR8Efm7iu04//4sBg249yNOwy5Q==", 329 | "cpu": [ 330 | "ppc64" 331 | ], 332 | "dev": true, 333 | "optional": true, 334 | "os": [ 335 | "linux" 336 | ], 337 | "engines": { 338 | "node": ">=12" 339 | } 340 | }, 341 | "node_modules/@esbuild/linux-riscv64": { 342 | "version": "0.16.3", 343 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.16.3.tgz", 344 | "integrity": "sha512-uDxqFOcLzFIJ+r/pkTTSE9lsCEaV/Y6rMlQjUI9BkzASEChYL/aSQjZjchtEmdnVxDKETnUAmsaZ4pqK1eE5BQ==", 345 | "cpu": [ 346 | "riscv64" 347 | ], 348 | "dev": true, 349 | "optional": true, 350 | "os": [ 351 | "linux" 352 | ], 353 | "engines": { 354 | "node": ">=12" 355 | } 356 | }, 357 | "node_modules/@esbuild/linux-s390x": { 358 | "version": "0.16.3", 359 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.16.3.tgz", 360 | "integrity": "sha512-NbeREhzSxYwFhnCAQOQZmajsPYtX71Ufej3IQ8W2Gxskfz9DK58ENEju4SbpIj48VenktRASC52N5Fhyf/aliQ==", 361 | "cpu": [ 362 | "s390x" 363 | ], 364 | "dev": true, 365 | "optional": true, 366 | "os": [ 367 | "linux" 368 | ], 369 | "engines": { 370 | "node": ">=12" 371 | } 372 | }, 373 | "node_modules/@esbuild/linux-x64": { 374 | "version": "0.16.3", 375 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.16.3.tgz", 376 | "integrity": "sha512-SDiG0nCixYO9JgpehoKgScwic7vXXndfasjnD5DLbp1xltANzqZ425l7LSdHynt19UWOcDjG9wJJzSElsPvk0w==", 377 | "cpu": [ 378 | "x64" 379 | ], 380 | "dev": true, 381 | "optional": true, 382 | "os": [ 383 | "linux" 384 | ], 385 | "engines": { 386 | "node": ">=12" 387 | } 388 | }, 389 | "node_modules/@esbuild/netbsd-x64": { 390 | "version": "0.16.3", 391 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.16.3.tgz", 392 | "integrity": "sha512-AzbsJqiHEq1I/tUvOfAzCY15h4/7Ivp3ff/o1GpP16n48JMNAtbW0qui2WCgoIZArEHD0SUQ95gvR0oSO7ZbdA==", 393 | "cpu": [ 394 | "x64" 395 | ], 396 | "dev": true, 397 | "optional": true, 398 | "os": [ 399 | "netbsd" 400 | ], 401 | "engines": { 402 | "node": ">=12" 403 | } 404 | }, 405 | "node_modules/@esbuild/openbsd-x64": { 406 | "version": "0.16.3", 407 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.16.3.tgz", 408 | "integrity": "sha512-gSABi8qHl8k3Cbi/4toAzHiykuBuWLZs43JomTcXkjMZVkp0gj3gg9mO+9HJW/8GB5H89RX/V0QP4JGL7YEEVg==", 409 | "cpu": [ 410 | "x64" 411 | ], 412 | "dev": true, 413 | "optional": true, 414 | "os": [ 415 | "openbsd" 416 | ], 417 | "engines": { 418 | "node": ">=12" 419 | } 420 | }, 421 | "node_modules/@esbuild/sunos-x64": { 422 | "version": "0.16.3", 423 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.16.3.tgz", 424 | "integrity": "sha512-SF9Kch5Ete4reovvRO6yNjMxrvlfT0F0Flm+NPoUw5Z4Q3r1d23LFTgaLwm3Cp0iGbrU/MoUI+ZqwCv5XJijCw==", 425 | "cpu": [ 426 | "x64" 427 | ], 428 | "dev": true, 429 | "optional": true, 430 | "os": [ 431 | "sunos" 432 | ], 433 | "engines": { 434 | "node": ">=12" 435 | } 436 | }, 437 | "node_modules/@esbuild/win32-arm64": { 438 | "version": "0.16.3", 439 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.16.3.tgz", 440 | "integrity": "sha512-u5aBonZIyGopAZyOnoPAA6fGsDeHByZ9CnEzyML9NqntK6D/xl5jteZUKm/p6nD09+v3pTM6TuUIqSPcChk5gg==", 441 | "cpu": [ 442 | "arm64" 443 | ], 444 | "dev": true, 445 | "optional": true, 446 | "os": [ 447 | "win32" 448 | ], 449 | "engines": { 450 | "node": ">=12" 451 | } 452 | }, 453 | "node_modules/@esbuild/win32-ia32": { 454 | "version": "0.16.3", 455 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.16.3.tgz", 456 | "integrity": "sha512-GlgVq1WpvOEhNioh74TKelwla9KDuAaLZrdxuuUgsP2vayxeLgVc+rbpIv0IYF4+tlIzq2vRhofV+KGLD+37EQ==", 457 | "cpu": [ 458 | "ia32" 459 | ], 460 | "dev": true, 461 | "optional": true, 462 | "os": [ 463 | "win32" 464 | ], 465 | "engines": { 466 | "node": ">=12" 467 | } 468 | }, 469 | "node_modules/@esbuild/win32-x64": { 470 | "version": "0.16.3", 471 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.16.3.tgz", 472 | "integrity": "sha512-5/JuTd8OWW8UzEtyf19fbrtMJENza+C9JoPIkvItgTBQ1FO2ZLvjbPO6Xs54vk0s5JB5QsfieUEshRQfu7ZHow==", 473 | "cpu": [ 474 | "x64" 475 | ], 476 | "dev": true, 477 | "optional": true, 478 | "os": [ 479 | "win32" 480 | ], 481 | "engines": { 482 | "node": ">=12" 483 | } 484 | }, 485 | "node_modules/acorn": { 486 | "version": "8.10.0", 487 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz", 488 | "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==", 489 | "dev": true, 490 | "bin": { 491 | "acorn": "bin/acorn" 492 | }, 493 | "engines": { 494 | "node": ">=0.4.0" 495 | } 496 | }, 497 | "node_modules/acorn-walk": { 498 | "version": "8.2.0", 499 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 500 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 501 | "dev": true, 502 | "engines": { 503 | "node": ">=0.4.0" 504 | } 505 | }, 506 | "node_modules/anymatch": { 507 | "version": "3.1.3", 508 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 509 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 510 | "dev": true, 511 | "dependencies": { 512 | "normalize-path": "^3.0.0", 513 | "picomatch": "^2.0.4" 514 | }, 515 | "engines": { 516 | "node": ">= 8" 517 | } 518 | }, 519 | "node_modules/as-table": { 520 | "version": "1.0.55", 521 | "resolved": "https://registry.npmjs.org/as-table/-/as-table-1.0.55.tgz", 522 | "integrity": "sha512-xvsWESUJn0JN421Xb9MQw6AsMHRCUknCe0Wjlxvjud80mU4E6hQf1A6NzQKcYNmYw62MfzEtXc+badstZP3JpQ==", 523 | "dev": true, 524 | "dependencies": { 525 | "printable-characters": "^1.0.42" 526 | } 527 | }, 528 | "node_modules/base64-js": { 529 | "version": "1.5.1", 530 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 531 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 532 | "dev": true, 533 | "funding": [ 534 | { 535 | "type": "github", 536 | "url": "https://github.com/sponsors/feross" 537 | }, 538 | { 539 | "type": "patreon", 540 | "url": "https://www.patreon.com/feross" 541 | }, 542 | { 543 | "type": "consulting", 544 | "url": "https://feross.org/support" 545 | } 546 | ] 547 | }, 548 | "node_modules/better-sqlite3": { 549 | "version": "8.4.0", 550 | "resolved": "https://registry.npmjs.org/better-sqlite3/-/better-sqlite3-8.4.0.tgz", 551 | "integrity": "sha512-NmsNW1CQvqMszu/CFAJ3pLct6NEFlNfuGM6vw72KHkjOD1UDnL96XNN1BMQc1hiHo8vE2GbOWQYIpZ+YM5wrZw==", 552 | "dev": true, 553 | "hasInstallScript": true, 554 | "dependencies": { 555 | "bindings": "^1.5.0", 556 | "prebuild-install": "^7.1.0" 557 | } 558 | }, 559 | "node_modules/binary-extensions": { 560 | "version": "2.2.0", 561 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 562 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 563 | "dev": true, 564 | "engines": { 565 | "node": ">=8" 566 | } 567 | }, 568 | "node_modules/bindings": { 569 | "version": "1.5.0", 570 | "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", 571 | "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", 572 | "dev": true, 573 | "dependencies": { 574 | "file-uri-to-path": "1.0.0" 575 | } 576 | }, 577 | "node_modules/bl": { 578 | "version": "4.1.0", 579 | "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz", 580 | "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==", 581 | "dev": true, 582 | "dependencies": { 583 | "buffer": "^5.5.0", 584 | "inherits": "^2.0.4", 585 | "readable-stream": "^3.4.0" 586 | } 587 | }, 588 | "node_modules/blake3-wasm": { 589 | "version": "2.1.5", 590 | "resolved": "https://registry.npmjs.org/blake3-wasm/-/blake3-wasm-2.1.5.tgz", 591 | "integrity": "sha512-F1+K8EbfOZE49dtoPtmxUQrpXaBIl3ICvasLh+nJta0xkz+9kF/7uet9fLnwKqhDrmj6g+6K3Tw9yQPUg2ka5g==", 592 | "dev": true 593 | }, 594 | "node_modules/braces": { 595 | "version": "3.0.2", 596 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 597 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 598 | "dev": true, 599 | "dependencies": { 600 | "fill-range": "^7.0.1" 601 | }, 602 | "engines": { 603 | "node": ">=8" 604 | } 605 | }, 606 | "node_modules/buffer": { 607 | "version": "5.7.1", 608 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", 609 | "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", 610 | "dev": true, 611 | "funding": [ 612 | { 613 | "type": "github", 614 | "url": "https://github.com/sponsors/feross" 615 | }, 616 | { 617 | "type": "patreon", 618 | "url": "https://www.patreon.com/feross" 619 | }, 620 | { 621 | "type": "consulting", 622 | "url": "https://feross.org/support" 623 | } 624 | ], 625 | "dependencies": { 626 | "base64-js": "^1.3.1", 627 | "ieee754": "^1.1.13" 628 | } 629 | }, 630 | "node_modules/buffer-from": { 631 | "version": "1.1.2", 632 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 633 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 634 | "dev": true 635 | }, 636 | "node_modules/busboy": { 637 | "version": "1.6.0", 638 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", 639 | "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", 640 | "dev": true, 641 | "dependencies": { 642 | "streamsearch": "^1.1.0" 643 | }, 644 | "engines": { 645 | "node": ">=10.16.0" 646 | } 647 | }, 648 | "node_modules/capnp-ts": { 649 | "version": "0.7.0", 650 | "resolved": "https://registry.npmjs.org/capnp-ts/-/capnp-ts-0.7.0.tgz", 651 | "integrity": "sha512-XKxXAC3HVPv7r674zP0VC3RTXz+/JKhfyw94ljvF80yynK6VkTnqE3jMuN8b3dUVmmc43TjyxjW4KTsmB3c86g==", 652 | "dev": true, 653 | "dependencies": { 654 | "debug": "^4.3.1", 655 | "tslib": "^2.2.0" 656 | } 657 | }, 658 | "node_modules/chokidar": { 659 | "version": "3.5.3", 660 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 661 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 662 | "dev": true, 663 | "funding": [ 664 | { 665 | "type": "individual", 666 | "url": "https://paulmillr.com/funding/" 667 | } 668 | ], 669 | "dependencies": { 670 | "anymatch": "~3.1.2", 671 | "braces": "~3.0.2", 672 | "glob-parent": "~5.1.2", 673 | "is-binary-path": "~2.1.0", 674 | "is-glob": "~4.0.1", 675 | "normalize-path": "~3.0.0", 676 | "readdirp": "~3.6.0" 677 | }, 678 | "engines": { 679 | "node": ">= 8.10.0" 680 | }, 681 | "optionalDependencies": { 682 | "fsevents": "~2.3.2" 683 | } 684 | }, 685 | "node_modules/chownr": { 686 | "version": "1.1.4", 687 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", 688 | "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", 689 | "dev": true 690 | }, 691 | "node_modules/cookie": { 692 | "version": "0.5.0", 693 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 694 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 695 | "dev": true, 696 | "engines": { 697 | "node": ">= 0.6" 698 | } 699 | }, 700 | "node_modules/data-uri-to-buffer": { 701 | "version": "2.0.2", 702 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-2.0.2.tgz", 703 | "integrity": "sha512-ND9qDTLc6diwj+Xe5cdAgVTbLVdXbtxTJRXRhli8Mowuaan+0EJOtdqJ0QCHNSSPyoXGx9HX2/VMnKeC34AChA==", 704 | "dev": true 705 | }, 706 | "node_modules/debug": { 707 | "version": "4.3.4", 708 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 709 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 710 | "dev": true, 711 | "dependencies": { 712 | "ms": "2.1.2" 713 | }, 714 | "engines": { 715 | "node": ">=6.0" 716 | }, 717 | "peerDependenciesMeta": { 718 | "supports-color": { 719 | "optional": true 720 | } 721 | } 722 | }, 723 | "node_modules/decompress-response": { 724 | "version": "6.0.0", 725 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-6.0.0.tgz", 726 | "integrity": "sha512-aW35yZM6Bb/4oJlZncMH2LCoZtJXTRxES17vE3hoRiowU2kWHaJKFkSBDnDR+cm9J+9QhXmREyIfv0pji9ejCQ==", 727 | "dev": true, 728 | "dependencies": { 729 | "mimic-response": "^3.1.0" 730 | }, 731 | "engines": { 732 | "node": ">=10" 733 | }, 734 | "funding": { 735 | "url": "https://github.com/sponsors/sindresorhus" 736 | } 737 | }, 738 | "node_modules/deep-extend": { 739 | "version": "0.6.0", 740 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 741 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 742 | "dev": true, 743 | "engines": { 744 | "node": ">=4.0.0" 745 | } 746 | }, 747 | "node_modules/detect-libc": { 748 | "version": "2.0.1", 749 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.1.tgz", 750 | "integrity": "sha512-463v3ZeIrcWtdgIg6vI6XUncguvr2TnGl4SzDXinkt9mSLpBJKXT3mW6xT3VQdDN11+WVs29pgvivTc4Lp8v+w==", 751 | "dev": true, 752 | "engines": { 753 | "node": ">=8" 754 | } 755 | }, 756 | "node_modules/end-of-stream": { 757 | "version": "1.4.4", 758 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 759 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 760 | "dev": true, 761 | "dependencies": { 762 | "once": "^1.4.0" 763 | } 764 | }, 765 | "node_modules/esbuild": { 766 | "version": "0.16.3", 767 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.16.3.tgz", 768 | "integrity": "sha512-71f7EjPWTiSguen8X/kxEpkAS7BFHwtQKisCDDV3Y4GLGWBaoSCyD5uXkaUew6JDzA9FEN1W23mdnSwW9kqCeg==", 769 | "dev": true, 770 | "hasInstallScript": true, 771 | "bin": { 772 | "esbuild": "bin/esbuild" 773 | }, 774 | "engines": { 775 | "node": ">=12" 776 | }, 777 | "optionalDependencies": { 778 | "@esbuild/android-arm": "0.16.3", 779 | "@esbuild/android-arm64": "0.16.3", 780 | "@esbuild/android-x64": "0.16.3", 781 | "@esbuild/darwin-arm64": "0.16.3", 782 | "@esbuild/darwin-x64": "0.16.3", 783 | "@esbuild/freebsd-arm64": "0.16.3", 784 | "@esbuild/freebsd-x64": "0.16.3", 785 | "@esbuild/linux-arm": "0.16.3", 786 | "@esbuild/linux-arm64": "0.16.3", 787 | "@esbuild/linux-ia32": "0.16.3", 788 | "@esbuild/linux-loong64": "0.16.3", 789 | "@esbuild/linux-mips64el": "0.16.3", 790 | "@esbuild/linux-ppc64": "0.16.3", 791 | "@esbuild/linux-riscv64": "0.16.3", 792 | "@esbuild/linux-s390x": "0.16.3", 793 | "@esbuild/linux-x64": "0.16.3", 794 | "@esbuild/netbsd-x64": "0.16.3", 795 | "@esbuild/openbsd-x64": "0.16.3", 796 | "@esbuild/sunos-x64": "0.16.3", 797 | "@esbuild/win32-arm64": "0.16.3", 798 | "@esbuild/win32-ia32": "0.16.3", 799 | "@esbuild/win32-x64": "0.16.3" 800 | } 801 | }, 802 | "node_modules/escape-string-regexp": { 803 | "version": "4.0.0", 804 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 805 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 806 | "dev": true, 807 | "engines": { 808 | "node": ">=10" 809 | }, 810 | "funding": { 811 | "url": "https://github.com/sponsors/sindresorhus" 812 | } 813 | }, 814 | "node_modules/estree-walker": { 815 | "version": "0.6.1", 816 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", 817 | "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", 818 | "dev": true 819 | }, 820 | "node_modules/exit-hook": { 821 | "version": "2.2.1", 822 | "resolved": "https://registry.npmjs.org/exit-hook/-/exit-hook-2.2.1.tgz", 823 | "integrity": "sha512-eNTPlAD67BmP31LDINZ3U7HSF8l57TxOY2PmBJ1shpCvpnxBF93mWCE8YHBnXs8qiUZJc9WDcWIeC3a2HIAMfw==", 824 | "dev": true, 825 | "engines": { 826 | "node": ">=6" 827 | }, 828 | "funding": { 829 | "url": "https://github.com/sponsors/sindresorhus" 830 | } 831 | }, 832 | "node_modules/expand-template": { 833 | "version": "2.0.3", 834 | "resolved": "https://registry.npmjs.org/expand-template/-/expand-template-2.0.3.tgz", 835 | "integrity": "sha512-XYfuKMvj4O35f/pOXLObndIRvyQ+/+6AhODh+OKWj9S9498pHHn/IMszH+gt0fBCRWMNfk1ZSp5x3AifmnI2vg==", 836 | "dev": true, 837 | "engines": { 838 | "node": ">=6" 839 | } 840 | }, 841 | "node_modules/file-uri-to-path": { 842 | "version": "1.0.0", 843 | "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", 844 | "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", 845 | "dev": true 846 | }, 847 | "node_modules/fill-range": { 848 | "version": "7.0.1", 849 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 850 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 851 | "dev": true, 852 | "dependencies": { 853 | "to-regex-range": "^5.0.1" 854 | }, 855 | "engines": { 856 | "node": ">=8" 857 | } 858 | }, 859 | "node_modules/fs-constants": { 860 | "version": "1.0.0", 861 | "resolved": "https://registry.npmjs.org/fs-constants/-/fs-constants-1.0.0.tgz", 862 | "integrity": "sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==", 863 | "dev": true 864 | }, 865 | "node_modules/fsevents": { 866 | "version": "2.3.2", 867 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 868 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 869 | "dev": true, 870 | "hasInstallScript": true, 871 | "optional": true, 872 | "os": [ 873 | "darwin" 874 | ], 875 | "engines": { 876 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 877 | } 878 | }, 879 | "node_modules/get-source": { 880 | "version": "2.0.12", 881 | "resolved": "https://registry.npmjs.org/get-source/-/get-source-2.0.12.tgz", 882 | "integrity": "sha512-X5+4+iD+HoSeEED+uwrQ07BOQr0kEDFMVqqpBuI+RaZBpBpHCuXxo70bjar6f0b0u/DQJsJ7ssurpP0V60Az+w==", 883 | "dev": true, 884 | "dependencies": { 885 | "data-uri-to-buffer": "^2.0.0", 886 | "source-map": "^0.6.1" 887 | } 888 | }, 889 | "node_modules/get-source/node_modules/source-map": { 890 | "version": "0.6.1", 891 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 892 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 893 | "dev": true, 894 | "engines": { 895 | "node": ">=0.10.0" 896 | } 897 | }, 898 | "node_modules/github-from-package": { 899 | "version": "0.0.0", 900 | "resolved": "https://registry.npmjs.org/github-from-package/-/github-from-package-0.0.0.tgz", 901 | "integrity": "sha512-SyHy3T1v2NUXn29OsWdxmK6RwHD+vkj3v8en8AOBZ1wBQ/hCAQ5bAQTD02kW4W9tUp/3Qh6J8r9EvntiyCmOOw==", 902 | "dev": true 903 | }, 904 | "node_modules/glob-parent": { 905 | "version": "5.1.2", 906 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 907 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 908 | "dev": true, 909 | "dependencies": { 910 | "is-glob": "^4.0.1" 911 | }, 912 | "engines": { 913 | "node": ">= 6" 914 | } 915 | }, 916 | "node_modules/glob-to-regexp": { 917 | "version": "0.4.1", 918 | "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz", 919 | "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==", 920 | "dev": true 921 | }, 922 | "node_modules/http-cache-semantics": { 923 | "version": "4.1.1", 924 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz", 925 | "integrity": "sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==", 926 | "dev": true 927 | }, 928 | "node_modules/ieee754": { 929 | "version": "1.2.1", 930 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 931 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", 932 | "dev": true, 933 | "funding": [ 934 | { 935 | "type": "github", 936 | "url": "https://github.com/sponsors/feross" 937 | }, 938 | { 939 | "type": "patreon", 940 | "url": "https://www.patreon.com/feross" 941 | }, 942 | { 943 | "type": "consulting", 944 | "url": "https://feross.org/support" 945 | } 946 | ] 947 | }, 948 | "node_modules/inherits": { 949 | "version": "2.0.4", 950 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 951 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 952 | "dev": true 953 | }, 954 | "node_modules/ini": { 955 | "version": "1.3.8", 956 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 957 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==", 958 | "dev": true 959 | }, 960 | "node_modules/is-binary-path": { 961 | "version": "2.1.0", 962 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 963 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 964 | "dev": true, 965 | "dependencies": { 966 | "binary-extensions": "^2.0.0" 967 | }, 968 | "engines": { 969 | "node": ">=8" 970 | } 971 | }, 972 | "node_modules/is-extglob": { 973 | "version": "2.1.1", 974 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 975 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 976 | "dev": true, 977 | "engines": { 978 | "node": ">=0.10.0" 979 | } 980 | }, 981 | "node_modules/is-glob": { 982 | "version": "4.0.3", 983 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 984 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 985 | "dev": true, 986 | "dependencies": { 987 | "is-extglob": "^2.1.1" 988 | }, 989 | "engines": { 990 | "node": ">=0.10.0" 991 | } 992 | }, 993 | "node_modules/is-number": { 994 | "version": "7.0.0", 995 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 996 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 997 | "dev": true, 998 | "engines": { 999 | "node": ">=0.12.0" 1000 | } 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/mime": { 1033 | "version": "3.0.0", 1034 | "resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz", 1035 | "integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==", 1036 | "dev": true, 1037 | "bin": { 1038 | "mime": "cli.js" 1039 | }, 1040 | "engines": { 1041 | "node": ">=10.0.0" 1042 | } 1043 | }, 1044 | "node_modules/mimic-response": { 1045 | "version": "3.1.0", 1046 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-3.1.0.tgz", 1047 | "integrity": "sha512-z0yWI+4FDrrweS8Zmt4Ej5HdJmky15+L2e6Wgn3+iK5fWzb6T3fhNFq2+MeTRb064c6Wr4N/wv0DzQTjNzHNGQ==", 1048 | "dev": true, 1049 | "engines": { 1050 | "node": ">=10" 1051 | }, 1052 | "funding": { 1053 | "url": "https://github.com/sponsors/sindresorhus" 1054 | } 1055 | }, 1056 | "node_modules/miniflare": { 1057 | "version": "3.20230710.0", 1058 | "resolved": "https://registry.npmjs.org/miniflare/-/miniflare-3.20230710.0.tgz", 1059 | "integrity": "sha512-kVxJoJFeepK+rGJp9UN0D8d3sL6hjFbzd3qcLUUUKosp0ouoleOa6uPNK0b8fEBWWqFUD2W4V4ziN7UvXFB4pg==", 1060 | "dev": true, 1061 | "dependencies": { 1062 | "acorn": "^8.8.0", 1063 | "acorn-walk": "^8.2.0", 1064 | "better-sqlite3": "^8.1.0", 1065 | "capnp-ts": "^0.7.0", 1066 | "exit-hook": "^2.2.1", 1067 | "glob-to-regexp": "^0.4.1", 1068 | "http-cache-semantics": "^4.1.0", 1069 | "kleur": "^4.1.5", 1070 | "set-cookie-parser": "^2.6.0", 1071 | "source-map-support": "0.5.21", 1072 | "stoppable": "^1.1.0", 1073 | "undici": "^5.13.0", 1074 | "workerd": "1.20230710.0", 1075 | "ws": "^8.11.0", 1076 | "youch": "^3.2.2", 1077 | "zod": "^3.20.6" 1078 | }, 1079 | "engines": { 1080 | "node": ">=16.13" 1081 | } 1082 | }, 1083 | "node_modules/minimist": { 1084 | "version": "1.2.8", 1085 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 1086 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 1087 | "dev": true, 1088 | "funding": { 1089 | "url": "https://github.com/sponsors/ljharb" 1090 | } 1091 | }, 1092 | "node_modules/mkdirp-classic": { 1093 | "version": "0.5.3", 1094 | "resolved": "https://registry.npmjs.org/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz", 1095 | "integrity": "sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A==", 1096 | "dev": true 1097 | }, 1098 | "node_modules/ms": { 1099 | "version": "2.1.2", 1100 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1101 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1102 | "dev": true 1103 | }, 1104 | "node_modules/mustache": { 1105 | "version": "4.2.0", 1106 | "resolved": "https://registry.npmjs.org/mustache/-/mustache-4.2.0.tgz", 1107 | "integrity": "sha512-71ippSywq5Yb7/tVYyGbkBggbU8H3u5Rz56fH60jGFgr8uHwxs+aSKeqmluIVzM0m0kB7xQjKS6qPfd0b2ZoqQ==", 1108 | "dev": true, 1109 | "bin": { 1110 | "mustache": "bin/mustache" 1111 | } 1112 | }, 1113 | "node_modules/nanoid": { 1114 | "version": "3.3.6", 1115 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz", 1116 | "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==", 1117 | "dev": true, 1118 | "funding": [ 1119 | { 1120 | "type": "github", 1121 | "url": "https://github.com/sponsors/ai" 1122 | } 1123 | ], 1124 | "bin": { 1125 | "nanoid": "bin/nanoid.cjs" 1126 | }, 1127 | "engines": { 1128 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1129 | } 1130 | }, 1131 | "node_modules/napi-build-utils": { 1132 | "version": "1.0.2", 1133 | "resolved": "https://registry.npmjs.org/napi-build-utils/-/napi-build-utils-1.0.2.tgz", 1134 | "integrity": "sha512-ONmRUqK7zj7DWX0D9ADe03wbwOBZxNAfF20PlGfCWQcD3+/MakShIHrMqx9YwPTfxDdF1zLeL+RGZiR9kGMLdg==", 1135 | "dev": true 1136 | }, 1137 | "node_modules/node-abi": { 1138 | "version": "3.45.0", 1139 | "resolved": "https://registry.npmjs.org/node-abi/-/node-abi-3.45.0.tgz", 1140 | "integrity": "sha512-iwXuFrMAcFVi/ZoZiqq8BzAdsLw9kxDfTC0HMyjXfSL/6CSDAGD5UmR7azrAgWV1zKYq7dUUMj4owusBWKLsiQ==", 1141 | "dev": true, 1142 | "dependencies": { 1143 | "semver": "^7.3.5" 1144 | }, 1145 | "engines": { 1146 | "node": ">=10" 1147 | } 1148 | }, 1149 | "node_modules/node-forge": { 1150 | "version": "1.3.1", 1151 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", 1152 | "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==", 1153 | "dev": true, 1154 | "engines": { 1155 | "node": ">= 6.13.0" 1156 | } 1157 | }, 1158 | "node_modules/normalize-path": { 1159 | "version": "3.0.0", 1160 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1161 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1162 | "dev": true, 1163 | "engines": { 1164 | "node": ">=0.10.0" 1165 | } 1166 | }, 1167 | "node_modules/once": { 1168 | "version": "1.4.0", 1169 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1170 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1171 | "dev": true, 1172 | "dependencies": { 1173 | "wrappy": "1" 1174 | } 1175 | }, 1176 | "node_modules/path-to-regexp": { 1177 | "version": "6.2.1", 1178 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz", 1179 | "integrity": "sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw==", 1180 | "dev": true 1181 | }, 1182 | "node_modules/picomatch": { 1183 | "version": "2.3.1", 1184 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1185 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1186 | "dev": true, 1187 | "engines": { 1188 | "node": ">=8.6" 1189 | }, 1190 | "funding": { 1191 | "url": "https://github.com/sponsors/jonschlinkert" 1192 | } 1193 | }, 1194 | "node_modules/prebuild-install": { 1195 | "version": "7.1.1", 1196 | "resolved": "https://registry.npmjs.org/prebuild-install/-/prebuild-install-7.1.1.tgz", 1197 | "integrity": "sha512-jAXscXWMcCK8GgCoHOfIr0ODh5ai8mj63L2nWrjuAgXE6tDyYGnx4/8o/rCgU+B4JSyZBKbeZqzhtwtC3ovxjw==", 1198 | "dev": true, 1199 | "dependencies": { 1200 | "detect-libc": "^2.0.0", 1201 | "expand-template": "^2.0.3", 1202 | "github-from-package": "0.0.0", 1203 | "minimist": "^1.2.3", 1204 | "mkdirp-classic": "^0.5.3", 1205 | "napi-build-utils": "^1.0.1", 1206 | "node-abi": "^3.3.0", 1207 | "pump": "^3.0.0", 1208 | "rc": "^1.2.7", 1209 | "simple-get": "^4.0.0", 1210 | "tar-fs": "^2.0.0", 1211 | "tunnel-agent": "^0.6.0" 1212 | }, 1213 | "bin": { 1214 | "prebuild-install": "bin.js" 1215 | }, 1216 | "engines": { 1217 | "node": ">=10" 1218 | } 1219 | }, 1220 | "node_modules/printable-characters": { 1221 | "version": "1.0.42", 1222 | "resolved": "https://registry.npmjs.org/printable-characters/-/printable-characters-1.0.42.tgz", 1223 | "integrity": "sha512-dKp+C4iXWK4vVYZmYSd0KBH5F/h1HoZRsbJ82AVKRO3PEo8L4lBS/vLwhVtpwwuYcoIsVY+1JYKR268yn480uQ==", 1224 | "dev": true 1225 | }, 1226 | "node_modules/pump": { 1227 | "version": "3.0.0", 1228 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1229 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1230 | "dev": true, 1231 | "dependencies": { 1232 | "end-of-stream": "^1.1.0", 1233 | "once": "^1.3.1" 1234 | } 1235 | }, 1236 | "node_modules/rc": { 1237 | "version": "1.2.8", 1238 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1239 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1240 | "dev": true, 1241 | "dependencies": { 1242 | "deep-extend": "^0.6.0", 1243 | "ini": "~1.3.0", 1244 | "minimist": "^1.2.0", 1245 | "strip-json-comments": "~2.0.1" 1246 | }, 1247 | "bin": { 1248 | "rc": "cli.js" 1249 | } 1250 | }, 1251 | "node_modules/readable-stream": { 1252 | "version": "3.6.2", 1253 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", 1254 | "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", 1255 | "dev": true, 1256 | "dependencies": { 1257 | "inherits": "^2.0.3", 1258 | "string_decoder": "^1.1.1", 1259 | "util-deprecate": "^1.0.1" 1260 | }, 1261 | "engines": { 1262 | "node": ">= 6" 1263 | } 1264 | }, 1265 | "node_modules/readdirp": { 1266 | "version": "3.6.0", 1267 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1268 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1269 | "dev": true, 1270 | "dependencies": { 1271 | "picomatch": "^2.2.1" 1272 | }, 1273 | "engines": { 1274 | "node": ">=8.10.0" 1275 | } 1276 | }, 1277 | "node_modules/rollup-plugin-inject": { 1278 | "version": "3.0.2", 1279 | "resolved": "https://registry.npmjs.org/rollup-plugin-inject/-/rollup-plugin-inject-3.0.2.tgz", 1280 | "integrity": "sha512-ptg9PQwzs3orn4jkgXJ74bfs5vYz1NCZlSQMBUA0wKcGp5i5pA1AO3fOUEte8enhGUC+iapTCzEWw2jEFFUO/w==", 1281 | "deprecated": "This package has been deprecated and is no longer maintained. Please use @rollup/plugin-inject.", 1282 | "dev": true, 1283 | "dependencies": { 1284 | "estree-walker": "^0.6.1", 1285 | "magic-string": "^0.25.3", 1286 | "rollup-pluginutils": "^2.8.1" 1287 | } 1288 | }, 1289 | "node_modules/rollup-plugin-node-polyfills": { 1290 | "version": "0.2.1", 1291 | "resolved": "https://registry.npmjs.org/rollup-plugin-node-polyfills/-/rollup-plugin-node-polyfills-0.2.1.tgz", 1292 | "integrity": "sha512-4kCrKPTJ6sK4/gLL/U5QzVT8cxJcofO0OU74tnB19F40cmuAKSzH5/siithxlofFEjwvw1YAhPmbvGNA6jEroA==", 1293 | "dev": true, 1294 | "dependencies": { 1295 | "rollup-plugin-inject": "^3.0.0" 1296 | } 1297 | }, 1298 | "node_modules/rollup-pluginutils": { 1299 | "version": "2.8.2", 1300 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", 1301 | "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", 1302 | "dev": true, 1303 | "dependencies": { 1304 | "estree-walker": "^0.6.1" 1305 | } 1306 | }, 1307 | "node_modules/safe-buffer": { 1308 | "version": "5.2.1", 1309 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1310 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1311 | "dev": true, 1312 | "funding": [ 1313 | { 1314 | "type": "github", 1315 | "url": "https://github.com/sponsors/feross" 1316 | }, 1317 | { 1318 | "type": "patreon", 1319 | "url": "https://www.patreon.com/feross" 1320 | }, 1321 | { 1322 | "type": "consulting", 1323 | "url": "https://feross.org/support" 1324 | } 1325 | ] 1326 | }, 1327 | "node_modules/selfsigned": { 1328 | "version": "2.1.1", 1329 | "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.1.1.tgz", 1330 | "integrity": "sha512-GSL3aowiF7wa/WtSFwnUrludWFoNhftq8bUkH9pkzjpN2XSPOAYEgg6e0sS9s0rZwgJzJiQRPU18A6clnoW5wQ==", 1331 | "dev": true, 1332 | "dependencies": { 1333 | "node-forge": "^1" 1334 | }, 1335 | "engines": { 1336 | "node": ">=10" 1337 | } 1338 | }, 1339 | "node_modules/semver": { 1340 | "version": "7.5.4", 1341 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", 1342 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", 1343 | "dev": true, 1344 | "dependencies": { 1345 | "lru-cache": "^6.0.0" 1346 | }, 1347 | "bin": { 1348 | "semver": "bin/semver.js" 1349 | }, 1350 | "engines": { 1351 | "node": ">=10" 1352 | } 1353 | }, 1354 | "node_modules/set-cookie-parser": { 1355 | "version": "2.6.0", 1356 | "resolved": "https://registry.npmjs.org/set-cookie-parser/-/set-cookie-parser-2.6.0.tgz", 1357 | "integrity": "sha512-RVnVQxTXuerk653XfuliOxBP81Sf0+qfQE73LIYKcyMYHG94AuH0kgrQpRDuTZnSmjpysHmzxJXKNfa6PjFhyQ==", 1358 | "dev": true 1359 | }, 1360 | "node_modules/simple-concat": { 1361 | "version": "1.0.1", 1362 | "resolved": "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.1.tgz", 1363 | "integrity": "sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q==", 1364 | "dev": true, 1365 | "funding": [ 1366 | { 1367 | "type": "github", 1368 | "url": "https://github.com/sponsors/feross" 1369 | }, 1370 | { 1371 | "type": "patreon", 1372 | "url": "https://www.patreon.com/feross" 1373 | }, 1374 | { 1375 | "type": "consulting", 1376 | "url": "https://feross.org/support" 1377 | } 1378 | ] 1379 | }, 1380 | "node_modules/simple-get": { 1381 | "version": "4.0.1", 1382 | "resolved": "https://registry.npmjs.org/simple-get/-/simple-get-4.0.1.tgz", 1383 | "integrity": "sha512-brv7p5WgH0jmQJr1ZDDfKDOSeWWg+OVypG99A/5vYGPqJ6pxiaHLy8nxtFjBA7oMa01ebA9gfh1uMCFqOuXxvA==", 1384 | "dev": true, 1385 | "funding": [ 1386 | { 1387 | "type": "github", 1388 | "url": "https://github.com/sponsors/feross" 1389 | }, 1390 | { 1391 | "type": "patreon", 1392 | "url": "https://www.patreon.com/feross" 1393 | }, 1394 | { 1395 | "type": "consulting", 1396 | "url": "https://feross.org/support" 1397 | } 1398 | ], 1399 | "dependencies": { 1400 | "decompress-response": "^6.0.0", 1401 | "once": "^1.3.1", 1402 | "simple-concat": "^1.0.0" 1403 | } 1404 | }, 1405 | "node_modules/source-map": { 1406 | "version": "0.7.4", 1407 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", 1408 | "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", 1409 | "dev": true, 1410 | "engines": { 1411 | "node": ">= 8" 1412 | } 1413 | }, 1414 | "node_modules/source-map-support": { 1415 | "version": "0.5.21", 1416 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 1417 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 1418 | "dev": true, 1419 | "dependencies": { 1420 | "buffer-from": "^1.0.0", 1421 | "source-map": "^0.6.0" 1422 | } 1423 | }, 1424 | "node_modules/source-map-support/node_modules/source-map": { 1425 | "version": "0.6.1", 1426 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1427 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1428 | "dev": true, 1429 | "engines": { 1430 | "node": ">=0.10.0" 1431 | } 1432 | }, 1433 | "node_modules/sourcemap-codec": { 1434 | "version": "1.4.8", 1435 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 1436 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 1437 | "deprecated": "Please use @jridgewell/sourcemap-codec instead", 1438 | "dev": true 1439 | }, 1440 | "node_modules/stacktracey": { 1441 | "version": "2.1.8", 1442 | "resolved": "https://registry.npmjs.org/stacktracey/-/stacktracey-2.1.8.tgz", 1443 | "integrity": "sha512-Kpij9riA+UNg7TnphqjH7/CzctQ/owJGNbFkfEeve4Z4uxT5+JapVLFXcsurIfN34gnTWZNJ/f7NMG0E8JDzTw==", 1444 | "dev": true, 1445 | "dependencies": { 1446 | "as-table": "^1.0.36", 1447 | "get-source": "^2.0.12" 1448 | } 1449 | }, 1450 | "node_modules/stoppable": { 1451 | "version": "1.1.0", 1452 | "resolved": "https://registry.npmjs.org/stoppable/-/stoppable-1.1.0.tgz", 1453 | "integrity": "sha512-KXDYZ9dszj6bzvnEMRYvxgeTHU74QBFL54XKtP3nyMuJ81CFYtABZ3bAzL2EdFUaEwJOBOgENyFj3R7oTzDyyw==", 1454 | "dev": true, 1455 | "engines": { 1456 | "node": ">=4", 1457 | "npm": ">=6" 1458 | } 1459 | }, 1460 | "node_modules/streamsearch": { 1461 | "version": "1.1.0", 1462 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", 1463 | "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", 1464 | "dev": true, 1465 | "engines": { 1466 | "node": ">=10.0.0" 1467 | } 1468 | }, 1469 | "node_modules/string_decoder": { 1470 | "version": "1.3.0", 1471 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 1472 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 1473 | "dev": true, 1474 | "dependencies": { 1475 | "safe-buffer": "~5.2.0" 1476 | } 1477 | }, 1478 | "node_modules/strip-json-comments": { 1479 | "version": "2.0.1", 1480 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1481 | "integrity": "sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ==", 1482 | "dev": true, 1483 | "engines": { 1484 | "node": ">=0.10.0" 1485 | } 1486 | }, 1487 | "node_modules/tar-fs": { 1488 | "version": "2.1.1", 1489 | "resolved": "https://registry.npmjs.org/tar-fs/-/tar-fs-2.1.1.tgz", 1490 | "integrity": "sha512-V0r2Y9scmbDRLCNex/+hYzvp/zyYjvFbHPNgVTKfQvVrb6guiE/fxP+XblDNR011utopbkex2nM4dHNV6GDsng==", 1491 | "dev": true, 1492 | "dependencies": { 1493 | "chownr": "^1.1.1", 1494 | "mkdirp-classic": "^0.5.2", 1495 | "pump": "^3.0.0", 1496 | "tar-stream": "^2.1.4" 1497 | } 1498 | }, 1499 | "node_modules/tar-stream": { 1500 | "version": "2.2.0", 1501 | "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-2.2.0.tgz", 1502 | "integrity": "sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ==", 1503 | "dev": true, 1504 | "dependencies": { 1505 | "bl": "^4.0.3", 1506 | "end-of-stream": "^1.4.1", 1507 | "fs-constants": "^1.0.0", 1508 | "inherits": "^2.0.3", 1509 | "readable-stream": "^3.1.1" 1510 | }, 1511 | "engines": { 1512 | "node": ">=6" 1513 | } 1514 | }, 1515 | "node_modules/to-regex-range": { 1516 | "version": "5.0.1", 1517 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1518 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1519 | "dev": true, 1520 | "dependencies": { 1521 | "is-number": "^7.0.0" 1522 | }, 1523 | "engines": { 1524 | "node": ">=8.0" 1525 | } 1526 | }, 1527 | "node_modules/tslib": { 1528 | "version": "2.6.0", 1529 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.0.tgz", 1530 | "integrity": "sha512-7At1WUettjcSRHXCyYtTselblcHl9PJFFVKiCAy/bY97+BPZXSQ2wbq0P9s8tK2G7dFQfNnlJnPAiArVBVBsfA==", 1531 | "dev": true 1532 | }, 1533 | "node_modules/tunnel-agent": { 1534 | "version": "0.6.0", 1535 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 1536 | "integrity": "sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w==", 1537 | "dev": true, 1538 | "dependencies": { 1539 | "safe-buffer": "^5.0.1" 1540 | }, 1541 | "engines": { 1542 | "node": "*" 1543 | } 1544 | }, 1545 | "node_modules/typescript": { 1546 | "version": "5.1.6", 1547 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.1.6.tgz", 1548 | "integrity": "sha512-zaWCozRZ6DLEWAWFrVDz1H6FVXzUSfTy5FUMWsQlU8Ym5JP9eO4xkTIROFCQvhQf61z6O/G6ugw3SgAnvvm+HA==", 1549 | "dev": true, 1550 | "bin": { 1551 | "tsc": "bin/tsc", 1552 | "tsserver": "bin/tsserver" 1553 | }, 1554 | "engines": { 1555 | "node": ">=14.17" 1556 | } 1557 | }, 1558 | "node_modules/undici": { 1559 | "version": "5.22.1", 1560 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.22.1.tgz", 1561 | "integrity": "sha512-Ji2IJhFXZY0x/0tVBXeQwgPlLWw13GVzpsWPQ3rV50IFMMof2I55PZZxtm4P6iNq+L5znYN9nSTAq0ZyE6lSJw==", 1562 | "dev": true, 1563 | "dependencies": { 1564 | "busboy": "^1.6.0" 1565 | }, 1566 | "engines": { 1567 | "node": ">=14.0" 1568 | } 1569 | }, 1570 | "node_modules/util-deprecate": { 1571 | "version": "1.0.2", 1572 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1573 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", 1574 | "dev": true 1575 | }, 1576 | "node_modules/workerd": { 1577 | "version": "1.20230710.0", 1578 | "resolved": "https://registry.npmjs.org/workerd/-/workerd-1.20230710.0.tgz", 1579 | "integrity": "sha512-4iC+8w3UNixJ+b6GA2VOG2B6rnfSbSnm7Fnvsvq9iJuolG34fnD9xrfaXu6oN7H3Wyby3z8OIm0fy3szTvuRcg==", 1580 | "dev": true, 1581 | "hasInstallScript": true, 1582 | "bin": { 1583 | "workerd": "bin/workerd" 1584 | }, 1585 | "engines": { 1586 | "node": ">=16" 1587 | }, 1588 | "optionalDependencies": { 1589 | "@cloudflare/workerd-darwin-64": "1.20230710.0", 1590 | "@cloudflare/workerd-darwin-arm64": "1.20230710.0", 1591 | "@cloudflare/workerd-linux-64": "1.20230710.0", 1592 | "@cloudflare/workerd-linux-arm64": "1.20230710.0", 1593 | "@cloudflare/workerd-windows-64": "1.20230710.0" 1594 | } 1595 | }, 1596 | "node_modules/wrangler": { 1597 | "version": "3.2.0", 1598 | "resolved": "https://registry.npmjs.org/wrangler/-/wrangler-3.2.0.tgz", 1599 | "integrity": "sha512-Fne5c91uolV4+E0B60F/meWbD/sr/oSPBfr6x1gapu6I7Ipu5uUt29K/fuGRgXRQcVVKnd5k3fS++ruuLODoxA==", 1600 | "dev": true, 1601 | "dependencies": { 1602 | "@cloudflare/kv-asset-handler": "^0.2.0", 1603 | "@esbuild-plugins/node-globals-polyfill": "^0.1.1", 1604 | "@esbuild-plugins/node-modules-polyfill": "^0.1.4", 1605 | "blake3-wasm": "^2.1.5", 1606 | "chokidar": "^3.5.3", 1607 | "esbuild": "0.16.3", 1608 | "miniflare": "3.20230710.0", 1609 | "nanoid": "^3.3.3", 1610 | "path-to-regexp": "^6.2.0", 1611 | "selfsigned": "^2.0.1", 1612 | "source-map": "^0.7.4", 1613 | "xxhash-wasm": "^1.0.1" 1614 | }, 1615 | "bin": { 1616 | "wrangler": "bin/wrangler.js", 1617 | "wrangler2": "bin/wrangler.js" 1618 | }, 1619 | "engines": { 1620 | "node": ">=16.13.0" 1621 | }, 1622 | "optionalDependencies": { 1623 | "fsevents": "~2.3.2" 1624 | } 1625 | }, 1626 | "node_modules/wrappy": { 1627 | "version": "1.0.2", 1628 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1629 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 1630 | "dev": true 1631 | }, 1632 | "node_modules/ws": { 1633 | "version": "8.13.0", 1634 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.13.0.tgz", 1635 | "integrity": "sha512-x9vcZYTrFPC7aSIbj7sRCYo7L/Xb8Iy+pW0ng0wt2vCJv7M9HOMy0UoN3rr+IFC7hb7vXoqS+P9ktyLLLhO+LA==", 1636 | "dev": true, 1637 | "engines": { 1638 | "node": ">=10.0.0" 1639 | }, 1640 | "peerDependencies": { 1641 | "bufferutil": "^4.0.1", 1642 | "utf-8-validate": ">=5.0.2" 1643 | }, 1644 | "peerDependenciesMeta": { 1645 | "bufferutil": { 1646 | "optional": true 1647 | }, 1648 | "utf-8-validate": { 1649 | "optional": true 1650 | } 1651 | } 1652 | }, 1653 | "node_modules/xxhash-wasm": { 1654 | "version": "1.0.2", 1655 | "resolved": "https://registry.npmjs.org/xxhash-wasm/-/xxhash-wasm-1.0.2.tgz", 1656 | "integrity": "sha512-ibF0Or+FivM9lNrg+HGJfVX8WJqgo+kCLDc4vx6xMeTce7Aj+DLttKbxxRR/gNLSAelRc1omAPlJ77N/Jem07A==", 1657 | "dev": true 1658 | }, 1659 | "node_modules/yallist": { 1660 | "version": "4.0.0", 1661 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1662 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1663 | "dev": true 1664 | }, 1665 | "node_modules/youch": { 1666 | "version": "3.2.3", 1667 | "resolved": "https://registry.npmjs.org/youch/-/youch-3.2.3.tgz", 1668 | "integrity": "sha512-ZBcWz/uzZaQVdCvfV4uk616Bbpf2ee+F/AvuKDR5EwX/Y4v06xWdtMluqTD7+KlZdM93lLm9gMZYo0sKBS0pgw==", 1669 | "dev": true, 1670 | "dependencies": { 1671 | "cookie": "^0.5.0", 1672 | "mustache": "^4.2.0", 1673 | "stacktracey": "^2.1.8" 1674 | } 1675 | }, 1676 | "node_modules/zod": { 1677 | "version": "3.21.4", 1678 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.21.4.tgz", 1679 | "integrity": "sha512-m46AKbrzKVzOzs/DZgVnG5H55N1sv1M8qZU3A8RIKbs3mrACDNeIOeilDymVb2HdmP8uwshOCF4uJ8uM9rCqJw==", 1680 | "dev": true, 1681 | "funding": { 1682 | "url": "https://github.com/sponsors/colinhacks" 1683 | } 1684 | } 1685 | } 1686 | } 1687 | -------------------------------------------------------------------------------- /GitHub-Starred-Notify/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "GitHub-Starred-Notify", 3 | "version": "0.0.0", 4 | "private": true, 5 | "scripts": { 6 | "deploy": "wrangler deploy", 7 | "start": "wrangler dev" 8 | }, 9 | "devDependencies": { 10 | "@cloudflare/workers-types": "^4.20230419.0", 11 | "typescript": "^5.0.4", 12 | "wrangler": "^3.0.0" 13 | } 14 | } -------------------------------------------------------------------------------- /GitHub-Starred-Notify/src/worker.ts: -------------------------------------------------------------------------------- 1 | export interface Env { 2 | // Example binding to KV. Learn more at https://developers.cloudflare.com/workers/runtime-apis/kv/ 3 | KVWatch: KVNamespace; 4 | KVStarred: KVNamespace; 5 | token: string; 6 | bot_token: string; 7 | } 8 | 9 | export interface User { 10 | id: string, 11 | url: string, 12 | } 13 | 14 | export interface UserList { 15 | list: Array < User > 16 | } 17 | 18 | async function getRepoStatus(token: string, reponame: string) { 19 | let url = 'https://api.github.com/repos/' + reponame 20 | 21 | let resp = await fetch(url, { 22 | headers: { 23 | 'Authentication': `Bearer ${token}`, 24 | 'User-Agent': 'China-Failure-1989-06-04-Tiananmen' 25 | } 26 | }); 27 | if (resp.ok === false) { 28 | return console.log('Fetch Repo data err.') 29 | } 30 | 31 | let repo = JSON.parse(await resp.text()) 32 | if (typeof repo != 'object') { 33 | return console.log('JSON Parse err') 34 | } 35 | return repo 36 | } 37 | 38 | async function getStarredUser(token: string, reponame: string, repo: any) { 39 | let starredList = [] 40 | var totalPages = Math.ceil(repo.stargazers_count / 100) + 1 41 | let url = 'https://api.github.com/repos/' + reponame + '/stargazers?per_page=100&page='; 42 | for (let i = 1; i < totalPages; i++) { 43 | var r = await fetch(url + i, { 44 | headers: { 45 | 'Authentication': `Bearer ${token}`, 46 | 'User-Agent': 'China-Failure-1989-06-04-Tiananmen' 47 | } 48 | }); 49 | var tmp = JSON.parse(await r.text()); 50 | for (let x = 0; x < tmp.length; x++) { 51 | // id name url | id login url 52 | let t = { 53 | "id": tmp[x].id.toString(), 54 | "url": tmp[x].login 55 | } 56 | starredList.push(t); 57 | } 58 | }; 59 | return starredList 60 | } 61 | 62 | 63 | async function broadcast(changeList: { 64 | starred: User[], 65 | unstarred: User[], 66 | }, reponame: string, env: Env) { 67 | async function mention(name: string) { 68 | return `${name}` 69 | } 70 | let url = `https://api.telegram.org/bot${env.bot_token}/sendMessage` 71 | // let payload = {} 72 | let text = '' 73 | if (changeList.starred.length > 0) { 74 | if (changeList.starred.length == 1) { 75 | text += '🎉 有一位新的朋友 ' + await mention(changeList.starred[0].url) + 76 | ' 給ㄌ ' + await mention(reponame) + ' 星星 🌟\n' 77 | } 78 | if (changeList.starred.length > 1) { 79 | text += '🎉 有 ' + changeList.starred.length + ' 位朋友給ㄌ ' + 80 | await mention(reponame) + ' 星星 🌟\n' 81 | for (let i = 0; i < changeList.starred.length; i++) { 82 | text += await mention(changeList.starred[i].url) 83 | if (i != changeList.starred.length - 1) { 84 | text += '、' 85 | } 86 | } 87 | } 88 | } 89 | 90 | if (changeList.unstarred.length > 0) { 91 | if (changeList.unstarred.length == 1) { 92 | text += '🤧 有一位朋友 ' + await mention(changeList.unstarred[0].url) + 93 | ' 從 ' + await mention(reponame) + ' 拿走ㄌ星星 🌠' 94 | } 95 | if (changeList.unstarred.length > 1) { 96 | text += '🤧 有 ' + changeList.unstarred.length + 97 | ' 位朋友從 ' + await mention(reponame) + 98 | ' 拿走ㄌ星星 🌠\n' 99 | for (let i = 0; i < changeList.unstarred.length; i++) { 100 | text += await mention(changeList.unstarred[i].url) 101 | if (i != changeList.unstarred.length - 1) { 102 | text += '、' 103 | } 104 | } 105 | } 106 | } 107 | let _ = await env.KVWatch.get(reponame) 108 | let repo = JSON.parse(_!) 109 | let data: { 110 | text: string, 111 | chat_id: string, 112 | parse_mode: string 113 | } = { 114 | text: text, 115 | chat_id: '', 116 | parse_mode: 'html' 117 | } 118 | for (let i = 0; i < repo.length; i++) { 119 | data.chat_id = repo[i] 120 | let init = { 121 | body: JSON.stringify(data), 122 | method: 'POST', 123 | headers: { 124 | 'content-type': 'application/json;charset=UTF-8', 125 | }, 126 | 127 | } 128 | let result = await fetch(url, init) 129 | } 130 | 131 | // post 132 | // payload 133 | 134 | } 135 | 136 | async function proccess(userlist: Array < User > , reponame: string, env: Env) { 137 | let starredList = await env.KVStarred.get(reponame); 138 | let cachedKeyList: Array < User > = JSON.parse(starredList!) 139 | let changeList: { 140 | starred: User[], 141 | unstarred: User[], 142 | } = { 143 | "starred": [], 144 | "unstarred": [], 145 | } 146 | if (starredList == null) { 147 | await env.KVStarred.put(reponame, JSON.stringify(userlist)) 148 | } 149 | 150 | // looping fetch latest list 151 | if (starredList != null) { 152 | for (let i = 1; i < userlist.length; i++) { 153 | // new user starred 154 | if (typeof cachedKeyList.find(obj => obj.id == userlist[i].id) != 'object') { 155 | changeList.starred.push(userlist[i]) 156 | await env.KVStarred.put(reponame, JSON.stringify(userlist)) 157 | } 158 | 159 | } 160 | 161 | for (let i = 0; i < cachedKeyList.length && starredList != null; i++) { 162 | if (typeof userlist.find(obj => obj.id == cachedKeyList[i].id) == 'undefined') { 163 | changeList.unstarred.push(cachedKeyList[i]) 164 | await env.KVStarred.put(reponame, JSON.stringify(userlist)) 165 | } 166 | } 167 | } 168 | return changeList 169 | } 170 | 171 | export default { 172 | // The scheduled handler is invoked at the interval set in our wrangler.toml's 173 | // [[triggers]] configuration. 174 | async fetch(request: Request, env: Env) { 175 | const repolist = await env.KVWatch.list(); 176 | 177 | // FutaGuard/LowTechFilter: null 178 | for (let i = 0; i < repolist.keys.length; i++) { 179 | let reponame: string = repolist.keys[i].name 180 | let repoStatus = await getRepoStatus(env.token, reponame) 181 | let users: Array < User > = await getStarredUser(env.token, reponame, repoStatus) 182 | // let b = {id: '123'} 183 | 184 | let chg = await proccess(users, reponame, env) 185 | await broadcast(chg, reponame, env) 186 | const json = JSON.stringify(chg, null, 2); 187 | return new Response(json, { 188 | headers: { 189 | "content-type": "application/json;charset=UTF-8", 190 | }, 191 | }); 192 | 193 | } 194 | 195 | }, 196 | 197 | async scheduled(event: ScheduledEvent, env: Env, ctx: ExecutionContext): Promise < void > { 198 | const repolist = await env.KVWatch.list(); 199 | 200 | // FutaGuard/LowTechFilter: null 201 | for (let i = 0; i < repolist.keys.length; i++) { 202 | let reponame: string = repolist.keys[i].name 203 | let repoStatus = await getRepoStatus(env.token, reponame) 204 | let users: Array < User > = await getStarredUser(env.token, reponame, repoStatus) 205 | 206 | let chg = await proccess(users, reponame, env) 207 | await broadcast(chg, reponame, env) 208 | } 209 | }, 210 | }; 211 | -------------------------------------------------------------------------------- /GitHub-Starred-Notify/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"] /* 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 | -------------------------------------------------------------------------------- /GitHub-Starred-Notify/wrangler.toml: -------------------------------------------------------------------------------- 1 | name = "github-starred-notify" 2 | main = "src/worker.ts" 3 | compatibility_date = "2023-05-15" 4 | 5 | kv_namespaces = [ 6 | { binding = "KVStarred", id = "80aa300d6ef748dc94f07e44ffa80805", preview_id = "f71b95969e31438cadfecdaa6af8ab56" }, 7 | { binding = "KVWatch", id = "933634e8bbda407bbd349a88b00b2185", preview_id = "05d1c0fbd0374fc69dcfc983b922fd80" }, 8 | ] 9 | 10 | # [triggers] 11 | # crons = ["* * * * *"] # * * * * * = run every minute 12 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | /* 2 | * -------------------------------------------------------------- 3 | * "海克斯真香協議" 初版 4 | * tdc@tdccc.com.tw 編訂此協議,並由 "海克斯" 宇宙成員們同意。 5 | * 只要你看到這個協議檔案,不管你有沒有打開看,只要使用了 "海克斯" 任何程式碼做 6 | * 任何事表示皆接受 "踢低吸真香" 此共識,並且將此協議文本保留在該專案底下,加入 7 | * 本協議可以隨時修改不再另行通知。未來有一天與我們任何一成員相遇了你可以買咖 8 | * 啡請當事人。 9 | * - @allen0099 @bestpika @DingChen_Tsai @smailzhu 10 | * 11 | * "Hex Agreement" Version 1.0 12 | * @DingChen_Tsai created this agreement, and has been agreed by the "Hex" Universe's crews. 13 | * Once you seen this agreement document, even if you didn't read it, the usage of any "Hex" source 14 | * code to do anything will make the you have the consensus of 'TDC has nice smelling'. Additionally, 15 | * this agreement paper will be saved under its belonged project, once joined the agreement will be able 16 | * to edit without any applicate. If you meet any crews of "Hex" some day, you can buy me a beer in return 17 | * - @allen0099 @bestpika @DingChen_Tsai @smailzhu 18 | * -------------------------------------------------------------- 19 | * 條文參考自 https://people.freebsd.org/~phk/ 20 | * Ref https://people.freebsd.org/~phk/ 21 | * -------------------------------------------------------------- 22 | */ 23 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # GitHub Starred Notify 2 | 3 | ![header](https://p176.p0.n0.cdn.getcloudapp.com/items/mXuyKWlb/CleanShot%202020-08-22%20at%2017.23.25@2x.png) 4 | 5 | 專給那些喜歡看 repo 星星的捧友。 6 | 7 | GitHub 星星通知器是一個使用 TypeScript 編寫的實用工具,旨在監控您的 GitHub 倉庫的點星行為。它運行在多元化的 Cloudflare Worker 平台上,並通過 Telegram 通知您誰點了星星,以及誰把星星拿走了。 8 | 9 | ## 功能 10 | 11 | - ⚡️ 實時監控您的 GitHub 倉庫的點星行為 12 | - 🚀 通知直接發送到您的 Telegram 13 | - 😎 使用 TypeScript 編寫 14 | - ✅ 運行在 Cloudflare Worker 不需要額外伺服器 15 | - 👷‍♂️ 不需額外維護 16 | - 🎳 多個群組、對話通知 17 | 18 | ## 預備條件 19 | 20 | - Cloudflare 帳戶 21 | - Telegram 機器人 token 22 | - GitHub 個人訪問權限 token 23 | 24 | ## 設定 25 | 26 | ### 複製倉庫: 27 | `git clone https://github.com/tasi788/GitHub-Starred-Notify.git` 28 | 29 | 將username和reponame替換為你的 GitHub 用戶名和倉庫名稱。 30 | 31 | ### 安裝依賴: 32 | bash 33 | yarn install 34 | # 或者 35 | npm install 36 | 37 | ### 設定環境變數: 38 | 在專案的根目錄中創建一個新的.env文件,並添加以下環境變數: 39 | 40 | 41 | TELEGRAM_BOT_TOKEN=您的telegram機器人token 42 | TELEGRAM_CHAT_ID=你的telegram聊天id 43 | GH_PERSONAL_ACCESS_TOKEN=您的github個人訪問權限token 44 | 45 | 將「你的telegram機器人token」、「你的telegram聊天id」和「您的github個人訪問權限token」替換為您實際的資料。 46 | ## 部署 47 | 將程式碼部署到 Cloudflare Worker,可以參考 Cloudflare 的官方文件。 48 | 49 | ## 警告 50 | 本工具功能用於監控個人或者組織的開源項目,請合理合法使用,尊重他人的隱私。 51 | 52 | 此文件由 ChatGPT 自動產生 -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tasi788/GitHub-Starred-Notify/6b541cd05c4fc01119d66df5b9fd51acec9fa6c7/index.js -------------------------------------------------------------------------------- /main.gs: -------------------------------------------------------------------------------- 1 | // Inital 2 | var SpreadsheetId = ""; 3 | var BotToken = ""; 4 | 5 | // 記錄塞進去 6 | function insertRecord(ss, reponame, data, cleanup) { 7 | var currentSheet = ss.getSheetByName(reponame); 8 | var LastRow = currentSheet.getLastRow() - 1; 9 | if (cleanup == true) { 10 | currentSheet.deleteRows(2, LastRow); 11 | } 12 | var pushData = [] 13 | for (i = 0; i < data.length; i++) { 14 | pushData.push([data[i].id, data[i].name, data[i].url]) 15 | } 16 | currentSheet 17 | .getRange(2, 1, data.length, 3) 18 | .setValues( 19 | pushData 20 | ); 21 | } 22 | 23 | function getStarsFromRemote(reponame) { 24 | var url = "https://api.github.com/repos/" + reponame; 25 | var resp = UrlFetchApp.fetch(url); 26 | if (resp.getResponseCode() != 200) { 27 | Logger.log(reponame + " not 200") 28 | return 29 | } 30 | // read stars total 31 | var repo = JSON.parse(resp.getContentText()); 32 | if (typeof repo != 'object') { 33 | Logger.log('json parse error.') 34 | return 35 | } 36 | 37 | // 四捨五入 38 | var starredList = []; 39 | var totalPages = Math.ceil(repo.stargazers_count / 100) 40 | var url = "https://api.github.com/repos/" + reponame + "/stargazers?per_page=100&page="; 41 | for (i = 1; i < totalPages; i++) { 42 | var r = UrlFetchApp.fetch(url + i); 43 | var tmp = JSON.parse(r.getContentText()); 44 | for (x = 0; x < tmp.length; x++) { 45 | // id name url | id login url 46 | t = { 47 | "id": tmp[x].id.toString(), 48 | "name": tmp[x].login, 49 | "url": tmp[x].html_url 50 | } 51 | starredList.push(t); 52 | } 53 | }; 54 | return starredList 55 | } 56 | 57 | function mentionHTML(name, url) { 58 | return "' + escape(name) + "" 59 | } 60 | 61 | function boardcast(chatId, text) { 62 | var apiUrl = "https://api.telegram.org/bot" + BotToken + "/sendMessage"; 63 | var splitChat = chatId.toString().split(",") 64 | for (i = 0; i < splitChat.length; i++) { 65 | var data = { 66 | 'chat_id': splitChat[i], 67 | 'text': text, 68 | 'parse_mode': 'html' 69 | }; 70 | var options = { 71 | 'method': 'post', 72 | 'contentType': 'application/json', 73 | 'payload': JSON.stringify(data) 74 | }; 75 | UrlFetchApp.fetch(apiUrl, options); 76 | } 77 | } 78 | 79 | function worker(ss, data) { 80 | var starredList = getStarsFromRemote(data.repo); 81 | var currentSheet = ss.getSheetByName(data.repo); 82 | 83 | // create sheet 84 | if (currentSheet == null) { 85 | ss.insertSheet(data.repo, ss.getSheets().length); 86 | var currentSheet = ss.getSheetByName(data.repo); 87 | var sheetHeaders = [ 88 | ['Id', 'Name', 'URL'] 89 | ]; 90 | currentSheet 91 | .getRange(1, 1, 1, sheetHeaders[0].length) 92 | .setFontWeight('bold') 93 | .setBackground('lightgray') 94 | .setValues(sheetHeaders); 95 | // Inital new data. 96 | if (starredList.length != 0) { 97 | insertRecord(ss, data.repo, starredList, false) 98 | Logger.log("新建 Sheet 不動作。"); 99 | } 100 | } else { 101 | var LastRow = currentSheet.getLastRow() - 1; 102 | var LastCol = currentSheet.getLastColumn(); 103 | // null 104 | if (LastRow != 0) { 105 | var record = currentSheet.getSheetValues(2, 1, LastRow, LastCol).map(function (recordData) { 106 | return { 107 | id: recordData[0].toString(), 108 | name: recordData[1], 109 | url: recordData[2], 110 | } 111 | }) 112 | } 113 | var statusList = { 114 | "starred": [], 115 | "unstarred": [] 116 | } 117 | // 空ㄉ表格 118 | if (typeof record == 'undefined') { 119 | for (i = 0; i < starredList.length; i++) { 120 | statusList.starred.push(starredList[i]) 121 | } 122 | insertRecord(ss, data.repo, starredList, false) 123 | } else { 124 | // track unsub 125 | for (i = 0; i < record.length; i++) { 126 | if (starredList.filter(rs => rs.id == record[i].id).length == 0) { 127 | statusList.unstarred.push(record[i]) 128 | } 129 | } 130 | 131 | // track new sub 132 | for (i = 0; i < starredList.length; i++) { 133 | if (record.filter(rs => rs.id == starredList[i].id).length == 0) { 134 | statusList.starred.push(starredList[i]) 135 | } 136 | } 137 | } 138 | if (statusList.starred.length > 0 || statusList.unstarred.length > 0) { 139 | insertRecord(ss, data.repo, starredList, true) 140 | 141 | // boardcast 142 | var text = ""; 143 | if (statusList.starred.length == 1) { 144 | // inline URL 145 | 146 | text += "🎉 有一位新的朋友 " + mentionHTML(statusList.starred[0].name, statusList.starred[0].url) + " 給ㄌ " + mentionHTML(data.repo, "https://github.com/" + data.repo) + " 星星 🌟\n" 147 | } else { 148 | if (statusList.starred.length > 1) { 149 | text += "🎉 有 " + statusList.starred.length + " 位朋友給ㄌ " + mentionHTML(data.repo, "https://github.com/" + data.repo) + " 星星 🌟\n" 150 | for (i = 0; i < statusList.starred.length; i++) { 151 | text += mentionHTML(statusList.starred[i].name, statusList.starred[i].url) 152 | if (i != statusList.starred.length - 1) { 153 | text += "、" 154 | } 155 | } 156 | } 157 | } 158 | if (text.length > 1) { 159 | text += "\n" 160 | } 161 | if (statusList.unstarred.length == 1) { 162 | text += "🤧 有一位朋友 " + mentionHTML(statusList.unstarred[0].name, statusList.unstarred[0].url) + " 從 " + mentionHTML(data.repo, "https://github.com/" + data.repo) + " 拿走ㄌ星星 🌠" 163 | } else { 164 | if (statusList.unstarred.length > 1) { 165 | text += "🤧 有 " + statusList.unstarred.length + " 位朋友從 " + mentionHTML(data.repo, "https://github.com/" + data.repo) + " 拿走ㄌ星星 🌠\n" 166 | for (i = 0; i < statusList.unstarred.length; i++) { 167 | text += mentionHTML(statusList.unstarred[i].name, statusList.unstarred[i].url) 168 | if (i != statusList.unstarred.length - 1) { 169 | text += "、" 170 | } 171 | } 172 | } 173 | } 174 | boardcast(data.chatId, text) 175 | } 176 | } 177 | } 178 | 179 | function main() { 180 | var ss = SpreadsheetApp.openById(SpreadsheetId); 181 | var DataSheet = ss.getSheetByName("data"); 182 | // 先看總共有幾筆好ㄌ 183 | var LastRow = DataSheet.getLastRow() - 1; 184 | var LastCol = DataSheet.getLastColumn(); 185 | 186 | // DataSheet.getSheetValues(1, 1, 2, 3) 187 | var watchDog = DataSheet.getSheetValues(2, 1, LastRow, LastCol).map(function (watchMenu) { 188 | return { 189 | repo: watchMenu[0], 190 | chatId: watchMenu[1].toString(), 191 | }; 192 | }); 193 | 194 | // 尻 worker 195 | for (n = 0; n < watchDog.length; n++) { 196 | worker(ss, watchDog[n]) 197 | }; 198 | } -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "GitHub-Starred-Notify", 3 | "lockfileVersion": 3, 4 | "requires": true, 5 | "packages": { 6 | "": { 7 | "dependencies": { 8 | "tsc": "^2.0.4" 9 | } 10 | }, 11 | "node_modules/tsc": { 12 | "version": "2.0.4", 13 | "resolved": "https://registry.npmjs.org/tsc/-/tsc-2.0.4.tgz", 14 | "integrity": "sha512-fzoSieZI5KKJVBYGvwbVZs/J5za84f2lSTLPYf6AGiIf43tZ3GNrI1QzTLcjtyDDP4aLxd46RTZq1nQxe7+k5Q==", 15 | "bin": { 16 | "tsc": "bin/tsc" 17 | } 18 | } 19 | } 20 | } 21 | --------------------------------------------------------------------------------