diff options
author | 2023-06-20 12:24:32 +0200 | |
---|---|---|
committer | 2023-06-20 11:24:32 +0100 | |
commit | 99e39f91faf475168ed3fe2b0a93323149550e4b (patch) | |
tree | 63dcca33556f3deba290ea54a5a24a70edcded55 /packages/integrations/cloudflare/src | |
parent | 58e8770d8f8202cb6cd5621b9c9372f0cac4c75b (diff) | |
download | astro-99e39f91faf475168ed3fe2b0a93323149550e4b.tar.gz astro-99e39f91faf475168ed3fe2b0a93323149550e4b.tar.zst astro-99e39f91faf475168ed3fe2b0a93323149550e4b.zip |
fix: cloudflare waitUntil not working as inteded with getRuntime (#7419)
Co-authored-by: Bjorn Lu <bjornlu.dev@gmail.com>
Diffstat (limited to 'packages/integrations/cloudflare/src')
-rw-r--r-- | packages/integrations/cloudflare/src/server.advanced.ts | 7 | ||||
-rw-r--r-- | packages/integrations/cloudflare/src/server.directory.ts | 6 |
2 files changed, 10 insertions, 3 deletions
diff --git a/packages/integrations/cloudflare/src/server.advanced.ts b/packages/integrations/cloudflare/src/server.advanced.ts index 510e4e7e5..9758b8b19 100644 --- a/packages/integrations/cloudflare/src/server.advanced.ts +++ b/packages/integrations/cloudflare/src/server.advanced.ts @@ -1,4 +1,4 @@ -import type { Request as CFRequest } from '@cloudflare/workers-types'; +import type { Request as CFRequest, ExecutionContext } from '@cloudflare/workers-types'; import type { SSRManifest } from 'astro'; import { App } from 'astro/app'; import { getProcessEnvProxy, isNode } from './util.js'; @@ -15,7 +15,7 @@ type Env = { export function createExports(manifest: SSRManifest) { const app = new App(manifest); - const fetch = async (request: Request & CFRequest, env: Env, context: any) => { + const fetch = async (request: Request & CFRequest, env: Env, context: ExecutionContext) => { process.env = env as any; const { pathname } = new URL(request.url); @@ -38,6 +38,9 @@ export function createExports(manifest: SSRManifest) { caches, cf: request.cf, ...context, + waitUntil: (promise: Promise<any>) => { + context.waitUntil(promise); + }, }); let response = await app.render(request, routeData); diff --git a/packages/integrations/cloudflare/src/server.directory.ts b/packages/integrations/cloudflare/src/server.directory.ts index a0f3299fd..649d0d99b 100644 --- a/packages/integrations/cloudflare/src/server.directory.ts +++ b/packages/integrations/cloudflare/src/server.directory.ts @@ -1,4 +1,4 @@ -import type { Request as CFRequest } from '@cloudflare/workers-types'; +import type { Request as CFRequest, EventContext } from '@cloudflare/workers-types'; import type { SSRManifest } from 'astro'; import { App } from 'astro/app'; import { getProcessEnvProxy, isNode } from './util.js'; @@ -17,6 +17,7 @@ export function createExports(manifest: SSRManifest) { }: { request: Request & CFRequest; next: (request: Request) => void; + waitUntil: EventContext<unknown, any, unknown>['waitUntil']; } & Record<string, unknown>) => { process.env = runtimeEnv.env as any; @@ -35,6 +36,9 @@ export function createExports(manifest: SSRManifest) { ); Reflect.set(request, Symbol.for('runtime'), { ...runtimeEnv, + waitUntil: (promise: Promise<any>) => { + runtimeEnv.waitUntil(promise); + }, name: 'cloudflare', next, caches, |