├── .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 | 
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 |
--------------------------------------------------------------------------------