@hot-updater/cloudflare 0.6.1-rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/LICENSE +21 -0
  2. package/dist/chunk-6TTCZ657.js +7340 -0
  3. package/dist/index.cjs +7936 -0
  4. package/dist/index.d.cts +17 -0
  5. package/dist/index.d.ts +17 -0
  6. package/dist/index.js +615 -0
  7. package/dist/utils/index.cjs +11618 -0
  8. package/dist/utils/index.d.cts +24 -0
  9. package/dist/utils/index.d.ts +24 -0
  10. package/dist/utils/index.js +4296 -0
  11. package/package.json +67 -0
  12. package/sql/bundles.sql +15 -0
  13. package/sql/prepareSql.ts +11 -0
  14. package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/759949203d579584bba36edd66058bea53c5fd18bbd8f45f1cf14abf011c468f.sqlite +0 -0
  15. package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/759949203d579584bba36edd66058bea53c5fd18bbd8f45f1cf14abf011c468f.sqlite-shm +0 -0
  16. package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/759949203d579584bba36edd66058bea53c5fd18bbd8f45f1cf14abf011c468f.sqlite-wal +0 -0
  17. package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/e7352547963de7050bd7d94658afc4fe78b61811b7815da12d90be8e863abf4d.sqlite +0 -0
  18. package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/e7352547963de7050bd7d94658afc4fe78b61811b7815da12d90be8e863abf4d.sqlite-shm +0 -0
  19. package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/e7352547963de7050bd7d94658afc4fe78b61811b7815da12d90be8e863abf4d.sqlite-wal +0 -0
  20. package/worker/migrations/0001_hot-updater_init.sql +16 -0
  21. package/worker/node_modules/.bin/esbuild +17 -0
  22. package/worker/node_modules/.bin/sass +17 -0
  23. package/worker/node_modules/.bin/terser +17 -0
  24. package/worker/node_modules/.bin/tsc +17 -0
  25. package/worker/node_modules/.bin/tsserver +17 -0
  26. package/worker/node_modules/.bin/vite +17 -0
  27. package/worker/node_modules/.bin/vitest +17 -0
  28. package/worker/node_modules/.bin/wrangler +17 -0
  29. package/worker/node_modules/.bin/wrangler2 +17 -0
  30. package/worker/node_modules/.cache/wrangler/wrangler-account.json +6 -0
  31. package/worker/node_modules/.mf/cf.json +1 -0
  32. package/worker/src/getUpdateInfo.spec.ts +73 -0
  33. package/worker/src/getUpdateInfo.ts +115 -0
  34. package/worker/src/index.ts +50 -0
  35. package/worker/wrangler.json +19 -0
  36. package/worker/wrangler.test.json +16 -0
