office-viewer-react 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/README.md +390 -0
  2. package/dist/client/assets/DocxViewer-NgAiZAEg.css +1 -0
  3. package/dist/client/assets/DocxViewer-gwdjm0mw.js +60 -0
  4. package/dist/client/assets/LogoIcon-BcnkueZW.js +1 -0
  5. package/dist/client/assets/PptxViewer-CLNaZa_4.js +59 -0
  6. package/dist/client/assets/PptxViewer-CYMXzyIj.css +1 -0
  7. package/dist/client/assets/XlsxViewer-BNso6L-X.css +1 -0
  8. package/dist/client/assets/XlsxViewer-C2ErMokS.js +64 -0
  9. package/dist/client/assets/_commonjs-dynamic-modules-DaXrHM_S.js +1 -0
  10. package/dist/client/assets/form-C1byQJR4.js +1 -0
  11. package/dist/client/assets/index-BDMLGHcR.js +2 -0
  12. package/dist/client/assets/index-CKjGwz9R.js +12 -0
  13. package/dist/client/assets/jszip.min-BwIaN_vk.js +2 -0
  14. package/dist/client/assets/login-DEy3R1iD.js +1 -0
  15. package/dist/client/assets/register-CUUVGLJE.js +1 -0
  16. package/dist/client/assets/styles-3a3CPFIV.css +1 -0
  17. package/dist/client/robots.txt +2 -0
  18. package/dist/index.cjs +1806 -0
  19. package/dist/index.d.cts +16 -0
  20. package/dist/index.d.ts +16 -0
  21. package/dist/index.js +1769 -0
  22. package/dist/server/assets/DocxViewer-Bm8UJY-7.js +469 -0
  23. package/dist/server/assets/LogoIcon-Dx0LU3or.js +26 -0
  24. package/dist/server/assets/PptxViewer-DS7Atucw.js +213 -0
  25. package/dist/server/assets/XlsxViewer-jzIgKmN2.js +841 -0
  26. package/dist/server/assets/_tanstack-start-manifest_v-CpFqMvFH.js +4 -0
  27. package/dist/server/assets/empty-plugin-adapters-BFgPZ6_d.js +6 -0
  28. package/dist/server/assets/form-CD9otjw-.js +236 -0
  29. package/dist/server/assets/index-gQHSGxNv.js +365 -0
  30. package/dist/server/assets/login-DvbAXNSQ.js +81 -0
  31. package/dist/server/assets/register-C2G9K9kP.js +102 -0
  32. package/dist/server/assets/router-F5YKPXkV.js +229 -0
  33. package/dist/server/assets/server-6Sfy37dh.js +1523 -0
  34. package/dist/server/assets/start-dMGD6DUy.js +56 -0
  35. package/dist/server/server.js +94 -0
  36. package/package.json +120 -0
