From 92fc8747d6fc4dcb48461517754725d16df4b1f6 Mon Sep 17 00:00:00 2001 From: Emma Hamilton Date: Wed, 23 Oct 2024 11:28:04 +1000 Subject: [PATCH] Support `@astrojs/cloudflare@10.0.0` and above (#1340) --- .changeset/hip-trees-swim.md | 5 ++++ packages/astro/src/api.tsx | 50 +++++++++++++++++++----------------- 2 files changed, 32 insertions(+), 23 deletions(-) create mode 100644 .changeset/hip-trees-swim.md diff --git a/.changeset/hip-trees-swim.md b/.changeset/hip-trees-swim.md new file mode 100644 index 000000000..238d7516f --- /dev/null +++ b/.changeset/hip-trees-swim.md @@ -0,0 +1,5 @@ +--- +'@keystatic/astro': patch +--- + +Support `@astrojs/cloudflare@10.0.0` and above diff --git a/packages/astro/src/api.tsx b/packages/astro/src/api.tsx index 38e36820e..3330c98a2 100644 --- a/packages/astro/src/api.tsx +++ b/packages/astro/src/api.tsx @@ -6,30 +6,34 @@ import type { APIContext } from 'astro'; import { parseString } from 'set-cookie-parser'; export function makeHandler(_config: APIRouteConfig) { - const handler = makeGenericAPIRouteHandler( - { - ..._config, - clientId: - _config.clientId ?? - tryOrUndefined(() => { - return import.meta.env.KEYSTATIC_GITHUB_CLIENT_ID; - }), - clientSecret: - _config.clientSecret ?? - tryOrUndefined(() => { - return import.meta.env.KEYSTATIC_GITHUB_CLIENT_SECRET; - }), - secret: - _config.secret ?? - tryOrUndefined(() => { - return import.meta.env.KEYSTATIC_SECRET; - }), - }, - { - slugEnvName: 'PUBLIC_KEYSTATIC_GITHUB_APP_SLUG', - } - ); return async function keystaticAPIRoute(context: APIContext) { + const envVarsForCf = (context.locals as any)?.runtime?.env; + const handler = makeGenericAPIRouteHandler( + { + ..._config, + clientId: + _config.clientId ?? + envVarsForCf?.KEYSTATIC_GITHUB_CLIENT_ID ?? + tryOrUndefined(() => { + return import.meta.env.KEYSTATIC_GITHUB_CLIENT_ID; + }), + clientSecret: + _config.clientSecret ?? + envVarsForCf?.KEYSTATIC_GITHUB_CLIENT_SECRET ?? + tryOrUndefined(() => { + return import.meta.env.KEYSTATIC_GITHUB_CLIENT_SECRET; + }), + secret: + _config.secret ?? + envVarsForCf?.KEYSTATIC_SECRET ?? + tryOrUndefined(() => { + return import.meta.env.KEYSTATIC_SECRET; + }), + }, + { + slugEnvName: 'PUBLIC_KEYSTATIC_GITHUB_APP_SLUG', + } + ); const { body, headers, status } = await handler(context.request); // all this stuff should be able to go away when astro is using a version of undici with getSetCookie let headersInADifferentStructure = new Map();