diff options
| author | 2023-08-15 09:24:06 +0100 | |
|---|---|---|
| committer | 2023-08-15 09:24:06 +0100 | |
| commit | 30cb576a4cc4fb9ee83a99007dbe7a1e2751c7cc (patch) | |
| tree | ab99d7612a92ba258197c60e706cc75b6d0d68ed /packages/integrations/netlify/src | |
| parent | e1d735b5e8671c6ed2236ded0c0b19056bf24645 (diff) | |
| parent | f2e1664b3e4bf731ca0ed7ee3138f8b6cd3169ab (diff) | |
| download | astro-30cb576a4cc4fb9ee83a99007dbe7a1e2751c7cc.tar.gz astro-30cb576a4cc4fb9ee83a99007dbe7a1e2751c7cc.tar.zst astro-30cb576a4cc4fb9ee83a99007dbe7a1e2751c7cc.zip | |
Merge remote-tracking branch 'origin/main' into next
Diffstat (limited to 'packages/integrations/netlify/src')
| -rw-r--r-- | packages/integrations/netlify/src/netlify-functions.ts | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/packages/integrations/netlify/src/netlify-functions.ts b/packages/integrations/netlify/src/netlify-functions.ts index 3da0718b0..8c051d9f6 100644 --- a/packages/integrations/netlify/src/netlify-functions.ts +++ b/packages/integrations/netlify/src/netlify-functions.ts @@ -68,18 +68,32 @@ export const createExports = (manifest: SSRManifest, args: Args) => { init.body = typeof requestBody === 'string' ? Buffer.from(requestBody, encoding) : requestBody; } + const request = new Request(rawUrl, init); const routeData = app.match(request); const ip = headers['x-nf-client-connection-ip']; Reflect.set(request, clientAddressSymbol, ip); - let locals = {}; + + let locals: Record<string, unknown> = {}; + if (request.headers.has(ASTRO_LOCALS_HEADER)) { let localsAsString = request.headers.get(ASTRO_LOCALS_HEADER); if (localsAsString) { locals = JSON.parse(localsAsString); } } + + let responseTtl = undefined; + + locals.runtime = builders + ? { + setBuildersTtl(ttl: number) { + responseTtl = ttl; + }, + } + : {}; + const response: Response = await app.render(request, routeData, locals); const responseHeaders = Object.fromEntries(response.headers.entries()); @@ -99,6 +113,7 @@ export const createExports = (manifest: SSRManifest, args: Args) => { headers: responseHeaders, body: responseBody, isBase64Encoded: responseIsBase64Encoded, + ttl: responseTtl, }; const cookies = response.headers.get('set-cookie'); |