@@ -0,0 +1,1523 @@
1
+ import { AsyncLocalStorage } from "node:async_hooks";
2
+ import { H3Event, toResponse } from "h3-v2";
3
+ import { rootRouteId, defaultSerovalPlugins, makeSerovalPlugin, createRawStreamRPCPlugin, invariant, isNotFound, isRedirect, getScriptPreloadAttrs, getStylesheetHref, resolveManifestCssLink, resolveManifestAssetLink, createSerializationAdapter, isResolvedRedirect, executeRewriteInput } from "@tanstack/router-core";
4
+ import { toCrossJSONStream, fromJSON, toCrossJSONAsync } from "seroval";
5
+ import { createMemoryHistory } from "@tanstack/history";
6
+ import { mergeHeaders } from "@tanstack/router-core/ssr/client";
7
+ import { getNormalizedURL, getOrigin, normalizeSsrResponse, attachRouterServerSsrUtils, replaceSsrResponse, stripSsrResponseBody, isSsrResponse } from "@tanstack/router-core/ssr/server";
8
+ import "react";
9
+ import { RouterProvider } from "@tanstack/react-router";
10
+ import { jsx } from "react/jsx-runtime";
11
+ import { defineHandlerCallback, renderRouterToStream } from "@tanstack/react-router/ssr/server";
12
+ function StartServer(props) {
13
+ return /* @__PURE__ */ jsx(RouterProvider, { router: props.router });
14
+ }
15
+ var defaultStreamHandler = defineHandlerCallback(({ request, router, responseHeaders }) => renderRouterToStream({
16
+ request,
17
+ router,
18
+ responseHeaders,
19
+ children: /* @__PURE__ */ jsx(StartServer, { router })
20
+ }));
21
+ var GLOBAL_EVENT_STORAGE_KEY = /* @__PURE__ */ Symbol.for("tanstack-start:event-storage");
22
+ var globalObj$1 = globalThis;
23
+ if (!globalObj$1[GLOBAL_EVENT_STORAGE_KEY]) globalObj$1[GLOBAL_EVENT_STORAGE_KEY] = new AsyncLocalStorage();
24
+ var eventStorage = globalObj$1[GLOBAL_EVENT_STORAGE_KEY];
25
+ function isPromiseLike(value) {
26
+ return typeof value.then === "function";
27
+ }
28
+ function getSetCookieValues(headers) {
29
+ const headersWithSetCookie = headers;
30
+ if (typeof headersWithSetCookie.getSetCookie === "function") return headersWithSetCookie.getSetCookie();
31
+ const value = headers.get("set-cookie");
32
+ return value ? [value] : [];
33
+ }
34
+ function mergeEventResponseHeaders(response, event) {
35
+ if (response.ok) return;
36
+ const eventSetCookies = getSetCookieValues(event.res.headers);
37
+ if (eventSetCookies.length === 0) return;
38
+ const responseSetCookies = getSetCookieValues(response.headers);
39
+ response.headers.delete("set-cookie");
40
+ for (const cookie of responseSetCookies) response.headers.append("set-cookie", cookie);
41
+ for (const cookie of eventSetCookies) response.headers.append("set-cookie", cookie);
42
+ }
43
+ function attachResponseHeaders(value, event) {
44
+ if (isPromiseLike(value)) return value.then((resolved) => {
45
+ if (resolved instanceof Response) mergeEventResponseHeaders(resolved, event);
46
+ return resolved;
47
+ });
48
+ if (value instanceof Response) mergeEventResponseHeaders(value, event);
49
+ return value;
50
+ }
51
+ function requestHandler(handler) {
52
+ return (request, requestOpts) => {
53
+ let h3Event;
54
+ try {
55
+ h3Event = new H3Event(request);
56
+ } catch (error) {
57
+ if (error instanceof URIError) return new Response(null, {
58
+ status: 400,
59
+ statusText: "Bad Request"
60
+ });
61
+ throw error;
62
+ }
63
+ return toResponse(attachResponseHeaders(eventStorage.run({ h3Event }, () => handler(request, requestOpts)), h3Event), h3Event);
64
+ };
65
+ }
66
+ function getH3Event() {
67
+ const event = eventStorage.getStore();
68
+ if (!event) throw new Error(`No StartEvent found in AsyncLocalStorage. Make sure you are using the function within the server runtime.`);
69
+ return event.h3Event;
70
+ }
71
+ function getResponse() {
72
+ return getH3Event().res;
73
+ }
74
+ var HEADERS = { TSS_SHELL: "X-TSS_SHELL" };
75
+ async function getStartManifest(matchedRoutes) {
76
+ const { tsrStartManifest } = await import("./_tanstack-start-manifest_v-CpFqMvFH.js");
77
+ const startManifest = tsrStartManifest();
78
+ let routes = startManifest.routes;
79
+ routes[rootRouteId];
80
+ const manifestRoutes = {};
81
+ for (const k in routes) {
82
+ const v = routes[k];
83
+ const result = {};
84
+ if (v.preloads && v.preloads.length > 0) result.preloads = v.preloads;
85
+ if (v.scripts && v.scripts.length > 0) result.scripts = v.scripts;
86
+ if (v.css?.length) result.css = v.css;
87
+ if (result.preloads || result.scripts || result.css) manifestRoutes[k] = result;
88
+ }
89
+ return {
90
+ ...startManifest.scriptFormat ? { scriptFormat: startManifest.scriptFormat } : {},
91
+ ...startManifest.inlineCss ? { inlineCss: startManifest.inlineCss } : {},
92
+ routes: manifestRoutes
93
+ };
94
+ }
95
+ const manifest = {};
96
+ async function getServerFnById(id, access) {
97
+ const serverFnInfo = manifest[id];
98
+ if (!serverFnInfo) {
99
+ throw new Error("Server function info not found for " + id);
100
+ }
101
+ const fnModule = serverFnInfo.module ?? await serverFnInfo.importer();
102
+ if (!fnModule) {
103
+ throw new Error("Server function module not resolved for " + id);
104
+ }
105
+ const action = fnModule[serverFnInfo.functionName];
106
+ if (!action) {
107
+ throw new Error("Server function module export not resolved for serverFn ID: " + id);
108
+ }
109
+ return action;
110
+ }
111
+ var TSS_FORMDATA_CONTEXT = "__TSS_CONTEXT";
112
+ var TSS_SERVER_FUNCTION = /* @__PURE__ */ Symbol.for("TSS_SERVER_FUNCTION");
113
+ var X_TSS_SERIALIZED = "x-tss-serialized";
114
+ var X_TSS_RAW_RESPONSE = "x-tss-raw";
115
+ var TSS_CONTENT_TYPE_FRAMED = "application/x-tss-framed";
116
+ var FrameType = {
117
+ /** Seroval JSON chunk (NDJSON line) */
118
+ JSON: 0,
119
+ /** Raw stream data chunk */
120
+ CHUNK: 1,
121
+ /** Raw stream end (EOF) */
122
+ END: 2,
123
+ /** Raw stream error */
124
+ ERROR: 3
125
+ };
126
+ var FRAME_HEADER_SIZE = 9;
127
+ var TSS_CONTENT_TYPE_FRAMED_VERSIONED = `${TSS_CONTENT_TYPE_FRAMED}; v=1`;
128
+ function isSafeKey(key) {
129
+ return key !== "__proto__" && key !== "constructor" && key !== "prototype";
130
+ }
131
+ function safeObjectMerge(target, source) {
132
+ const result = /* @__PURE__ */ Object.create(null);
133
+ if (target) {
134
+ for (const key of Object.keys(target)) if (isSafeKey(key)) result[key] = target[key];
135
+ }
136
+ if (source && typeof source === "object") {
137
+ for (const key of Object.keys(source)) if (isSafeKey(key)) result[key] = source[key];
138
+ }
139
+ return result;
140
+ }
141
+ function createNullProtoObject(source) {
142
+ if (!source) return /* @__PURE__ */ Object.create(null);
143
+ const obj = /* @__PURE__ */ Object.create(null);
144
+ for (const key of Object.keys(source)) if (isSafeKey(key)) obj[key] = source[key];
145
+ return obj;
146
+ }
147
+ var GLOBAL_STORAGE_KEY = /* @__PURE__ */ Symbol.for("tanstack-start:start-storage-context");
148
+ var globalObj = globalThis;
149
+ if (!globalObj[GLOBAL_STORAGE_KEY]) globalObj[GLOBAL_STORAGE_KEY] = new AsyncLocalStorage();
150
+ var startStorage = globalObj[GLOBAL_STORAGE_KEY];
151
+ async function runWithStartContext(context, fn) {
152
+ return startStorage.run(context, fn);
153
+ }
154
+ function getStartContext(opts) {
155
+ const context = startStorage.getStore();
156
+ 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.`);
157
+ return context;
158
+ }
159
+ var getStartOptions = () => getStartContext().startOptions;
160
+ function flattenMiddlewares(middlewares, maxDepth = 100) {
161
+ const seen = /* @__PURE__ */ new Set();
162
+ const flattened = [];
163
+ const recurse = (middleware, depth) => {
164
+ if (depth > maxDepth) throw new Error(`Middleware nesting depth exceeded maximum of ${maxDepth}. Check for circular references.`);
165
+ middleware.forEach((m) => {
166
+ if (m.options.middleware) recurse(m.options.middleware, depth + 1);
167
+ if (!seen.has(m)) {
168
+ seen.add(m);
169
+ flattened.push(m);
170
+ }
171
+ });
172
+ };
173
+ recurse(middlewares, 0);
174
+ return flattened;
175
+ }
176
+ var createMiddleware = (options, __opts) => {
177
+ const resolvedOptions = {
178
+ type: "request",
179
+ ...__opts || options
180
+ };
181
+ return {
182
+ options: resolvedOptions,
183
+ middleware: (middleware) => {
184
+ return createMiddleware({}, Object.assign(resolvedOptions, { middleware }));
185
+ },
186
+ inputValidator: (inputValidator) => {
187
+ return createMiddleware({}, Object.assign(resolvedOptions, { inputValidator }));
188
+ },
189
+ client: (client) => {
190
+ return createMiddleware({}, Object.assign(resolvedOptions, { client }));
191
+ },
192
+ server: (server2) => {
193
+ return createMiddleware({}, Object.assign(resolvedOptions, { server: server2 }));
194
+ }
195
+ };
196
+ };
197
+ var innerCreateCsrfMiddleware = (opts = {}) => {
198
+ const middleware = createMiddleware().server(async (ctx) => {
199
+ const csrfCtx = ctx;
200
+ if (opts.filter && !await opts.filter(csrfCtx)) return ctx.next();
201
+ if (await isCsrfRequestAllowed(opts, csrfCtx)) return ctx.next();
202
+ return getFailureResponse(opts, csrfCtx);
203
+ });
204
+ return middleware;
205
+ };
206
+ var createCsrfMiddleware = innerCreateCsrfMiddleware;
207
+ async function isCsrfRequestAllowed(opts, ctx) {
208
+ const result = await getCsrfRequestValidationResult(opts, ctx);
209
+ return result === true || result === void 0 && opts.allowRequestsWithoutOriginCheck === true;
210
+ }
211
+ async function getCsrfRequestValidationResult(opts, ctx) {
212
+ const fetchSite = ctx.request.headers.get("Sec-Fetch-Site");
213
+ if (fetchSite !== null) return matchValue(opts.secFetchSite ?? "same-origin", fetchSite, ctx);
214
+ const origin = ctx.request.headers.get("Origin");
215
+ if (origin !== null) {
216
+ if (opts.origin) return matchValue(opts.origin, origin, ctx);
217
+ return origin === new URL(ctx.request.url).origin;
218
+ }
219
+ const referer = ctx.request.headers.get("Referer");
220
+ if (referer === null || opts.referer === false) return;
221
+ if (typeof opts.referer === "function") return opts.referer(referer, ctx);
222
+ if (opts.origin) {
223
+ const refererOrigin = getOriginFromUrl(referer);
224
+ return refererOrigin !== void 0 && matchValue(opts.origin, refererOrigin, ctx);
225
+ }
226
+ return isRefererSameOrigin(referer, new URL(ctx.request.url).origin);
227
+ }
228
+ async function matchValue(matcher, value, ctx) {
229
+ if (typeof matcher === "function") return matcher(value, ctx);
230
+ if (Array.isArray(matcher)) return matcher.includes(value);
231
+ return value === matcher;
232
+ }
233
+ function getOriginFromUrl(url) {
234
+ try {
235
+ return new URL(url).origin;
236
+ } catch {
237
+ return;
238
+ }
239
+ }
240
+ function isRefererSameOrigin(referer, requestOrigin) {
241
+ if (referer === requestOrigin) return true;
242
+ if (!referer.startsWith(requestOrigin)) return false;
243
+ if (referer.length === requestOrigin.length) return true;
244
+ const code = referer.charCodeAt(requestOrigin.length);
245
+ return code === 47 || code === 63 || code === 35;
246
+ }
247
+ async function getFailureResponse(opts, ctx) {
248
+ if (typeof opts.failureResponse === "function") return opts.failureResponse(ctx);
249
+ return opts.failureResponse?.clone() ?? new Response("Forbidden", {
250
+ status: 403
251
+ });
252
+ }
253
+ function getDefaultSerovalPlugins() {
254
+ return [...getStartOptions()?.serializationAdapters?.map(makeSerovalPlugin) ?? [], ...defaultSerovalPlugins];
255
+ }
256
+ var textEncoder = new TextEncoder();
257
+ var EMPTY_PAYLOAD = new Uint8Array(0);
258
+ function encodeFrame(type, streamId, payload) {
259
+ const frame = new Uint8Array(FRAME_HEADER_SIZE + payload.length);
260
+ frame[0] = type;
261
+ frame[1] = streamId >>> 24 & 255;
262
+ frame[2] = streamId >>> 16 & 255;
263
+ frame[3] = streamId >>> 8 & 255;
264
+ frame[4] = streamId & 255;
265
+ frame[5] = payload.length >>> 24 & 255;
266
+ frame[6] = payload.length >>> 16 & 255;
267
+ frame[7] = payload.length >>> 8 & 255;
268
+ frame[8] = payload.length & 255;
269
+ frame.set(payload, FRAME_HEADER_SIZE);
270
+ return frame;
271
+ }
272
+ function encodeJSONFrame(json) {
273
+ return encodeFrame(FrameType.JSON, 0, textEncoder.encode(json));
274
+ }
275
+ function encodeChunkFrame(streamId, chunk) {
276
+ return encodeFrame(FrameType.CHUNK, streamId, chunk);
277
+ }
278
+ function encodeEndFrame(streamId) {
279
+ return encodeFrame(FrameType.END, streamId, EMPTY_PAYLOAD);
280
+ }
281
+ function encodeErrorFrame(streamId, error) {
282
+ const message = error instanceof Error ? error.message : String(error ?? "Unknown error");
283
+ return encodeFrame(FrameType.ERROR, streamId, textEncoder.encode(message));
284
+ }
285
+ function createMultiplexedStream(jsonStream, rawStreams, lateStreamSource) {
286
+ let controller;
287
+ let cancelled = false;
288
+ const readers = [];
289
+ const enqueue = (frame) => {
290
+ if (cancelled) return false;
291
+ try {
292
+ controller.enqueue(frame);
293
+ return true;
294
+ } catch {
295
+ return false;
296
+ }
297
+ };
298
+ const errorOutput = (error) => {
299
+ if (cancelled) return;
300
+ cancelled = true;
301
+ try {
302
+ controller.error(error);
303
+ } catch {
304
+ }
305
+ for (const reader of readers) reader.cancel().catch(() => {
306
+ });
307
+ };
308
+ async function pumpRawStream(streamId, stream) {
309
+ const reader = stream.getReader();
310
+ readers.push(reader);
311
+ try {
312
+ while (!cancelled) {
313
+ const { done, value } = await reader.read();
314
+ if (done) {
315
+ enqueue(encodeEndFrame(streamId));
316
+ return;
317
+ }
318
+ if (!enqueue(encodeChunkFrame(streamId, value))) return;
319
+ }
320
+ } catch (error) {
321
+ enqueue(encodeErrorFrame(streamId, error));
322
+ } finally {
323
+ reader.releaseLock();
324
+ }
325
+ }
326
+ async function pumpJSON() {
327
+ const reader = jsonStream.getReader();
328
+ readers.push(reader);
329
+ try {
330
+ while (!cancelled) {
331
+ const { done, value } = await reader.read();
332
+ if (done) return;
333
+ if (!enqueue(encodeJSONFrame(value))) return;
334
+ }
335
+ } catch (error) {
336
+ errorOutput(error);
337
+ throw error;
338
+ } finally {
339
+ reader.releaseLock();
340
+ }
341
+ }
342
+ async function pumpLateStreams() {
343
+ if (!lateStreamSource) return [];
344
+ const lateStreamPumps = [];
345
+ const reader = lateStreamSource.getReader();
346
+ readers.push(reader);
347
+ try {
348
+ while (!cancelled) {
349
+ const { done, value } = await reader.read();
350
+ if (done) break;
351
+ lateStreamPumps.push(pumpRawStream(value.id, value.stream));
352
+ }
353
+ } finally {
354
+ reader.releaseLock();
355
+ }
356
+ return lateStreamPumps;
357
+ }
358
+ return new ReadableStream({
359
+ async start(ctrl) {
360
+ controller = ctrl;
361
+ const pumps = [pumpJSON()];
362
+ for (const [streamId, stream] of rawStreams) pumps.push(pumpRawStream(streamId, stream));
363
+ if (lateStreamSource) pumps.push(pumpLateStreams());
364
+ try {
365
+ const latePumps = (await Promise.all(pumps)).find(Array.isArray);
366
+ if (latePumps && latePumps.length > 0) await Promise.all(latePumps);
367
+ if (!cancelled) try {
368
+ controller.close();
369
+ } catch {
370
+ }
371
+ } catch {
372
+ }
373
+ },
374
+ cancel() {
375
+ cancelled = true;
376
+ for (const reader of readers) reader.cancel().catch(() => {
377
+ });
378
+ readers.length = 0;
379
+ }
380
+ });
381
+ }
382
+ var serovalPlugins = void 0;
383
+ var FORM_DATA_CONTENT_TYPES = ["multipart/form-data", "application/x-www-form-urlencoded"];
384
+ var MAX_PAYLOAD_SIZE = 1e6;
385
+ var handleServerAction = async ({ request, context, serverFnId }) => {
386
+ const methodUpper = request.method.toUpperCase();
387
+ const url = new URL(request.url);
388
+ const action = await getServerFnById(serverFnId);
389
+ if (action.method && methodUpper !== action.method) return new Response(`expected ${action.method} method. Got ${methodUpper}`, {
390
+ status: 405,
391
+ headers: { Allow: action.method }
392
+ });
393
+ const isServerFn = request.headers.get("x-tsr-serverFn") === "true";
394
+ if (!serovalPlugins) serovalPlugins = getDefaultSerovalPlugins();
395
+ const contentType = request.headers.get("Content-Type");
396
+ function parsePayload(payload) {
397
+ return fromJSON(payload, { plugins: serovalPlugins });
398
+ }
399
+ return await (async () => {
400
+ try {
401
+ let serializeResult = function(res2) {
402
+ let nonStreamingBody = void 0;
403
+ const alsResponse = getResponse();
404
+ if (res2 !== void 0) {
405
+ const rawStreams = /* @__PURE__ */ new Map();
406
+ let initialPhase = true;
407
+ let lateStreamWriter;
408
+ let lateStreamReadable = void 0;
409
+ const pendingLateStreams = [];
410
+ const plugins = [createRawStreamRPCPlugin((id, stream) => {
411
+ if (initialPhase) {
412
+ rawStreams.set(id, stream);
413
+ return;
414
+ }
415
+ if (lateStreamWriter) {
416
+ lateStreamWriter.write({
417
+ id,
418
+ stream
419
+ }).catch(() => {
420
+ });
421
+ return;
422
+ }
423
+ pendingLateStreams.push({
424
+ id,
425
+ stream
426
+ });
427
+ }), ...serovalPlugins || []];
428
+ let done = false;
429
+ const callbacks = {
430
+ onParse: (value) => {
431
+ nonStreamingBody = value;
432
+ },
433
+ onDone: () => {
434
+ done = true;
435
+ },
436
+ onError: (error) => {
437
+ throw error;
438
+ }
439
+ };
440
+ toCrossJSONStream(res2, {
441
+ refs: /* @__PURE__ */ new Map(),
442
+ plugins,
443
+ onParse(value) {
444
+ callbacks.onParse(value);
445
+ },
446
+ onDone() {
447
+ callbacks.onDone();
448
+ },
449
+ onError: (error) => {
450
+ callbacks.onError(error);
451
+ }
452
+ });
453
+ initialPhase = false;
454
+ if (done && rawStreams.size === 0) return new Response(nonStreamingBody ? JSON.stringify(nonStreamingBody) : void 0, {
455
+ status: alsResponse.status,
456
+ statusText: alsResponse.statusText,
457
+ headers: {
458
+ "Content-Type": "application/json",
459
+ [X_TSS_SERIALIZED]: "true"
460
+ }
461
+ });
462
+ const { readable, writable } = new TransformStream();
463
+ lateStreamReadable = readable;
464
+ lateStreamWriter = writable.getWriter();
465
+ for (const registration of pendingLateStreams) lateStreamWriter.write(registration).catch(() => {
466
+ });
467
+ pendingLateStreams.length = 0;
468
+ const multiplexedStream = createMultiplexedStream(new ReadableStream({
469
+ start(controller) {
470
+ callbacks.onParse = (value) => {
471
+ controller.enqueue(JSON.stringify(value) + "\n");
472
+ };
473
+ callbacks.onDone = () => {
474
+ try {
475
+ controller.close();
476
+ } catch {
477
+ }
478
+ lateStreamWriter?.close().catch(() => {
479
+ }).finally(() => {
480
+ lateStreamWriter = void 0;
481
+ });
482
+ };
483
+ callbacks.onError = (error) => {
484
+ controller.error(error);
485
+ lateStreamWriter?.abort(error).catch(() => {
486
+ }).finally(() => {
487
+ lateStreamWriter = void 0;
488
+ });
489
+ };
490
+ if (nonStreamingBody !== void 0) callbacks.onParse(nonStreamingBody);
491
+ if (done) callbacks.onDone();
492
+ },
493
+ cancel() {
494
+ lateStreamWriter?.abort().catch(() => {
495
+ });
496
+ lateStreamWriter = void 0;
497
+ }
498
+ }), rawStreams, lateStreamReadable);
499
+ return new Response(multiplexedStream, {
500
+ status: alsResponse.status,
501
+ statusText: alsResponse.statusText,
502
+ headers: {
503
+ "Content-Type": TSS_CONTENT_TYPE_FRAMED_VERSIONED,
504
+ [X_TSS_SERIALIZED]: "true"
505
+ }
506
+ });
507
+ }
508
+ return new Response(void 0, {
509
+ status: alsResponse.status,
510
+ statusText: alsResponse.statusText
511
+ });
512
+ };
513
+ let res = await (async () => {
514
+ if (FORM_DATA_CONTENT_TYPES.some((type) => contentType && contentType.includes(type))) {
515
+ if (methodUpper === "GET") {
516
+ if (false) ;
517
+ invariant();
518
+ }
519
+ const formData = await request.formData();
520
+ const serializedContext = formData.get(TSS_FORMDATA_CONTEXT);
521
+ formData.delete(TSS_FORMDATA_CONTEXT);
522
+ const params = {
523
+ context,
524
+ data: formData,
525
+ method: methodUpper
526
+ };
527
+ if (typeof serializedContext === "string") try {
528
+ const deserializedContext = fromJSON(JSON.parse(serializedContext), { plugins: serovalPlugins });
529
+ if (typeof deserializedContext === "object" && deserializedContext) params.context = safeObjectMerge(deserializedContext, context);
530
+ } catch (e) {
531
+ if (false) ;
532
+ }
533
+ return await action(params);
534
+ }
535
+ if (methodUpper === "GET") {
536
+ const payloadParam = url.searchParams.get("payload");
537
+ if (payloadParam && payloadParam.length > MAX_PAYLOAD_SIZE) throw new Error("Payload too large");
538
+ const payload2 = payloadParam ? parsePayload(JSON.parse(payloadParam)) : {};
539
+ payload2.context = safeObjectMerge(payload2.context, context);
540
+ payload2.method = methodUpper;
541
+ return await action(payload2);
542
+ }
543
+ let jsonPayload;
544
+ if (contentType?.includes("application/json")) jsonPayload = await request.json();
545
+ const payload = jsonPayload ? parsePayload(jsonPayload) : {};
546
+ payload.context = safeObjectMerge(payload.context, context);
547
+ payload.method = methodUpper;
548
+ return await action(payload);
549
+ })();
550
+ const unwrapped = res.result || res.error;
551
+ if (isNotFound(res)) res = isNotFoundResponse(res);
552
+ if (!isServerFn) return unwrapped;
553
+ if (unwrapped instanceof Response) {
554
+ if (isRedirect(unwrapped)) return unwrapped;
555
+ unwrapped.headers.set(X_TSS_RAW_RESPONSE, "true");
556
+ return unwrapped;
557
+ }
558
+ return serializeResult(res);
559
+ } catch (error) {
560
+ if (error instanceof Response) return error;
561
+ if (isNotFound(error)) return isNotFoundResponse(error);
562
+ console.info();
563
+ console.info("Server Fn Error!");
564
+ console.info();
565
+ console.error(error);
566
+ console.info();
567
+ const serializedError = JSON.stringify(await Promise.resolve(toCrossJSONAsync(error, {
568
+ refs: /* @__PURE__ */ new Map(),
569
+ plugins: serovalPlugins
570
+ })));
571
+ const response = getResponse();
572
+ return new Response(serializedError, {
573
+ status: response.status ?? 500,
574
+ statusText: response.statusText,
575
+ headers: {
576
+ "Content-Type": "application/json",
577
+ [X_TSS_SERIALIZED]: "true"
578
+ }
579
+ });
580
+ }
581
+ })();
582
+ };
583
+ function isNotFoundResponse(error) {
584
+ const { headers, ...rest } = error;
585
+ return new Response(JSON.stringify(rest), {
586
+ status: 404,
587
+ headers: {
588
+ "Content-Type": "application/json",
589
+ ...headers || {}
590
+ }
591
+ });
592
+ }
593
+ var LINK_PARAM_TOKEN_RE = /^[!#$%&'*+\-.^_`|~0-9A-Za-z]+$/;
594
+ var PRELOAD_AS_VALUES = /* @__PURE__ */ new Set([
595
+ "fetch",
596
+ "font",
597
+ "image",
598
+ "script",
599
+ "style",
600
+ "track"
601
+ ]);
602
+ function buildLinkParam(name, value) {
603
+ if (value === void 0) return name;
604
+ if (LINK_PARAM_TOKEN_RE.test(value)) return `${name}=${value}`;
605
+ return `${name}=${JSON.stringify(value)}`;
606
+ }
607
+ function serializeEarlyHint(hint) {
608
+ const parts = [`<${hint.href}>`, buildLinkParam("rel", hint.rel)];
609
+ if (hint.as) parts.push(buildLinkParam("as", hint.as));
610
+ if (hint.crossOrigin !== void 0) parts.push(buildLinkParam("crossorigin", hint.crossOrigin || void 0));
611
+ if (hint.type) parts.push(buildLinkParam("type", hint.type));
612
+ if (hint.integrity) parts.push(buildLinkParam("integrity", hint.integrity));
613
+ if (hint.referrerPolicy) parts.push(buildLinkParam("referrerpolicy", hint.referrerPolicy));
614
+ if (hint.fetchPriority) parts.push(buildLinkParam("fetchpriority", hint.fetchPriority));
615
+ return parts.join("; ");
616
+ }
617
+ function getStringAttr(attrs, name, fallbackName) {
618
+ const value = attrs?.[name] ?? (fallbackName ? attrs?.[fallbackName] : void 0);
619
+ return typeof value === "string" ? value : void 0;
620
+ }
621
+ function getPreloadAs(attrs) {
622
+ const as = getStringAttr(attrs, "as");
623
+ return as && PRELOAD_AS_VALUES.has(as) ? as : void 0;
624
+ }
625
+ function addEarlyHintFetchAttrs(hint, attrs) {
626
+ const crossOrigin = getStringAttr(attrs, "crossOrigin", "crossorigin");
627
+ const type = getStringAttr(attrs, "type");
628
+ const integrity = getStringAttr(attrs, "integrity");
629
+ const referrerPolicy = getStringAttr(attrs, "referrerPolicy", "referrerpolicy");
630
+ const fetchPriority = getStringAttr(attrs, "fetchPriority", "fetchpriority");
631
+ if (crossOrigin !== void 0) hint.crossOrigin = crossOrigin;
632
+ if (type) hint.type = type;
633
+ if (integrity) hint.integrity = integrity;
634
+ if (referrerPolicy) hint.referrerPolicy = referrerPolicy;
635
+ if (fetchPriority) hint.fetchPriority = fetchPriority;
636
+ }
637
+ function linkAttrsToEarlyHint(attrs) {
638
+ const href = getStringAttr(attrs, "href");
639
+ const rel = getStringAttr(attrs, "rel");
640
+ if (!href || !rel) return void 0;
641
+ const relTokens = rel.split(/\s+/);
642
+ let hintRel;
643
+ let hintAs;
644
+ if (relTokens.includes("modulepreload")) {
645
+ hintRel = "modulepreload";
646
+ hintAs = "script";
647
+ } else if (relTokens.includes("stylesheet")) {
648
+ hintRel = "preload";
649
+ hintAs = "style";
650
+ } else if (relTokens.includes("preload")) {
651
+ hintAs = getPreloadAs(attrs);
652
+ if (!hintAs) return void 0;
653
+ hintRel = "preload";
654
+ } else if (relTokens.includes("preconnect")) {
655
+ hintRel = "preconnect";
656
+ hintAs = void 0;
657
+ } else if (relTokens.includes("dns-prefetch")) {
658
+ hintRel = "dns-prefetch";
659
+ hintAs = void 0;
660
+ }
661
+ if (!hintRel) return void 0;
662
+ const hint = {
663
+ href,
664
+ rel: hintRel
665
+ };
666
+ if (hintAs) hint.as = hintAs;
667
+ addEarlyHintFetchAttrs(hint, attrs);
668
+ return hint;
669
+ }
670
+ function collectStaticHintsFromManifest(manifest2, matchedRoutes) {
671
+ const hints = [];
672
+ for (const route of matchedRoutes) {
673
+ const routeManifest = manifest2.routes[route.id];
674
+ if (!routeManifest) continue;
675
+ for (const link of routeManifest.preloads ?? []) {
676
+ const attrs = getScriptPreloadAttrs(manifest2, link);
677
+ const hint = {
678
+ href: attrs.href,
679
+ rel: attrs.rel,
680
+ as: "script"
681
+ };
682
+ if (attrs.crossOrigin !== void 0) hint.crossOrigin = attrs.crossOrigin;
683
+ hints.push(hint);
684
+ }
685
+ for (const link of routeManifest.css ?? []) {
686
+ const stylesheetHref = getStylesheetHref(link);
687
+ if (manifest2.inlineCss?.styles[stylesheetHref] !== void 0) continue;
688
+ const resolvedLink = resolveManifestCssLink(link);
689
+ const hint = {
690
+ href: stylesheetHref,
691
+ rel: "preload",
692
+ as: "style"
693
+ };
694
+ if (resolvedLink.crossOrigin !== void 0) hint.crossOrigin = resolvedLink.crossOrigin;
695
+ hints.push(hint);
696
+ }
697
+ }
698
+ return hints;
699
+ }
700
+ function collectDynamicHintsFromMatches(matches) {
701
+ const hints = [];
702
+ for (const match of matches) {
703
+ const links = match.links;
704
+ if (!Array.isArray(links)) continue;
705
+ for (const link of links) {
706
+ const hint = linkAttrsToEarlyHint(link);
707
+ if (hint) hints.push(hint);
708
+ }
709
+ }
710
+ return hints;
711
+ }
712
+ function createEarlyHintsEvent(opts) {
713
+ const nextHints = [];
714
+ const nextLinks = [];
715
+ for (const hint of opts.hints) {
716
+ const link = serializeEarlyHint(hint);
717
+ if (opts.sentLinks.has(link)) continue;
718
+ opts.sentLinks.add(link);
719
+ opts.sentHints.push(hint);
720
+ nextHints.push(hint);
721
+ nextLinks.push(link);
722
+ }
723
+ if (!nextHints.length && opts.phase !== "dynamic") return void 0;
724
+ return {
725
+ phase: opts.phase,
726
+ hints: nextHints,
727
+ links: nextLinks,
728
+ allHints: opts.sentHints.slice(),
729
+ allLinks: Array.from(opts.sentLinks)
730
+ };
731
+ }
732
+ function createResponseLinkHeaderEntries(opts) {
733
+ for (const hint of opts.hints) {
734
+ const link = serializeEarlyHint(hint);
735
+ if (opts.sentLinks.has(link)) continue;
736
+ opts.sentLinks.add(link);
737
+ opts.entries.push({
738
+ phase: opts.phase,
739
+ hint,
740
+ link
741
+ });
742
+ }
743
+ }
744
+ function getResponseLinkHeaderEntries(opts) {
745
+ if (!opts.filter) return opts.entries.map((entry) => entry.link);
746
+ try {
747
+ const links = [];
748
+ for (const entry of opts.entries) if (opts.filter(entry)) links.push(entry.link);
749
+ return links;
750
+ } catch (err) {
751
+ console.error("Error filtering response Link headers:", err);
752
+ return [];
753
+ }
754
+ }
755
+ function notifyEarlyHints(phase, event, onEarlyHints) {
756
+ try {
757
+ const result = onEarlyHints(event);
758
+ if (result) Promise.resolve(result).catch((err) => {
759
+ console.error(`Error sending ${phase} early hints:`, err);
760
+ });
761
+ } catch (err) {
762
+ console.error(`Error sending ${phase} early hints:`, err);
763
+ }
764
+ }
765
+ function getResponseLinkHeaderFilter(responseLinkHeader) {
766
+ if (typeof responseLinkHeader !== "object") return;
767
+ return responseLinkHeader.filter;
768
+ }
769
+ function appendResponseLinkHeaders(opts) {
770
+ for (const link of getResponseLinkHeaderEntries(opts)) opts.responseHeaders.append("Link", link);
771
+ }
772
+ function collectResponseLinkHeaderEntries(opts) {
773
+ for (let index = 0; index < opts.event.hints.length; index++) opts.entries.push({
774
+ phase: opts.phase,
775
+ hint: opts.event.hints[index],
776
+ link: opts.event.links[index]
777
+ });
778
+ }
779
+ function collectEarlyHintsPhase(opts) {
780
+ const event = opts.onEarlyHints ? createEarlyHintsEvent({
781
+ phase: opts.phase,
782
+ hints: opts.hints,
783
+ sentLinks: opts.sentLinks,
784
+ sentHints: opts.sentHints
785
+ }) : void 0;
786
+ if (event) notifyEarlyHints(opts.phase, event, opts.onEarlyHints);
787
+ if (!opts.responseLinkHeaderEntries) return;
788
+ if (event) {
789
+ collectResponseLinkHeaderEntries({
790
+ phase: opts.phase,
791
+ event,
792
+ entries: opts.responseLinkHeaderEntries
793
+ });
794
+ return;
795
+ }
796
+ createResponseLinkHeaderEntries({
797
+ phase: opts.phase,
798
+ hints: opts.hints,
799
+ sentLinks: opts.sentLinks,
800
+ entries: opts.responseLinkHeaderEntries
801
+ });
802
+ }
803
+ function createEarlyHintsCollector(opts) {
804
+ if (!opts?.onEarlyHints && !opts?.responseLinkHeader) return;
805
+ const sentLinks = /* @__PURE__ */ new Set();
806
+ const sentHints = opts.onEarlyHints ? new Array() : void 0;
807
+ const responseLinkHeaderEntries = opts.responseLinkHeader ? new Array() : void 0;
808
+ const responseLinkHeaderFilter = getResponseLinkHeaderFilter(opts.responseLinkHeader);
809
+ return {
810
+ collectStatic: ({ manifest: manifest2, matchedRoutes }) => {
811
+ if (!matchedRoutes?.length) return;
812
+ collectEarlyHintsPhase({
813
+ phase: "static",
814
+ hints: collectStaticHintsFromManifest(manifest2, matchedRoutes),
815
+ sentLinks,
816
+ sentHints,
817
+ onEarlyHints: opts.onEarlyHints,
818
+ responseLinkHeaderEntries
819
+ });
820
+ },
821
+ collectDynamic: (matches) => {
822
+ collectEarlyHintsPhase({
823
+ phase: "dynamic",
824
+ hints: collectDynamicHintsFromMatches(matches),
825
+ sentLinks,
826
+ sentHints,
827
+ onEarlyHints: opts.onEarlyHints,
828
+ responseLinkHeaderEntries
829
+ });
830
+ },
831
+ appendResponseHeaders: (headers) => {
832
+ if (!responseLinkHeaderEntries?.length) return;
833
+ appendResponseLinkHeaders({
834
+ responseHeaders: headers,
835
+ entries: responseLinkHeaderEntries,
836
+ filter: responseLinkHeaderFilter
837
+ });
838
+ }
839
+ };
840
+ }
841
+ function normalizeTransformAssetResult(result) {
842
+ if (typeof result === "string") return { href: result };
843
+ return result;
844
+ }
845
+ function escapeCssString(value) {
846
+ return value.replace(/\\/g, "\\\\").replace(/"/g, '\\"').replace(/\n/g, "\\a ").replace(/\r/g, "\\d ").replace(/\f/g, "\\c ");
847
+ }
848
+ async function transformInlineCssTemplate(options) {
849
+ const { strings, urls } = options.template;
850
+ if (strings.length !== urls.length + 1) throw new Error(`TanStack Start inlineCss template for ${options.stylesheetHref} is invalid`);
851
+ let css = strings[0];
852
+ for (let index = 0; index < urls.length; index++) {
853
+ const transformed = normalizeTransformAssetResult(await options.transformFn({
854
+ kind: "css-url",
855
+ url: urls[index],
856
+ stylesheetHref: options.stylesheetHref
857
+ }));
858
+ css += escapeCssString(transformed.href) + strings[index + 1];
859
+ }
860
+ return css;
861
+ }
862
+ async function transformInlineCssStyles(inlineCss, transformFn) {
863
+ const transformedStyles = {};
864
+ const transformedEntries = await Promise.all(Object.entries(inlineCss.styles).map(async ([stylesheetHref, css]) => {
865
+ const template = inlineCss.templates?.[stylesheetHref];
866
+ return [stylesheetHref, template ? await transformInlineCssTemplate({
867
+ stylesheetHref,
868
+ template,
869
+ transformFn
870
+ }) : css];
871
+ }));
872
+ for (const [stylesheetHref, css] of transformedEntries) transformedStyles[stylesheetHref] = css;
873
+ return {
874
+ styles: transformedStyles,
875
+ ...inlineCss.templates ? { templates: inlineCss.templates } : {}
876
+ };
877
+ }
878
+ function resolveTransformAssetsCrossOrigin(config, kind) {
879
+ if (!config) return void 0;
880
+ if (typeof config === "string") return config;
881
+ return config[kind];
882
+ }
883
+ function isObjectShorthand(transform) {
884
+ return "prefix" in transform;
885
+ }
886
+ function resolveTransformAssetsConfig(transform) {
887
+ if (typeof transform === "string") {
888
+ const prefix = transform;
889
+ return {
890
+ type: "transform",
891
+ transformFn: ({ url }) => ({ href: `${prefix}${url}` }),
892
+ cache: true
893
+ };
894
+ }
895
+ if (typeof transform === "function") return {
896
+ type: "transform",
897
+ transformFn: transform,
898
+ cache: true
899
+ };
900
+ if (isObjectShorthand(transform)) {
901
+ const { prefix, crossOrigin } = transform;
902
+ return {
903
+ type: "transform",
904
+ transformFn: ({ url, kind }) => {
905
+ const href = `${prefix}${url}`;
906
+ if (kind === "css-url") return { href };
907
+ const co = resolveTransformAssetsCrossOrigin(crossOrigin, kind);
908
+ return co ? {
909
+ href,
910
+ crossOrigin: co
911
+ } : { href };
912
+ },
913
+ cache: true
914
+ };
915
+ }
916
+ if ("createTransform" in transform && transform.createTransform) return {
917
+ type: "createTransform",
918
+ createTransform: transform.createTransform,
919
+ cache: transform.cache !== false
920
+ };
921
+ return {
922
+ type: "transform",
923
+ transformFn: typeof transform.transform === "string" ? (({ url }) => ({ href: `${transform.transform}${url}` })) : transform.transform,
924
+ cache: transform.cache !== false
925
+ };
926
+ }
927
+ function assignManifestLink(link, next) {
928
+ if (typeof link === "string") return next.crossOrigin ? next : next.href;
929
+ const nextLink = {
930
+ ...link,
931
+ href: next.href
932
+ };
933
+ if (next.crossOrigin) nextLink.crossOrigin = next.crossOrigin;
934
+ else delete nextLink.crossOrigin;
935
+ return nextLink;
936
+ }
937
+ async function transformManifestAssets(source, transformFn, _opts) {
938
+ const manifest2 = structuredClone(source);
939
+ const inlineCssEnabled = _opts?.inlineCss !== false;
940
+ const scriptTransforms = /* @__PURE__ */ new Map();
941
+ const transformScript = (url) => {
942
+ const cached = scriptTransforms.get(url);
943
+ if (cached) return cached;
944
+ const transformed = Promise.resolve(transformFn({
945
+ url,
946
+ kind: "script"
947
+ })).then(normalizeTransformAssetResult);
948
+ scriptTransforms.set(url, transformed);
949
+ return transformed;
950
+ };
951
+ if (!inlineCssEnabled) delete manifest2.inlineCss;
952
+ else if (manifest2.inlineCss) manifest2.inlineCss = await transformInlineCssStyles(manifest2.inlineCss, transformFn);
953
+ for (const route of Object.values(manifest2.routes)) {
954
+ if (route.preloads?.length) route.preloads = await Promise.all(route.preloads.map(async (link) => {
955
+ const result = await transformScript(resolveManifestAssetLink(link).href);
956
+ return assignManifestLink(link, {
957
+ href: result.href,
958
+ crossOrigin: result.crossOrigin
959
+ });
960
+ }));
961
+ if (route.css?.length && !manifest2.inlineCss) route.css = await Promise.all(route.css.map(async (link) => {
962
+ const result = normalizeTransformAssetResult(await transformFn({
963
+ url: resolveManifestCssLink(link).href,
964
+ kind: "stylesheet"
965
+ }));
966
+ return assignManifestLink(link, {
967
+ href: result.href,
968
+ crossOrigin: result.crossOrigin
969
+ });
970
+ }));
971
+ if (route.scripts?.length) for (const script of route.scripts) {
972
+ const src = script.attrs?.src;
973
+ if (typeof src !== "string") continue;
974
+ const result = await transformScript(src);
975
+ script.attrs = {
976
+ ...script.attrs,
977
+ src: result.href
978
+ };
979
+ if (result.crossOrigin) script.attrs.crossOrigin = result.crossOrigin;
980
+ else delete script.attrs.crossOrigin;
981
+ }
982
+ }
983
+ return manifest2;
984
+ }
985
+ function buildManifest(source, opts) {
986
+ return {
987
+ ...source.scriptFormat ? { scriptFormat: source.scriptFormat } : {},
988
+ ...opts?.inlineCss !== false && source.inlineCss ? { inlineCss: structuredClone(source.inlineCss) } : {},
989
+ routes: { ...source.routes }
990
+ };
991
+ }
992
+ function getStaticHandlerInlineCssDefault(handlerInlineCss) {
993
+ if (typeof handlerInlineCss === "function") return;
994
+ return handlerInlineCss ?? true;
995
+ }
996
+ async function resolveInlineCssForRequest(opts) {
997
+ if (opts.requestInlineCss !== void 0) return opts.requestInlineCss;
998
+ if (typeof opts.handlerInlineCss === "function") return await opts.handlerInlineCss({ request: opts.request });
999
+ return opts.handlerInlineCss ?? true;
1000
+ }
1001
+ function createCachedBaseManifestLoader(loadBaseManifest) {
1002
+ let baseManifestPromise;
1003
+ return () => {
1004
+ if (!baseManifestPromise) baseManifestPromise = loadBaseManifest().catch((error) => {
1005
+ baseManifestPromise = void 0;
1006
+ throw error;
1007
+ });
1008
+ return baseManifestPromise;
1009
+ };
1010
+ }
1011
+ function createFinalManifestTransformResolver(transformAssets, opts) {
1012
+ const transformConfig = transformAssets !== void 0 ? resolveTransformAssetsConfig(transformAssets) : void 0;
1013
+ const cache = transformConfig ? transformConfig.cache : true;
1014
+ const warmup = !!transformAssets && typeof transformAssets === "object" && "warmup" in transformAssets && transformAssets.warmup === true;
1015
+ let cachedCreateTransformPromise;
1016
+ const clearCachedCreateTransform = () => {
1017
+ cachedCreateTransformPromise = void 0;
1018
+ };
1019
+ return {
1020
+ cache,
1021
+ warmup,
1022
+ clearCachedCreateTransform,
1023
+ getTransformFn: async (ctx) => {
1024
+ if (!transformConfig) return void 0;
1025
+ if (transformConfig.type !== "createTransform") return transformConfig.transformFn;
1026
+ if (!cache || false) return transformConfig.createTransform(ctx);
1027
+ if (!cachedCreateTransformPromise) cachedCreateTransformPromise = Promise.resolve(transformConfig.createTransform(ctx)).catch((error) => {
1028
+ clearCachedCreateTransform();
1029
+ throw error;
1030
+ });
1031
+ return cachedCreateTransformPromise;
1032
+ }
1033
+ };
1034
+ }
1035
+ function createFinalManifestResolver(opts) {
1036
+ const finalManifestCache = /* @__PURE__ */ new Map();
1037
+ const transformResolver = createFinalManifestTransformResolver(opts.transformAssets);
1038
+ const handlerDefaultInlineCss = getStaticHandlerInlineCssDefault(opts.inlineCss);
1039
+ const getRequestManifestOptions = async (requestOpts) => {
1040
+ const transformFn = await transformResolver.getTransformFn({
1041
+ warmup: false,
1042
+ request: requestOpts.request
1043
+ });
1044
+ const inlineCss = await resolveInlineCssForRequest({
1045
+ request: requestOpts.request,
1046
+ handlerInlineCss: opts.inlineCss,
1047
+ requestInlineCss: requestOpts.requestInlineCss
1048
+ });
1049
+ return {
1050
+ getBaseManifest: requestOpts.getBaseManifest,
1051
+ transformFn,
1052
+ cache: transformResolver.cache,
1053
+ inlineCss
1054
+ };
1055
+ };
1056
+ const resolveRequest = async (requestOpts, cache) => {
1057
+ return resolveFinalManifest({
1058
+ ...await getRequestManifestOptions(requestOpts),
1059
+ finalManifestCache: cache
1060
+ });
1061
+ };
1062
+ return {
1063
+ warmup: ({ getBaseManifest: getBaseManifest2 }) => warmupFinalManifest({
1064
+ enabled: transformResolver.warmup,
1065
+ handlerDefaultInlineCss,
1066
+ cache: transformResolver.cache,
1067
+ finalManifestCache,
1068
+ getBaseManifest: getBaseManifest2,
1069
+ getTransformFn: () => transformResolver.getTransformFn({ warmup: true }),
1070
+ onError: transformResolver.clearCachedCreateTransform
1071
+ }),
1072
+ resolveCached: (requestOpts) => resolveRequest(requestOpts, finalManifestCache),
1073
+ resolveUncached: (requestOpts) => resolveRequest(requestOpts, void 0)
1074
+ };
1075
+ }
1076
+ function getFinalManifestCacheKey(inlineCss) {
1077
+ return inlineCss ? "inline-css" : "linked-css";
1078
+ }
1079
+ function cacheFinalManifestPromise(cachedFinalManifestPromises, cacheKey, promise) {
1080
+ const cachedFinalManifestPromise = promise.catch((error) => {
1081
+ if (cachedFinalManifestPromises.get(cacheKey) === cachedFinalManifestPromise) cachedFinalManifestPromises.delete(cacheKey);
1082
+ throw error;
1083
+ });
1084
+ cachedFinalManifestPromises.set(cacheKey, cachedFinalManifestPromise);
1085
+ return cachedFinalManifestPromise;
1086
+ }
1087
+ function getOrCreateCachedFinalManifestPromise(cachedFinalManifestPromises, cacheKey, computeFinalManifest) {
1088
+ const cachedFinalManifestPromise = cachedFinalManifestPromises.get(cacheKey);
1089
+ if (cachedFinalManifestPromise) return cachedFinalManifestPromise;
1090
+ return cacheFinalManifestPromise(cachedFinalManifestPromises, cacheKey, Promise.resolve().then(computeFinalManifest));
1091
+ }
1092
+ async function buildFinalManifest(opts) {
1093
+ return opts.transformFn ? await transformManifestAssets(opts.base, opts.transformFn, { inlineCss: opts.inlineCss }) : buildManifest(opts.base, { inlineCss: opts.inlineCss });
1094
+ }
1095
+ async function resolveFinalManifest(opts) {
1096
+ const computeFinalManifest = async () => {
1097
+ return buildFinalManifest({
1098
+ base: await opts.getBaseManifest(),
1099
+ transformFn: opts.transformFn,
1100
+ inlineCss: opts.inlineCss
1101
+ });
1102
+ };
1103
+ if (opts.finalManifestCache && (!opts.transformFn || opts.cache)) return getOrCreateCachedFinalManifestPromise(opts.finalManifestCache, getFinalManifestCacheKey(opts.inlineCss), computeFinalManifest);
1104
+ return computeFinalManifest();
1105
+ }
1106
+ function warmupFinalManifest(opts) {
1107
+ if (!opts.enabled || opts.handlerDefaultInlineCss === void 0 || !opts.cache) return;
1108
+ const inlineCss = opts.handlerDefaultInlineCss;
1109
+ const warmupPromise = getOrCreateCachedFinalManifestPromise(opts.finalManifestCache, getFinalManifestCacheKey(inlineCss), async () => {
1110
+ const [base, transformFn] = await Promise.all([opts.getBaseManifest(), opts.getTransformFn()]);
1111
+ return buildFinalManifest({
1112
+ base,
1113
+ transformFn,
1114
+ inlineCss
1115
+ });
1116
+ });
1117
+ if (opts.onError) warmupPromise.catch(opts.onError);
1118
+ return warmupPromise;
1119
+ }
1120
+ var ServerFunctionSerializationAdapter = createSerializationAdapter({
1121
+ key: "$TSS/serverfn",
1122
+ test: (v) => {
1123
+ if (typeof v !== "function") return false;
1124
+ if (!(TSS_SERVER_FUNCTION in v)) return false;
1125
+ return !!v[TSS_SERVER_FUNCTION];
1126
+ },
1127
+ toSerializable: ({ serverFnMeta }) => ({ functionId: serverFnMeta.id }),
1128
+ fromSerializable: ({ functionId }) => {
1129
+ const fn = async (opts, signal) => {
1130
+ return (await (await getServerFnById(functionId))(opts ?? {}, signal)).result;
1131
+ };
1132
+ return fn;
1133
+ }
1134
+ });
1135
+ function getStartResponseHeaders(opts) {
1136
+ return mergeHeaders({ "Content-Type": "text/html; charset=utf-8" }, ...opts.router.stores.matches.get().map((match) => {
1137
+ return match.headers;
1138
+ }));
1139
+ }
1140
+ var entriesPromise;
1141
+ var hasWarnedMissingCsrfMiddleware = false;
1142
+ var defaultCsrfMiddleware = createCsrfMiddleware({ filter: (ctx) => ctx.handlerType === "serverFn" });
1143
+ var getCachedBaseManifest = createCachedBaseManifestLoader(() => getStartManifest());
1144
+ var getProdBaseManifest = () => getCachedBaseManifest();
1145
+ var getBaseManifest = getProdBaseManifest;
1146
+ var createEarlyHintsForRequest = createEarlyHintsCollector;
1147
+ async function loadEntries() {
1148
+ const [routerEntry, startEntry, pluginAdapters] = await Promise.all([
1149
+ import("./router-F5YKPXkV.js"),
1150
+ import("./start-dMGD6DUy.js"),
1151
+ import("./empty-plugin-adapters-BFgPZ6_d.js")
1152
+ ]);
1153
+ return {
1154
+ routerEntry,
1155
+ startEntry,
1156
+ pluginAdapters
1157
+ };
1158
+ }
1159
+ function getEntries() {
1160
+ if (!entriesPromise) entriesPromise = loadEntries();
1161
+ return entriesPromise;
1162
+ }
1163
+ function warnMissingCsrfMiddlewareOnce() {
1164
+ if (hasWarnedMissingCsrfMiddleware) return;
1165
+ hasWarnedMissingCsrfMiddleware = true;
1166
+ console.warn(`TanStack Start server functions are not protected by the CSRF middleware.
1167
+
1168
+ Server functions are same-origin RPC endpoints and should be protected from cross-site requests.
1169
+
1170
+ Add the CSRF middleware in src/start.ts:
1171
+
1172
+ const csrfMiddleware = createCsrfMiddleware({
1173
+ filter: (ctx) => ctx.handlerType === 'serverFn',
1174
+ })
1175
+
1176
+ export const startInstance = createStart(() => ({
1177
+ requestMiddleware: [csrfMiddleware],
1178
+ }))
1179
+
1180
+ If you intentionally handle CSRF another way, disable this warning:
1181
+
1182
+ tanstackStart({
1183
+ serverFns: {
1184
+ disableCsrfMiddlewareWarning: true,
1185
+ },
1186
+ })`);
1187
+ }
1188
+ var ROUTER_BASEPATH = "/";
1189
+ var SERVER_FN_BASE = "/_serverFn/";
1190
+ var IS_PRERENDERING = process.env.TSS_PRERENDERING === "true";
1191
+ var IS_SHELL_ENV = process.env.TSS_SHELL === "true";
1192
+ var ERR_NO_RESPONSE = "Internal Server Error";
1193
+ var ERR_NO_DEFER = "Internal Server Error";
1194
+ function throwRouteHandlerError() {
1195
+ throw new Error(ERR_NO_RESPONSE);
1196
+ }
1197
+ function throwIfMayNotDefer() {
1198
+ throw new Error(ERR_NO_DEFER);
1199
+ }
1200
+ function isSpecialResponse(value) {
1201
+ return value instanceof Response || isRedirect(value);
1202
+ }
1203
+ function handleCtxResult(result) {
1204
+ if (isSsrResponse(result) || isSpecialResponse(result)) return { response: result };
1205
+ return result;
1206
+ }
1207
+ async function executeMiddleware(middlewares, ctx) {
1208
+ let index = -1;
1209
+ let streamResponse;
1210
+ const setResponse = (response) => {
1211
+ if (isSsrResponse(response)) {
1212
+ if (response.serverSsrCleanup === "stream") streamResponse = response;
1213
+ ctx.response = response.response;
1214
+ return;
1215
+ }
1216
+ ctx.response = response;
1217
+ };
1218
+ const disposeStreamResponse = async (reason) => {
1219
+ const response = streamResponse;
1220
+ if (!response) return;
1221
+ streamResponse = void 0;
1222
+ const currentResponse = ctx.response;
1223
+ if (currentResponse === response.response || currentResponse instanceof Response && response.response.body !== null && currentResponse.body === response.response.body) ctx.response = void 0;
1224
+ await response.dispose(reason);
1225
+ };
1226
+ const getFinalResponse = async () => {
1227
+ const response = ctx.response;
1228
+ if (!response) throwRouteHandlerError();
1229
+ if (!streamResponse) return response;
1230
+ if (response === streamResponse.response) return streamResponse;
1231
+ if (streamResponse.response.body !== null && response.body === streamResponse.response.body) return {
1232
+ ...streamResponse,
1233
+ response
1234
+ };
1235
+ await disposeStreamResponse("middleware response replaced");
1236
+ return response;
1237
+ };
1238
+ const next = async (nextCtx) => {
1239
+ if (nextCtx) {
1240
+ if (nextCtx.context) ctx.context = safeObjectMerge(ctx.context, nextCtx.context);
1241
+ for (const key of Object.keys(nextCtx)) if (key === "response") setResponse(nextCtx.response);
1242
+ else if (key !== "context") ctx[key] = nextCtx[key];
1243
+ }
1244
+ index++;
1245
+ const middleware = middlewares[index];
1246
+ if (!middleware) return ctx;
1247
+ let result;
1248
+ try {
1249
+ result = await middleware({
1250
+ ...ctx,
1251
+ next
1252
+ });
1253
+ } catch (err) {
1254
+ if (isSpecialResponse(err)) {
1255
+ setResponse(err);
1256
+ return ctx;
1257
+ }
1258
+ await disposeStreamResponse("middleware error");
1259
+ throw err;
1260
+ }
1261
+ const normalized = handleCtxResult(result);
1262
+ if (normalized) {
1263
+ if (normalized.response !== void 0) setResponse(normalized.response);
1264
+ if (normalized.context) ctx.context = safeObjectMerge(ctx.context, normalized.context);
1265
+ }
1266
+ return ctx;
1267
+ };
1268
+ await next();
1269
+ return {
1270
+ ctx,
1271
+ response: await getFinalResponse()
1272
+ };
1273
+ }
1274
+ function handlerToMiddleware(handler, mayDefer = false) {
1275
+ if (mayDefer) return handler;
1276
+ return async (ctx) => {
1277
+ const response = await handler({
1278
+ ...ctx,
1279
+ next: throwIfMayNotDefer
1280
+ });
1281
+ if (!response) throwRouteHandlerError();
1282
+ return response;
1283
+ };
1284
+ }
1285
+ function createStartHandler(cbOrOptions) {
1286
+ const handlerOptions = typeof cbOrOptions === "function" ? {} : cbOrOptions;
1287
+ const cb = typeof cbOrOptions === "function" ? cbOrOptions : cbOrOptions.handler;
1288
+ const finalManifestResolver = createFinalManifestResolver({
1289
+ ...handlerOptions
1290
+ });
1291
+ const resolveManifestForRequest = finalManifestResolver.resolveCached;
1292
+ finalManifestResolver.warmup({ getBaseManifest: () => getBaseManifest() });
1293
+ const startRequestResolver = async (request, requestOpts) => {
1294
+ let router = null;
1295
+ let responseOwnsCleanup = false;
1296
+ try {
1297
+ const { url, handledProtocolRelativeURL } = getNormalizedURL(request.url);
1298
+ const href = url.pathname + url.search + url.hash;
1299
+ const origin = getOrigin(request);
1300
+ if (handledProtocolRelativeURL) return Response.redirect(url, 308);
1301
+ const entries = await getEntries();
1302
+ const hasStartInstance = !!entries.startEntry.startInstance;
1303
+ const startOptions = await entries.startEntry.startInstance?.getOptions() || {};
1304
+ const { hasPluginAdapters, pluginSerializationAdapters } = entries.pluginAdapters;
1305
+ const serializationAdapters = [
1306
+ ...startOptions.serializationAdapters || [],
1307
+ ...hasPluginAdapters ? pluginSerializationAdapters : [],
1308
+ ServerFunctionSerializationAdapter
1309
+ ];
1310
+ const requestStartOptions = {
1311
+ ...startOptions,
1312
+ requestMiddleware: hasStartInstance ? startOptions.requestMiddleware : [defaultCsrfMiddleware],
1313
+ serializationAdapters
1314
+ };
1315
+ const flattenedRequestMiddlewares = requestStartOptions.requestMiddleware ? flattenMiddlewares(requestStartOptions.requestMiddleware) : [];
1316
+ const executedRequestMiddlewares = new Set(flattenedRequestMiddlewares);
1317
+ const getRouter = async () => {
1318
+ if (router) return router;
1319
+ router = await entries.routerEntry.getRouter();
1320
+ let isShell = IS_SHELL_ENV;
1321
+ if (IS_PRERENDERING && !isShell) isShell = request.headers.get(HEADERS.TSS_SHELL) === "true";
1322
+ const history = createMemoryHistory({ initialEntries: [href] });
1323
+ router.update({
1324
+ history,
1325
+ isShell,
1326
+ isPrerendering: IS_PRERENDERING,
1327
+ origin: router.options.origin ?? origin,
1328
+ defaultSsr: requestStartOptions.defaultSsr,
1329
+ serializationAdapters: [...requestStartOptions.serializationAdapters, ...router.options.serializationAdapters || []],
1330
+ basepath: ROUTER_BASEPATH
1331
+ });
1332
+ return router;
1333
+ };
1334
+ if (SERVER_FN_BASE && url.pathname.startsWith(SERVER_FN_BASE)) {
1335
+ if (false) ;
1336
+ const serverFnId = url.pathname.slice(SERVER_FN_BASE.length).split("/")[0];
1337
+ if (!serverFnId) throw new Error("Invalid server action param for serverFnId");
1338
+ const serverFnHandler = async ({ context }) => {
1339
+ return runWithStartContext({
1340
+ getRouter,
1341
+ startOptions: requestStartOptions,
1342
+ contextAfterGlobalMiddlewares: context,
1343
+ request,
1344
+ executedRequestMiddlewares,
1345
+ handlerType: "serverFn"
1346
+ }, () => handleServerAction({
1347
+ request,
1348
+ context: requestOpts?.context,
1349
+ serverFnId
1350
+ }));
1351
+ };
1352
+ const { response: middlewareResponse2 } = await executeMiddleware([...flattenedRequestMiddlewares.map((d) => d.options.server), serverFnHandler], {
1353
+ request,
1354
+ pathname: url.pathname,
1355
+ handlerType: "serverFn",
1356
+ context: createNullProtoObject(requestOpts?.context)
1357
+ });
1358
+ const result = await handleRedirectResponse(middlewareResponse2, request, getRouter);
1359
+ responseOwnsCleanup = result.serverSsrCleanup === "stream";
1360
+ return result.response;
1361
+ }
1362
+ const executeRouter = async (serverContext, matchedRoutes) => {
1363
+ const acceptParts = (request.headers.get("Accept") || "*/*").split(",");
1364
+ 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 }));
1365
+ const manifest2 = await resolveManifestForRequest({
1366
+ request,
1367
+ requestInlineCss: requestOpts?.inlineCss,
1368
+ getBaseManifest: () => getBaseManifest(matchedRoutes)
1369
+ });
1370
+ const earlyHints = createEarlyHintsForRequest({
1371
+ onEarlyHints: requestOpts?.onEarlyHints,
1372
+ responseLinkHeader: requestOpts?.responseLinkHeader
1373
+ });
1374
+ earlyHints?.collectStatic({
1375
+ manifest: manifest2,
1376
+ matchedRoutes
1377
+ });
1378
+ const routerInstance = await getRouter();
1379
+ attachRouterServerSsrUtils({
1380
+ router: routerInstance,
1381
+ manifest: manifest2,
1382
+ getRequestAssets: () => getStartContext({ throwIfNotFound: false })?.requestAssets
1383
+ });
1384
+ routerInstance.update({ additionalContext: { serverContext } });
1385
+ await routerInstance.load();
1386
+ if (routerInstance.state.redirect) return normalizeSsrResponse(routerInstance.state.redirect);
1387
+ earlyHints?.collectDynamic(routerInstance.stores.matches.get());
1388
+ const ctx = getStartContext({ throwIfNotFound: false });
1389
+ await routerInstance.serverSsr.dehydrate({ requestAssets: ctx?.requestAssets });
1390
+ const responseHeaders = getStartResponseHeaders({ router: routerInstance });
1391
+ earlyHints?.appendResponseHeaders(responseHeaders);
1392
+ return normalizeSsrResponse(await cb({
1393
+ request,
1394
+ router: routerInstance,
1395
+ responseHeaders
1396
+ }));
1397
+ };
1398
+ const requestHandlerMiddleware = async ({ context }) => {
1399
+ return runWithStartContext({
1400
+ getRouter,
1401
+ startOptions: requestStartOptions,
1402
+ contextAfterGlobalMiddlewares: context,
1403
+ request,
1404
+ executedRequestMiddlewares,
1405
+ handlerType: "router"
1406
+ }, async () => {
1407
+ try {
1408
+ return await handleServerRoutes({
1409
+ getRouter,
1410
+ request,
1411
+ url,
1412
+ executeRouter,
1413
+ context,
1414
+ executedRequestMiddlewares
1415
+ });
1416
+ } catch (err) {
1417
+ if (err instanceof Response) return err;
1418
+ throw err;
1419
+ }
1420
+ });
1421
+ };
1422
+ const { response: middlewareResponse } = await executeMiddleware([...flattenedRequestMiddlewares.map((d) => d.options.server), requestHandlerMiddleware], {
1423
+ request,
1424
+ pathname: url.pathname,
1425
+ handlerType: "router",
1426
+ context: createNullProtoObject(requestOpts?.context)
1427
+ });
1428
+ const response = await handleRedirectResponse(middlewareResponse, request, getRouter);
1429
+ responseOwnsCleanup = response.serverSsrCleanup === "stream";
1430
+ return response.response;
1431
+ } finally {
1432
+ if (router?.serverSsr && !responseOwnsCleanup) router.serverSsr.cleanup();
1433
+ router = null;
1434
+ }
1435
+ };
1436
+ return requestHandler(startRequestResolver);
1437
+ }
1438
+ async function handleRedirectResponse(response, request, getRouter) {
1439
+ const ssrResponse = normalizeSsrResponse(response);
1440
+ if (!isRedirect(ssrResponse.response)) return ssrResponse;
1441
+ if (isResolvedRedirect(ssrResponse.response)) {
1442
+ if (request.headers.get("x-tsr-serverFn") === "true") return replaceSsrResponse(ssrResponse, Response.json({
1443
+ ...ssrResponse.response.options,
1444
+ isSerializedRedirect: true
1445
+ }, { headers: ssrResponse.response.headers }), "redirect response replaced");
1446
+ return ssrResponse;
1447
+ }
1448
+ const opts = ssrResponse.response.options;
1449
+ 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)}`);
1450
+ if ([
1451
+ "params",
1452
+ "search",
1453
+ "hash"
1454
+ ].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(", ")}`);
1455
+ const redirect = (await getRouter()).resolveRedirect(ssrResponse.response);
1456
+ if (request.headers.get("x-tsr-serverFn") === "true") return replaceSsrResponse(ssrResponse, Response.json({
1457
+ ...ssrResponse.response.options,
1458
+ isSerializedRedirect: true
1459
+ }, { headers: ssrResponse.response.headers }), "redirect response replaced");
1460
+ return replaceSsrResponse(ssrResponse, redirect, "redirect response replaced");
1461
+ }
1462
+ async function handleServerRoutes({ getRouter, request, url, executeRouter, context, executedRequestMiddlewares }) {
1463
+ const router = await getRouter();
1464
+ const pathname = executeRewriteInput(router.rewrite, url).pathname;
1465
+ const { matchedRoutes, foundRoute, routeParams } = router.getMatchedRoutes(pathname);
1466
+ const isExactMatch = foundRoute && routeParams["**"] === void 0;
1467
+ const routeMiddlewares = [];
1468
+ for (const route of matchedRoutes) {
1469
+ const serverMiddleware = route.options.server?.middleware;
1470
+ if (serverMiddleware) {
1471
+ const flattened = flattenMiddlewares(serverMiddleware);
1472
+ for (const m of flattened) if (!executedRequestMiddlewares.has(m)) routeMiddlewares.push(m.options.server);
1473
+ }
1474
+ }
1475
+ const server2 = foundRoute?.options.server;
1476
+ let isHeadFallback = false;
1477
+ if (server2?.handlers && isExactMatch) {
1478
+ const handlers = typeof server2.handlers === "function" ? server2.handlers({ createHandlers: (d) => d }) : server2.handlers;
1479
+ const requestMethod = request.method.toUpperCase();
1480
+ const handler = requestMethod === "HEAD" ? handlers["HEAD"] ?? handlers["GET"] ?? handlers["ANY"] : handlers[requestMethod] ?? handlers["ANY"];
1481
+ isHeadFallback = requestMethod === "HEAD" && handler !== void 0 && !handlers["HEAD"];
1482
+ if (handler) {
1483
+ const mayDefer = !!foundRoute.options.component;
1484
+ if (typeof handler === "function") routeMiddlewares.push(handlerToMiddleware(handler, mayDefer));
1485
+ else {
1486
+ if (handler.middleware?.length) {
1487
+ const handlerMiddlewares = flattenMiddlewares(handler.middleware);
1488
+ for (const m of handlerMiddlewares) routeMiddlewares.push(m.options.server);
1489
+ }
1490
+ if (handler.handler) routeMiddlewares.push(handlerToMiddleware(handler.handler, mayDefer));
1491
+ }
1492
+ }
1493
+ }
1494
+ routeMiddlewares.push(((ctx2) => executeRouter(ctx2.context, matchedRoutes)));
1495
+ const { ctx, response } = await executeMiddleware(routeMiddlewares, {
1496
+ request,
1497
+ context,
1498
+ params: routeParams,
1499
+ pathname,
1500
+ handlerType: "router"
1501
+ });
1502
+ if (isHeadFallback) {
1503
+ if (!ctx.response) throwRouteHandlerError();
1504
+ return stripSsrResponseBody(await handleRedirectResponse(response, request, getRouter), "HEAD body stripped");
1505
+ }
1506
+ return normalizeSsrResponse(response);
1507
+ }
1508
+ var fetch = createStartHandler(defaultStreamHandler);
1509
+ function createServerEntry(entry) {
1510
+ return { async fetch(...args) {
1511
+ return await entry.fetch(...args);
1512
+ } };
1513
+ }
1514
+ var server_default = createServerEntry({ fetch });
1515
+ const server = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
1516
+ __proto__: null,
1517
+ createServerEntry,
1518
+ default: server_default
1519
+ }, Symbol.toStringTag, { value: "Module" }));
1520
+ export {
1521
+ createMiddleware as c,
1522
+ server as s
1523
+ };