package/dist/index.js ADDED
@@ -0,0 +1,615 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ ExecaError,
4
+ __commonJS,
5
+ __require,
6
+ __toESM,
7
+ createWrangler
8
+ } from "./chunk-6TTCZ657.js";
9
+
10
+ // ../../node_modules/.pnpm/pg-minify@1.6.5/node_modules/pg-minify/lib/utils.js
11
+ var require_utils = __commonJS({
12
+ "../../node_modules/.pnpm/pg-minify@1.6.5/node_modules/pg-minify/lib/utils.js"(exports, module) {
13
+ "use strict";
14
+ var { inspect } = __require("util");
15
+ function getIndexPos(text, index) {
16
+ let lineIdx = 0, colIdx = index, pos = 0;
17
+ do {
18
+ pos = text.indexOf("\n", pos);
19
+ if (pos === -1 || index < pos + 1) {
20
+ break;
21
+ }
22
+ lineIdx++;
23
+ pos++;
24
+ colIdx = index - pos;
25
+ } while (pos < index);
26
+ return {
27
+ line: lineIdx + 1,
28
+ column: colIdx + 1
29
+ };
30
+ }
31
+ function messageGap(level) {
32
+ return " ".repeat(level * 4);
33
+ }
34
+ function addInspection(type, cb) {
35
+ type[inspect.custom] = cb;
36
+ }
37
+ module.exports = {
38
+ getIndexPos,
39
+ messageGap,
40
+ addInspection
41
+ };
42
+ }
43
+ });
44
+
45
+ // ../../node_modules/.pnpm/pg-minify@1.6.5/node_modules/pg-minify/lib/error.js
46
+ var require_error = __commonJS({
47
+ "../../node_modules/.pnpm/pg-minify@1.6.5/node_modules/pg-minify/lib/error.js"(exports, module) {
48
+ "use strict";
49
+ var { EOL } = __require("os");
50
+ var { addInspection, messageGap } = require_utils();
51
+ var parsingErrorCode = {
52
+ unclosedMLC: 0,
53
+ // Unclosed multi-line comment.
54
+ unclosedText: 1,
55
+ // Unclosed text block.
56
+ unclosedQI: 2,
57
+ // Unclosed quoted identifier.
58
+ multiLineQI: 3
59
+ // Multi-line quoted identifiers are not supported.
60
+ };
61
+ Object.freeze(parsingErrorCode);
62
+ var errorMessages = [
63
+ { name: "unclosedMLC", message: "Unclosed multi-line comment." },
64
+ { name: "unclosedText", message: "Unclosed text block." },
65
+ { name: "unclosedQI", message: "Unclosed quoted identifier." },
66
+ { name: "multiLineQI", message: "Multi-line quoted identifiers are not supported." }
67
+ ];
68
+ var SQLParsingError = class extends Error {
69
+ constructor(code, position) {
70
+ const err = errorMessages[code].message;
71
+ const message = `Error parsing SQL at {line:${position.line},col:${position.column}}: ${err}`;
72
+ super(message);
73
+ this.name = this.constructor.name;
74
+ this.error = err;
75
+ this.code = code;
76
+ this.position = position;
77
+ Error.captureStackTrace(this, this.constructor);
78
+ }
79
+ };
80
+ SQLParsingError.prototype.toString = function(level) {
81
+ level = level > 0 ? parseInt(level) : 0;
82
+ const gap = messageGap(level + 1);
83
+ const lines = [
84
+ "SQLParsingError {",
85
+ `${gap}code: parsingErrorCode.${errorMessages[this.code].name}`,
86
+ `${gap}error: "${this.error}"`,
87
+ `${gap}position: {line: ${this.position.line}, col: ${this.position.column}}`,
88
+ `${messageGap(level)}}`
89
+ ];
90
+ return lines.join(EOL);
91
+ };
92
+ addInspection(SQLParsingError.prototype, function() {
93
+ return this.toString();
94
+ });
95
+ module.exports = {
96
+ SQLParsingError,
97
+ parsingErrorCode
98
+ };
99
+ }
100
+ });
101
+
102
+ // ../../node_modules/.pnpm/pg-minify@1.6.5/node_modules/pg-minify/lib/parser.js
103
+ var require_parser = __commonJS({
104
+ "../../node_modules/.pnpm/pg-minify@1.6.5/node_modules/pg-minify/lib/parser.js"(exports, module) {
105
+ "use strict";
106
+ var { parsingErrorCode, SQLParsingError } = require_error();
107
+ var { getIndexPos } = require_utils();
108
+ var compressors = ".,;:()[]=<>+-*/|!?@#";
109
+ function minify2(sql, options) {
110
+ if (typeof sql !== "string") {
111
+ throw new TypeError("Input SQL must be a text string.");
112
+ }
113
+ if (!sql.length) {
114
+ return "";
115
+ }
116
+ sql = sql.replace(/\r\n/g, "\n");
117
+ options = options || {};
118
+ let idx = 0, result = "", space = false;
119
+ const len = sql.length;
120
+ do {
121
+ const s = sql[idx], s1 = sql[idx + 1];
122
+ if (isGap(s)) {
123
+ while (++idx < len && isGap(sql[idx])) ;
124
+ if (idx < len) {
125
+ space = true;
126
+ }
127
+ idx--;
128
+ continue;
129
+ }
130
+ if (s === "-" && s1 === "-") {
131
+ const lb = sql.indexOf("\n", idx + 2);
132
+ if (lb < 0) {
133
+ break;
134
+ }
135
+ idx = lb - 1;
136
+ skipGaps();
137
+ continue;
138
+ }
139
+ if (s === "/" && s1 === "*") {
140
+ let c = idx + 1, open = 0, close = 0, lastOpen, lastClose;
141
+ while (++c < len - 1 && close <= open) {
142
+ if (sql[c] === "/" && sql[c + 1] === "*") {
143
+ lastOpen = c;
144
+ open++;
145
+ c++;
146
+ } else {
147
+ if (sql[c] === "*" && sql[c + 1] === "/") {
148
+ lastClose = c;
149
+ close++;
150
+ c++;
151
+ }
152
+ }
153
+ }
154
+ if (close <= open) {
155
+ idx = lastOpen;
156
+ throwError(parsingErrorCode.unclosedMLC);
157
+ }
158
+ if (sql[idx + 2] === "!" && !options.removeAll) {
159
+ if (options.compress) {
160
+ space = false;
161
+ }
162
+ addSpace();
163
+ result += sql.substring(idx, lastClose + 2).replace(/\n/g, "\r\n");
164
+ }
165
+ idx = lastClose + 1;
166
+ skipGaps();
167
+ continue;
168
+ }
169
+ let closeIdx, text;
170
+ if (s === '"') {
171
+ closeIdx = sql.indexOf('"', idx + 1);
172
+ if (closeIdx < 0) {
173
+ throwError(parsingErrorCode.unclosedQI);
174
+ }
175
+ text = sql.substring(idx, closeIdx + 1);
176
+ if (text.indexOf("\n") > 0) {
177
+ throwError(parsingErrorCode.multiLineQI);
178
+ }
179
+ if (options.compress) {
180
+ space = false;
181
+ }
182
+ addSpace();
183
+ result += text;
184
+ idx = closeIdx;
185
+ skipGaps();
186
+ continue;
187
+ }
188
+ if (s === "'") {
189
+ closeIdx = idx;
190
+ do {
191
+ closeIdx = sql.indexOf("'", closeIdx + 1);
192
+ if (closeIdx > 0) {
193
+ let i = closeIdx;
194
+ while (sql[--i] === "\\") ;
195
+ if ((closeIdx - i) % 2) {
196
+ let step = closeIdx;
197
+ while (++step < len && sql[step] === "'") ;
198
+ if ((step - closeIdx) % 2) {
199
+ closeIdx = step - 1;
200
+ break;
201
+ }
202
+ closeIdx = step === len ? -1 : step;
203
+ }
204
+ }
205
+ } while (closeIdx > 0);
206
+ if (closeIdx < 0) {
207
+ throwError(parsingErrorCode.unclosedText);
208
+ }
209
+ if (options.compress) {
210
+ space = false;
211
+ }
212
+ addSpace();
213
+ text = sql.substring(idx, closeIdx + 1);
214
+ const hasLB = text.indexOf("\n") > 0;
215
+ if (hasLB) {
216
+ text = text.split("\n").map((m) => {
217
+ return m.replace(/^\s+|\s+$/g, "");
218
+ }).join("\\n");
219
+ }
220
+ const hasTabs = text.indexOf(" ") > 0;
221
+ if (hasLB || hasTabs) {
222
+ const prev = idx ? sql[idx - 1] : "";
223
+ if (prev !== "E" && prev !== "e") {
224
+ const r = result ? result[result.length - 1] : "";
225
+ if (r && r !== " " && compressors.indexOf(r) < 0) {
226
+ result += " ";
227
+ }
228
+ result += "E";
229
+ }
230
+ if (hasTabs) {
231
+ text = text.replace(/\t/g, "\\t");
232
+ }
233
+ }
234
+ result += text;
235
+ idx = closeIdx;
236
+ skipGaps();
237
+ continue;
238
+ }
239
+ if (options.compress && compressors.indexOf(s) >= 0) {
240
+ space = false;
241
+ skipGaps();
242
+ }
243
+ addSpace();
244
+ result += s;
245
+ } while (++idx < len);
246
+ return result;
247
+ function skipGaps() {
248
+ if (options.compress) {
249
+ while (idx < len - 1 && isGap(sql[idx + 1]) && idx++) ;
250
+ }
251
+ }
252
+ function addSpace() {
253
+ if (space) {
254
+ if (result.length) {
255
+ result += " ";
256
+ }
257
+ space = false;
258
+ }
259
+ }
260
+ function throwError(code) {
261
+ const position = getIndexPos(sql, idx);
262
+ throw new SQLParsingError(code, position);
263
+ }
264
+ }
265
+ function isGap(s) {
266
+ return s === " " || s === " " || s === "\r" || s === "\n";
267
+ }
268
+ module.exports = minify2;
269
+ }
270
+ });
271
+
272
+ // ../../node_modules/.pnpm/pg-minify@1.6.5/node_modules/pg-minify/lib/index.js
273
+ var require_lib = __commonJS({
274
+ "../../node_modules/.pnpm/pg-minify@1.6.5/node_modules/pg-minify/lib/index.js"(exports, module) {
275
+ "use strict";
276
+ var parser = require_parser();
277
+ var error = require_error();
278
+ parser.SQLParsingError = error.SQLParsingError;
279
+ parser.parsingErrorCode = error.parsingErrorCode;
280
+ module.exports = parser;
281
+ }
282
+ });
283
+
284
+ // src/d1Database.ts
285
+ var import_pg_minify = __toESM(require_lib(), 1);
286
+ import Cloudflare from "cloudflare";
287
+ var d1Database = (config, hooks) => (_) => {
288
+ const cf = new Cloudflare({
289
+ apiToken: config.cloudflareApiToken
290
+ });
291
+ let bundles = [];
292
+ const changedIds = /* @__PURE__ */ new Set();
293
+ function markChanged(id) {
294
+ changedIds.add(id);
295
+ }
296
+ return {
297
+ name: "d1Database",
298
+ async commitBundle() {
299
+ if (changedIds.size === 0) {
300
+ return;
301
+ }
302
+ const changedBundles = bundles.filter((b) => changedIds.has(b.id));
303
+ if (changedBundles.length === 0) {
304
+ return;
305
+ }
306
+ const params = [];
307
+ const valuesSql = changedBundles.map((b) => {
308
+ params.push(
309
+ b.id,
310
+ b.enabled ? 1 : 0,
311
+ b.fileUrl,
312
+ b.shouldForceUpdate ? 1 : 0,
313
+ b.fileHash,
314
+ b.gitCommitHash || null,
315
+ b.message || null,
316
+ b.platform,
317
+ b.targetAppVersion
318
+ );
319
+ return "(?, ?, ?, ?, ?, ?, ?, ?, ?)";
320
+ }).join(",\n");
321
+ const sql = (0, import_pg_minify.default)(
322
+ /* sql */
323
+ `
324
+ INSERT OR REPLACE INTO bundles (
325
+ id,
326
+ enabled,
327
+ file_url,
328
+ should_force_update,
329
+ file_hash,
330
+ git_commit_hash,
331
+ message,
332
+ platform,
333
+ target_app_version
334
+ )
335
+ VALUES
336
+ ${valuesSql};`
337
+ );
338
+ await cf.d1.database.query(config.databaseId, {
339
+ account_id: config.accountId,
340
+ sql,
341
+ // why this type is string[] ?
342
+ params
343
+ });
344
+ changedIds.clear();
345
+ hooks?.onDatabaseUpdated?.();
346
+ },
347
+ async updateBundle(targetBundleId, newBundle) {
348
+ const index = bundles.findIndex((b) => b.id === targetBundleId);
349
+ if (index === -1) {
350
+ throw new Error(`Cannot find bundle with id ${targetBundleId}`);
351
+ }
352
+ Object.assign(bundles[index], newBundle);
353
+ markChanged(targetBundleId);
354
+ },
355
+ async appendBundle(inputBundle) {
356
+ bundles.unshift(inputBundle);
357
+ markChanged(inputBundle.id);
358
+ },
359
+ async setBundles(inputBundles) {
360
+ bundles = inputBundles;
361
+ for (const b of inputBundles) {
362
+ markChanged(b.id);
363
+ }
364
+ },
365
+ async getBundleById(bundleId) {
366
+ const found = bundles.find((b) => b.id === bundleId);
367
+ if (found) {
368
+ return found;
369
+ }
370
+ const sql = (0, import_pg_minify.default)(
371
+ /* sql */
372
+ `
373
+ SELECT * FROM bundles WHERE id = ? LIMIT 1`
374
+ );
375
+ const [response] = await cf.d1.database.query(config.databaseId, {
376
+ account_id: config.accountId,
377
+ sql,
378
+ params: [bundleId]
379
+ });
380
+ if (!response.success) {
381
+ return null;
382
+ }
383
+ const rows = response.results;
384
+ if (!rows?.length) {
385
+ return null;
386
+ }
387
+ const row = rows[0];
388
+ return {
389
+ enabled: Boolean(row.enabled),
390
+ fileUrl: row.file_url,
391
+ shouldForceUpdate: Boolean(row.should_force_update),
392
+ fileHash: row.file_hash,
393
+ gitCommitHash: row.git_commit_hash,
394
+ id: row.id,
395
+ message: row.message,
396
+ platform: row.platform,
397
+ targetAppVersion: row.target_app_version
398
+ };
399
+ },
400
+ async getBundles(refresh = false) {
401
+ if (bundles.length > 0 && !refresh) {
402
+ return bundles;
403
+ }
404
+ const sql = (0, import_pg_minify.default)(
405
+ /* sql */
406
+ `
407
+ SELECT
408
+ id,
409
+ enabled,
410
+ file_url,
411
+ should_force_update,
412
+ file_hash,
413
+ git_commit_hash,
414
+ message,
415
+ platform,
416
+ target_app_version
417
+ FROM bundles
418
+ ORDER BY id DESC
419
+ `
420
+ );
421
+ const [response] = await cf.d1.database.query(config.databaseId, {
422
+ account_id: config.accountId,
423
+ sql,
424
+ params: []
425
+ });
426
+ if (!response.success) {
427
+ bundles = [];
428
+ return bundles;
429
+ }
430
+ const rows = response.results;
431
+ if (!rows?.length) {
432
+ bundles = [];
433
+ } else {
434
+ bundles = rows.map((row) => ({
435
+ id: row.id,
436
+ enabled: Boolean(row.enabled),
437
+ fileUrl: row.file_url,
438
+ shouldForceUpdate: Boolean(row.should_force_update),
439
+ fileHash: row.file_hash,
440
+ gitCommitHash: row.git_commit_hash,
441
+ message: row.message,
442
+ platform: row.platform,
443
+ targetAppVersion: row.target_app_version
444
+ }));
445
+ }
446
+ return bundles;
447
+ }
448
+ };
449
+ };
450
+
451
+ // src/r2Storage.ts
452
+ import path from "path";
453
+
454
+ // ../../node_modules/.pnpm/mime@4.0.4/node_modules/mime/dist/types/other.js
455
+ var types = { "application/prs.cww": ["cww"], "application/prs.xsf+xml": ["xsf"], "application/vnd.1000minds.decision-model+xml": ["1km"], "application/vnd.3gpp.pic-bw-large": ["plb"], "application/vnd.3gpp.pic-bw-small": ["psb"], "application/vnd.3gpp.pic-bw-var": ["pvb"], "application/vnd.3gpp2.tcap": ["tcap"], "application/vnd.3m.post-it-notes": ["pwn"], "application/vnd.accpac.simply.aso": ["aso"], "application/vnd.accpac.simply.imp": ["imp"], "application/vnd.acucobol": ["acu"], "application/vnd.acucorp": ["atc", "acutc"], "application/vnd.adobe.air-application-installer-package+zip": ["air"], "application/vnd.adobe.formscentral.fcdt": ["fcdt"], "application/vnd.adobe.fxp": ["fxp", "fxpl"], "application/vnd.adobe.xdp+xml": ["xdp"], "application/vnd.adobe.xfdf": ["*xfdf"], "application/vnd.age": ["age"], "application/vnd.ahead.space": ["ahead"], "application/vnd.airzip.filesecure.azf": ["azf"], "application/vnd.airzip.filesecure.azs": ["azs"], "application/vnd.amazon.ebook": ["azw"], "application/vnd.americandynamics.acc": ["acc"], "application/vnd.amiga.ami": ["ami"], "application/vnd.android.package-archive": ["apk"], "application/vnd.anser-web-certificate-issue-initiation": ["cii"], "application/vnd.anser-web-funds-transfer-initiation": ["fti"], "application/vnd.antix.game-component": ["atx"], "application/vnd.apple.installer+xml": ["mpkg"], "application/vnd.apple.keynote": ["key"], "application/vnd.apple.mpegurl": ["m3u8"], "application/vnd.apple.numbers": ["numbers"], "application/vnd.apple.pages": ["pages"], "application/vnd.apple.pkpass": ["pkpass"], "application/vnd.aristanetworks.swi": ["swi"], "application/vnd.astraea-software.iota": ["iota"], "application/vnd.audiograph": ["aep"], "application/vnd.balsamiq.bmml+xml": ["bmml"], "application/vnd.blueice.multipass": ["mpm"], "application/vnd.bmi": ["bmi"], "application/vnd.businessobjects": ["rep"], "application/vnd.chemdraw+xml": ["cdxml"], "application/vnd.chipnuts.karaoke-mmd": ["mmd"], "application/vnd.cinderella": ["cdy"], "application/vnd.citationstyles.style+xml": ["csl"], "application/vnd.claymore": ["cla"], "application/vnd.cloanto.rp9": ["rp9"], "application/vnd.clonk.c4group": ["c4g", "c4d", "c4f", "c4p", "c4u"], "application/vnd.cluetrust.cartomobile-config": ["c11amc"], "application/vnd.cluetrust.cartomobile-config-pkg": ["c11amz"], "application/vnd.commonspace": ["csp"], "application/vnd.contact.cmsg": ["cdbcmsg"], "application/vnd.cosmocaller": ["cmc"], "application/vnd.crick.clicker": ["clkx"], "application/vnd.crick.clicker.keyboard": ["clkk"], "application/vnd.crick.clicker.palette": ["clkp"], "application/vnd.crick.clicker.template": ["clkt"], "application/vnd.crick.clicker.wordbank": ["clkw"], "application/vnd.criticaltools.wbs+xml": ["wbs"], "application/vnd.ctc-posml": ["pml"], "application/vnd.cups-ppd": ["ppd"], "application/vnd.curl.car": ["car"], "application/vnd.curl.pcurl": ["pcurl"], "application/vnd.dart": ["dart"], "application/vnd.data-vision.rdz": ["rdz"], "application/vnd.dbf": ["dbf"], "application/vnd.dece.data": ["uvf", "uvvf", "uvd", "uvvd"], "application/vnd.dece.ttml+xml": ["uvt", "uvvt"], "application/vnd.dece.unspecified": ["uvx", "uvvx"], "application/vnd.dece.zip": ["uvz", "uvvz"], "application/vnd.denovo.fcselayout-link": ["fe_launch"], "application/vnd.dna": ["dna"], "application/vnd.dolby.mlp": ["mlp"], "application/vnd.dpgraph": ["dpg"], "application/vnd.dreamfactory": ["dfac"], "application/vnd.ds-keypoint": ["kpxx"], "application/vnd.dvb.ait": ["ait"], "application/vnd.dvb.service": ["svc"], "application/vnd.dynageo": ["geo"], "application/vnd.ecowin.chart": ["mag"], "application/vnd.enliven": ["nml"], "application/vnd.epson.esf": ["esf"], "application/vnd.epson.msf": ["msf"], "application/vnd.epson.quickanime": ["qam"], "application/vnd.epson.salt": ["slt"], "application/vnd.epson.ssf": ["ssf"], "application/vnd.eszigno3+xml": ["es3", "et3"], "application/vnd.ezpix-album": ["ez2"], "application/vnd.ezpix-package": ["ez3"], "application/vnd.fdf": ["*fdf"], "application/vnd.fdsn.mseed": ["mseed"], "application/vnd.fdsn.seed": ["seed", "dataless"], "application/vnd.flographit": ["gph"], "application/vnd.fluxtime.clip": ["ftc"], "application/vnd.framemaker": ["fm", "frame", "maker", "book"], "application/vnd.frogans.fnc": ["fnc"], "application/vnd.frogans.ltf": ["ltf"], "application/vnd.fsc.weblaunch": ["fsc"], "application/vnd.fujitsu.oasys": ["oas"], "application/vnd.fujitsu.oasys2": ["oa2"], "application/vnd.fujitsu.oasys3": ["oa3"], "application/vnd.fujitsu.oasysgp": ["fg5"], "application/vnd.fujitsu.oasysprs": ["bh2"], "application/vnd.fujixerox.ddd": ["ddd"], "application/vnd.fujixerox.docuworks": ["xdw"], "application/vnd.fujixerox.docuworks.binder": ["xbd"], "application/vnd.fuzzysheet": ["fzs"], "application/vnd.genomatix.tuxedo": ["txd"], "application/vnd.geogebra.file": ["ggb"], "application/vnd.geogebra.tool": ["ggt"], "application/vnd.geometry-explorer": ["gex", "gre"], "application/vnd.geonext": ["gxt"], "application/vnd.geoplan": ["g2w"], "application/vnd.geospace": ["g3w"], "application/vnd.gmx": ["gmx"], "application/vnd.google-apps.document": ["gdoc"], "application/vnd.google-apps.presentation": ["gslides"], "application/vnd.google-apps.spreadsheet": ["gsheet"], "application/vnd.google-earth.kml+xml": ["kml"], "application/vnd.google-earth.kmz": ["kmz"], "application/vnd.grafeq": ["gqf", "gqs"], "application/vnd.groove-account": ["gac"], "application/vnd.groove-help": ["ghf"], "application/vnd.groove-identity-message": ["gim"], "application/vnd.groove-injector": ["grv"], "application/vnd.groove-tool-message": ["gtm"], "application/vnd.groove-tool-template": ["tpl"], "application/vnd.groove-vcard": ["vcg"], "application/vnd.hal+xml": ["hal"], "application/vnd.handheld-entertainment+xml": ["zmm"], "application/vnd.hbci": ["hbci"], "application/vnd.hhe.lesson-player": ["les"], "application/vnd.hp-hpgl": ["hpgl"], "application/vnd.hp-hpid": ["hpid"], "application/vnd.hp-hps": ["hps"], "application/vnd.hp-jlyt": ["jlt"], "application/vnd.hp-pcl": ["pcl"], "application/vnd.hp-pclxl": ["pclxl"], "application/vnd.hydrostatix.sof-data": ["sfd-hdstx"], "application/vnd.ibm.minipay": ["mpy"], "application/vnd.ibm.modcap": ["afp", "listafp", "list3820"], "application/vnd.ibm.rights-management": ["irm"], "application/vnd.ibm.secure-container": ["sc"], "application/vnd.iccprofile": ["icc", "icm"], "application/vnd.igloader": ["igl"], "application/vnd.immervision-ivp": ["ivp"], "application/vnd.immervision-ivu": ["ivu"], "application/vnd.insors.igm": ["igm"], "application/vnd.intercon.formnet": ["xpw", "xpx"], "application/vnd.intergeo": ["i2g"], "application/vnd.intu.qbo": ["qbo"], "application/vnd.intu.qfx": ["qfx"], "application/vnd.ipunplugged.rcprofile": ["rcprofile"], "application/vnd.irepository.package+xml": ["irp"], "application/vnd.is-xpr": ["xpr"], "application/vnd.isac.fcs": ["fcs"], "application/vnd.jam": ["jam"], "application/vnd.jcp.javame.midlet-rms": ["rms"], "application/vnd.jisp": ["jisp"], "application/vnd.joost.joda-archive": ["joda"], "application/vnd.kahootz": ["ktz", "ktr"], "application/vnd.kde.karbon": ["karbon"], "application/vnd.kde.kchart": ["chrt"], "application/vnd.kde.kformula": ["kfo"], "application/vnd.kde.kivio": ["flw"], "application/vnd.kde.kontour": ["kon"], "application/vnd.kde.kpresenter": ["kpr", "kpt"], "application/vnd.kde.kspread": ["ksp"], "application/vnd.kde.kword": ["kwd", "kwt"], "application/vnd.kenameaapp": ["htke"], "application/vnd.kidspiration": ["kia"], "application/vnd.kinar": ["kne", "knp"], "application/vnd.koan": ["skp", "skd", "skt", "skm"], "application/vnd.kodak-descriptor": ["sse"], "application/vnd.las.las+xml": ["lasxml"], "application/vnd.llamagraphics.life-balance.desktop": ["lbd"], "application/vnd.llamagraphics.life-balance.exchange+xml": ["lbe"], "application/vnd.lotus-1-2-3": ["123"], "application/vnd.lotus-approach": ["apr"], "application/vnd.lotus-freelance": ["pre"], "application/vnd.lotus-notes": ["nsf"], "application/vnd.lotus-organizer": ["org"], "application/vnd.lotus-screencam": ["scm"], "application/vnd.lotus-wordpro": ["lwp"], "application/vnd.macports.portpkg": ["portpkg"], "application/vnd.mapbox-vector-tile": ["mvt"], "application/vnd.mcd": ["mcd"], "application/vnd.medcalcdata": ["mc1"], "application/vnd.mediastation.cdkey": ["cdkey"], "application/vnd.mfer": ["mwf"], "application/vnd.mfmp": ["mfm"], "application/vnd.micrografx.flo": ["flo"], "application/vnd.micrografx.igx": ["igx"], "application/vnd.mif": ["mif"], "application/vnd.mobius.daf": ["daf"], "application/vnd.mobius.dis": ["dis"], "application/vnd.mobius.mbk": ["mbk"], "application/vnd.mobius.mqy": ["mqy"], "application/vnd.mobius.msl": ["msl"], "application/vnd.mobius.plc": ["plc"], "application/vnd.mobius.txf": ["txf"], "application/vnd.mophun.application": ["mpn"], "application/vnd.mophun.certificate": ["mpc"], "application/vnd.mozilla.xul+xml": ["xul"], "application/vnd.ms-artgalry": ["cil"], "application/vnd.ms-cab-compressed": ["cab"], "application/vnd.ms-excel": ["xls", "xlm", "xla", "xlc", "xlt", "xlw"], "application/vnd.ms-excel.addin.macroenabled.12": ["xlam"], "application/vnd.ms-excel.sheet.binary.macroenabled.12": ["xlsb"], "application/vnd.ms-excel.sheet.macroenabled.12": ["xlsm"], "application/vnd.ms-excel.template.macroenabled.12": ["xltm"], "application/vnd.ms-fontobject": ["eot"], "application/vnd.ms-htmlhelp": ["chm"], "application/vnd.ms-ims": ["ims"], "application/vnd.ms-lrm": ["lrm"], "application/vnd.ms-officetheme": ["thmx"], "application/vnd.ms-outlook": ["msg"], "application/vnd.ms-pki.seccat": ["cat"], "application/vnd.ms-pki.stl": ["*stl"], "application/vnd.ms-powerpoint": ["ppt", "pps", "pot"], "application/vnd.ms-powerpoint.addin.macroenabled.12": ["ppam"], "application/vnd.ms-powerpoint.presentation.macroenabled.12": ["pptm"], "application/vnd.ms-powerpoint.slide.macroenabled.12": ["sldm"], "application/vnd.ms-powerpoint.slideshow.macroenabled.12": ["ppsm"], "application/vnd.ms-powerpoint.template.macroenabled.12": ["potm"], "application/vnd.ms-project": ["*mpp", "mpt"], "application/vnd.ms-word.document.macroenabled.12": ["docm"], "application/vnd.ms-word.template.macroenabled.12": ["dotm"], "application/vnd.ms-works": ["wps", "wks", "wcm", "wdb"], "application/vnd.ms-wpl": ["wpl"], "application/vnd.ms-xpsdocument": ["xps"], "application/vnd.mseq": ["mseq"], "application/vnd.musician": ["mus"], "application/vnd.muvee.style": ["msty"], "application/vnd.mynfc": ["taglet"], "application/vnd.neurolanguage.nlu": ["nlu"], "application/vnd.nitf": ["ntf", "nitf"], "application/vnd.noblenet-directory": ["nnd"], "application/vnd.noblenet-sealer": ["nns"], "application/vnd.noblenet-web": ["nnw"], "application/vnd.nokia.n-gage.ac+xml": ["*ac"], "application/vnd.nokia.n-gage.data": ["ngdat"], "application/vnd.nokia.n-gage.symbian.install": ["n-gage"], "application/vnd.nokia.radio-preset": ["rpst"], "application/vnd.nokia.radio-presets": ["rpss"], "application/vnd.novadigm.edm": ["edm"], "application/vnd.novadigm.edx": ["edx"], "application/vnd.novadigm.ext": ["ext"], "application/vnd.oasis.opendocument.chart": ["odc"], "application/vnd.oasis.opendocument.chart-template": ["otc"], "application/vnd.oasis.opendocument.database": ["odb"], "application/vnd.oasis.opendocument.formula": ["odf"], "application/vnd.oasis.opendocument.formula-template": ["odft"], "application/vnd.oasis.opendocument.graphics": ["odg"], "application/vnd.oasis.opendocument.graphics-template": ["otg"], "application/vnd.oasis.opendocument.image": ["odi"], "application/vnd.oasis.opendocument.image-template": ["oti"], "application/vnd.oasis.opendocument.presentation": ["odp"], "application/vnd.oasis.opendocument.presentation-template": ["otp"], "application/vnd.oasis.opendocument.spreadsheet": ["ods"], "application/vnd.oasis.opendocument.spreadsheet-template": ["ots"], "application/vnd.oasis.opendocument.text": ["odt"], "application/vnd.oasis.opendocument.text-master": ["odm"], "application/vnd.oasis.opendocument.text-template": ["ott"], "application/vnd.oasis.opendocument.text-web": ["oth"], "application/vnd.olpc-sugar": ["xo"], "application/vnd.oma.dd2+xml": ["dd2"], "application/vnd.openblox.game+xml": ["obgx"], "application/vnd.openofficeorg.extension": ["oxt"], "application/vnd.openstreetmap.data+xml": ["osm"], "application/vnd.openxmlformats-officedocument.presentationml.presentation": ["pptx"], "application/vnd.openxmlformats-officedocument.presentationml.slide": ["sldx"], "application/vnd.openxmlformats-officedocument.presentationml.slideshow": ["ppsx"], "application/vnd.openxmlformats-officedocument.presentationml.template": ["potx"], "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet": ["xlsx"], "application/vnd.openxmlformats-officedocument.spreadsheetml.template": ["xltx"], "application/vnd.openxmlformats-officedocument.wordprocessingml.document": ["docx"], "application/vnd.openxmlformats-officedocument.wordprocessingml.template": ["dotx"], "application/vnd.osgeo.mapguide.package": ["mgp"], "application/vnd.osgi.dp": ["dp"], "application/vnd.osgi.subsystem": ["esa"], "application/vnd.palm": ["pdb", "pqa", "oprc"], "application/vnd.pawaafile": ["paw"], "application/vnd.pg.format": ["str"], "application/vnd.pg.osasli": ["ei6"], "application/vnd.picsel": ["efif"], "application/vnd.pmi.widget": ["wg"], "application/vnd.pocketlearn": ["plf"], "application/vnd.powerbuilder6": ["pbd"], "application/vnd.previewsystems.box": ["box"], "application/vnd.proteus.magazine": ["mgz"], "application/vnd.publishare-delta-tree": ["qps"], "application/vnd.pvi.ptid1": ["ptid"], "application/vnd.pwg-xhtml-print+xml": ["xhtm"], "application/vnd.quark.quarkxpress": ["qxd", "qxt", "qwd", "qwt", "qxl", "qxb"], "application/vnd.rar": ["rar"], "application/vnd.realvnc.bed": ["bed"], "application/vnd.recordare.musicxml": ["mxl"], "application/vnd.recordare.musicxml+xml": ["musicxml"], "application/vnd.rig.cryptonote": ["cryptonote"], "application/vnd.rim.cod": ["cod"], "application/vnd.rn-realmedia": ["rm"], "application/vnd.rn-realmedia-vbr": ["rmvb"], "application/vnd.route66.link66+xml": ["link66"], "application/vnd.sailingtracker.track": ["st"], "application/vnd.seemail": ["see"], "application/vnd.sema": ["sema"], "application/vnd.semd": ["semd"], "application/vnd.semf": ["semf"], "application/vnd.shana.informed.formdata": ["ifm"], "application/vnd.shana.informed.formtemplate": ["itp"], "application/vnd.shana.informed.interchange": ["iif"], "application/vnd.shana.informed.package": ["ipk"], "application/vnd.simtech-mindmapper": ["twd", "twds"], "application/vnd.smaf": ["mmf"], "application/vnd.smart.teacher": ["teacher"], "application/vnd.software602.filler.form+xml": ["fo"], "application/vnd.solent.sdkm+xml": ["sdkm", "sdkd"], "application/vnd.spotfire.dxp": ["dxp"], "application/vnd.spotfire.sfs": ["sfs"], "application/vnd.stardivision.calc": ["sdc"], "application/vnd.stardivision.draw": ["sda"], "application/vnd.stardivision.impress": ["sdd"], "application/vnd.stardivision.math": ["smf"], "application/vnd.stardivision.writer": ["sdw", "vor"], "application/vnd.stardivision.writer-global": ["sgl"], "application/vnd.stepmania.package": ["smzip"], "application/vnd.stepmania.stepchart": ["sm"], "application/vnd.sun.wadl+xml": ["wadl"], "application/vnd.sun.xml.calc": ["sxc"], "application/vnd.sun.xml.calc.template": ["stc"], "application/vnd.sun.xml.draw": ["sxd"], "application/vnd.sun.xml.draw.template": ["std"], "application/vnd.sun.xml.impress": ["sxi"], "application/vnd.sun.xml.impress.template": ["sti"], "application/vnd.sun.xml.math": ["sxm"], "application/vnd.sun.xml.writer": ["sxw"], "application/vnd.sun.xml.writer.global": ["sxg"], "application/vnd.sun.xml.writer.template": ["stw"], "application/vnd.sus-calendar": ["sus", "susp"], "application/vnd.svd": ["svd"], "application/vnd.symbian.install": ["sis", "sisx"], "application/vnd.syncml+xml": ["xsm"], "application/vnd.syncml.dm+wbxml": ["bdm"], "application/vnd.syncml.dm+xml": ["xdm"], "application/vnd.syncml.dmddf+xml": ["ddf"], "application/vnd.tao.intent-module-archive": ["tao"], "application/vnd.tcpdump.pcap": ["pcap", "cap", "dmp"], "application/vnd.tmobile-livetv": ["tmo"], "application/vnd.trid.tpt": ["tpt"], "application/vnd.triscape.mxs": ["mxs"], "application/vnd.trueapp": ["tra"], "application/vnd.ufdl": ["ufd", "ufdl"], "application/vnd.uiq.theme": ["utz"], "application/vnd.umajin": ["umj"], "application/vnd.unity": ["unityweb"], "application/vnd.uoml+xml": ["uoml", "uo"], "application/vnd.vcx": ["vcx"], "application/vnd.visio": ["vsd", "vst", "vss", "vsw"], "application/vnd.visionary": ["vis"], "application/vnd.vsf": ["vsf"], "application/vnd.wap.wbxml": ["wbxml"], "application/vnd.wap.wmlc": ["wmlc"], "application/vnd.wap.wmlscriptc": ["wmlsc"], "application/vnd.webturbo": ["wtb"], "application/vnd.wolfram.player": ["nbp"], "application/vnd.wordperfect": ["wpd"], "application/vnd.wqd": ["wqd"], "application/vnd.wt.stf": ["stf"], "application/vnd.xara": ["xar"], "application/vnd.xfdl": ["xfdl"], "application/vnd.yamaha.hv-dic": ["hvd"], "application/vnd.yamaha.hv-script": ["hvs"], "application/vnd.yamaha.hv-voice": ["hvp"], "application/vnd.yamaha.openscoreformat": ["osf"], "application/vnd.yamaha.openscoreformat.osfpvg+xml": ["osfpvg"], "application/vnd.yamaha.smaf-audio": ["saf"], "application/vnd.yamaha.smaf-phrase": ["spf"], "application/vnd.yellowriver-custom-menu": ["cmp"], "application/vnd.zul": ["zir", "zirz"], "application/vnd.zzazz.deck+xml": ["zaz"], "application/x-7z-compressed": ["7z"], "application/x-abiword": ["abw"], "application/x-ace-compressed": ["ace"], "application/x-apple-diskimage": ["*dmg"], "application/x-arj": ["arj"], "application/x-authorware-bin": ["aab", "x32", "u32", "vox"], "application/x-authorware-map": ["aam"], "application/x-authorware-seg": ["aas"], "application/x-bcpio": ["bcpio"], "application/x-bdoc": ["*bdoc"], "application/x-bittorrent": ["torrent"], "application/x-blorb": ["blb", "blorb"], "application/x-bzip": ["bz"], "application/x-bzip2": ["bz2", "boz"], "application/x-cbr": ["cbr", "cba", "cbt", "cbz", "cb7"], "application/x-cdlink": ["vcd"], "application/x-cfs-compressed": ["cfs"], "application/x-chat": ["chat"], "application/x-chess-pgn": ["pgn"], "application/x-chrome-extension": ["crx"], "application/x-cocoa": ["cco"], "application/x-conference": ["nsc"], "application/x-cpio": ["cpio"], "application/x-csh": ["csh"], "application/x-debian-package": ["*deb", "udeb"], "application/x-dgc-compressed": ["dgc"], "application/x-director": ["dir", "dcr", "dxr", "cst", "cct", "cxt", "w3d", "fgd", "swa"], "application/x-doom": ["wad"], "application/x-dtbncx+xml": ["ncx"], "application/x-dtbook+xml": ["dtb"], "application/x-dtbresource+xml": ["res"], "application/x-dvi": ["dvi"], "application/x-envoy": ["evy"], "application/x-eva": ["eva"], "application/x-font-bdf": ["bdf"], "application/x-font-ghostscript": ["gsf"], "application/x-font-linux-psf": ["psf"], "application/x-font-pcf": ["pcf"], "application/x-font-snf": ["snf"], "application/x-font-type1": ["pfa", "pfb", "pfm", "afm"], "application/x-freearc": ["arc"], "application/x-futuresplash": ["spl"], "application/x-gca-compressed": ["gca"], "application/x-glulx": ["ulx"], "application/x-gnumeric": ["gnumeric"], "application/x-gramps-xml": ["gramps"], "application/x-gtar": ["gtar"], "application/x-hdf": ["hdf"], "application/x-httpd-php": ["php"], "application/x-install-instructions": ["install"], "application/x-iso9660-image": ["*iso"], "application/x-iwork-keynote-sffkey": ["*key"], "application/x-iwork-numbers-sffnumbers": ["*numbers"], "application/x-iwork-pages-sffpages": ["*pages"], "application/x-java-archive-diff": ["jardiff"], "application/x-java-jnlp-file": ["jnlp"], "application/x-keepass2": ["kdbx"], "application/x-latex": ["latex"], "application/x-lua-bytecode": ["luac"], "application/x-lzh-compressed": ["lzh", "lha"], "application/x-makeself": ["run"], "application/x-mie": ["mie"], "application/x-mobipocket-ebook": ["*prc", "mobi"], "application/x-ms-application": ["application"], "application/x-ms-shortcut": ["lnk"], "application/x-ms-wmd": ["wmd"], "application/x-ms-wmz": ["wmz"], "application/x-ms-xbap": ["xbap"], "application/x-msaccess": ["mdb"], "application/x-msbinder": ["obd"], "application/x-mscardfile": ["crd"], "application/x-msclip": ["clp"], "application/x-msdos-program": ["*exe"], "application/x-msdownload": ["*exe", "*dll", "com", "bat", "*msi"], "application/x-msmediaview": ["mvb", "m13", "m14"], "application/x-msmetafile": ["*wmf", "*wmz", "*emf", "emz"], "application/x-msmoney": ["mny"], "application/x-mspublisher": ["pub"], "application/x-msschedule": ["scd"], "application/x-msterminal": ["trm"], "application/x-mswrite": ["wri"], "application/x-netcdf": ["nc", "cdf"], "application/x-ns-proxy-autoconfig": ["pac"], "application/x-nzb": ["nzb"], "application/x-perl": ["pl", "pm"], "application/x-pilot": ["*prc", "*pdb"], "application/x-pkcs12": ["p12", "pfx"], "application/x-pkcs7-certificates": ["p7b", "spc"], "application/x-pkcs7-certreqresp": ["p7r"], "application/x-rar-compressed": ["*rar"], "application/x-redhat-package-manager": ["rpm"], "application/x-research-info-systems": ["ris"], "application/x-sea": ["sea"], "application/x-sh": ["sh"], "application/x-shar": ["shar"], "application/x-shockwave-flash": ["swf"], "application/x-silverlight-app": ["xap"], "application/x-sql": ["*sql"], "application/x-stuffit": ["sit"], "application/x-stuffitx": ["sitx"], "application/x-subrip": ["srt"], "application/x-sv4cpio": ["sv4cpio"], "application/x-sv4crc": ["sv4crc"], "application/x-t3vm-image": ["t3"], "application/x-tads": ["gam"], "application/x-tar": ["tar"], "application/x-tcl": ["tcl", "tk"], "application/x-tex": ["tex"], "application/x-tex-tfm": ["tfm"], "application/x-texinfo": ["texinfo", "texi"], "application/x-tgif": ["*obj"], "application/x-ustar": ["ustar"], "application/x-virtualbox-hdd": ["hdd"], "application/x-virtualbox-ova": ["ova"], "application/x-virtualbox-ovf": ["ovf"], "application/x-virtualbox-vbox": ["vbox"], "application/x-virtualbox-vbox-extpack": ["vbox-extpack"], "application/x-virtualbox-vdi": ["vdi"], "application/x-virtualbox-vhd": ["vhd"], "application/x-virtualbox-vmdk": ["vmdk"], "application/x-wais-source": ["src"], "application/x-web-app-manifest+json": ["webapp"], "application/x-x509-ca-cert": ["der", "crt", "pem"], "application/x-xfig": ["fig"], "application/x-xliff+xml": ["*xlf"], "application/x-xpinstall": ["xpi"], "application/x-xz": ["xz"], "application/x-zmachine": ["z1", "z2", "z3", "z4", "z5", "z6", "z7", "z8"], "audio/vnd.dece.audio": ["uva", "uvva"], "audio/vnd.digital-winds": ["eol"], "audio/vnd.dra": ["dra"], "audio/vnd.dts": ["dts"], "audio/vnd.dts.hd": ["dtshd"], "audio/vnd.lucent.voice": ["lvp"], "audio/vnd.ms-playready.media.pya": ["pya"], "audio/vnd.nuera.ecelp4800": ["ecelp4800"], "audio/vnd.nuera.ecelp7470": ["ecelp7470"], "audio/vnd.nuera.ecelp9600": ["ecelp9600"], "audio/vnd.rip": ["rip"], "audio/x-aac": ["*aac"], "audio/x-aiff": ["aif", "aiff", "aifc"], "audio/x-caf": ["caf"], "audio/x-flac": ["flac"], "audio/x-m4a": ["*m4a"], "audio/x-matroska": ["mka"], "audio/x-mpegurl": ["m3u"], "audio/x-ms-wax": ["wax"], "audio/x-ms-wma": ["wma"], "audio/x-pn-realaudio": ["ram", "ra"], "audio/x-pn-realaudio-plugin": ["rmp"], "audio/x-realaudio": ["*ra"], "audio/x-wav": ["*wav"], "chemical/x-cdx": ["cdx"], "chemical/x-cif": ["cif"], "chemical/x-cmdf": ["cmdf"], "chemical/x-cml": ["cml"], "chemical/x-csml": ["csml"], "chemical/x-xyz": ["xyz"], "image/prs.btif": ["btif", "btf"], "image/prs.pti": ["pti"], "image/vnd.adobe.photoshop": ["psd"], "image/vnd.airzip.accelerator.azv": ["azv"], "image/vnd.dece.graphic": ["uvi", "uvvi", "uvg", "uvvg"], "image/vnd.djvu": ["djvu", "djv"], "image/vnd.dvb.subtitle": ["*sub"], "image/vnd.dwg": ["dwg"], "image/vnd.dxf": ["dxf"], "image/vnd.fastbidsheet": ["fbs"], "image/vnd.fpx": ["fpx"], "image/vnd.fst": ["fst"], "image/vnd.fujixerox.edmics-mmr": ["mmr"], "image/vnd.fujixerox.edmics-rlc": ["rlc"], "image/vnd.microsoft.icon": ["ico"], "image/vnd.ms-dds": ["dds"], "image/vnd.ms-modi": ["mdi"], "image/vnd.ms-photo": ["wdp"], "image/vnd.net-fpx": ["npx"], "image/vnd.pco.b16": ["b16"], "image/vnd.tencent.tap": ["tap"], "image/vnd.valve.source.texture": ["vtf"], "image/vnd.wap.wbmp": ["wbmp"], "image/vnd.xiff": ["xif"], "image/vnd.zbrush.pcx": ["pcx"], "image/x-3ds": ["3ds"], "image/x-cmu-raster": ["ras"], "image/x-cmx": ["cmx"], "image/x-freehand": ["fh", "fhc", "fh4", "fh5", "fh7"], "image/x-icon": ["*ico"], "image/x-jng": ["jng"], "image/x-mrsid-image": ["sid"], "image/x-ms-bmp": ["*bmp"], "image/x-pcx": ["*pcx"], "image/x-pict": ["pic", "pct"], "image/x-portable-anymap": ["pnm"], "image/x-portable-bitmap": ["pbm"], "image/x-portable-graymap": ["pgm"], "image/x-portable-pixmap": ["ppm"], "image/x-rgb": ["rgb"], "image/x-tga": ["tga"], "image/x-xbitmap": ["xbm"], "image/x-xpixmap": ["xpm"], "image/x-xwindowdump": ["xwd"], "message/vnd.wfa.wsc": ["wsc"], "model/vnd.cld": ["cld"], "model/vnd.collada+xml": ["dae"], "model/vnd.dwf": ["dwf"], "model/vnd.gdl": ["gdl"], "model/vnd.gtw": ["gtw"], "model/vnd.mts": ["mts"], "model/vnd.opengex": ["ogex"], "model/vnd.parasolid.transmit.binary": ["x_b"], "model/vnd.parasolid.transmit.text": ["x_t"], "model/vnd.pytha.pyox": ["pyo", "pyox"], "model/vnd.sap.vds": ["vds"], "model/vnd.usda": ["usda"], "model/vnd.usdz+zip": ["usdz"], "model/vnd.valve.source.compiled-map": ["bsp"], "model/vnd.vtu": ["vtu"], "text/prs.lines.tag": ["dsc"], "text/vnd.curl": ["curl"], "text/vnd.curl.dcurl": ["dcurl"], "text/vnd.curl.mcurl": ["mcurl"], "text/vnd.curl.scurl": ["scurl"], "text/vnd.dvb.subtitle": ["sub"], "text/vnd.familysearch.gedcom": ["ged"], "text/vnd.fly": ["fly"], "text/vnd.fmi.flexstor": ["flx"], "text/vnd.graphviz": ["gv"], "text/vnd.in3d.3dml": ["3dml"], "text/vnd.in3d.spot": ["spot"], "text/vnd.sun.j2me.app-descriptor": ["jad"], "text/vnd.wap.wml": ["wml"], "text/vnd.wap.wmlscript": ["wmls"], "text/x-asm": ["s", "asm"], "text/x-c": ["c", "cc", "cxx", "cpp", "h", "hh", "dic"], "text/x-component": ["htc"], "text/x-fortran": ["f", "for", "f77", "f90"], "text/x-handlebars-template": ["hbs"], "text/x-java-source": ["java"], "text/x-lua": ["lua"], "text/x-markdown": ["mkd"], "text/x-nfo": ["nfo"], "text/x-opml": ["opml"], "text/x-org": ["*org"], "text/x-pascal": ["p", "pas"], "text/x-processing": ["pde"], "text/x-sass": ["sass"], "text/x-scss": ["scss"], "text/x-setext": ["etx"], "text/x-sfv": ["sfv"], "text/x-suse-ymp": ["ymp"], "text/x-uuencode": ["uu"], "text/x-vcalendar": ["vcs"], "text/x-vcard": ["vcf"], "video/vnd.dece.hd": ["uvh", "uvvh"], "video/vnd.dece.mobile": ["uvm", "uvvm"], "video/vnd.dece.pd": ["uvp", "uvvp"], "video/vnd.dece.sd": ["uvs", "uvvs"], "video/vnd.dece.video": ["uvv", "uvvv"], "video/vnd.dvb.file": ["dvb"], "video/vnd.fvt": ["fvt"], "video/vnd.mpegurl": ["mxu", "m4u"], "video/vnd.ms-playready.media.pyv": ["pyv"], "video/vnd.uvvu.mp4": ["uvu", "uvvu"], "video/vnd.vivo": ["viv"], "video/x-f4v": ["f4v"], "video/x-fli": ["fli"], "video/x-flv": ["flv"], "video/x-m4v": ["m4v"], "video/x-matroska": ["mkv", "mk3d", "mks"], "video/x-mng": ["mng"], "video/x-ms-asf": ["asf", "asx"], "video/x-ms-vob": ["vob"], "video/x-ms-wm": ["wm"], "video/x-ms-wmv": ["wmv"], "video/x-ms-wmx": ["wmx"], "video/x-ms-wvx": ["wvx"], "video/x-msvideo": ["avi"], "video/x-sgi-movie": ["movie"], "video/x-smv": ["smv"], "x-conference/x-cooltalk": ["ice"] };
456
+ Object.freeze(types);
457
+ var other_default = types;
458
+
459
+ // ../../node_modules/.pnpm/mime@4.0.4/node_modules/mime/dist/types/standard.js
460
+ var types2 = { "application/andrew-inset": ["ez"], "application/appinstaller": ["appinstaller"], "application/applixware": ["aw"], "application/appx": ["appx"], "application/appxbundle": ["appxbundle"], "application/atom+xml": ["atom"], "application/atomcat+xml": ["atomcat"], "application/atomdeleted+xml": ["atomdeleted"], "application/atomsvc+xml": ["atomsvc"], "application/atsc-dwd+xml": ["dwd"], "application/atsc-held+xml": ["held"], "application/atsc-rsat+xml": ["rsat"], "application/automationml-aml+xml": ["aml"], "application/automationml-amlx+zip": ["amlx"], "application/bdoc": ["bdoc"], "application/calendar+xml": ["xcs"], "application/ccxml+xml": ["ccxml"], "application/cdfx+xml": ["cdfx"], "application/cdmi-capability": ["cdmia"], "application/cdmi-container": ["cdmic"], "application/cdmi-domain": ["cdmid"], "application/cdmi-object": ["cdmio"], "application/cdmi-queue": ["cdmiq"], "application/cpl+xml": ["cpl"], "application/cu-seeme": ["cu"], "application/cwl": ["cwl"], "application/dash+xml": ["mpd"], "application/dash-patch+xml": ["mpp"], "application/davmount+xml": ["davmount"], "application/docbook+xml": ["dbk"], "application/dssc+der": ["dssc"], "application/dssc+xml": ["xdssc"], "application/ecmascript": ["ecma"], "application/emma+xml": ["emma"], "application/emotionml+xml": ["emotionml"], "application/epub+zip": ["epub"], "application/exi": ["exi"], "application/express": ["exp"], "application/fdf": ["fdf"], "application/fdt+xml": ["fdt"], "application/font-tdpfr": ["pfr"], "application/geo+json": ["geojson"], "application/gml+xml": ["gml"], "application/gpx+xml": ["gpx"], "application/gxf": ["gxf"], "application/gzip": ["gz"], "application/hjson": ["hjson"], "application/hyperstudio": ["stk"], "application/inkml+xml": ["ink", "inkml"], "application/ipfix": ["ipfix"], "application/its+xml": ["its"], "application/java-archive": ["jar", "war", "ear"], "application/java-serialized-object": ["ser"], "application/java-vm": ["class"], "application/javascript": ["*js"], "application/json": ["json", "map"], "application/json5": ["json5"], "application/jsonml+json": ["jsonml"], "application/ld+json": ["jsonld"], "application/lgr+xml": ["lgr"], "application/lost+xml": ["lostxml"], "application/mac-binhex40": ["hqx"], "application/mac-compactpro": ["cpt"], "application/mads+xml": ["mads"], "application/manifest+json": ["webmanifest"], "application/marc": ["mrc"], "application/marcxml+xml": ["mrcx"], "application/mathematica": ["ma", "nb", "mb"], "application/mathml+xml": ["mathml"], "application/mbox": ["mbox"], "application/media-policy-dataset+xml": ["mpf"], "application/mediaservercontrol+xml": ["mscml"], "application/metalink+xml": ["metalink"], "application/metalink4+xml": ["meta4"], "application/mets+xml": ["mets"], "application/mmt-aei+xml": ["maei"], "application/mmt-usd+xml": ["musd"], "application/mods+xml": ["mods"], "application/mp21": ["m21", "mp21"], "application/mp4": ["*mp4", "*mpg4", "mp4s", "m4p"], "application/msix": ["msix"], "application/msixbundle": ["msixbundle"], "application/msword": ["doc", "dot"], "application/mxf": ["mxf"], "application/n-quads": ["nq"], "application/n-triples": ["nt"], "application/node": ["cjs"], "application/octet-stream": ["bin", "dms", "lrf", "mar", "so", "dist", "distz", "pkg", "bpk", "dump", "elc", "deploy", "exe", "dll", "deb", "dmg", "iso", "img", "msi", "msp", "msm", "buffer"], "application/oda": ["oda"], "application/oebps-package+xml": ["opf"], "application/ogg": ["ogx"], "application/omdoc+xml": ["omdoc"], "application/onenote": ["onetoc", "onetoc2", "onetmp", "onepkg"], "application/oxps": ["oxps"], "application/p2p-overlay+xml": ["relo"], "application/patch-ops-error+xml": ["xer"], "application/pdf": ["pdf"], "application/pgp-encrypted": ["pgp"], "application/pgp-keys": ["asc"], "application/pgp-signature": ["sig", "*asc"], "application/pics-rules": ["prf"], "application/pkcs10": ["p10"], "application/pkcs7-mime": ["p7m", "p7c"], "application/pkcs7-signature": ["p7s"], "application/pkcs8": ["p8"], "application/pkix-attr-cert": ["ac"], "application/pkix-cert": ["cer"], "application/pkix-crl": ["crl"], "application/pkix-pkipath": ["pkipath"], "application/pkixcmp": ["pki"], "application/pls+xml": ["pls"], "application/postscript": ["ai", "eps", "ps"], "application/provenance+xml": ["provx"], "application/pskc+xml": ["pskcxml"], "application/raml+yaml": ["raml"], "application/rdf+xml": ["rdf", "owl"], "application/reginfo+xml": ["rif"], "application/relax-ng-compact-syntax": ["rnc"], "application/resource-lists+xml": ["rl"], "application/resource-lists-diff+xml": ["rld"], "application/rls-services+xml": ["rs"], "application/route-apd+xml": ["rapd"], "application/route-s-tsid+xml": ["sls"], "application/route-usd+xml": ["rusd"], "application/rpki-ghostbusters": ["gbr"], "application/rpki-manifest": ["mft"], "application/rpki-roa": ["roa"], "application/rsd+xml": ["rsd"], "application/rss+xml": ["rss"], "application/rtf": ["rtf"], "application/sbml+xml": ["sbml"], "application/scvp-cv-request": ["scq"], "application/scvp-cv-response": ["scs"], "application/scvp-vp-request": ["spq"], "application/scvp-vp-response": ["spp"], "application/sdp": ["sdp"], "application/senml+xml": ["senmlx"], "application/sensml+xml": ["sensmlx"], "application/set-payment-initiation": ["setpay"], "application/set-registration-initiation": ["setreg"], "application/shf+xml": ["shf"], "application/sieve": ["siv", "sieve"], "application/smil+xml": ["smi", "smil"], "application/sparql-query": ["rq"], "application/sparql-results+xml": ["srx"], "application/sql": ["sql"], "application/srgs": ["gram"], "application/srgs+xml": ["grxml"], "application/sru+xml": ["sru"], "application/ssdl+xml": ["ssdl"], "application/ssml+xml": ["ssml"], "application/swid+xml": ["swidtag"], "application/tei+xml": ["tei", "teicorpus"], "application/thraud+xml": ["tfi"], "application/timestamped-data": ["tsd"], "application/toml": ["toml"], "application/trig": ["trig"], "application/ttml+xml": ["ttml"], "application/ubjson": ["ubj"], "application/urc-ressheet+xml": ["rsheet"], "application/urc-targetdesc+xml": ["td"], "application/voicexml+xml": ["vxml"], "application/wasm": ["wasm"], "application/watcherinfo+xml": ["wif"], "application/widget": ["wgt"], "application/winhlp": ["hlp"], "application/wsdl+xml": ["wsdl"], "application/wspolicy+xml": ["wspolicy"], "application/xaml+xml": ["xaml"], "application/xcap-att+xml": ["xav"], "application/xcap-caps+xml": ["xca"], "application/xcap-diff+xml": ["xdf"], "application/xcap-el+xml": ["xel"], "application/xcap-ns+xml": ["xns"], "application/xenc+xml": ["xenc"], "application/xfdf": ["xfdf"], "application/xhtml+xml": ["xhtml", "xht"], "application/xliff+xml": ["xlf"], "application/xml": ["xml", "xsl", "xsd", "rng"], "application/xml-dtd": ["dtd"], "application/xop+xml": ["xop"], "application/xproc+xml": ["xpl"], "application/xslt+xml": ["*xsl", "xslt"], "application/xspf+xml": ["xspf"], "application/xv+xml": ["mxml", "xhvml", "xvml", "xvm"], "application/yang": ["yang"], "application/yin+xml": ["yin"], "application/zip": ["zip"], "audio/3gpp": ["*3gpp"], "audio/aac": ["adts", "aac"], "audio/adpcm": ["adp"], "audio/amr": ["amr"], "audio/basic": ["au", "snd"], "audio/midi": ["mid", "midi", "kar", "rmi"], "audio/mobile-xmf": ["mxmf"], "audio/mp3": ["*mp3"], "audio/mp4": ["m4a", "mp4a"], "audio/mpeg": ["mpga", "mp2", "mp2a", "mp3", "m2a", "m3a"], "audio/ogg": ["oga", "ogg", "spx", "opus"], "audio/s3m": ["s3m"], "audio/silk": ["sil"], "audio/wav": ["wav"], "audio/wave": ["*wav"], "audio/webm": ["weba"], "audio/xm": ["xm"], "font/collection": ["ttc"], "font/otf": ["otf"], "font/ttf": ["ttf"], "font/woff": ["woff"], "font/woff2": ["woff2"], "image/aces": ["exr"], "image/apng": ["apng"], "image/avci": ["avci"], "image/avcs": ["avcs"], "image/avif": ["avif"], "image/bmp": ["bmp", "dib"], "image/cgm": ["cgm"], "image/dicom-rle": ["drle"], "image/dpx": ["dpx"], "image/emf": ["emf"], "image/fits": ["fits"], "image/g3fax": ["g3"], "image/gif": ["gif"], "image/heic": ["heic"], "image/heic-sequence": ["heics"], "image/heif": ["heif"], "image/heif-sequence": ["heifs"], "image/hej2k": ["hej2"], "image/hsj2": ["hsj2"], "image/ief": ["ief"], "image/jls": ["jls"], "image/jp2": ["jp2", "jpg2"], "image/jpeg": ["jpeg", "jpg", "jpe"], "image/jph": ["jph"], "image/jphc": ["jhc"], "image/jpm": ["jpm", "jpgm"], "image/jpx": ["jpx", "jpf"], "image/jxr": ["jxr"], "image/jxra": ["jxra"], "image/jxrs": ["jxrs"], "image/jxs": ["jxs"], "image/jxsc": ["jxsc"], "image/jxsi": ["jxsi"], "image/jxss": ["jxss"], "image/ktx": ["ktx"], "image/ktx2": ["ktx2"], "image/png": ["png"], "image/sgi": ["sgi"], "image/svg+xml": ["svg", "svgz"], "image/t38": ["t38"], "image/tiff": ["tif", "tiff"], "image/tiff-fx": ["tfx"], "image/webp": ["webp"], "image/wmf": ["wmf"], "message/disposition-notification": ["disposition-notification"], "message/global": ["u8msg"], "message/global-delivery-status": ["u8dsn"], "message/global-disposition-notification": ["u8mdn"], "message/global-headers": ["u8hdr"], "message/rfc822": ["eml", "mime"], "model/3mf": ["3mf"], "model/gltf+json": ["gltf"], "model/gltf-binary": ["glb"], "model/iges": ["igs", "iges"], "model/jt": ["jt"], "model/mesh": ["msh", "mesh", "silo"], "model/mtl": ["mtl"], "model/obj": ["obj"], "model/prc": ["prc"], "model/step+xml": ["stpx"], "model/step+zip": ["stpz"], "model/step-xml+zip": ["stpxz"], "model/stl": ["stl"], "model/u3d": ["u3d"], "model/vrml": ["wrl", "vrml"], "model/x3d+binary": ["*x3db", "x3dbz"], "model/x3d+fastinfoset": ["x3db"], "model/x3d+vrml": ["*x3dv", "x3dvz"], "model/x3d+xml": ["x3d", "x3dz"], "model/x3d-vrml": ["x3dv"], "text/cache-manifest": ["appcache", "manifest"], "text/calendar": ["ics", "ifb"], "text/coffeescript": ["coffee", "litcoffee"], "text/css": ["css"], "text/csv": ["csv"], "text/html": ["html", "htm", "shtml"], "text/jade": ["jade"], "text/javascript": ["js", "mjs"], "text/jsx": ["jsx"], "text/less": ["less"], "text/markdown": ["md", "markdown"], "text/mathml": ["mml"], "text/mdx": ["mdx"], "text/n3": ["n3"], "text/plain": ["txt", "text", "conf", "def", "list", "log", "in", "ini"], "text/richtext": ["rtx"], "text/rtf": ["*rtf"], "text/sgml": ["sgml", "sgm"], "text/shex": ["shex"], "text/slim": ["slim", "slm"], "text/spdx": ["spdx"], "text/stylus": ["stylus", "styl"], "text/tab-separated-values": ["tsv"], "text/troff": ["t", "tr", "roff", "man", "me", "ms"], "text/turtle": ["ttl"], "text/uri-list": ["uri", "uris", "urls"], "text/vcard": ["vcard"], "text/vtt": ["vtt"], "text/wgsl": ["wgsl"], "text/xml": ["*xml"], "text/yaml": ["yaml", "yml"], "video/3gpp": ["3gp", "3gpp"], "video/3gpp2": ["3g2"], "video/h261": ["h261"], "video/h263": ["h263"], "video/h264": ["h264"], "video/iso.segment": ["m4s"], "video/jpeg": ["jpgv"], "video/jpm": ["*jpm", "*jpgm"], "video/mj2": ["mj2", "mjp2"], "video/mp2t": ["ts"], "video/mp4": ["mp4", "mp4v", "mpg4"], "video/mpeg": ["mpeg", "mpg", "mpe", "m1v", "m2v"], "video/ogg": ["ogv"], "video/quicktime": ["qt", "mov"], "video/webm": ["webm"] };
461
+ Object.freeze(types2);
462
+ var standard_default = types2;
463
+
464
+ // ../../node_modules/.pnpm/mime@4.0.4/node_modules/mime/dist/src/Mime.js
465
+ var __classPrivateFieldGet = function(receiver, state, kind, f) {
466
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
467
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
468
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
469
+ };
470
+ var _Mime_extensionToType;
471
+ var _Mime_typeToExtension;
472
+ var _Mime_typeToExtensions;
473
+ var Mime = class {
474
+ constructor(...args) {
475
+ _Mime_extensionToType.set(this, /* @__PURE__ */ new Map());
476
+ _Mime_typeToExtension.set(this, /* @__PURE__ */ new Map());
477
+ _Mime_typeToExtensions.set(this, /* @__PURE__ */ new Map());
478
+ for (const arg of args) {
479
+ this.define(arg);
480
+ }
481
+ }
482
+ define(typeMap, force = false) {
483
+ for (let [type, extensions] of Object.entries(typeMap)) {
484
+ type = type.toLowerCase();
485
+ extensions = extensions.map((ext) => ext.toLowerCase());
486
+ if (!__classPrivateFieldGet(this, _Mime_typeToExtensions, "f").has(type)) {
487
+ __classPrivateFieldGet(this, _Mime_typeToExtensions, "f").set(type, /* @__PURE__ */ new Set());
488
+ }
489
+ const allExtensions = __classPrivateFieldGet(this, _Mime_typeToExtensions, "f").get(type);
490
+ let first = true;
491
+ for (let extension of extensions) {
492
+ const starred = extension.startsWith("*");
493
+ extension = starred ? extension.slice(1) : extension;
494
+ allExtensions?.add(extension);
495
+ if (first) {
496
+ __classPrivateFieldGet(this, _Mime_typeToExtension, "f").set(type, extension);
497
+ }
498
+ first = false;
499
+ if (starred)
500
+ continue;
501
+ const currentType = __classPrivateFieldGet(this, _Mime_extensionToType, "f").get(extension);
502
+ if (currentType && currentType != type && !force) {
503
+ throw new Error(`"${type} -> ${extension}" conflicts with "${currentType} -> ${extension}". Pass \`force=true\` to override this definition.`);
504
+ }
505
+ __classPrivateFieldGet(this, _Mime_extensionToType, "f").set(extension, type);
506
+ }
507
+ }
508
+ return this;
509
+ }
510
+ getType(path2) {
511
+ if (typeof path2 !== "string")
512
+ return null;
513
+ const last = path2.replace(/^.*[/\\]/, "").toLowerCase();
514
+ const ext = last.replace(/^.*\./, "").toLowerCase();
515
+ const hasPath = last.length < path2.length;
516
+ const hasDot = ext.length < last.length - 1;
517
+ if (!hasDot && hasPath)
518
+ return null;
519
+ return __classPrivateFieldGet(this, _Mime_extensionToType, "f").get(ext) ?? null;
520
+ }
521
+ getExtension(type) {
522
+ if (typeof type !== "string")
523
+ return null;
524
+ type = type?.split?.(";")[0];
525
+ return (type && __classPrivateFieldGet(this, _Mime_typeToExtension, "f").get(type.trim().toLowerCase())) ?? null;
526
+ }
527
+ getAllExtensions(type) {
528
+ if (typeof type !== "string")
529
+ return null;
530
+ return __classPrivateFieldGet(this, _Mime_typeToExtensions, "f").get(type.toLowerCase()) ?? null;
531
+ }
532
+ _freeze() {
533
+ this.define = () => {
534
+ throw new Error("define() not allowed for built-in Mime objects. See https://github.com/broofa/mime/blob/main/README.md#custom-mime-instances");
535
+ };
536
+ Object.freeze(this);
537
+ for (const extensions of __classPrivateFieldGet(this, _Mime_typeToExtensions, "f").values()) {
538
+ Object.freeze(extensions);
539
+ }
540
+ return this;
541
+ }
542
+ _getTestState() {
543
+ return {
544
+ types: __classPrivateFieldGet(this, _Mime_extensionToType, "f"),
545
+ extensions: __classPrivateFieldGet(this, _Mime_typeToExtension, "f")
546
+ };
547
+ }
548
+ };
549
+ _Mime_extensionToType = /* @__PURE__ */ new WeakMap(), _Mime_typeToExtension = /* @__PURE__ */ new WeakMap(), _Mime_typeToExtensions = /* @__PURE__ */ new WeakMap();
550
+ var Mime_default = Mime;
551
+
552
+ // ../../node_modules/.pnpm/mime@4.0.4/node_modules/mime/dist/src/index.js
553
+ var src_default = new Mime_default(standard_default, other_default)._freeze();
554
+
555
+ // src/r2Storage.ts
556
+ import Cloudflare2 from "cloudflare";
557
+ var r2Storage = (config, hooks) => (_) => {
558
+ const { bucketName, cloudflareApiToken, accountId } = config;
559
+ const cf = new Cloudflare2({
560
+ apiToken: cloudflareApiToken
561
+ });
562
+ const wrangler = createWrangler({
563
+ cloudflareApiToken,
564
+ cwd: process.cwd()
565
+ });
566
+ return {
567
+ name: "r2Storage",
568
+ async deleteBundle(bundleId) {
569
+ await wrangler(
570
+ "r2",
571
+ "object",
572
+ "delete",
573
+ [bucketName, bundleId].join("/")
574
+ );
575
+ throw new Error("Bundle Not Found");
576
+ },
577
+ async uploadBundle(bundleId, bundlePath) {
578
+ const contentType = src_default.getType(bundlePath) ?? void 0;
579
+ const filename = path.basename(bundlePath);
580
+ const Key = [bundleId, filename].join("/");
581
+ try {
582
+ await wrangler(
583
+ "r2",
584
+ "object",
585
+ "put",
586
+ [bucketName, Key].join("/"),
587
+ "--file",
588
+ bundlePath,
589
+ ...contentType ? ["--content-type", contentType] : []
590
+ );
591
+ } catch (error) {
592
+ if (error instanceof ExecaError) {
593
+ throw new Error(error.stderr);
594
+ }
595
+ throw error;
596
+ }
597
+ hooks?.onStorageUploaded?.();
598
+ if (hooks?.transformFileUrl) {
599
+ return {
600
+ fileUrl: hooks.transformFileUrl(Key)
601
+ };
602
+ }
603
+ const publicUrl = await cf.r2.buckets.domains.managed.list(bucketName, {
604
+ account_id: accountId
605
+ });
606
+ return {
607
+ fileUrl: `https://${publicUrl.domain}/${Key}`
608
+ };
609
+ }
610
+ };
611
+ };
612
+ export {
613
+ d1Database,
614
+ r2Storage
615
+ };