mirror of
https://github.com/geoffsee/open-gsio.git
synced 2025-09-08 22:56:46 +00:00
49 lines
1.2 KiB
TypeScript
49 lines
1.2 KiB
TypeScript
import { types } from "mobx-state-tree";
|
|
import renderPage from "@open-gsio/client/server";
|
|
|
|
export default types
|
|
.model("StaticAssetStore", {})
|
|
.volatile((self) => ({
|
|
env: {} as Env,
|
|
ctx: {} as ExecutionContext,
|
|
}))
|
|
.actions((self) => ({
|
|
setEnv(env: Env) {
|
|
self.env = env;
|
|
},
|
|
setCtx(ctx: ExecutionContext) {
|
|
self.ctx = ctx;
|
|
},
|
|
async handleSsr(
|
|
url: string,
|
|
headers: Headers,
|
|
env: Vike.PageContext.env,
|
|
) {
|
|
const pageContextInit = {
|
|
urlOriginal: url,
|
|
headersOriginal: headers,
|
|
fetch: (...args: Parameters<typeof fetch>) => fetch(...args),
|
|
env,
|
|
};
|
|
|
|
const pageContext = await renderPage(pageContextInit);
|
|
const { httpResponse } = pageContext;
|
|
|
|
|
|
if (!httpResponse) {
|
|
return null;
|
|
} else {
|
|
const { statusCode: status, headers } = httpResponse;
|
|
return new Response(httpResponse.pipe, { headers, status });
|
|
}
|
|
},
|
|
async handleStaticAssets(request: Request, env) {
|
|
try {
|
|
return await env.ASSETS.fetch(request);
|
|
} catch (error) {
|
|
console.error("Error serving static asset:", error);
|
|
return new Response("Asset not found", { status: 404 });
|
|
}
|
|
},
|
|
}));
|