wrangler 0.0.0-e6733a3 → 0.0.0-e6ada079
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.
Potentially problematic release.
This version of wrangler might be problematic. Click here for more details.
- package/README.md +47 -16
- package/bin/wrangler.js +94 -31
- package/config-schema.json +3100 -0
- package/kv-asset-handler.js +1 -0
- package/package.json +154 -82
- package/templates/__tests__/pages-dev-util.test.ts +128 -0
- package/templates/__tests__/tsconfig-sanity.ts +12 -0
- package/templates/__tests__/tsconfig.json +8 -0
- package/templates/checked-fetch.js +30 -0
- package/templates/facade.d.ts +19 -0
- package/templates/gitignore +170 -0
- package/templates/init-tests/test-jest-new-worker.js +23 -0
- package/templates/init-tests/test-vitest-new-worker.js +24 -0
- package/templates/init-tests/test-vitest-new-worker.ts +25 -0
- package/templates/middleware/common.ts +67 -0
- package/templates/middleware/loader-modules.ts +134 -0
- package/templates/middleware/loader-sw.ts +229 -0
- package/templates/middleware/middleware-ensure-req-body-drained.ts +18 -0
- package/templates/middleware/middleware-miniflare3-json-error.ts +32 -0
- package/templates/middleware/middleware-pretty-error.ts +40 -0
- package/templates/middleware/middleware-scheduled.ts +15 -0
- package/templates/middleware/middleware-serve-static-assets.d.ts +6 -0
- package/templates/middleware/middleware-serve-static-assets.ts +56 -0
- package/templates/modules-watch-stub.js +4 -0
- package/templates/new-worker-scheduled.js +17 -0
- package/templates/new-worker-scheduled.ts +32 -0
- package/templates/new-worker.js +15 -0
- package/templates/new-worker.ts +33 -0
- package/templates/no-op-worker.js +10 -0
- package/templates/pages-dev-pipeline.ts +32 -0
- package/templates/pages-dev-util.ts +55 -0
- package/templates/pages-shim.ts +9 -0
- package/templates/pages-template-plugin.ts +190 -0
- package/templates/pages-template-worker.ts +198 -0
- package/templates/startDevWorker/InspectorProxyWorker.ts +664 -0
- package/templates/startDevWorker/ProxyWorker.ts +334 -0
- package/templates/tsconfig-sanity.ts +11 -0
- package/templates/tsconfig.init.json +22 -0
- package/templates/tsconfig.json +8 -0
- package/wrangler-dist/InspectorProxyWorker.js +464 -0
- package/wrangler-dist/InspectorProxyWorker.js.map +6 -0
- package/wrangler-dist/ProxyWorker.js +240 -0
- package/wrangler-dist/ProxyWorker.js.map +6 -0
- package/wrangler-dist/cli.d.ts +26391 -0
- package/wrangler-dist/cli.js +204293 -116652
- package/wrangler-dist/wasm-sync.wasm +0 -0
- package/import_meta_url.js +0 -3
- package/miniflare-config-stubs/.env.empty +0 -0
- package/miniflare-config-stubs/package.empty.json +0 -1
- package/miniflare-config-stubs/wrangler.empty.toml +0 -0
- package/pages/functions/buildWorker.ts +0 -62
- package/pages/functions/filepath-routing.test.ts +0 -39
- package/pages/functions/filepath-routing.ts +0 -221
- package/pages/functions/identifiers.ts +0 -78
- package/pages/functions/routes.ts +0 -158
- package/pages/functions/template-worker.ts +0 -144
- package/src/__tests__/clipboardy-mock.js +0 -4
- package/src/__tests__/dev.test.tsx +0 -66
- package/src/__tests__/index.test.ts +0 -287
- package/src/__tests__/jest.setup.ts +0 -22
- package/src/__tests__/kv.test.ts +0 -1098
- package/src/__tests__/mock-cfetch.ts +0 -171
- package/src/__tests__/mock-dialogs.ts +0 -65
- package/src/__tests__/run-in-tmp.ts +0 -19
- package/src/__tests__/run-wrangler.ts +0 -32
- package/src/api/form_data.ts +0 -131
- package/src/api/preview.ts +0 -128
- package/src/api/worker.ts +0 -155
- package/src/cfetch/index.ts +0 -102
- package/src/cfetch/internal.ts +0 -69
- package/src/cli.ts +0 -9
- package/src/config.ts +0 -487
- package/src/dev.tsx +0 -771
- package/src/dialogs.tsx +0 -77
- package/src/index.tsx +0 -1974
- package/src/inspect.ts +0 -524
- package/src/kv.tsx +0 -267
- package/src/module-collection.ts +0 -64
- package/src/pages.tsx +0 -1031
- package/src/proxy.ts +0 -294
- package/src/publish.ts +0 -358
- package/src/sites.tsx +0 -114
- package/src/tail.tsx +0 -73
- package/src/user.tsx +0 -1025
- package/static-asset-facade.js +0 -47
- package/vendor/@cloudflare/kv-asset-handler/CHANGELOG.md +0 -332
- package/vendor/@cloudflare/kv-asset-handler/LICENSE_APACHE +0 -176
- package/vendor/@cloudflare/kv-asset-handler/LICENSE_MIT +0 -25
- package/vendor/@cloudflare/kv-asset-handler/README.md +0 -245
- package/vendor/@cloudflare/kv-asset-handler/dist/index.d.ts +0 -32
- package/vendor/@cloudflare/kv-asset-handler/dist/index.js +0 -354
- package/vendor/@cloudflare/kv-asset-handler/dist/mocks.d.ts +0 -13
- package/vendor/@cloudflare/kv-asset-handler/dist/mocks.js +0 -148
- package/vendor/@cloudflare/kv-asset-handler/dist/test/getAssetFromKV.d.ts +0 -1
- package/vendor/@cloudflare/kv-asset-handler/dist/test/getAssetFromKV.js +0 -436
- package/vendor/@cloudflare/kv-asset-handler/dist/test/mapRequestToAsset.d.ts +0 -1
- package/vendor/@cloudflare/kv-asset-handler/dist/test/mapRequestToAsset.js +0 -40
- package/vendor/@cloudflare/kv-asset-handler/dist/test/serveSinglePageApp.d.ts +0 -1
- package/vendor/@cloudflare/kv-asset-handler/dist/test/serveSinglePageApp.js +0 -42
- package/vendor/@cloudflare/kv-asset-handler/dist/types.d.ts +0 -26
- package/vendor/@cloudflare/kv-asset-handler/dist/types.js +0 -31
- package/vendor/@cloudflare/kv-asset-handler/package.json +0 -52
- package/vendor/@cloudflare/kv-asset-handler/src/index.ts +0 -296
- package/vendor/@cloudflare/kv-asset-handler/src/mocks.ts +0 -136
- package/vendor/@cloudflare/kv-asset-handler/src/test/getAssetFromKV.ts +0 -464
- package/vendor/@cloudflare/kv-asset-handler/src/test/mapRequestToAsset.ts +0 -33
- package/vendor/@cloudflare/kv-asset-handler/src/test/serveSinglePageApp.ts +0 -42
- package/vendor/@cloudflare/kv-asset-handler/src/types.ts +0 -39
- package/vendor/wrangler-mime/CHANGELOG.md +0 -289
- package/vendor/wrangler-mime/LICENSE +0 -21
- package/vendor/wrangler-mime/Mime.js +0 -97
- package/vendor/wrangler-mime/README.md +0 -187
- package/vendor/wrangler-mime/cli.js +0 -46
- package/vendor/wrangler-mime/index.js +0 -4
- package/vendor/wrangler-mime/lite.js +0 -4
- package/vendor/wrangler-mime/package.json +0 -52
- package/vendor/wrangler-mime/types/other.js +0 -1
- package/vendor/wrangler-mime/types/standard.js +0 -1
- package/wrangler-dist/cli.js.map +0 -7
@@ -0,0 +1,24 @@
|
|
1
|
+
import { afterAll, beforeAll, describe, expect, it } from "vitest";
|
2
|
+
import { unstable_dev } from "wrangler";
|
3
|
+
|
4
|
+
describe("Worker", () => {
|
5
|
+
let worker;
|
6
|
+
|
7
|
+
beforeAll(async () => {
|
8
|
+
worker = await unstable_dev("src/index.js", {
|
9
|
+
experimental: { disableExperimentalWarning: true },
|
10
|
+
});
|
11
|
+
});
|
12
|
+
|
13
|
+
afterAll(async () => {
|
14
|
+
await worker.stop();
|
15
|
+
});
|
16
|
+
|
17
|
+
it("should return Hello World", async () => {
|
18
|
+
const resp = await worker.fetch();
|
19
|
+
if (resp) {
|
20
|
+
const text = await resp.text();
|
21
|
+
expect(text).toMatchInlineSnapshot(`"Hello World!"`);
|
22
|
+
}
|
23
|
+
});
|
24
|
+
});
|
@@ -0,0 +1,25 @@
|
|
1
|
+
import { afterAll, beforeAll, describe, expect, it } from "vitest";
|
2
|
+
import { unstable_dev } from "wrangler";
|
3
|
+
import type { UnstableDevWorker } from "wrangler";
|
4
|
+
|
5
|
+
describe("Worker", () => {
|
6
|
+
let worker: UnstableDevWorker;
|
7
|
+
|
8
|
+
beforeAll(async () => {
|
9
|
+
worker = await unstable_dev("src/index.ts", {
|
10
|
+
experimental: { disableExperimentalWarning: true },
|
11
|
+
});
|
12
|
+
});
|
13
|
+
|
14
|
+
afterAll(async () => {
|
15
|
+
await worker.stop();
|
16
|
+
});
|
17
|
+
|
18
|
+
it("should return Hello World", async () => {
|
19
|
+
const resp = await worker.fetch();
|
20
|
+
if (resp) {
|
21
|
+
const text = await resp.text();
|
22
|
+
expect(text).toMatchInlineSnapshot(`"Hello World!"`);
|
23
|
+
}
|
24
|
+
});
|
25
|
+
});
|
@@ -0,0 +1,67 @@
|
|
1
|
+
export type Awaitable<T> = T | Promise<T>;
|
2
|
+
// TODO: allow dispatching more events?
|
3
|
+
export type Dispatcher = (
|
4
|
+
type: "scheduled",
|
5
|
+
init: { cron?: string }
|
6
|
+
) => Awaitable<void>;
|
7
|
+
|
8
|
+
export type IncomingRequest = Request<
|
9
|
+
unknown,
|
10
|
+
IncomingRequestCfProperties<unknown>
|
11
|
+
>;
|
12
|
+
|
13
|
+
export interface MiddlewareContext {
|
14
|
+
dispatch: Dispatcher;
|
15
|
+
next(request: IncomingRequest, env: any): Awaitable<Response>;
|
16
|
+
}
|
17
|
+
|
18
|
+
export type Middleware = (
|
19
|
+
request: IncomingRequest,
|
20
|
+
env: any,
|
21
|
+
ctx: ExecutionContext,
|
22
|
+
middlewareCtx: MiddlewareContext
|
23
|
+
) => Awaitable<Response>;
|
24
|
+
|
25
|
+
const __facade_middleware__: Middleware[] = [];
|
26
|
+
|
27
|
+
// The register functions allow for the insertion of one or many middleware,
|
28
|
+
// We register internal middleware first in the stack, but have no way of controlling
|
29
|
+
// the order that addMiddleware is run in service workers so need an internal function.
|
30
|
+
export function __facade_register__(...args: (Middleware | Middleware[])[]) {
|
31
|
+
__facade_middleware__.push(...args.flat());
|
32
|
+
}
|
33
|
+
export function __facade_registerInternal__(
|
34
|
+
...args: (Middleware | Middleware[])[]
|
35
|
+
) {
|
36
|
+
__facade_middleware__.unshift(...args.flat());
|
37
|
+
}
|
38
|
+
|
39
|
+
function __facade_invokeChain__(
|
40
|
+
request: IncomingRequest,
|
41
|
+
env: any,
|
42
|
+
ctx: ExecutionContext,
|
43
|
+
dispatch: Dispatcher,
|
44
|
+
middlewareChain: Middleware[]
|
45
|
+
): Awaitable<Response> {
|
46
|
+
const [head, ...tail] = middlewareChain;
|
47
|
+
const middlewareCtx: MiddlewareContext = {
|
48
|
+
dispatch,
|
49
|
+
next(newRequest, newEnv) {
|
50
|
+
return __facade_invokeChain__(newRequest, newEnv, ctx, dispatch, tail);
|
51
|
+
},
|
52
|
+
};
|
53
|
+
return head(request, env, ctx, middlewareCtx);
|
54
|
+
}
|
55
|
+
|
56
|
+
export function __facade_invoke__(
|
57
|
+
request: IncomingRequest,
|
58
|
+
env: any,
|
59
|
+
ctx: ExecutionContext,
|
60
|
+
dispatch: Dispatcher,
|
61
|
+
finalMiddleware: Middleware
|
62
|
+
): Awaitable<Response> {
|
63
|
+
return __facade_invokeChain__(request, env, ctx, dispatch, [
|
64
|
+
...__facade_middleware__,
|
65
|
+
finalMiddleware,
|
66
|
+
]);
|
67
|
+
}
|
@@ -0,0 +1,134 @@
|
|
1
|
+
// This loads all middlewares exposed on the middleware object and then starts
|
2
|
+
// the invocation chain. The big idea is that we can add these to the middleware
|
3
|
+
// export dynamically through wrangler, or we can potentially let users directly
|
4
|
+
// add them as a sort of "plugin" system.
|
5
|
+
|
6
|
+
import ENTRY, { __INTERNAL_WRANGLER_MIDDLEWARE__ } from "__ENTRY_POINT__";
|
7
|
+
import { __facade_invoke__, __facade_register__, Dispatcher } from "./common";
|
8
|
+
import type { WorkerEntrypointConstructor } from "__ENTRY_POINT__";
|
9
|
+
|
10
|
+
// Preserve all the exports from the worker
|
11
|
+
export * from "__ENTRY_POINT__";
|
12
|
+
|
13
|
+
class __Facade_ScheduledController__ implements ScheduledController {
|
14
|
+
readonly #noRetry: ScheduledController["noRetry"];
|
15
|
+
|
16
|
+
constructor(
|
17
|
+
readonly scheduledTime: number,
|
18
|
+
readonly cron: string,
|
19
|
+
noRetry: ScheduledController["noRetry"]
|
20
|
+
) {
|
21
|
+
this.#noRetry = noRetry;
|
22
|
+
}
|
23
|
+
|
24
|
+
noRetry() {
|
25
|
+
if (!(this instanceof __Facade_ScheduledController__)) {
|
26
|
+
throw new TypeError("Illegal invocation");
|
27
|
+
}
|
28
|
+
// Need to call native method immediately in case uncaught error thrown
|
29
|
+
this.#noRetry();
|
30
|
+
}
|
31
|
+
}
|
32
|
+
|
33
|
+
function wrapExportedHandler(worker: ExportedHandler): ExportedHandler {
|
34
|
+
// If we don't have any middleware defined, just return the handler as is
|
35
|
+
if (
|
36
|
+
__INTERNAL_WRANGLER_MIDDLEWARE__ === undefined ||
|
37
|
+
__INTERNAL_WRANGLER_MIDDLEWARE__.length === 0
|
38
|
+
) {
|
39
|
+
return worker;
|
40
|
+
}
|
41
|
+
// Otherwise, register all middleware once
|
42
|
+
for (const middleware of __INTERNAL_WRANGLER_MIDDLEWARE__) {
|
43
|
+
__facade_register__(middleware);
|
44
|
+
}
|
45
|
+
|
46
|
+
const fetchDispatcher: ExportedHandlerFetchHandler = function (
|
47
|
+
request,
|
48
|
+
env,
|
49
|
+
ctx
|
50
|
+
) {
|
51
|
+
if (worker.fetch === undefined) {
|
52
|
+
throw new Error("Handler does not export a fetch() function.");
|
53
|
+
}
|
54
|
+
return worker.fetch(request, env, ctx);
|
55
|
+
};
|
56
|
+
|
57
|
+
return {
|
58
|
+
...worker,
|
59
|
+
fetch(request, env, ctx) {
|
60
|
+
const dispatcher: Dispatcher = function (type, init) {
|
61
|
+
if (type === "scheduled" && worker.scheduled !== undefined) {
|
62
|
+
const controller = new __Facade_ScheduledController__(
|
63
|
+
Date.now(),
|
64
|
+
init.cron ?? "",
|
65
|
+
() => {}
|
66
|
+
);
|
67
|
+
return worker.scheduled(controller, env, ctx);
|
68
|
+
}
|
69
|
+
};
|
70
|
+
return __facade_invoke__(request, env, ctx, dispatcher, fetchDispatcher);
|
71
|
+
},
|
72
|
+
};
|
73
|
+
}
|
74
|
+
|
75
|
+
function wrapWorkerEntrypoint(
|
76
|
+
klass: WorkerEntrypointConstructor
|
77
|
+
): WorkerEntrypointConstructor {
|
78
|
+
// If we don't have any middleware defined, just return the handler as is
|
79
|
+
if (
|
80
|
+
__INTERNAL_WRANGLER_MIDDLEWARE__ === undefined ||
|
81
|
+
__INTERNAL_WRANGLER_MIDDLEWARE__.length === 0
|
82
|
+
) {
|
83
|
+
return klass;
|
84
|
+
}
|
85
|
+
// Otherwise, register all middleware once
|
86
|
+
for (const middleware of __INTERNAL_WRANGLER_MIDDLEWARE__) {
|
87
|
+
__facade_register__(middleware);
|
88
|
+
}
|
89
|
+
|
90
|
+
// `extend`ing `klass` here so other RPC methods remain callable
|
91
|
+
return class extends klass {
|
92
|
+
#fetchDispatcher: ExportedHandlerFetchHandler<Record<string, unknown>> = (
|
93
|
+
request,
|
94
|
+
env,
|
95
|
+
ctx
|
96
|
+
) => {
|
97
|
+
this.env = env;
|
98
|
+
this.ctx = ctx;
|
99
|
+
if (super.fetch === undefined) {
|
100
|
+
throw new Error("Entrypoint class does not define a fetch() function.");
|
101
|
+
}
|
102
|
+
return super.fetch(request);
|
103
|
+
};
|
104
|
+
|
105
|
+
#dispatcher: Dispatcher = (type, init) => {
|
106
|
+
if (type === "scheduled" && super.scheduled !== undefined) {
|
107
|
+
const controller = new __Facade_ScheduledController__(
|
108
|
+
Date.now(),
|
109
|
+
init.cron ?? "",
|
110
|
+
() => {}
|
111
|
+
);
|
112
|
+
return super.scheduled(controller);
|
113
|
+
}
|
114
|
+
};
|
115
|
+
|
116
|
+
fetch(request: Request<unknown, IncomingRequestCfProperties>) {
|
117
|
+
return __facade_invoke__(
|
118
|
+
request,
|
119
|
+
this.env,
|
120
|
+
this.ctx,
|
121
|
+
this.#dispatcher,
|
122
|
+
this.#fetchDispatcher
|
123
|
+
);
|
124
|
+
}
|
125
|
+
};
|
126
|
+
}
|
127
|
+
|
128
|
+
let WRAPPED_ENTRY: ExportedHandler | WorkerEntrypointConstructor | undefined;
|
129
|
+
if (typeof ENTRY === "object") {
|
130
|
+
WRAPPED_ENTRY = wrapExportedHandler(ENTRY);
|
131
|
+
} else if (typeof ENTRY === "function") {
|
132
|
+
WRAPPED_ENTRY = wrapWorkerEntrypoint(ENTRY);
|
133
|
+
}
|
134
|
+
export default WRAPPED_ENTRY;
|
@@ -0,0 +1,229 @@
|
|
1
|
+
import {
|
2
|
+
__facade_invoke__,
|
3
|
+
__facade_register__,
|
4
|
+
__facade_registerInternal__,
|
5
|
+
Awaitable,
|
6
|
+
Dispatcher,
|
7
|
+
IncomingRequest,
|
8
|
+
Middleware,
|
9
|
+
} from "./common";
|
10
|
+
|
11
|
+
export { __facade_register__, __facade_registerInternal__ };
|
12
|
+
|
13
|
+
// Miniflare 2's `EventTarget` follows the spec and doesn't allow exceptions to
|
14
|
+
// be caught by `dispatchEvent`. Instead it has a custom `ThrowingEventTarget`
|
15
|
+
// class that rethrows errors from event listeners in `dispatchEvent`.
|
16
|
+
// We'd like errors to be propagated to the top-level `addEventListener`, so
|
17
|
+
// we'd like to use `ThrowingEventTarget`. Unfortunately, `ThrowingEventTarget`
|
18
|
+
// isn't exposed on the global scope, but `WorkerGlobalScope` (which extends
|
19
|
+
// `ThrowingEventTarget`) is. Therefore, we get at it in this nasty way.
|
20
|
+
let __FACADE_EVENT_TARGET__: EventTarget;
|
21
|
+
if ((globalThis as any).MINIFLARE) {
|
22
|
+
__FACADE_EVENT_TARGET__ = new (Object.getPrototypeOf(WorkerGlobalScope))();
|
23
|
+
} else {
|
24
|
+
__FACADE_EVENT_TARGET__ = new EventTarget();
|
25
|
+
}
|
26
|
+
|
27
|
+
function __facade_isSpecialEvent__(
|
28
|
+
type: string
|
29
|
+
): type is "fetch" | "scheduled" {
|
30
|
+
return type === "fetch" || type === "scheduled";
|
31
|
+
}
|
32
|
+
const __facade__originalAddEventListener__ = globalThis.addEventListener;
|
33
|
+
const __facade__originalRemoveEventListener__ = globalThis.removeEventListener;
|
34
|
+
const __facade__originalDispatchEvent__ = globalThis.dispatchEvent;
|
35
|
+
|
36
|
+
globalThis.addEventListener = function (type, listener, options) {
|
37
|
+
if (__facade_isSpecialEvent__(type)) {
|
38
|
+
__FACADE_EVENT_TARGET__.addEventListener(
|
39
|
+
type,
|
40
|
+
listener as EventListenerOrEventListenerObject,
|
41
|
+
options
|
42
|
+
);
|
43
|
+
} else {
|
44
|
+
__facade__originalAddEventListener__(type, listener, options);
|
45
|
+
}
|
46
|
+
};
|
47
|
+
globalThis.removeEventListener = function (type, listener, options) {
|
48
|
+
if (__facade_isSpecialEvent__(type)) {
|
49
|
+
__FACADE_EVENT_TARGET__.removeEventListener(
|
50
|
+
type,
|
51
|
+
listener as EventListenerOrEventListenerObject,
|
52
|
+
options
|
53
|
+
);
|
54
|
+
} else {
|
55
|
+
__facade__originalRemoveEventListener__(type, listener, options);
|
56
|
+
}
|
57
|
+
};
|
58
|
+
globalThis.dispatchEvent = function (event) {
|
59
|
+
if (__facade_isSpecialEvent__(event.type)) {
|
60
|
+
return __FACADE_EVENT_TARGET__.dispatchEvent(event);
|
61
|
+
} else {
|
62
|
+
return __facade__originalDispatchEvent__(event);
|
63
|
+
}
|
64
|
+
};
|
65
|
+
|
66
|
+
declare global {
|
67
|
+
var addMiddleware: typeof __facade_register__;
|
68
|
+
var addMiddlewareInternal: typeof __facade_registerInternal__;
|
69
|
+
}
|
70
|
+
globalThis.addMiddleware = __facade_register__;
|
71
|
+
globalThis.addMiddlewareInternal = __facade_registerInternal__;
|
72
|
+
|
73
|
+
const __facade_waitUntil__ = Symbol("__facade_waitUntil__");
|
74
|
+
const __facade_response__ = Symbol("__facade_response__");
|
75
|
+
const __facade_dispatched__ = Symbol("__facade_dispatched__");
|
76
|
+
|
77
|
+
class __Facade_ExtendableEvent__ extends Event {
|
78
|
+
[__facade_waitUntil__]: Awaitable<unknown>[] = [];
|
79
|
+
|
80
|
+
waitUntil(promise: Awaitable<any>) {
|
81
|
+
if (!(this instanceof __Facade_ExtendableEvent__)) {
|
82
|
+
throw new TypeError("Illegal invocation");
|
83
|
+
}
|
84
|
+
this[__facade_waitUntil__].push(promise);
|
85
|
+
}
|
86
|
+
}
|
87
|
+
|
88
|
+
interface FetchEventInit extends EventInit {
|
89
|
+
request: Request;
|
90
|
+
passThroughOnException: FetchEvent["passThroughOnException"];
|
91
|
+
}
|
92
|
+
|
93
|
+
class __Facade_FetchEvent__ extends __Facade_ExtendableEvent__ {
|
94
|
+
#request: Request;
|
95
|
+
#passThroughOnException: FetchEvent["passThroughOnException"];
|
96
|
+
[__facade_response__]?: Awaitable<Response>;
|
97
|
+
[__facade_dispatched__] = false;
|
98
|
+
|
99
|
+
constructor(type: "fetch", init: FetchEventInit) {
|
100
|
+
super(type);
|
101
|
+
this.#request = init.request;
|
102
|
+
this.#passThroughOnException = init.passThroughOnException;
|
103
|
+
}
|
104
|
+
|
105
|
+
get request() {
|
106
|
+
return this.#request;
|
107
|
+
}
|
108
|
+
|
109
|
+
respondWith(response: Awaitable<Response>) {
|
110
|
+
if (!(this instanceof __Facade_FetchEvent__)) {
|
111
|
+
throw new TypeError("Illegal invocation");
|
112
|
+
}
|
113
|
+
if (this[__facade_response__] !== undefined) {
|
114
|
+
throw new DOMException(
|
115
|
+
"FetchEvent.respondWith() has already been called; it can only be called once.",
|
116
|
+
"InvalidStateError"
|
117
|
+
);
|
118
|
+
}
|
119
|
+
if (this[__facade_dispatched__]) {
|
120
|
+
throw new DOMException(
|
121
|
+
"Too late to call FetchEvent.respondWith(). It must be called synchronously in the event handler.",
|
122
|
+
"InvalidStateError"
|
123
|
+
);
|
124
|
+
}
|
125
|
+
this.stopImmediatePropagation();
|
126
|
+
this[__facade_response__] = response;
|
127
|
+
}
|
128
|
+
|
129
|
+
passThroughOnException() {
|
130
|
+
if (!(this instanceof __Facade_FetchEvent__)) {
|
131
|
+
throw new TypeError("Illegal invocation");
|
132
|
+
}
|
133
|
+
// Need to call native method immediately in case uncaught error thrown
|
134
|
+
this.#passThroughOnException();
|
135
|
+
}
|
136
|
+
}
|
137
|
+
|
138
|
+
interface ScheduledEventInit extends EventInit {
|
139
|
+
scheduledTime: number;
|
140
|
+
cron: string;
|
141
|
+
noRetry: ScheduledEvent["noRetry"];
|
142
|
+
}
|
143
|
+
|
144
|
+
class __Facade_ScheduledEvent__ extends __Facade_ExtendableEvent__ {
|
145
|
+
#scheduledTime: number;
|
146
|
+
#cron: string;
|
147
|
+
#noRetry: ScheduledEvent["noRetry"];
|
148
|
+
|
149
|
+
constructor(type: "scheduled", init: ScheduledEventInit) {
|
150
|
+
super(type);
|
151
|
+
this.#scheduledTime = init.scheduledTime;
|
152
|
+
this.#cron = init.cron;
|
153
|
+
this.#noRetry = init.noRetry;
|
154
|
+
}
|
155
|
+
|
156
|
+
get scheduledTime() {
|
157
|
+
return this.#scheduledTime;
|
158
|
+
}
|
159
|
+
|
160
|
+
get cron() {
|
161
|
+
return this.#cron;
|
162
|
+
}
|
163
|
+
|
164
|
+
noRetry() {
|
165
|
+
if (!(this instanceof __Facade_ScheduledEvent__)) {
|
166
|
+
throw new TypeError("Illegal invocation");
|
167
|
+
}
|
168
|
+
// Need to call native method immediately in case uncaught error thrown
|
169
|
+
this.#noRetry();
|
170
|
+
}
|
171
|
+
}
|
172
|
+
|
173
|
+
__facade__originalAddEventListener__("fetch", (event) => {
|
174
|
+
const ctx: ExecutionContext = {
|
175
|
+
waitUntil: event.waitUntil.bind(event),
|
176
|
+
passThroughOnException: event.passThroughOnException.bind(event),
|
177
|
+
};
|
178
|
+
|
179
|
+
const __facade_sw_dispatch__: Dispatcher = function (type, init) {
|
180
|
+
if (type === "scheduled") {
|
181
|
+
const facadeEvent = new __Facade_ScheduledEvent__("scheduled", {
|
182
|
+
scheduledTime: Date.now(),
|
183
|
+
cron: init.cron ?? "",
|
184
|
+
noRetry() {},
|
185
|
+
});
|
186
|
+
|
187
|
+
__FACADE_EVENT_TARGET__.dispatchEvent(facadeEvent);
|
188
|
+
event.waitUntil(Promise.all(facadeEvent[__facade_waitUntil__]));
|
189
|
+
}
|
190
|
+
};
|
191
|
+
|
192
|
+
const __facade_sw_fetch__: Middleware = function (request, _env, ctx) {
|
193
|
+
const facadeEvent = new __Facade_FetchEvent__("fetch", {
|
194
|
+
request,
|
195
|
+
passThroughOnException: ctx.passThroughOnException,
|
196
|
+
});
|
197
|
+
|
198
|
+
__FACADE_EVENT_TARGET__.dispatchEvent(facadeEvent);
|
199
|
+
facadeEvent[__facade_dispatched__] = true;
|
200
|
+
event.waitUntil(Promise.all(facadeEvent[__facade_waitUntil__]));
|
201
|
+
|
202
|
+
const response = facadeEvent[__facade_response__];
|
203
|
+
if (response === undefined) {
|
204
|
+
throw new Error("No response!"); // TODO: proper error message
|
205
|
+
}
|
206
|
+
return response;
|
207
|
+
};
|
208
|
+
|
209
|
+
event.respondWith(
|
210
|
+
__facade_invoke__(
|
211
|
+
event.request as IncomingRequest,
|
212
|
+
globalThis,
|
213
|
+
ctx,
|
214
|
+
__facade_sw_dispatch__,
|
215
|
+
__facade_sw_fetch__
|
216
|
+
)
|
217
|
+
);
|
218
|
+
});
|
219
|
+
|
220
|
+
__facade__originalAddEventListener__("scheduled", (event) => {
|
221
|
+
const facadeEvent = new __Facade_ScheduledEvent__("scheduled", {
|
222
|
+
scheduledTime: event.scheduledTime,
|
223
|
+
cron: event.cron,
|
224
|
+
noRetry: event.noRetry.bind(event),
|
225
|
+
});
|
226
|
+
|
227
|
+
__FACADE_EVENT_TARGET__.dispatchEvent(facadeEvent);
|
228
|
+
event.waitUntil(Promise.all(facadeEvent[__facade_waitUntil__]));
|
229
|
+
});
|
@@ -0,0 +1,18 @@
|
|
1
|
+
import type { Middleware } from "./common";
|
2
|
+
|
3
|
+
const drainBody: Middleware = async (request, env, _ctx, middlewareCtx) => {
|
4
|
+
try {
|
5
|
+
return await middlewareCtx.next(request, env);
|
6
|
+
} finally {
|
7
|
+
try {
|
8
|
+
if (request.body !== null && !request.bodyUsed) {
|
9
|
+
const reader = request.body.getReader();
|
10
|
+
while (!(await reader.read()).done) {}
|
11
|
+
}
|
12
|
+
} catch (e) {
|
13
|
+
console.error("Failed to drain the unused request body.", e);
|
14
|
+
}
|
15
|
+
}
|
16
|
+
};
|
17
|
+
|
18
|
+
export default drainBody;
|
@@ -0,0 +1,32 @@
|
|
1
|
+
import type { Middleware } from "./common";
|
2
|
+
|
3
|
+
interface JsonError {
|
4
|
+
message?: string;
|
5
|
+
name?: string;
|
6
|
+
stack?: string;
|
7
|
+
cause?: JsonError;
|
8
|
+
}
|
9
|
+
|
10
|
+
function reduceError(e: any): JsonError {
|
11
|
+
return {
|
12
|
+
name: e?.name,
|
13
|
+
message: e?.message ?? String(e),
|
14
|
+
stack: e?.stack,
|
15
|
+
cause: e?.cause === undefined ? undefined : reduceError(e.cause),
|
16
|
+
};
|
17
|
+
}
|
18
|
+
|
19
|
+
// See comment in `bundle.ts` for details on why this is needed
|
20
|
+
const jsonError: Middleware = async (request, env, _ctx, middlewareCtx) => {
|
21
|
+
try {
|
22
|
+
return await middlewareCtx.next(request, env);
|
23
|
+
} catch (e: any) {
|
24
|
+
const error = reduceError(e);
|
25
|
+
return Response.json(error, {
|
26
|
+
status: 500,
|
27
|
+
headers: { "MF-Experimental-Error-Stack": "true" },
|
28
|
+
});
|
29
|
+
}
|
30
|
+
};
|
31
|
+
|
32
|
+
export default jsonError;
|
@@ -0,0 +1,40 @@
|
|
1
|
+
import type { Middleware } from "./common";
|
2
|
+
|
3
|
+
// A middleware has to be a function of type Middleware
|
4
|
+
const prettyError: Middleware = async (request, env, _ctx, middlewareCtx) => {
|
5
|
+
try {
|
6
|
+
const response = await middlewareCtx.next(request, env);
|
7
|
+
return response;
|
8
|
+
} catch (e: any) {
|
9
|
+
const html = `
|
10
|
+
<!DOCTYPE html>
|
11
|
+
<html lang="en">
|
12
|
+
<head>
|
13
|
+
<meta charset="UTF-8">
|
14
|
+
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
15
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
16
|
+
<title>Error 🚨</title>
|
17
|
+
<style>
|
18
|
+
pre {
|
19
|
+
margin: 16px auto;
|
20
|
+
max-width: 600px;
|
21
|
+
background-color: #eeeeee;
|
22
|
+
border-radius: 4px;
|
23
|
+
padding: 16px;
|
24
|
+
}
|
25
|
+
</style>
|
26
|
+
</head>
|
27
|
+
<body>
|
28
|
+
<pre>${e.stack}</pre>
|
29
|
+
</body>
|
30
|
+
</html>
|
31
|
+
`;
|
32
|
+
|
33
|
+
return new Response(html, {
|
34
|
+
status: 500,
|
35
|
+
headers: { "Content-Type": "text/html;charset=utf-8" },
|
36
|
+
});
|
37
|
+
}
|
38
|
+
};
|
39
|
+
|
40
|
+
export default prettyError;
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import type { Middleware } from "./common";
|
2
|
+
|
3
|
+
// A middleware has to be a function of type Middleware
|
4
|
+
const scheduled: Middleware = async (request, env, _ctx, middlewareCtx) => {
|
5
|
+
const url = new URL(request.url);
|
6
|
+
if (url.pathname === "/__scheduled") {
|
7
|
+
const cron = url.searchParams.get("cron") ?? "";
|
8
|
+
await middlewareCtx.dispatch("scheduled", { cron });
|
9
|
+
|
10
|
+
return new Response("Ran scheduled event");
|
11
|
+
}
|
12
|
+
return middlewareCtx.next(request, env);
|
13
|
+
};
|
14
|
+
|
15
|
+
export default scheduled;
|
@@ -0,0 +1,56 @@
|
|
1
|
+
/// <reference path="middleware-serve-static-assets.d.ts"/>
|
2
|
+
|
3
|
+
import manifest from "__STATIC_CONTENT_MANIFEST";
|
4
|
+
import {
|
5
|
+
getAssetFromKV,
|
6
|
+
MethodNotAllowedError,
|
7
|
+
NotFoundError,
|
8
|
+
serveSinglePageApp,
|
9
|
+
} from "@cloudflare/kv-asset-handler";
|
10
|
+
import { cacheControl, spaMode } from "config:middleware/serve-static-assets";
|
11
|
+
import type { Middleware } from "./common";
|
12
|
+
import type { Options } from "@cloudflare/kv-asset-handler";
|
13
|
+
import type * as kvAssetHandler from "@cloudflare/kv-asset-handler";
|
14
|
+
|
15
|
+
const ASSET_MANIFEST = JSON.parse(manifest);
|
16
|
+
|
17
|
+
const staticAssets: Middleware = async (request, env, _ctx, middlewareCtx) => {
|
18
|
+
let options: Partial<Options> = {
|
19
|
+
ASSET_MANIFEST,
|
20
|
+
ASSET_NAMESPACE: env.__STATIC_CONTENT,
|
21
|
+
cacheControl: cacheControl,
|
22
|
+
mapRequestToAsset: spaMode ? serveSinglePageApp : undefined,
|
23
|
+
};
|
24
|
+
|
25
|
+
try {
|
26
|
+
const page = await (getAssetFromKV as typeof kvAssetHandler.getAssetFromKV)(
|
27
|
+
{
|
28
|
+
request,
|
29
|
+
waitUntil(promise) {
|
30
|
+
return _ctx.waitUntil(promise);
|
31
|
+
},
|
32
|
+
},
|
33
|
+
options
|
34
|
+
);
|
35
|
+
|
36
|
+
// allow headers to be altered
|
37
|
+
const response = new Response(page.body, page);
|
38
|
+
|
39
|
+
response.headers.set("X-XSS-Protection", "1; mode=block");
|
40
|
+
response.headers.set("X-Content-Type-Options", "nosniff");
|
41
|
+
response.headers.set("X-Frame-Options", "DENY");
|
42
|
+
response.headers.set("Referrer-Policy", "unsafe-url");
|
43
|
+
response.headers.set("Feature-Policy", "none");
|
44
|
+
|
45
|
+
return response;
|
46
|
+
} catch (e) {
|
47
|
+
if (e instanceof NotFoundError || e instanceof MethodNotAllowedError) {
|
48
|
+
// if a known error is thrown then serve from actual worker
|
49
|
+
return await middlewareCtx.next(request, env);
|
50
|
+
}
|
51
|
+
// otherwise it's a real error, so throw it
|
52
|
+
throw e;
|
53
|
+
}
|
54
|
+
};
|
55
|
+
|
56
|
+
export default staticAssets;
|
@@ -0,0 +1,17 @@
|
|
1
|
+
/**
|
2
|
+
* Welcome to Cloudflare Workers! This is your first scheduled worker.
|
3
|
+
*
|
4
|
+
* - Run `wrangler dev --local` in your terminal to start a development server
|
5
|
+
* - Run `curl "http://localhost:8787/cdn-cgi/mf/scheduled"` to trigger the scheduled event
|
6
|
+
* - Go back to the console to see what your worker has logged
|
7
|
+
* - Update the Cron trigger in wrangler.toml (see https://developers.cloudflare.com/workers/wrangler/configuration/#triggers)
|
8
|
+
* - Run `wrangler publish --name my-worker` to publish your worker
|
9
|
+
*
|
10
|
+
* Learn more at https://developers.cloudflare.com/workers/runtime-apis/scheduled-event/
|
11
|
+
*/
|
12
|
+
|
13
|
+
export default {
|
14
|
+
async scheduled(controller, env, ctx) {
|
15
|
+
console.log(`Hello World!`);
|
16
|
+
},
|
17
|
+
};
|