diff options
author | 2023-08-15 09:24:06 +0100 | |
---|---|---|
committer | 2023-08-15 09:24:06 +0100 | |
commit | 7530d5689db67eb77d2dce0db0e13d25b3d13063 (patch) | |
tree | 0f33f492b25ace9dd7ca2cfc5de4fec311f9be14 /packages/integrations/netlify/src | |
parent | 68efd4a8b29f248397667801465b3152dc98e9a7 (diff) | |
parent | c19987df0be3520cf774476cea270c03edd08354 (diff) | |
download | astro-7530d5689db67eb77d2dce0db0e13d25b3d13063.tar.gz astro-7530d5689db67eb77d2dce0db0e13d25b3d13063.tar.zst astro-7530d5689db67eb77d2dce0db0e13d25b3d13063.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'); |