/proc/self/root/proc/self/root/proc/self/root/var/task/_ssr
This explorer reads the filesystem of the server it runs on, so /workspace/user isn't present here. Browsing and the terminal still work against this server's own disk from /.
import { n as __exportAll } from "../_runtime.mjs";import { A as isNotFound, C as resolveManifestAssetLink, D as isResolvedRedirect, E as isRedirect, M as invariant, O as parseRedirect, P as require_react, S as getStylesheetHref, T as executeRewriteInput, a as replaceSsrResponse, g as require_jsx_runtime, i as normalizeSsrResponse, k as rootRouteId, l as RouterProvider, n as defineHandlerCallback, o as stripSsrResponseBody, r as isSsrResponse, t as renderRouterToStream, w as resolveManifestCssLink, x as getScriptPreloadAttrs } from "../_libs/@tanstack/react-router+[...].mjs";import { n as createMemoryHistory } from "../_libs/tanstack__history.mjs";import { a as defaultSerovalPlugins, c as makeSerovalPlugin, d as su, i as getOrigin, l as Pu, n as attachRouterServerSsrUtils, o as createRawStreamRPCPlugin, r as getNormalizedURL, s as createSerializationAdapter, t as mergeHeaders, u as iu } from "../_libs/@tanstack/router-core+[...].mjs";import { n as toResponse, t as H3Event } from "../_libs/h3-v2.mjs";import { AsyncLocalStorage } from "node:async_hooks";//#region node_modules/.nitro/vite/services/ssr/index.jsvar ssr_exports = /* @__PURE__ */ __exportAll({ createServerEntry: () => createServerEntry, default: () => server_default, n: () => TSS_SERVER_FUNCTION, r: () => getServerFnById, t: () => createServerFn});require_react();var import_jsx_runtime = require_jsx_runtime();function StartServer(props) { return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(RouterProvider, { router: props.router });}var defaultStreamHandler = defineHandlerCallback(({ request, router, responseHeaders }) => renderRouterToStream({ request, router, responseHeaders, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(StartServer, { router })}));var GLOBAL_EVENT_STORAGE_KEY = Symbol.for("tanstack-start:event-storage");var globalObj$1 = globalThis;if (!globalObj$1[GLOBAL_EVENT_STORAGE_KEY]) globalObj$1[GLOBAL_EVENT_STORAGE_KEY] = new AsyncLocalStorage();var eventStorage = globalObj$1[GLOBAL_EVENT_STORAGE_KEY];function isPromiseLike(value) { return typeof value.then === "function";}function getSetCookieValues(headers) { const headersWithSetCookie = headers; if (typeof headersWithSetCookie.getSetCookie === "function") return headersWithSetCookie.getSetCookie(); const value = headers.get("set-cookie"); return value ? [value] : [];}function mergeEventResponseHeaders(response, event) { if (response.ok) return; const eventSetCookies = getSetCookieValues(event.res.headers); if (eventSetCookies.length === 0) return; const responseSetCookies = getSetCookieValues(response.headers); response.headers.delete("set-cookie"); for (const cookie of responseSetCookies) response.headers.append("set-cookie", cookie); for (const cookie of eventSetCookies) response.headers.append("set-cookie", cookie);}function attachResponseHeaders(value, event) { if (isPromiseLike(value)) return value.then((resolved) => { if (resolved instanceof Response) mergeEventResponseHeaders(resolved, event); return resolved; }); if (value instanceof Response) mergeEventResponseHeaders(value, event); return value;}function requestHandler(handler) { return (request, requestOpts) => { let h3Event; try { h3Event = new H3Event(request); } catch (error) { if (error instanceof URIError) return new Response(null, { status: 400, statusText: "Bad Request" }); throw error; } return toResponse(attachResponseHeaders(eventStorage.run({ h3Event }, () => handler(request, requestOpts)), h3Event), h3Event); };}function getH3Event() { const event = eventStorage.getStore(); if (!event) throw new Error(`No StartEvent found in AsyncLocalStorage. Make sure you are using the function within the server runtime.`); return event.h3Event;}function getResponse() { return getH3Event().res;}var HEADERS = { TSS_SHELL: "X-TSS_SHELL" };/*** @description Returns the router manifest data that should be sent to the client.* This includes only the assets and preloads for the current route and any* special assets that are needed for the client. It does not include relationships* between routes or any other data that is not needed for the client.** @param matchedRoutes - In dev mode, the matched routes are used to build* the dev styles URL for route-scoped CSS collection.*/async function getStartManifest(matchedRoutes) { const { tsrStartManifest } = await import("../_tanstack-start-manifest_v-C1t-89m5.mjs"); const startManifest = tsrStartManifest(); let routes = startManifest.routes; routes[rootRouteId]; const manifestRoutes = {}; for (const k in routes) { const v = routes[k]; const result = {}; if (v.preloads && v.preloads.length > 0) result.preloads = v.preloads; if (v.scripts && v.scripts.length > 0) result.scripts = v.scripts; if (v.css?.length) result.css = v.css; if (result.preloads || result.scripts || result.css) manifestRoutes[k] = result; } return { ...startManifest.scriptFormat ? { scriptFormat: startManifest.scriptFormat } : {}, ...startManifest.inlineCss ? { inlineCss: startManifest.inlineCss } : {}, routes: manifestRoutes };}var manifest = { "2aec5ec073e4b4933393facf0ef90c23771c7832c98d6e2a18f21b54aa694d82": { functionName: "readFile_createServerFn_handler", importer: () => import("./fs-server-BLMW8vuu.mjs") }, "3e9ad7efb5ff1b6ad57a93cc9f3882a022f3d539053d163dfd6fb95a332c1f69": { functionName: "saveFile_createServerFn_handler", importer: () => import("./shell-server-DFeDm4h2.mjs") }, "43655b12b2525448f49cc143e8e0a1f9d366816530f47cde443331fced610278": { functionName: "runCommand_createServerFn_handler", importer: () => import("./shell-server-DFeDm4h2.mjs") }, "5423ddc1186c87712090018fdf3b2cd2b27df4037b35d013b3323d1110de1d4d": { functionName: "probeEnv_createServerFn_handler", importer: () => import("./fs-server-BLMW8vuu.mjs") }, "67ab0753c5977d86d998fe2b62b3d160fa7d511fddac5d00d3db6f488f99ecbb": { functionName: "listDir_createServerFn_handler", importer: () => import("./fs-server-BLMW8vuu.mjs") }};async function getServerFnById(id, access) { const serverFnInfo = manifest[id]; if (!serverFnInfo) throw new Error("Server function info not found for " + id); const fnModule = serverFnInfo.module ?? await serverFnInfo.importer(); if (!fnModule) throw new Error("Server function module not resolved for " + id); const action = fnModule[serverFnInfo.functionName]; if (!action) throw new Error("Server function module export not resolved for serverFn ID: " + id); return action;}var TSS_FORMDATA_CONTEXT = "__TSS_CONTEXT";var TSS_SERVER_FUNCTION = Symbol.for("TSS_SERVER_FUNCTION");var TSS_SERVER_FUNCTION_FACTORY = Symbol.for("TSS_SERVER_FUNCTION_FACTORY");var X_TSS_SERIALIZED = "x-tss-serialized";var X_TSS_RAW_RESPONSE = "x-tss-raw";/** Content-Type for multiplexed framed responses (RawStream support) */var TSS_CONTENT_TYPE_FRAMED = "application/x-tss-framed";/*** Frame types for binary multiplexing protocol.*/var FrameType = { /** Seroval JSON chunk (NDJSON line) */ JSON: 0, /** Raw stream data chunk */ CHUNK: 1, /** Raw stream end (EOF) */ END: 2, /** Raw stream error */ ERROR: 3};/** Full Content-Type header value with version parameter */var TSS_CONTENT_TYPE_FRAMED_VERSIONED = `${TSS_CONTENT_TYPE_FRAMED}; v=1`;function isSafeKey(key) { return key !== "__proto__" && key !== "constructor" && key !== "prototype";}/*** Merge target and source into a new null-proto object, filtering dangerous keys.*/function safeObjectMerge(target, source) { const result = Object.create(null); if (target) { for (const key of Object.keys(target)) if (isSafeKey(key)) result[key] = target[key]; } if (source && typeof source === "object") { for (const key of Object.keys(source)) if (isSafeKey(key)) result[key] = source[key]; } return result;}/*** Create a null-prototype object, optionally copying from source.*/function createNullProtoObject(source) { if (!source) return Object.create(null); const obj = Object.create(null); for (const key of Object.keys(source)) if (isSafeKey(key)) obj[key] = source[key]; return obj;}var GLOBAL_STORAGE_KEY = Symbol.for("tanstack-start:start-storage-context");var globalObj = globalThis;if (!globalObj[GLOBAL_STORAGE_KEY]) globalObj[GLOBAL_STORAGE_KEY] = new AsyncLocalStorage();var startStorage = globalObj[GLOBAL_STORAGE_KEY];async function runWithStartContext(context, fn) { return startStorage.run(context, fn);}function getStartContext(opts) { const context = startStorage.getStore(); if (!context && opts?.throwIfNotFound !== false) throw new Error(`No Start context found in AsyncLocalStorage. Make sure you are using the function within the server runtime.`); return context;}var getStartOptions = () => getStartContext().startOptions;var getStartContextServerOnly = getStartContext;var createServerFn = (options, __opts) => { const resolvedOptions = __opts || options || {}; if (typeof resolvedOptions.method === "undefined") resolvedOptions.method = "GET"; const setValidator = (validator) => { return createServerFn(void 0, { ...resolvedOptions, validator, inputValidator: validator }); }; const res = { options: resolvedOptions, middleware: (middleware) => { const newMiddleware = [...resolvedOptions.middleware || []]; middleware.map((m) => { if (TSS_SERVER_FUNCTION_FACTORY in m) { if (m.options.middleware) newMiddleware.push(...m.options.middleware); } else newMiddleware.push(m); }); const res = createServerFn(void 0, { ...resolvedOptions, middleware: newMiddleware }); res[TSS_SERVER_FUNCTION_FACTORY] = true; return res; }, validator: setValidator, inputValidator: setValidator, handler: (...args) => { const [extractedFn, serverFn] = args; const newOptions = { ...resolvedOptions, extractedFn, serverFn }; const resolvedMiddleware = [...newOptions.middleware || [], serverFnBaseToMiddleware(newOptions)]; extractedFn.method = resolvedOptions.method; return Object.assign(async (opts) => { const result = await executeMiddleware$1(resolvedMiddleware, "client", { ...extractedFn, ...newOptions, data: opts?.data, headers: opts?.headers, signal: opts?.signal, fetch: opts?.fetch, context: createNullProtoObject() }); const redirect = parseRedirect(result.error); if (redirect) throw redirect; if (result.error) throw result.error; return result.result; }, { ...extractedFn, method: resolvedOptions.method, __executeServer: async (opts) => { const startContext = getStartContextServerOnly(); const serverContextAfterGlobalMiddlewares = startContext.contextAfterGlobalMiddlewares; return await executeMiddleware$1(resolvedMiddleware, "server", { ...extractedFn, ...opts, serverFnMeta: extractedFn.serverFnMeta, context: safeObjectMerge(opts.context, serverContextAfterGlobalMiddlewares), request: startContext.request }).then((d) => ({ result: d.result, error: d.error, context: d.sendContext })); } }); } }; const fun = (options) => { return createServerFn(void 0, { ...resolvedOptions, ...options }); }; return Object.assign(fun, res);};async function executeMiddleware$1(middlewares, env, opts) { let flattenedMiddlewares = flattenMiddlewares([...getStartOptions()?.functionMiddleware || [], ...middlewares]); if (env === "server") { const startContext = getStartContextServerOnly({ throwIfNotFound: false }); if (startContext?.executedRequestMiddlewares) flattenedMiddlewares = flattenedMiddlewares.filter((m) => !startContext.executedRequestMiddlewares.has(m)); } const callNextMiddleware = async (ctx) => { const nextMiddleware = flattenedMiddlewares.shift(); if (!nextMiddleware) return ctx; try { let validator = "validator" in nextMiddleware.options ? nextMiddleware.options.validator : void 0; if (!validator && "inputValidator" in nextMiddleware.options) validator = nextMiddleware.options.inputValidator; if (validator && env === "server") ctx.data = await execValidator(validator, ctx.data); let middlewareFn = void 0; if (env === "client") { if ("client" in nextMiddleware.options) middlewareFn = nextMiddleware.options.client; } else if ("server" in nextMiddleware.options) middlewareFn = nextMiddleware.options.server; if (middlewareFn) { const userNext = async (userCtx = {}) => { const result = await callNextMiddleware({ ...ctx, ...userCtx, context: safeObjectMerge(ctx.context, userCtx.context), sendContext: safeObjectMerge(ctx.sendContext, userCtx.sendContext), headers: mergeHeaders(ctx.headers, userCtx.headers), _callSiteFetch: ctx._callSiteFetch, fetch: ctx._callSiteFetch ?? userCtx.fetch ?? ctx.fetch, result: userCtx.result !== void 0 ? userCtx.result : userCtx instanceof Response ? userCtx : ctx.result, error: userCtx.error ?? ctx.error }); if (result.error) throw result.error; return result; }; const result = await middlewareFn({ ...ctx, next: userNext }); if (isRedirect(result)) return { ...ctx, error: result }; if (result instanceof Response) return { ...ctx, result }; if (!result) throw new Error("User middleware returned undefined. You must call next() or return a result in your middlewares."); return result; } return callNextMiddleware(ctx); } catch (error) { return { ...ctx, error }; } }; return callNextMiddleware({ ...opts, headers: opts.headers || {}, sendContext: opts.sendContext || {}, context: opts.context || createNullProtoObject(), _callSiteFetch: opts.fetch });}function flattenMiddlewares(middlewares, maxDepth = 100) { const seen = /* @__PURE__ */ new Set(); const flattened = []; const recurse = (middleware, depth) => { if (depth > maxDepth) throw new Error(`Middleware nesting depth exceeded maximum of ${maxDepth}. Check for circular references.`); middleware.forEach((m) => { if (m.options.middleware) recurse(m.options.middleware, depth + 1); if (!seen.has(m)) { seen.add(m); flattened.push(m); } }); }; recurse(middlewares, 0); return flattened;}async function execValidator(validator, input) { if (validator == null) return {}; if ("~standard" in validator) { const result = await validator["~standard"].validate(input); if (result.issues) throw new Error(JSON.stringify(result.issues, void 0, 2)); return result.value; } if ("parse" in validator) return validator.parse(input); if (typeof validator === "function") return validator(input); throw new Error("Invalid validator type!");}function serverFnBaseToMiddleware(options) { return { "~types": void 0, options: { inputValidator: options.validator ?? options.inputValidator, client: async ({ next, sendContext, fetch, ...ctx }) => { const payload = { ...ctx, context: sendContext, fetch }; return next(await options.extractedFn?.(payload)); }, server: async ({ next, ...ctx }) => { const result = await options.serverFn?.(ctx); return next({ ...ctx, result }); } } };}var createMiddleware = (options, __opts) => { const resolvedOptions = { type: "request", ...__opts || options }; const setValidator = (validator) => { return createMiddleware({}, Object.assign(resolvedOptions, { validator, inputValidator: validator })); }; return { options: resolvedOptions, middleware: (middleware) => { return createMiddleware({}, Object.assign(resolvedOptions, { middleware })); }, validator: setValidator, inputValidator: setValidator, client: (client) => { return createMiddleware({}, Object.assign(resolvedOptions, { client })); }, server: (server) => { return createMiddleware({}, Object.assign(resolvedOptions, { server })); } };};var innerCreateCsrfMiddleware = (opts = {}) => { return createMiddleware().server(async (ctx) => { const csrfCtx = ctx; if (opts.filter && !await opts.filter(csrfCtx)) return ctx.next(); if (await isCsrfRequestAllowed(opts, csrfCtx)) return ctx.next(); return getFailureResponse(opts, csrfCtx); });};var createCsrfMiddleware = innerCreateCsrfMiddleware;async function isCsrfRequestAllowed(opts, ctx) { const result = await getCsrfRequestValidationResult(opts, ctx); return result === true || result === void 0 && opts.allowRequestsWithoutOriginCheck === true;}async function getCsrfRequestValidationResult(opts, ctx) { const fetchSite = ctx.request.headers.get("Sec-Fetch-Site"); if (fetchSite !== null) return matchValue(opts.secFetchSite ?? "same-origin", fetchSite, ctx); const origin = ctx.request.headers.get("Origin"); if (origin !== null) { if (opts.origin) return matchValue(opts.origin, origin, ctx); return origin === new URL(ctx.request.url).origin; } const referer = ctx.request.headers.get("Referer"); if (referer === null || opts.referer === false) return; if (typeof opts.referer === "function") return opts.referer(referer, ctx); if (opts.origin) { const refererOrigin = getOriginFromUrl(referer); return refererOrigin !== void 0 && matchValue(opts.origin, refererOrigin, ctx); } return isRefererSameOrigin(referer, new URL(ctx.request.url).origin);}async function matchValue(matcher, value, ctx) { if (typeof matcher === "function") return matcher(value, ctx); if (Array.isArray(matcher)) return matcher.includes(value); return value === matcher;}function getOriginFromUrl(url) { try { return new URL(url).origin; } catch { return; }}function isRefererSameOrigin(referer, requestOrigin) { if (referer === requestOrigin) return true; if (!referer.startsWith(requestOrigin)) return false; if (referer.length === requestOrigin.length) return true; const code = referer.charCodeAt(requestOrigin.length); return code === 47 || code === 63 || code === 35;}async function getFailureResponse(opts, ctx) { if (typeof opts.failureResponse === "function") return opts.failureResponse(ctx); return opts.failureResponse?.clone() ?? new Response("Forbidden", { status: 403 });}function getDefaultSerovalPlugins() { return [...(getStartOptions()?.serializationAdapters)?.map(makeSerovalPlugin) ?? [], ...defaultSerovalPlugins];}/*** Binary frame protocol for multiplexing JSON and raw streams over HTTP.** Frame format: [type:1][streamId:4][length:4][payload:length]* - type: 1 byte - frame type (JSON, CHUNK, END, ERROR)* - streamId: 4 bytes big-endian uint32 - stream identifier* - length: 4 bytes big-endian uint32 - payload length* - payload: variable length bytes*//** Cached TextEncoder for frame encoding */var textEncoder = new TextEncoder();/** Shared empty payload for END frames - avoids allocation per call */var EMPTY_PAYLOAD = new Uint8Array(0);/*** Encodes a single frame with header and payload.*/function encodeFrame(type, streamId, payload) { const frame = new Uint8Array(9 + payload.length); frame[0] = type; frame[1] = streamId >>> 24 & 255; frame[2] = streamId >>> 16 & 255; frame[3] = streamId >>> 8 & 255; frame[4] = streamId & 255; frame[5] = payload.length >>> 24 & 255; frame[6] = payload.length >>> 16 & 255; frame[7] = payload.length >>> 8 & 255; frame[8] = payload.length & 255; frame.set(payload, 9); return frame;}/*** Encodes a JSON frame (type 0, streamId 0).*/function encodeJSONFrame(json) { return encodeFrame(FrameType.JSON, 0, textEncoder.encode(json));}/*** Encodes a raw stream chunk frame.*/function encodeChunkFrame(streamId, chunk) { return encodeFrame(FrameType.CHUNK, streamId, chunk);}/*** Encodes a raw stream end frame.*/function encodeEndFrame(streamId) { return encodeFrame(FrameType.END, streamId, EMPTY_PAYLOAD);}/*** Encodes a raw stream error frame.*/function encodeErrorFrame(streamId, error) { const message = error instanceof Error ? error.message : String(error ?? "Unknown error"); return encodeFrame(FrameType.ERROR, streamId, textEncoder.encode(message));}/*** Creates a multiplexed ReadableStream from JSON stream and raw streams.** The JSON stream emits NDJSON lines (from seroval's toCrossJSONStream).* Raw streams are pumped concurrently, interleaved with JSON frames.** Supports late stream registration for RawStreams discovered after initial* serialization (e.g., from resolved Promises).** @param jsonStream Stream of JSON strings (each string is one NDJSON line)* @param rawStreams Map of stream IDs to raw binary streams (known at start)* @param lateStreamSource Optional stream of late registrations for streams discovered later*/function createMultiplexedStream(jsonStream, rawStreams, lateStreamSource) { let controller; let cancelled = false; const readers = []; const enqueue = (frame) => { if (cancelled) return false; try { controller.enqueue(frame); return true; } catch { return false; } }; const errorOutput = (error) => { if (cancelled) return; cancelled = true; try { controller.error(error); } catch {} for (const reader of readers) reader.cancel().catch(() => {}); }; async function pumpRawStream(streamId, stream) { const reader = stream.getReader(); readers.push(reader); try { while (!cancelled) { const { done, value } = await reader.read(); if (done) { enqueue(encodeEndFrame(streamId)); return; } if (!enqueue(encodeChunkFrame(streamId, value))) return; } } catch (error) { enqueue(encodeErrorFrame(streamId, error)); } finally { reader.releaseLock(); } } async function pumpJSON() { const reader = jsonStream.getReader(); readers.push(reader); try { while (!cancelled) { const { done, value } = await reader.read(); if (done) return; if (!enqueue(encodeJSONFrame(value))) return; } } catch (error) { errorOutput(error); throw error; } finally { reader.releaseLock(); } } async function pumpLateStreams() { if (!lateStreamSource) return []; const lateStreamPumps = []; const reader = lateStreamSource.getReader(); readers.push(reader); try { while (!cancelled) { const { done, value } = await reader.read(); if (done) break; lateStreamPumps.push(pumpRawStream(value.id, value.stream)); } } finally { reader.releaseLock(); } return lateStreamPumps; } return new ReadableStream({ async start(ctrl) { controller = ctrl; const pumps = [pumpJSON()]; for (const [streamId, stream] of rawStreams) pumps.push(pumpRawStream(streamId, stream)); if (lateStreamSource) pumps.push(pumpLateStreams()); try { const latePumps = (await Promise.all(pumps)).find(Array.isArray); if (latePumps && latePumps.length > 0) await Promise.all(latePumps); if (!cancelled) try { controller.close(); } catch {} } catch {} }, cancel() { cancelled = true; for (const reader of readers) reader.cancel().catch(() => {}); readers.length = 0; } });}var serovalPlugins = void 0;var FORM_DATA_CONTENT_TYPES = ["multipart/form-data", "application/x-www-form-urlencoded"];var MAX_PAYLOAD_SIZE = 1e6;var handleServerAction = async ({ request, context, serverFnId }) => { const methodUpper = request.method.toUpperCase(); const url = new URL(request.url); const action = await getServerFnById(serverFnId, { origin: "client" }); if (action.method && methodUpper !== action.method) return new Response(`expected ${action.method} method. Got ${methodUpper}`, { status: 405, headers: { Allow: action.method } }); const isServerFn = request.headers.get("x-tsr-serverFn") === "true"; if (!serovalPlugins) serovalPlugins = getDefaultSerovalPlugins(); const contentType = request.headers.get("Content-Type"); function parsePayload(payload) { return Pu(payload, { plugins: serovalPlugins }); } return await (async () => { try { let res = await (async () => { if (FORM_DATA_CONTENT_TYPES.some((type) => contentType && contentType.includes(type))) { if (methodUpper === "GET") invariant(); const formData = await request.formData(); const serializedContext = formData.get(TSS_FORMDATA_CONTEXT); formData.delete(TSS_FORMDATA_CONTEXT); const params = { context, data: formData, method: methodUpper }; if (typeof serializedContext === "string") try { const deserializedContext = Pu(JSON.parse(serializedContext), { plugins: serovalPlugins }); if (typeof deserializedContext === "object" && deserializedContext) params.context = safeObjectMerge(deserializedContext, context); } catch (e) {} return await action(params); } if (methodUpper === "GET") { const payloadParam = url.searchParams.get("payload"); if (payloadParam && payloadParam.length > MAX_PAYLOAD_SIZE) throw new Error("Payload too large"); const payload = payloadParam ? parsePayload(JSON.parse(payloadParam)) : {}; payload.context = safeObjectMerge(payload.context, context); payload.method = methodUpper; return await action(payload); } let jsonPayload; if (contentType?.includes("application/json")) jsonPayload = await request.json(); const payload = jsonPayload ? parsePayload(jsonPayload) : {}; payload.context = safeObjectMerge(payload.context, context); payload.method = methodUpper; return await action(payload); })(); const unwrapped = res.result || res.error; if (isNotFound(res)) res = isNotFoundResponse(res); if (!isServerFn) return unwrapped; if (unwrapped instanceof Response) { if (isRedirect(unwrapped)) return unwrapped; unwrapped.headers.set(X_TSS_RAW_RESPONSE, "true"); return unwrapped; } return serializeResult(res); function serializeResult(res) { let nonStreamingBody = void 0; const alsResponse = getResponse(); if (res !== void 0) { const rawStreams = /* @__PURE__ */ new Map(); let initialPhase = true; let lateStreamWriter; let lateStreamReadable = void 0; const pendingLateStreams = []; const plugins = [createRawStreamRPCPlugin((id, stream) => { if (initialPhase) { rawStreams.set(id, stream); return; } if (lateStreamWriter) { lateStreamWriter.write({ id, stream }).catch(() => {}); return; } pendingLateStreams.push({ id, stream }); }), ...serovalPlugins || []]; let done = false; const callbacks = { onParse: (value) => { nonStreamingBody = value; }, onDone: () => { done = true; }, onError: (error) => { throw error; } }; iu(res, { refs: /* @__PURE__ */ new Map(), plugins, onParse(value) { callbacks.onParse(value); }, onDone() { callbacks.onDone(); }, onError: (error) => { callbacks.onError(error); } }); initialPhase = false; if (done && rawStreams.size === 0) return new Response(nonStreamingBody ? JSON.stringify(nonStreamingBody) : void 0, { status: alsResponse.status, statusText: alsResponse.statusText, headers: { "Content-Type": "application/json", [X_TSS_SERIALIZED]: "true" } }); const { readable, writable } = new TransformStream(); lateStreamReadable = readable; lateStreamWriter = writable.getWriter(); for (const registration of pendingLateStreams) lateStreamWriter.write(registration).catch(() => {}); pendingLateStreams.length = 0; const multiplexedStream = createMultiplexedStream(new ReadableStream({ start(controller) { callbacks.onParse = (value) => { controller.enqueue(JSON.stringify(value) + "\n"); }; callbacks.onDone = () => { try { controller.close(); } catch {} lateStreamWriter?.close().catch(() => {}).finally(() => { lateStreamWriter = void 0; }); }; callbacks.onError = (error) => { controller.error(error); lateStreamWriter?.abort(error).catch(() => {}).finally(() => { lateStreamWriter = void 0; }); }; if (nonStreamingBody !== void 0) callbacks.onParse(nonStreamingBody); if (done) callbacks.onDone(); }, cancel() { lateStreamWriter?.abort().catch(() => {}); lateStreamWriter = void 0; } }), rawStreams, lateStreamReadable); return new Response(multiplexedStream, { status: alsResponse.status, statusText: alsResponse.statusText, headers: { "Content-Type": TSS_CONTENT_TYPE_FRAMED_VERSIONED, [X_TSS_SERIALIZED]: "true" } }); } return new Response(void 0, { status: alsResponse.status, statusText: alsResponse.statusText }); } } catch (error) { if (error instanceof Response) return error; if (isNotFound(error)) return isNotFoundResponse(error); console.info(); console.info("Server Fn Error!"); console.info(); console.error(error); console.info(); const serializedError = JSON.stringify(await Promise.resolve(su(error, { refs: /* @__PURE__ */ new Map(), plugins: serovalPlugins }))); const response = getResponse(); return new Response(serializedError, { status: response.status ?? 500, statusText: response.statusText, headers: { "Content-Type": "application/json", [X_TSS_SERIALIZED]: "true" } }); } })();};function isNotFoundResponse(error) { const { headers, ...rest } = error; return new Response(JSON.stringify(rest), { status: 404, headers: { "Content-Type": "application/json", ...headers || {} } });}var LINK_PARAM_TOKEN_RE = /^[!#$%&'*+\-.^_`|~0-9A-Za-z]+$/;var PRELOAD_AS_VALUES = new Set([ "fetch", "font", "image", "script", "style", "track"]);function buildLinkParam(name, value) { if (value === void 0) return name; if (LINK_PARAM_TOKEN_RE.test(value)) return `${name}=${value}`; return `${name}=${JSON.stringify(value)}`;}function serializeEarlyHint(hint) { const parts = [`<${hint.href}>`, buildLinkParam("rel", hint.rel)]; if (hint.as) parts.push(buildLinkParam("as", hint.as)); if (hint.crossOrigin !== void 0) parts.push(buildLinkParam("crossorigin", hint.crossOrigin || void 0)); if (hint.type) parts.push(buildLinkParam("type", hint.type)); if (hint.integrity) parts.push(buildLinkParam("integrity", hint.integrity)); if (hint.referrerPolicy) parts.push(buildLinkParam("referrerpolicy", hint.referrerPolicy)); if (hint.fetchPriority) parts.push(buildLinkParam("fetchpriority", hint.fetchPriority)); return parts.join("; ");}function getStringAttr(attrs, name, fallbackName) { const value = attrs?.[name] ?? (fallbackName ? attrs?.[fallbackName] : void 0); return typeof value === "string" ? value : void 0;}function getPreloadAs(attrs) { const as = getStringAttr(attrs, "as"); return as && PRELOAD_AS_VALUES.has(as) ? as : void 0;}function addEarlyHintFetchAttrs(hint, attrs) { const crossOrigin = getStringAttr(attrs, "crossOrigin", "crossorigin"); const type = getStringAttr(attrs, "type"); const integrity = getStringAttr(attrs, "integrity"); const referrerPolicy = getStringAttr(attrs, "referrerPolicy", "referrerpolicy"); const fetchPriority = getStringAttr(attrs, "fetchPriority", "fetchpriority"); if (crossOrigin !== void 0) hint.crossOrigin = crossOrigin; if (type) hint.type = type; if (integrity) hint.integrity = integrity; if (referrerPolicy) hint.referrerPolicy = referrerPolicy; if (fetchPriority) hint.fetchPriority = fetchPriority;}function linkAttrsToEarlyHint(attrs) { const href = getStringAttr(attrs, "href"); const rel = getStringAttr(attrs, "rel"); if (!href || !rel) return void 0; const relTokens = rel.split(/\s+/); let hintRel; let hintAs; if (relTokens.includes("modulepreload")) { hintRel = "modulepreload"; hintAs = "script"; } else if (relTokens.includes("stylesheet")) { hintRel = "preload"; hintAs = "style"; } else if (relTokens.includes("preload")) { hintAs = getPreloadAs(attrs); if (!hintAs) return void 0; hintRel = "preload"; } else if (relTokens.includes("preconnect")) { hintRel = "preconnect"; hintAs = void 0; } else if (relTokens.includes("dns-prefetch")) { hintRel = "dns-prefetch"; hintAs = void 0; } if (!hintRel) return void 0; const hint = { href, rel: hintRel }; if (hintAs) hint.as = hintAs; addEarlyHintFetchAttrs(hint, attrs); return hint;}function collectStaticHintsFromManifest(manifest, matchedRoutes) { const hints = []; for (const route of matchedRoutes) { const routeManifest = manifest.routes[route.id]; if (!routeManifest) continue; for (const link of routeManifest.preloads ?? []) { const attrs = getScriptPreloadAttrs(manifest, link); const hint = { href: attrs.href, rel: attrs.rel, as: "script" }; if (attrs.crossOrigin !== void 0) hint.crossOrigin = attrs.crossOrigin; hints.push(hint); } for (const link of routeManifest.css ?? []) { const stylesheetHref = getStylesheetHref(link); if (manifest.inlineCss?.styles[stylesheetHref] !== void 0) continue; const resolvedLink = resolveManifestCssLink(link); const hint = { href: stylesheetHref, rel: "preload", as: "style" }; if (resolvedLink.crossOrigin !== void 0) hint.crossOrigin = resolvedLink.crossOrigin; hints.push(hint); } } return hints;}function collectDynamicHintsFromMatches(matches) { const hints = []; for (const match of matches) { const links = match.links; if (!Array.isArray(links)) continue; for (const link of links) { const hint = linkAttrsToEarlyHint(link); if (hint) hints.push(hint); } } return hints;}function createEarlyHintsEvent(opts) { const nextHints = []; const nextLinks = []; for (const hint of opts.hints) { const link = serializeEarlyHint(hint); if (opts.sentLinks.has(link)) continue; opts.sentLinks.add(link); opts.sentHints.push(hint); nextHints.push(hint); nextLinks.push(link); } if (!nextHints.length && opts.phase !== "dynamic") return void 0; return { phase: opts.phase, hints: nextHints, links: nextLinks, allHints: opts.sentHints.slice(), allLinks: Array.from(opts.sentLinks) };}function createResponseLinkHeaderEntries(opts) { for (const hint of opts.hints) { const link = serializeEarlyHint(hint); if (opts.sentLinks.has(link)) continue; opts.sentLinks.add(link); opts.entries.push({ phase: opts.phase, hint, link }); }}function getResponseLinkHeaderEntries(opts) { if (!opts.filter) return opts.entries.map((entry) => entry.link); try { const links = []; for (const entry of opts.entries) if (opts.filter(entry)) links.push(entry.link); return links; } catch (err) { console.error("Error filtering response Link headers:", err); return []; }}function notifyEarlyHints(phase, event, onEarlyHints) { try { const result = onEarlyHints(event); if (result) Promise.resolve(result).catch((err) => { console.error(`Error sending ${phase} early hints:`, err); }); } catch (err) { console.error(`Error sending ${phase} early hints:`, err); }}function getResponseLinkHeaderFilter(responseLinkHeader) { if (typeof responseLinkHeader !== "object") return; return responseLinkHeader.filter;}function appendResponseLinkHeaders(opts) { for (const link of getResponseLinkHeaderEntries(opts)) opts.responseHeaders.append("Link", link);}function collectResponseLinkHeaderEntries(opts) { for (let index = 0; index < opts.event.hints.length; index++) opts.entries.push({ phase: opts.phase, hint: opts.event.hints[index], link: opts.event.links[index] });}function collectEarlyHintsPhase(opts) { const event = opts.onEarlyHints ? createEarlyHintsEvent({ phase: opts.phase, hints: opts.hints, sentLinks: opts.sentLinks, sentHints: opts.sentHints }) : void 0; if (event) notifyEarlyHints(opts.phase, event, opts.onEarlyHints); if (!opts.responseLinkHeaderEntries) return; if (event) { collectResponseLinkHeaderEntries({ phase: opts.phase, event, entries: opts.responseLinkHeaderEntries }); return; } createResponseLinkHeaderEntries({ phase: opts.phase, hints: opts.hints, sentLinks: opts.sentLinks, entries: opts.responseLinkHeaderEntries });}function createEarlyHintsCollector(opts) { if (!opts?.onEarlyHints && !opts?.responseLinkHeader) return; const sentLinks = /* @__PURE__ */ new Set(); const sentHints = opts.onEarlyHints ? new Array() : void 0; const responseLinkHeaderEntries = opts.responseLinkHeader ? new Array() : void 0; const responseLinkHeaderFilter = getResponseLinkHeaderFilter(opts.responseLinkHeader); return { collectStatic: ({ manifest, matchedRoutes }) => { if (!matchedRoutes?.length) return; collectEarlyHintsPhase({ phase: "static", hints: collectStaticHintsFromManifest(manifest, matchedRoutes), sentLinks, sentHints, onEarlyHints: opts.onEarlyHints, responseLinkHeaderEntries }); }, collectDynamic: (matches) => { collectEarlyHintsPhase({ phase: "dynamic", hints: collectDynamicHintsFromMatches(matches), sentLinks, sentHints, onEarlyHints: opts.onEarlyHints, responseLinkHeaderEntries }); }, appendResponseHeaders: (headers) => { if (!responseLinkHeaderEntries?.length) return; appendResponseLinkHeaders({ responseHeaders: headers, entries: responseLinkHeaderEntries, filter: responseLinkHeaderFilter }); } };}function normalizeTransformAssetResult(result) { if (typeof result === "string") return { href: result }; return result;}function escapeCssString(value) { return value.replace(/\\/g, "\\\\").replace(/"/g, "\\\"").replace(/\n/g, "\\a ").replace(/\r/g, "\\d ").replace(/\f/g, "\\c ");}async function transformInlineCssTemplate(options) { const { strings, urls } = options.template; if (strings.length !== urls.length + 1) throw new Error(`TanStack Start inlineCss template for ${options.stylesheetHref} is invalid`); let css = strings[0]; for (let index = 0; index < urls.length; index++) { const transformed = normalizeTransformAssetResult(await options.transformFn({ kind: "css-url", url: urls[index], stylesheetHref: options.stylesheetHref })); css += escapeCssString(transformed.href) + strings[index + 1]; } return css;}async function transformInlineCssStyles(inlineCss, transformFn) { const transformedStyles = {}; const transformedEntries = await Promise.all(Object.entries(inlineCss.styles).map(async ([stylesheetHref, css]) => { const template = inlineCss.templates?.[stylesheetHref]; return [stylesheetHref, template ? await transformInlineCssTemplate({ stylesheetHref, template, transformFn }) : css]; })); for (const [stylesheetHref, css] of transformedEntries) transformedStyles[stylesheetHref] = css; return { styles: transformedStyles, ...inlineCss.templates ? { templates: inlineCss.templates } : {} };}function resolveTransformAssetsCrossOrigin(config, kind) { if (!config) return void 0; if (typeof config === "string") return config; return config[kind];}function isObjectShorthand(transform) { return "prefix" in transform;}function resolveTransformAssetsConfig(transform) { if (typeof transform === "string") { const prefix = transform; return { type: "transform", transformFn: ({ url }) => ({ href: `${prefix}${url}` }), cache: true }; } if (typeof transform === "function") return { type: "transform", transformFn: transform, cache: true }; if (isObjectShorthand(transform)) { const { prefix, crossOrigin } = transform; return { type: "transform", transformFn: ({ url, kind }) => { const href = `${prefix}${url}`; if (kind === "css-url") return { href }; const co = resolveTransformAssetsCrossOrigin(crossOrigin, kind); return co ? { href, crossOrigin: co } : { href }; }, cache: true }; } if ("createTransform" in transform && transform.createTransform) return { type: "createTransform", createTransform: transform.createTransform, cache: transform.cache !== false }; return { type: "transform", transformFn: typeof transform.transform === "string" ? (({ url }) => ({ href: `${transform.transform}${url}` })) : transform.transform, cache: transform.cache !== false };}function assignManifestLink(link, next) { if (typeof link === "string") return next.crossOrigin ? next : next.href; const nextLink = { ...link, href: next.href }; if (next.crossOrigin) nextLink.crossOrigin = next.crossOrigin; else delete nextLink.crossOrigin; return nextLink;}async function transformManifestAssets(source, transformFn, _opts) { const manifest = structuredClone(source); const inlineCssEnabled = _opts?.inlineCss !== false; const scriptTransforms = /* @__PURE__ */ new Map(); const transformScript = (url) => { const cached = scriptTransforms.get(url); if (cached) return cached; const transformed = Promise.resolve(transformFn({ url, kind: "script" })).then(normalizeTransformAssetResult); scriptTransforms.set(url, transformed); return transformed; }; if (!inlineCssEnabled) delete manifest.inlineCss; else if (manifest.inlineCss) manifest.inlineCss = await transformInlineCssStyles(manifest.inlineCss, transformFn); for (const route of Object.values(manifest.routes)) { if (route.preloads?.length) route.preloads = await Promise.all(route.preloads.map(async (link) => { const result = await transformScript(resolveManifestAssetLink(link).href); return assignManifestLink(link, { href: result.href, crossOrigin: result.crossOrigin }); })); if (route.css?.length && !manifest.inlineCss) route.css = await Promise.all(route.css.map(async (link) => { const result = normalizeTransformAssetResult(await transformFn({ url: resolveManifestCssLink(link).href, kind: "stylesheet" })); return assignManifestLink(link, { href: result.href, crossOrigin: result.crossOrigin }); })); if (route.scripts?.length) for (const script of route.scripts) { const src = script.attrs?.src; if (typeof src !== "string") continue; const result = await transformScript(src); script.attrs = { ...script.attrs, src: result.href }; if (result.crossOrigin) script.attrs.crossOrigin = result.crossOrigin; else delete script.attrs.crossOrigin; } } return manifest;}/*** Builds a final ServerManifest without URL transforms. Used when no* transformAssets option is provided.** Returns a new manifest object so the cached base manifest is never mutated.*/function buildManifest(source, opts) { return { ...source.scriptFormat ? { scriptFormat: source.scriptFormat } : {}, ...opts?.inlineCss !== false && source.inlineCss ? { inlineCss: structuredClone(source.inlineCss) } : {}, routes: { ...source.routes } };}function getStaticHandlerInlineCssDefault(handlerInlineCss) { if (typeof handlerInlineCss === "function") return; return handlerInlineCss ?? true;}async function resolveInlineCssForRequest(opts) { if (opts.requestInlineCss !== void 0) return opts.requestInlineCss; if (typeof opts.handlerInlineCss === "function") return await opts.handlerInlineCss({ request: opts.request }); return opts.handlerInlineCss ?? true;}function createCachedBaseManifestLoader(loadBaseManifest) { let baseManifestPromise; return () => { if (!baseManifestPromise) baseManifestPromise = loadBaseManifest().catch((error) => { baseManifestPromise = void 0; throw error; }); return baseManifestPromise; };}function createFinalManifestTransformResolver(transformAssets, opts) { const transformConfig = transformAssets !== void 0 ? resolveTransformAssetsConfig(transformAssets) : void 0; const cache = transformConfig ? transformConfig.cache : true; const warmup = !!transformAssets && typeof transformAssets === "object" && "warmup" in transformAssets && transformAssets.warmup === true; let cachedCreateTransformPromise; const clearCachedCreateTransform = () => { cachedCreateTransformPromise = void 0; }; return { cache, warmup, clearCachedCreateTransform, getTransformFn: async (ctx) => { if (!transformConfig) return void 0; if (transformConfig.type !== "createTransform") return transformConfig.transformFn; if (!cache || !opts.cacheCreateTransform) return transformConfig.createTransform(ctx); if (!cachedCreateTransformPromise) cachedCreateTransformPromise = Promise.resolve(transformConfig.createTransform(ctx)).catch((error) => { clearCachedCreateTransform(); throw error; }); return cachedCreateTransformPromise; } };}function createFinalManifestResolver(opts) { const finalManifestCache = /* @__PURE__ */ new Map(); const transformResolver = createFinalManifestTransformResolver(opts.transformAssets, { cacheCreateTransform: opts.cacheCreateTransform }); const handlerDefaultInlineCss = getStaticHandlerInlineCssDefault(opts.inlineCss); const getRequestManifestOptions = async (requestOpts) => { const transformFn = await transformResolver.getTransformFn({ warmup: false, request: requestOpts.request }); const inlineCss = await resolveInlineCssForRequest({ request: requestOpts.request, handlerInlineCss: opts.inlineCss, requestInlineCss: requestOpts.requestInlineCss }); return { getBaseManifest: requestOpts.getBaseManifest, transformFn, cache: transformResolver.cache, inlineCss }; }; const resolveRequest = async (requestOpts, cache) => { return resolveFinalManifest({ ...await getRequestManifestOptions(requestOpts), finalManifestCache: cache }); }; return { warmup: ({ getBaseManifest }) => warmupFinalManifest({ enabled: transformResolver.warmup, handlerDefaultInlineCss, cache: transformResolver.cache, finalManifestCache, getBaseManifest, getTransformFn: () => transformResolver.getTransformFn({ warmup: true }), onError: transformResolver.clearCachedCreateTransform }), resolveCached: (requestOpts) => resolveRequest(requestOpts, finalManifestCache), resolveUncached: (requestOpts) => resolveRequest(requestOpts, void 0) };}function getFinalManifestCacheKey(inlineCss) { return inlineCss ? "inline-css" : "linked-css";}function cacheFinalManifestPromise(cachedFinalManifestPromises, cacheKey, promise) { const cachedFinalManifestPromise = promise.catch((error) => { if (cachedFinalManifestPromises.get(cacheKey) === cachedFinalManifestPromise) cachedFinalManifestPromises.delete(cacheKey); throw error; }); cachedFinalManifestPromises.set(cacheKey, cachedFinalManifestPromise); return cachedFinalManifestPromise;}function getOrCreateCachedFinalManifestPromise(cachedFinalManifestPromises, cacheKey, computeFinalManifest) { const cachedFinalManifestPromise = cachedFinalManifestPromises.get(cacheKey); if (cachedFinalManifestPromise) return cachedFinalManifestPromise; return cacheFinalManifestPromise(cachedFinalManifestPromises, cacheKey, Promise.resolve().then(computeFinalManifest));}async function buildFinalManifest(opts) { return opts.transformFn ? await transformManifestAssets(opts.base, opts.transformFn, { inlineCss: opts.inlineCss }) : buildManifest(opts.base, { inlineCss: opts.inlineCss });}async function resolveFinalManifest(opts) { const computeFinalManifest = async () => { return buildFinalManifest({ base: await opts.getBaseManifest(), transformFn: opts.transformFn, inlineCss: opts.inlineCss }); }; if (opts.finalManifestCache && (!opts.transformFn || opts.cache)) return getOrCreateCachedFinalManifestPromise(opts.finalManifestCache, getFinalManifestCacheKey(opts.inlineCss), computeFinalManifest); return computeFinalManifest();}function warmupFinalManifest(opts) { if (!opts.enabled || opts.handlerDefaultInlineCss === void 0 || !opts.cache) return; const inlineCss = opts.handlerDefaultInlineCss; const warmupPromise = getOrCreateCachedFinalManifestPromise(opts.finalManifestCache, getFinalManifestCacheKey(inlineCss), async () => { const [base, transformFn] = await Promise.all([opts.getBaseManifest(), opts.getTransformFn()]); return buildFinalManifest({ base, transformFn, inlineCss }); }); if (opts.onError) warmupPromise.catch(opts.onError); return warmupPromise;}var ServerFunctionSerializationAdapter = createSerializationAdapter({ key: "$TSS/serverfn", test: (v) => { if (typeof v !== "function") return false; if (!(TSS_SERVER_FUNCTION in v)) return false; return !!v[TSS_SERVER_FUNCTION]; }, toSerializable: ({ serverFnMeta }) => ({ functionId: serverFnMeta.id }), fromSerializable: ({ functionId }) => { const fn = async (opts, signal) => { return (await (await getServerFnById(functionId, { origin: "client" }))(opts ?? {}, signal)).result; }; return fn; }});function getStartResponseHeaders(opts) { return mergeHeaders({ "Content-Type": "text/html; charset=utf-8" }, ...opts.router.stores.matches.get().map((match) => { return match.headers; }));}var entriesPromise;var defaultCsrfMiddleware = createCsrfMiddleware({ filter: (ctx) => ctx.handlerType === "serverFn" });var getCachedBaseManifest = createCachedBaseManifestLoader(() => getStartManifest());var getProdBaseManifest = () => getCachedBaseManifest();var getBaseManifest = getProdBaseManifest;var createEarlyHintsForRequest = createEarlyHintsCollector;async function loadEntries() { const [routerEntry, startEntry, pluginAdapters] = await Promise.all([ import("./router-C56V3RPr.mjs"), import("./start-5Z2QO8AU.mjs"), import("./empty-plugin-adapters-D9UWiqvJ.mjs") ]); return { routerEntry, startEntry, pluginAdapters };}function getEntries() { if (!entriesPromise) entriesPromise = loadEntries(); return entriesPromise;}var ROUTER_BASEPATH = "/";var SERVER_FN_BASE = "/_serverFn/";var IS_PRERENDERING = process.env.TSS_PRERENDERING === "true";var IS_SHELL_ENV = process.env.TSS_SHELL === "true";var IS_DEV = false;var ERR_NO_RESPONSE = IS_DEV ? `It looks like you forgot to return a response from your server route handler. If you want to defer to the app router, make sure to have a component set in this route.` : "Internal Server Error";var ERR_NO_DEFER = IS_DEV ? `You cannot defer to the app router if there is no component defined on this route.` : "Internal Server Error";function throwRouteHandlerError() { throw new Error(ERR_NO_RESPONSE);}function throwIfMayNotDefer() { throw new Error(ERR_NO_DEFER);}/*** Check if a value is a special response (Response or Redirect)*/function isSpecialResponse(value) { return value instanceof Response || isRedirect(value);}/*** Normalize middleware result to context shape*/function handleCtxResult(result) { if (isSsrResponse(result) || isSpecialResponse(result)) return { response: result }; return result;}/*** Execute a middleware chain*/async function executeMiddleware(middlewares, ctx) { let index = -1; let streamResponse; const setResponse = (response) => { if (isSsrResponse(response)) { if (response.serverSsrCleanup === "stream") streamResponse = response; ctx.response = response.response; return; } ctx.response = response; }; const disposeStreamResponse = async (reason) => { const response = streamResponse; if (!response) return; streamResponse = void 0; const currentResponse = ctx.response; if (currentResponse === response.response || currentResponse instanceof Response && response.response.body !== null && currentResponse.body === response.response.body) ctx.response = void 0; await response.dispose(reason); }; const getFinalResponse = async () => { const response = ctx.response; if (!response) throwRouteHandlerError(); if (!streamResponse) return response; if (response === streamResponse.response) return streamResponse; if (streamResponse.response.body !== null && response.body === streamResponse.response.body) return { ...streamResponse, response }; await disposeStreamResponse("middleware response replaced"); return response; }; const next = async (nextCtx) => { if (nextCtx) { if (nextCtx.context) ctx.context = safeObjectMerge(ctx.context, nextCtx.context); for (const key of Object.keys(nextCtx)) if (key === "response") setResponse(nextCtx.response); else if (key !== "context") ctx[key] = nextCtx[key]; } index++; const middleware = middlewares[index]; if (!middleware) return ctx; let result; try { result = await middleware({ ...ctx, next }); } catch (err) { if (isSpecialResponse(err)) { setResponse(err); return ctx; } await disposeStreamResponse("middleware error"); throw err; } const normalized = handleCtxResult(result); if (normalized) { if (normalized.response !== void 0) setResponse(normalized.response); if (normalized.context) ctx.context = safeObjectMerge(ctx.context, normalized.context); } return ctx; }; await next(); return { ctx, response: await getFinalResponse() };}/*** Wrap a route handler as middleware*/function handlerToMiddleware(handler, mayDefer = false) { if (mayDefer) return handler; return async (ctx) => { const response = await handler({ ...ctx, next: throwIfMayNotDefer }); if (!response) throwRouteHandlerError(); return response; };}/*** Creates the TanStack Start request handler.** @example Backwards-compatible usage (handler callback only):* ```ts* export default createStartHandler(defaultStreamHandler)* ```** @example With CDN URL rewriting:* ```ts* export default createStartHandler({* handler: defaultStreamHandler,* transformAssets: 'https://cdn.example.com',* })* ```** @example With per-request URL rewriting:* ```ts* export default createStartHandler({* handler: defaultStreamHandler,* transformAssets: {* transform: ({ url }) => {* const cdnBase = getRequest().headers.get('x-cdn-base') || ''* return { href: `${cdnBase}${url}` }* },* cache: false,* },* })* ```*/function createStartHandler(cbOrOptions) { const handlerOptions = typeof cbOrOptions === "function" ? {} : cbOrOptions; const cb = typeof cbOrOptions === "function" ? cbOrOptions : cbOrOptions.handler; const finalManifestResolver = createFinalManifestResolver({ ...handlerOptions, cacheCreateTransform: true }); const resolveManifestForRequest = finalManifestResolver.resolveCached; finalManifestResolver.warmup({ getBaseManifest: () => getBaseManifest(void 0) }); const startRequestResolver = async (request, requestOpts) => { let router = null; let responseOwnsCleanup = false; try { const { url, handledProtocolRelativeURL } = getNormalizedURL(request.url); const href = url.pathname + url.search + url.hash; const origin = getOrigin(request); if (handledProtocolRelativeURL) return Response.redirect(url, 308); const entries = await getEntries(); const hasStartInstance = !!entries.startEntry.startInstance; const startOptions = await entries.startEntry.startInstance?.getOptions() || {}; const { hasPluginAdapters, pluginSerializationAdapters } = entries.pluginAdapters; const serializationAdapters = [ ...startOptions.serializationAdapters || [], ...hasPluginAdapters ? pluginSerializationAdapters : [], ServerFunctionSerializationAdapter ]; const requestStartOptions = { ...startOptions, requestMiddleware: hasStartInstance ? startOptions.requestMiddleware : [defaultCsrfMiddleware], serializationAdapters }; const flattenedRequestMiddlewares = requestStartOptions.requestMiddleware ? flattenMiddlewares(requestStartOptions.requestMiddleware) : []; const executedRequestMiddlewares = new Set(flattenedRequestMiddlewares); const getRouter = async () => { if (router) return router; router = await entries.routerEntry.getRouter(); let isShell = IS_SHELL_ENV; if (IS_PRERENDERING && !isShell) isShell = request.headers.get(HEADERS.TSS_SHELL) === "true"; const history = createMemoryHistory({ initialEntries: [href] }); router.update({ history, isShell, isPrerendering: IS_PRERENDERING, origin: router.options.origin ?? origin, defaultSsr: requestStartOptions.defaultSsr, serializationAdapters: [...requestStartOptions.serializationAdapters, ...router.options.serializationAdapters || []], basepath: ROUTER_BASEPATH }); return router; }; if (SERVER_FN_BASE && url.pathname.startsWith(SERVER_FN_BASE)) { const serverFnId = url.pathname.slice(SERVER_FN_BASE.length).split("/")[0]; if (!serverFnId) throw new Error("Invalid server action param for serverFnId"); const serverFnHandler = async ({ context }) => { return runWithStartContext({ getRouter, startOptions: requestStartOptions, contextAfterGlobalMiddlewares: context, request, executedRequestMiddlewares, handlerType: "serverFn" }, () => handleServerAction({ request, context: requestOpts?.context, serverFnId })); }; const { response: middlewareResponse } = await executeMiddleware([...flattenedRequestMiddlewares.map((d) => d.options.server), serverFnHandler], { request, pathname: url.pathname, handlerType: "serverFn", context: createNullProtoObject(requestOpts?.context) }); const result = await handleRedirectResponse(middlewareResponse, request, getRouter); responseOwnsCleanup = result.serverSsrCleanup === "stream"; return result.response; } const executeRouter = async (serverContext, matchedRoutes) => { const acceptParts = (request.headers.get("Accept") || "*/*").split(","); if (!["*/*", "text/html"].some((mimeType) => acceptParts.some((part) => part.trim().startsWith(mimeType)))) return normalizeSsrResponse(Response.json({ error: "Only HTML requests are supported here" }, { status: 500 })); const manifest = await resolveManifestForRequest({ request, requestInlineCss: requestOpts?.inlineCss, getBaseManifest: () => getBaseManifest(matchedRoutes) }); const earlyHints = createEarlyHintsForRequest({ onEarlyHints: requestOpts?.onEarlyHints, responseLinkHeader: requestOpts?.responseLinkHeader }); earlyHints?.collectStatic({ manifest, matchedRoutes }); const routerInstance = await getRouter(); attachRouterServerSsrUtils({ router: routerInstance, manifest, getRequestAssets: () => getStartContext({ throwIfNotFound: false })?.requestAssets }); routerInstance.options.additionalContext = { serverContext }; await routerInstance.load(); if (routerInstance.state.redirect) return normalizeSsrResponse(routerInstance.state.redirect); earlyHints?.collectDynamic(routerInstance.stores.matches.get()); const ctx = getStartContext({ throwIfNotFound: false }); await routerInstance.serverSsr.dehydrate({ requestAssets: ctx?.requestAssets }); const responseHeaders = getStartResponseHeaders({ router: routerInstance }); earlyHints?.appendResponseHeaders(responseHeaders); return normalizeSsrResponse(await cb({ request, router: routerInstance, responseHeaders })); }; const requestHandlerMiddleware = async ({ context }) => { return runWithStartContext({ getRouter, startOptions: requestStartOptions, contextAfterGlobalMiddlewares: context, request, executedRequestMiddlewares, handlerType: "router" }, async () => { try { return await handleServerRoutes({ getRouter, request, url, executeRouter, context, executedRequestMiddlewares }); } catch (err) { if (err instanceof Response) return err; throw err; } }); }; const { response: middlewareResponse } = await executeMiddleware([...flattenedRequestMiddlewares.map((d) => d.options.server), requestHandlerMiddleware], { request, pathname: url.pathname, handlerType: "router", context: createNullProtoObject(requestOpts?.context) }); const response = await handleRedirectResponse(middlewareResponse, request, getRouter); responseOwnsCleanup = response.serverSsrCleanup === "stream"; return response.response; } finally { if (router?.serverSsr && !responseOwnsCleanup) router.serverSsr.cleanup(); router = null; } }; return requestHandler(startRequestResolver);}async function handleRedirectResponse(response, request, getRouter) { const ssrResponse = normalizeSsrResponse(response); if (!isRedirect(ssrResponse.response)) return ssrResponse; if (isResolvedRedirect(ssrResponse.response)) { if (request.headers.get("x-tsr-serverFn") === "true") return replaceSsrResponse(ssrResponse, Response.json({ ...ssrResponse.response.options, isSerializedRedirect: true }, { headers: ssrResponse.response.headers }), "redirect response replaced"); return ssrResponse; } const opts = ssrResponse.response.options; if (opts.to && typeof opts.to === "string" && !opts.to.startsWith("/")) throw new Error(`Server side redirects must use absolute paths via the 'href' or 'to' options. The redirect() method's "to" property accepts an internal path only. Use the "href" property to provide an external URL. Received: ${JSON.stringify(opts)}`); if ([ "params", "search", "hash" ].some((d) => typeof opts[d] === "function")) throw new Error(`Server side redirects must use static search, params, and hash values and do not support functional values. Received functional values for: ${Object.keys(opts).filter((d) => typeof opts[d] === "function").map((d) => `"${d}"`).join(", ")}`); const redirect = (await getRouter()).resolveRedirect(ssrResponse.response); if (request.headers.get("x-tsr-serverFn") === "true") return replaceSsrResponse(ssrResponse, Response.json({ ...ssrResponse.response.options, isSerializedRedirect: true }, { headers: ssrResponse.response.headers }), "redirect response replaced"); return replaceSsrResponse(ssrResponse, redirect, "redirect response replaced");}async function handleServerRoutes({ getRouter, request, url, executeRouter, context, executedRequestMiddlewares }) { const router = await getRouter(); const pathname = executeRewriteInput(router.rewrite, url).pathname; const { matchedRoutes, foundRoute, routeParams } = router.getMatchedRoutes(pathname); const isExactMatch = foundRoute && routeParams["**"] === void 0; const routeMiddlewares = []; for (const route of matchedRoutes) { const serverMiddleware = route.options.server?.middleware; if (serverMiddleware) { const flattened = flattenMiddlewares(serverMiddleware); for (const m of flattened) if (!executedRequestMiddlewares.has(m)) routeMiddlewares.push(m.options.server); } } const server = foundRoute?.options.server; let isHeadFallback = false; if (server?.handlers && isExactMatch) { const handlers = typeof server.handlers === "function" ? server.handlers({ createHandlers: (d) => d }) : server.handlers; const requestMethod = request.method.toUpperCase(); const handler = requestMethod === "HEAD" ? handlers["HEAD"] ?? handlers["GET"] ?? handlers["ANY"] : handlers[requestMethod] ?? handlers["ANY"]; isHeadFallback = requestMethod === "HEAD" && handler !== void 0 && !handlers["HEAD"]; if (handler) { const mayDefer = !!foundRoute.options.component; if (typeof handler === "function") routeMiddlewares.push(handlerToMiddleware(handler, mayDefer)); else { if (handler.middleware?.length) { const handlerMiddlewares = flattenMiddlewares(handler.middleware); for (const m of handlerMiddlewares) routeMiddlewares.push(m.options.server); } if (handler.handler) routeMiddlewares.push(handlerToMiddleware(handler.handler, mayDefer)); } } } routeMiddlewares.push(((ctx) => executeRouter(ctx.context, matchedRoutes))); const { ctx, response } = await executeMiddleware(routeMiddlewares, { request, context, params: routeParams, pathname, handlerType: "router" }); if (isHeadFallback) { if (!ctx.response) throwRouteHandlerError(); return stripSsrResponseBody(await handleRedirectResponse(response, request, getRouter), "HEAD body stripped"); } return normalizeSsrResponse(response);}var fetch = createStartHandler(defaultStreamHandler);function createServerEntry(entry) { return { async fetch(...args) { return await entry.fetch(...args); } };}var server_default = createServerEntry({ fetch });//#endregionexport { ssr_exports as i, createServerFn as n, getServerFnById as r, TSS_SERVER_FUNCTION as t };