2023-07-20 07:47:36 -05:00
|
|
|
import type { Request as CFRequest, ExecutionContext } from '@cloudflare/workers-types';
|
2023-06-13 15:37:42 -05:00
|
|
|
import type { SSRManifest } from 'astro';
|
2022-06-16 09:12:25 -05:00
|
|
|
import { App } from 'astro/app';
|
2023-01-26 12:43:39 -05:00
|
|
|
import { getProcessEnvProxy, isNode } from './util.js';
|
2022-11-08 08:54:49 -05:00
|
|
|
|
2023-01-26 12:45:39 -05:00
|
|
|
if (!isNode) {
|
2023-01-26 12:43:39 -05:00
|
|
|
process.env = getProcessEnvProxy();
|
|
|
|
}
|
2022-06-16 09:12:25 -05:00
|
|
|
|
|
|
|
type Env = {
|
|
|
|
ASSETS: { fetch: (req: Request) => Promise<Response> };
|
2022-10-26 08:46:25 -05:00
|
|
|
name: string;
|
2022-06-16 09:12:25 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
export function createExports(manifest: SSRManifest) {
|
2023-01-26 08:44:09 -05:00
|
|
|
const app = new App(manifest);
|
2022-06-16 09:12:25 -05:00
|
|
|
|
2023-06-20 05:24:32 -05:00
|
|
|
const fetch = async (request: Request & CFRequest, env: Env, context: ExecutionContext) => {
|
2022-11-08 08:54:49 -05:00
|
|
|
process.env = env as any;
|
|
|
|
|
2022-11-21 08:31:21 -05:00
|
|
|
const { pathname } = new URL(request.url);
|
2022-06-16 09:12:25 -05:00
|
|
|
|
2022-11-21 08:31:21 -05:00
|
|
|
// static assets fallback, in case default _routes.json is not used
|
2022-06-16 09:12:25 -05:00
|
|
|
if (manifest.assets.has(pathname)) {
|
2022-11-21 08:31:21 -05:00
|
|
|
return env.ASSETS.fetch(request);
|
2022-06-16 09:12:25 -05:00
|
|
|
}
|
|
|
|
|
2022-07-22 15:30:17 -05:00
|
|
|
let routeData = app.match(request, { matchNotFound: true });
|
|
|
|
if (routeData) {
|
2022-07-19 15:11:53 -05:00
|
|
|
Reflect.set(
|
|
|
|
request,
|
|
|
|
Symbol.for('astro.clientAddress'),
|
|
|
|
request.headers.get('cf-connecting-ip')
|
|
|
|
);
|
2023-06-13 15:34:44 -05:00
|
|
|
Reflect.set(request, Symbol.for('runtime'), {
|
|
|
|
env,
|
|
|
|
name: 'cloudflare',
|
|
|
|
caches,
|
|
|
|
cf: request.cf,
|
|
|
|
...context,
|
2023-06-20 05:24:32 -05:00
|
|
|
waitUntil: (promise: Promise<any>) => {
|
|
|
|
context.waitUntil(promise);
|
|
|
|
},
|
2023-06-13 15:34:44 -05:00
|
|
|
});
|
2022-09-28 15:55:27 -05:00
|
|
|
let response = await app.render(request, routeData);
|
|
|
|
|
2022-09-28 15:57:35 -05:00
|
|
|
if (app.setCookieHeaders) {
|
|
|
|
for (const setCookieHeader of app.setCookieHeaders(response)) {
|
2022-09-28 15:55:27 -05:00
|
|
|
response.headers.append('Set-Cookie', setCookieHeader);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return response;
|
2022-06-24 14:30:47 -05:00
|
|
|
}
|
|
|
|
|
2022-06-16 09:12:25 -05:00
|
|
|
return new Response(null, {
|
|
|
|
status: 404,
|
|
|
|
statusText: 'Not found',
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
return { default: { fetch } };
|
|
|
|
}
|