@tanstack/start-server-core 1.20.3-alpha.1

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 (89) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +12 -0
  3. package/dist/cjs/createRequestHandler.cjs +50 -0
  4. package/dist/cjs/createRequestHandler.cjs.map +1 -0
  5. package/dist/cjs/createRequestHandler.d.cts +8 -0
  6. package/dist/cjs/createStartHandler.cjs +254 -0
  7. package/dist/cjs/createStartHandler.cjs.map +1 -0
  8. package/dist/cjs/createStartHandler.d.cts +10 -0
  9. package/dist/cjs/h3.cjs +355 -0
  10. package/dist/cjs/h3.cjs.map +1 -0
  11. package/dist/cjs/h3.d.cts +109 -0
  12. package/dist/cjs/handlerCallback.cjs +7 -0
  13. package/dist/cjs/handlerCallback.cjs.map +1 -0
  14. package/dist/cjs/handlerCallback.d.cts +9 -0
  15. package/dist/cjs/index.cjs +245 -0
  16. package/dist/cjs/index.cjs.map +1 -0
  17. package/dist/cjs/index.d.cts +12 -0
  18. package/dist/cjs/router-manifest.cjs +44 -0
  19. package/dist/cjs/router-manifest.cjs.map +1 -0
  20. package/dist/cjs/router-manifest.d.cts +17 -0
  21. package/dist/cjs/server-functions-handler.cjs +154 -0
  22. package/dist/cjs/server-functions-handler.cjs.map +1 -0
  23. package/dist/cjs/server-functions-handler.d.cts +4 -0
  24. package/dist/cjs/serverRoute.cjs +100 -0
  25. package/dist/cjs/serverRoute.cjs.map +1 -0
  26. package/dist/cjs/serverRoute.d.cts +115 -0
  27. package/dist/cjs/ssr-server.cjs +246 -0
  28. package/dist/cjs/ssr-server.cjs.map +1 -0
  29. package/dist/cjs/ssr-server.d.cts +29 -0
  30. package/dist/cjs/transformStreamWithRouter.cjs +183 -0
  31. package/dist/cjs/transformStreamWithRouter.cjs.map +1 -0
  32. package/dist/cjs/transformStreamWithRouter.d.cts +6 -0
  33. package/dist/cjs/tsrScript.cjs +4 -0
  34. package/dist/cjs/tsrScript.cjs.map +1 -0
  35. package/dist/cjs/tsrScript.d.cts +1 -0
  36. package/dist/cjs/undici.cjs +14 -0
  37. package/dist/cjs/undici.cjs.map +1 -0
  38. package/dist/cjs/undici.d.cts +43 -0
  39. package/dist/esm/createRequestHandler.d.ts +8 -0
  40. package/dist/esm/createRequestHandler.js +50 -0
  41. package/dist/esm/createRequestHandler.js.map +1 -0
  42. package/dist/esm/createStartHandler.d.ts +10 -0
  43. package/dist/esm/createStartHandler.js +232 -0
  44. package/dist/esm/createStartHandler.js.map +1 -0
  45. package/dist/esm/h3.d.ts +109 -0
  46. package/dist/esm/h3.js +248 -0
  47. package/dist/esm/h3.js.map +1 -0
  48. package/dist/esm/handlerCallback.d.ts +9 -0
  49. package/dist/esm/handlerCallback.js +7 -0
  50. package/dist/esm/handlerCallback.js.map +1 -0
  51. package/dist/esm/index.d.ts +12 -0
  52. package/dist/esm/index.js +137 -0
  53. package/dist/esm/index.js.map +1 -0
  54. package/dist/esm/router-manifest.d.ts +17 -0
  55. package/dist/esm/router-manifest.js +44 -0
  56. package/dist/esm/router-manifest.js.map +1 -0
  57. package/dist/esm/server-functions-handler.d.ts +4 -0
  58. package/dist/esm/server-functions-handler.js +154 -0
  59. package/dist/esm/server-functions-handler.js.map +1 -0
  60. package/dist/esm/serverRoute.d.ts +115 -0
  61. package/dist/esm/serverRoute.js +100 -0
  62. package/dist/esm/serverRoute.js.map +1 -0
  63. package/dist/esm/ssr-server.d.ts +29 -0
  64. package/dist/esm/ssr-server.js +246 -0
  65. package/dist/esm/ssr-server.js.map +1 -0
  66. package/dist/esm/transformStreamWithRouter.d.ts +6 -0
  67. package/dist/esm/transformStreamWithRouter.js +183 -0
  68. package/dist/esm/transformStreamWithRouter.js.map +1 -0
  69. package/dist/esm/tsrScript.d.ts +1 -0
  70. package/dist/esm/tsrScript.js +5 -0
  71. package/dist/esm/tsrScript.js.map +1 -0
  72. package/dist/esm/undici.d.ts +43 -0
  73. package/dist/esm/undici.js +14 -0
  74. package/dist/esm/undici.js.map +1 -0
  75. package/package.json +68 -0
  76. package/src/createRequestHandler.ts +73 -0
  77. package/src/createStartHandler.ts +348 -0
  78. package/src/h3.ts +492 -0
  79. package/src/handlerCallback.ts +15 -0
  80. package/src/index.tsx +24 -0
  81. package/src/router-manifest.ts +79 -0
  82. package/src/server-functions-handler.ts +273 -0
  83. package/src/serverRoute.ts +661 -0
  84. package/src/ssr-server.ts +350 -0
  85. package/src/tanstack-start.d.ts +5 -0
  86. package/src/transformStreamWithRouter.ts +258 -0
  87. package/src/tsrScript.ts +91 -0
  88. package/src/undici.ts +60 -0
  89. package/src/vite-env.d.ts +4 -0
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const undici = require("undici");
4
+ const __setGlobalOrigin = undici.setGlobalOrigin;
5
+ function __getAbsoluteUrl(req, options = { trustProxy: false }) {
6
+ const headers = req.headers;
7
+ const host = options.trustProxy ? headers.get("x-forwarded-host") || headers.get("host") : headers.get("host");
8
+ const protocol = options.trustProxy ? headers.get("x-forwarded-proto") || "http" : "http";
9
+ if (!host) throw new Error("Cannot determine host from request headers");
10
+ return `${protocol}://${host}`;
11
+ }
12
+ exports.__getAbsoluteUrl = __getAbsoluteUrl;
13
+ exports.__setGlobalOrigin = __setGlobalOrigin;
14
+ //# sourceMappingURL=undici.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"undici.cjs","sources":["../../src/undici.ts"],"sourcesContent":["import { setGlobalOrigin } from 'undici'\n\n/**\n * DO NOT USE THIS FUNCTION. THIS FUNCTION IS FOR INTERNAL USE ONLY.\n *\n * @internal\n */\nexport const __setGlobalOrigin = setGlobalOrigin\n\n/**\n * DO NOT USE THIS FUNCTION. THIS FUNCTION IS FOR INTERNAL USE ONLY.\n *\n * Constructs an absolute URL from the given request object and options.\n *\n * @internal\n * @param req - The `Request` object containing the headers to extract the host and protocol.\n * @param options - Configuration options for determining the trust level of proxy headers.\n * @param options.trustProxy - If `true`, the function will trust the `x-forwarded-host` and `x-forwarded-proto` headers\n * to determine the host and protocol. Defaults to `false`.\n * @returns The absolute URL constructed from the request headers as a string.\n * @throws Will throw an error if the `host` cannot be determined from the request headers.\n *\n * @example\n * ```ts\n * // Example usage:\n * const req = new Request('http://example.com', {\n * headers: {\n * 'host': 'example.com',\n * 'x-forwarded-host': 'proxy.example.com',\n * 'x-forwarded-proto': 'https',\n * },\n * });\n *\n * // Without trusting proxy headers\n * const url1 = getAbsoluteUrl(req);\n * console.log(url1); // Output: \"http://example.com\"\n *\n * // With trusting proxy headers\n * const url2 = getAbsoluteUrl(req, { trustProxy: true });\n * console.log(url2); // Output: \"https://proxy.example.com\"\n * ```\n */\nexport function __getAbsoluteUrl(\n req: Request,\n options: { trustProxy: boolean } = { trustProxy: false },\n): string {\n const headers = req.headers\n\n const host = options.trustProxy\n ? headers.get('x-forwarded-host') || headers.get('host')\n : headers.get('host')\n\n const protocol = options.trustProxy\n ? headers.get('x-forwarded-proto') || 'http'\n : 'http'\n\n if (!host) throw new Error('Cannot determine host from request headers')\n\n return `${protocol}://${host}`\n}\n"],"names":["setGlobalOrigin"],"mappings":";;;AAOO,MAAM,oBAAoBA,OAAAA;AAmC1B,SAAS,iBACd,KACA,UAAmC,EAAE,YAAY,SACzC;AACR,QAAM,UAAU,IAAI;AAEpB,QAAM,OAAO,QAAQ,aACjB,QAAQ,IAAI,kBAAkB,KAAK,QAAQ,IAAI,MAAM,IACrD,QAAQ,IAAI,MAAM;AAEtB,QAAM,WAAW,QAAQ,aACrB,QAAQ,IAAI,mBAAmB,KAAK,SACpC;AAEJ,MAAI,CAAC,KAAY,OAAA,IAAI,MAAM,4CAA4C;AAEhE,SAAA,GAAG,QAAQ,MAAM,IAAI;AAC9B;;;"}
@@ -0,0 +1,43 @@
1
+ import { setGlobalOrigin } from 'undici';
2
+ /**
3
+ * DO NOT USE THIS FUNCTION. THIS FUNCTION IS FOR INTERNAL USE ONLY.
4
+ *
5
+ * @internal
6
+ */
7
+ export declare const __setGlobalOrigin: typeof setGlobalOrigin;
8
+ /**
9
+ * DO NOT USE THIS FUNCTION. THIS FUNCTION IS FOR INTERNAL USE ONLY.
10
+ *
11
+ * Constructs an absolute URL from the given request object and options.
12
+ *
13
+ * @internal
14
+ * @param req - The `Request` object containing the headers to extract the host and protocol.
15
+ * @param options - Configuration options for determining the trust level of proxy headers.
16
+ * @param options.trustProxy - If `true`, the function will trust the `x-forwarded-host` and `x-forwarded-proto` headers
17
+ * to determine the host and protocol. Defaults to `false`.
18
+ * @returns The absolute URL constructed from the request headers as a string.
19
+ * @throws Will throw an error if the `host` cannot be determined from the request headers.
20
+ *
21
+ * @example
22
+ * ```ts
23
+ * // Example usage:
24
+ * const req = new Request('http://example.com', {
25
+ * headers: {
26
+ * 'host': 'example.com',
27
+ * 'x-forwarded-host': 'proxy.example.com',
28
+ * 'x-forwarded-proto': 'https',
29
+ * },
30
+ * });
31
+ *
32
+ * // Without trusting proxy headers
33
+ * const url1 = getAbsoluteUrl(req);
34
+ * console.log(url1); // Output: "http://example.com"
35
+ *
36
+ * // With trusting proxy headers
37
+ * const url2 = getAbsoluteUrl(req, { trustProxy: true });
38
+ * console.log(url2); // Output: "https://proxy.example.com"
39
+ * ```
40
+ */
41
+ export declare function __getAbsoluteUrl(req: Request, options?: {
42
+ trustProxy: boolean;
43
+ }): string;
@@ -0,0 +1,8 @@
1
+ import { HandlerCallback } from './handlerCallback.js';
2
+ import { AnyRouter, Manifest } from '@tanstack/router-core';
3
+ export type RequestHandler<TRouter extends AnyRouter> = (cb: HandlerCallback<TRouter>) => Promise<Response>;
4
+ export declare function createRequestHandler<TRouter extends AnyRouter>({ createRouter, request, getRouterManifest, }: {
5
+ createRouter: () => TRouter;
6
+ request: Request;
7
+ getRouterManifest?: () => Manifest | Promise<Manifest>;
8
+ }): RequestHandler<TRouter>;
@@ -0,0 +1,50 @@
1
+ import { createMemoryHistory } from "@tanstack/history";
2
+ import { mergeHeaders } from "@tanstack/start-client-core";
3
+ import { attachRouterServerSsrUtils, dehydrateRouter } from "./ssr-server.js";
4
+ function createRequestHandler({
5
+ createRouter,
6
+ request,
7
+ getRouterManifest
8
+ }) {
9
+ return async (cb) => {
10
+ const router = createRouter();
11
+ attachRouterServerSsrUtils(router, await (getRouterManifest == null ? void 0 : getRouterManifest()));
12
+ const url = new URL(request.url, "http://localhost");
13
+ const href = url.href.replace(url.origin, "");
14
+ const history = createMemoryHistory({
15
+ initialEntries: [href]
16
+ });
17
+ router.update({
18
+ history
19
+ });
20
+ await router.load();
21
+ dehydrateRouter(router);
22
+ const responseHeaders = getRequestHeaders({
23
+ router
24
+ });
25
+ return cb({
26
+ request,
27
+ router,
28
+ responseHeaders
29
+ });
30
+ };
31
+ }
32
+ function getRequestHeaders(opts) {
33
+ let headers = mergeHeaders(
34
+ {
35
+ "Content-Type": "text/html; charset=UTF-8"
36
+ },
37
+ ...opts.router.state.matches.map((match) => {
38
+ return match.headers;
39
+ })
40
+ );
41
+ const { redirect } = opts.router.state;
42
+ if (redirect) {
43
+ headers = mergeHeaders(headers, redirect.headers);
44
+ }
45
+ return headers;
46
+ }
47
+ export {
48
+ createRequestHandler
49
+ };
50
+ //# sourceMappingURL=createRequestHandler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createRequestHandler.js","sources":["../../src/createRequestHandler.ts"],"sourcesContent":["import { createMemoryHistory } from '@tanstack/history'\nimport { mergeHeaders } from '@tanstack/start-client-core'\nimport { attachRouterServerSsrUtils, dehydrateRouter } from './ssr-server'\nimport type { HandlerCallback } from './handlerCallback'\nimport type { AnyRouter, Manifest } from '@tanstack/router-core'\n\nexport type RequestHandler<TRouter extends AnyRouter> = (\n cb: HandlerCallback<TRouter>,\n) => Promise<Response>\n\nexport function createRequestHandler<TRouter extends AnyRouter>({\n createRouter,\n request,\n getRouterManifest,\n}: {\n createRouter: () => TRouter\n request: Request\n getRouterManifest?: () => Manifest | Promise<Manifest>\n}): RequestHandler<TRouter> {\n return async (cb) => {\n const router = createRouter()\n\n attachRouterServerSsrUtils(router, await getRouterManifest?.())\n\n const url = new URL(request.url, 'http://localhost')\n\n const href = url.href.replace(url.origin, '')\n\n // Create a history for the router\n const history = createMemoryHistory({\n initialEntries: [href],\n })\n\n // Update the router with the history and context\n router.update({\n history,\n })\n\n await router.load()\n\n dehydrateRouter(router)\n\n const responseHeaders = getRequestHeaders({\n router,\n })\n\n return cb({\n request,\n router,\n responseHeaders,\n } as any)\n }\n}\n\nfunction getRequestHeaders(opts: { router: AnyRouter }): Headers {\n let headers = mergeHeaders(\n {\n 'Content-Type': 'text/html; charset=UTF-8',\n },\n ...opts.router.state.matches.map((match) => {\n return match.headers\n }),\n )\n\n // Handle Redirects\n const { redirect } = opts.router.state\n\n if (redirect) {\n headers = mergeHeaders(headers, redirect.headers)\n }\n\n return headers\n}\n"],"names":[],"mappings":";;;AAUO,SAAS,qBAAgD;AAAA,EAC9D;AAAA,EACA;AAAA,EACA;AACF,GAI4B;AAC1B,SAAO,OAAO,OAAO;AACnB,UAAM,SAAS,aAAa;AAED,+BAAA,QAAQ,OAAM,yDAAqB;AAE9D,UAAM,MAAM,IAAI,IAAI,QAAQ,KAAK,kBAAkB;AAEnD,UAAM,OAAO,IAAI,KAAK,QAAQ,IAAI,QAAQ,EAAE;AAG5C,UAAM,UAAU,oBAAoB;AAAA,MAClC,gBAAgB,CAAC,IAAI;AAAA,IAAA,CACtB;AAGD,WAAO,OAAO;AAAA,MACZ;AAAA,IAAA,CACD;AAED,UAAM,OAAO,KAAK;AAElB,oBAAgB,MAAM;AAEtB,UAAM,kBAAkB,kBAAkB;AAAA,MACxC;AAAA,IAAA,CACD;AAED,WAAO,GAAG;AAAA,MACR;AAAA,MACA;AAAA,MACA;AAAA,IAAA,CACM;AAAA,EACV;AACF;AAEA,SAAS,kBAAkB,MAAsC;AAC/D,MAAI,UAAU;AAAA,IACZ;AAAA,MACE,gBAAgB;AAAA,IAClB;AAAA,IACA,GAAG,KAAK,OAAO,MAAM,QAAQ,IAAI,CAAC,UAAU;AAC1C,aAAO,MAAM;AAAA,IACd,CAAA;AAAA,EACH;AAGA,QAAM,EAAE,SAAA,IAAa,KAAK,OAAO;AAEjC,MAAI,UAAU;AACF,cAAA,aAAa,SAAS,SAAS,OAAO;AAAA,EAAA;AAG3C,SAAA;AACT;"}
@@ -0,0 +1,10 @@
1
+ import { RequestHandler } from './h3.js';
2
+ import { AnyRouter } from '@tanstack/router-core';
3
+ import { HandlerCallback } from './handlerCallback.js';
4
+ export type CustomizeStartHandler<TRouter extends AnyRouter> = (cb: HandlerCallback<TRouter>) => RequestHandler;
5
+ export declare function getStartResponseHeaders(opts: {
6
+ router: AnyRouter;
7
+ }): Headers;
8
+ export declare function createStartHandler<TRouter extends AnyRouter>({ createRouter, }: {
9
+ createRouter: () => TRouter;
10
+ }): CustomizeStartHandler<TRouter>;
@@ -0,0 +1,232 @@
1
+ import path from "node:path";
2
+ import { createMemoryHistory } from "@tanstack/history";
3
+ import { mergeHeaders, json, flattenMiddlewares } from "@tanstack/start-client-core";
4
+ import { isRedirect, tsrRedirectHeaderKey, processRouteTree, getMatchedRoutes, rootRouteId } from "@tanstack/router-core";
5
+ import { getResponseHeaders, requestHandler } from "./h3.js";
6
+ import { attachRouterServerSsrUtils, dehydrateRouter } from "./ssr-server.js";
7
+ import { getStartManifest } from "./router-manifest.js";
8
+ import { handleServerAction } from "./server-functions-handler.js";
9
+ function getStartResponseHeaders(opts) {
10
+ let headers = mergeHeaders(
11
+ getResponseHeaders(),
12
+ {
13
+ "Content-Type": "text/html; charset=UTF-8"
14
+ },
15
+ ...opts.router.state.matches.map((match) => {
16
+ return match.headers;
17
+ })
18
+ );
19
+ const { redirect } = opts.router.state;
20
+ if (redirect) {
21
+ headers = mergeHeaders(headers, redirect.headers);
22
+ }
23
+ return headers;
24
+ }
25
+ function createStartHandler({
26
+ createRouter
27
+ }) {
28
+ return (cb) => {
29
+ return requestHandler(async ({ request }) => {
30
+ const url = new URL(request.url);
31
+ const href = url.href.replace(url.origin, "");
32
+ const history = createMemoryHistory({
33
+ initialEntries: [href]
34
+ });
35
+ const router = createRouter();
36
+ attachRouterServerSsrUtils(router, getStartManifest());
37
+ router.update({
38
+ history
39
+ });
40
+ const response = await (async () => {
41
+ try {
42
+ if (!process.env.TSS_SERVER_FN_BASE) {
43
+ throw new Error(
44
+ "tanstack/start-server-core: TSS_SERVER_FN_BASE must be defined in your environment for createStartHandler()"
45
+ );
46
+ }
47
+ if (href.startsWith(path.join("/", process.env.TSS_SERVER_FN_BASE, "/"))) {
48
+ return await handleServerAction({ request });
49
+ }
50
+ const serverRouteTreeModule = await (async () => {
51
+ try {
52
+ return await import("tanstack:server-routes");
53
+ } catch (e) {
54
+ console.log(e);
55
+ return void 0;
56
+ }
57
+ })();
58
+ if (serverRouteTreeModule) {
59
+ const [matchedRoutes, response3] = await handleServerRoutes({
60
+ routeTree: serverRouteTreeModule.routeTree,
61
+ request
62
+ });
63
+ if (response3) return response3;
64
+ }
65
+ const requestAcceptHeader = request.headers.get("Accept") || "*/*";
66
+ const splitRequestAcceptHeader = requestAcceptHeader.split(",");
67
+ const supportedMimeTypes = ["*/*", "text/html"];
68
+ const isRouterAcceptSupported = supportedMimeTypes.some(
69
+ (mimeType) => splitRequestAcceptHeader.some(
70
+ (acceptedMimeType) => acceptedMimeType.trim().startsWith(mimeType)
71
+ )
72
+ );
73
+ if (!isRouterAcceptSupported) {
74
+ return json(
75
+ {
76
+ error: "Only HTML requests are supported here"
77
+ },
78
+ {
79
+ status: 500
80
+ }
81
+ );
82
+ }
83
+ await router.load();
84
+ if (router.state.redirect) return router.state.redirect;
85
+ dehydrateRouter(router);
86
+ const responseHeaders = getStartResponseHeaders({ router });
87
+ const response2 = await cb({
88
+ request,
89
+ router,
90
+ responseHeaders
91
+ });
92
+ return response2;
93
+ } catch (err) {
94
+ if (err instanceof Response) {
95
+ return err;
96
+ }
97
+ throw err;
98
+ }
99
+ })();
100
+ if (isRedirect(response)) {
101
+ if (response.options.to && typeof response.options.to === "string" && !response.options.to.startsWith("/")) {
102
+ throw new Error(
103
+ `Server side redirects must use absolute paths via the 'href' or 'to' options. Received: ${JSON.stringify(response.options)}`
104
+ );
105
+ }
106
+ if (["params", "search", "hash"].some(
107
+ (d) => typeof response.options[d] === "function"
108
+ )) {
109
+ throw new Error(
110
+ `Server side redirects must use static search, params, and hash values and do not support functional values. Received functional values for: ${Object.keys(
111
+ response.options
112
+ ).filter((d) => typeof response.options[d] === "function").map((d) => `"${d}"`).join(", ")}`
113
+ );
114
+ }
115
+ const redirect = router.resolveRedirect(response);
116
+ if (request.headers.get("x-tsr-redirect") === "manual") {
117
+ return json(
118
+ {
119
+ ...response.options,
120
+ isSerializedRedirect: true
121
+ },
122
+ {
123
+ headers: redirect.headers
124
+ }
125
+ );
126
+ }
127
+ return redirect;
128
+ }
129
+ response.headers.append(
130
+ "Access-Control-Expose-Headers",
131
+ tsrRedirectHeaderKey
132
+ );
133
+ return response;
134
+ });
135
+ };
136
+ }
137
+ async function handleServerRoutes({
138
+ routeTree,
139
+ request
140
+ }) {
141
+ const { flatRoutes, routesById, routesByPath } = processRouteTree({
142
+ routeTree,
143
+ initRoute: (route, i) => {
144
+ route.init({
145
+ originalIndex: i
146
+ });
147
+ }
148
+ });
149
+ const url = new URL(request.url);
150
+ const pathname = url.pathname;
151
+ const history = createMemoryHistory({
152
+ initialEntries: [pathname]
153
+ });
154
+ const { matchedRoutes, foundRoute, routeParams } = getMatchedRoutes({
155
+ pathname: history.location.pathname,
156
+ basepath: "/",
157
+ caseSensitive: true,
158
+ routesByPath,
159
+ routesById,
160
+ flatRoutes
161
+ });
162
+ let response;
163
+ if (foundRoute && foundRoute.id !== rootRouteId) {
164
+ const method = Object.keys(foundRoute.options.methods).find(
165
+ (method2) => method2.toLowerCase() === request.method.toLowerCase()
166
+ );
167
+ if (method) {
168
+ const handler = foundRoute.options.methods[method];
169
+ if (handler) {
170
+ const middlewares = flattenMiddlewares(
171
+ matchedRoutes.flatMap((r) => r.options.middleware).filter(Boolean)
172
+ ).map((d) => d.options.server);
173
+ middlewares.push(handlerToMiddleware(handler));
174
+ const ctx = await executeMiddleware(middlewares, {
175
+ request,
176
+ context: {},
177
+ params: routeParams,
178
+ pathname: history.location.pathname
179
+ });
180
+ response = ctx.response;
181
+ }
182
+ }
183
+ }
184
+ return [matchedRoutes, response];
185
+ }
186
+ function handlerToMiddleware(handler) {
187
+ return async ({ next, ...rest }) => ({
188
+ response: await handler(rest)
189
+ });
190
+ }
191
+ function executeMiddleware(middlewares, ctx) {
192
+ let index = -1;
193
+ const next = async (ctx2) => {
194
+ index++;
195
+ const middleware = middlewares[index];
196
+ if (!middleware) return ctx2;
197
+ const result = await middleware({
198
+ ...ctx2,
199
+ // Allow the middleware to call the next middleware in the chain
200
+ next: async (nextCtx) => {
201
+ const nextResult = await next({ ...ctx2, ...nextCtx });
202
+ return Object.assign(ctx2, handleCtxResult(nextResult));
203
+ }
204
+ // Allow the middleware result to extend the return context
205
+ }).catch((err) => {
206
+ if (isSpecialResponse(err)) {
207
+ return {
208
+ response: err
209
+ };
210
+ }
211
+ throw err;
212
+ });
213
+ return Object.assign(ctx2, handleCtxResult(result));
214
+ };
215
+ return handleCtxResult(next(ctx));
216
+ }
217
+ function handleCtxResult(result) {
218
+ if (isSpecialResponse(result)) {
219
+ return {
220
+ response: result
221
+ };
222
+ }
223
+ return result;
224
+ }
225
+ function isSpecialResponse(err) {
226
+ return err instanceof Response || isRedirect(err);
227
+ }
228
+ export {
229
+ createStartHandler,
230
+ getStartResponseHeaders
231
+ };
232
+ //# sourceMappingURL=createStartHandler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createStartHandler.js","sources":["../../src/createStartHandler.ts"],"sourcesContent":["import path from 'node:path'\nimport { createMemoryHistory } from '@tanstack/history'\nimport {\n flattenMiddlewares,\n json,\n mergeHeaders,\n} from '@tanstack/start-client-core'\nimport {\n getMatchedRoutes,\n isRedirect,\n processRouteTree,\n rootRouteId,\n tsrRedirectHeaderKey,\n} from '@tanstack/router-core'\nimport { getResponseHeaders, requestHandler } from './h3'\nimport { attachRouterServerSsrUtils, dehydrateRouter } from './ssr-server'\nimport { getStartManifest } from './router-manifest'\nimport { handleServerAction } from './server-functions-handler'\nimport type { AnyServerRoute, AnyServerRouteWithTypes } from './serverRoute'\nimport type { RequestHandler } from './h3'\nimport type { AnyRouter } from '@tanstack/router-core'\nimport type { HandlerCallback } from './handlerCallback'\n\ntype TODO = any\n\nexport type CustomizeStartHandler<TRouter extends AnyRouter> = (\n cb: HandlerCallback<TRouter>,\n) => RequestHandler\n\nexport function getStartResponseHeaders(opts: { router: AnyRouter }) {\n let headers = mergeHeaders(\n getResponseHeaders(),\n {\n 'Content-Type': 'text/html; charset=UTF-8',\n },\n ...opts.router.state.matches.map((match) => {\n return match.headers\n }),\n )\n // Handle Redirects\n const { redirect } = opts.router.state\n\n if (redirect) {\n headers = mergeHeaders(headers, redirect.headers)\n }\n return headers\n}\n\nexport function createStartHandler<TRouter extends AnyRouter>({\n createRouter,\n}: {\n createRouter: () => TRouter\n}): CustomizeStartHandler<TRouter> {\n return (cb) => {\n return requestHandler(async ({ request }) => {\n const url = new URL(request.url)\n const href = url.href.replace(url.origin, '')\n\n // Create a history for the client-side router\n const history = createMemoryHistory({\n initialEntries: [href],\n })\n\n // Create the client-side router\n const router = createRouter()\n\n // Attach the server-side SSR utils to the client-side router\n attachRouterServerSsrUtils(router, getStartManifest())\n\n // Update the client-side router with the history and context\n router.update({\n history,\n })\n\n const response = await (async () => {\n try {\n if (!process.env.TSS_SERVER_FN_BASE) {\n throw new Error(\n 'tanstack/start-server-core: TSS_SERVER_FN_BASE must be defined in your environment for createStartHandler()',\n )\n }\n\n // First, let's attempt to handle server functions\n if (\n href.startsWith(path.join('/', process.env.TSS_SERVER_FN_BASE, '/'))\n ) {\n return await handleServerAction({ request })\n }\n\n // Then move on to attempting to load server routes\n const serverRouteTreeModule = await (async () => {\n try {\n // @ts-expect-error\n return (await import('tanstack:server-routes')) as {\n routeTree: AnyServerRoute\n }\n } catch (e) {\n console.log(e)\n return undefined\n }\n })()\n\n // If we have a server route tree, then we try matching to see if we have a\n // server route that matches the request.\n if (serverRouteTreeModule) {\n const [matchedRoutes, response] = await handleServerRoutes({\n routeTree: serverRouteTreeModule.routeTree,\n request,\n })\n\n if (response) return response\n }\n\n const requestAcceptHeader = request.headers.get('Accept') || '*/*'\n const splitRequestAcceptHeader = requestAcceptHeader.split(',')\n\n const supportedMimeTypes = ['*/*', 'text/html']\n const isRouterAcceptSupported = supportedMimeTypes.some((mimeType) =>\n splitRequestAcceptHeader.some((acceptedMimeType) =>\n acceptedMimeType.trim().startsWith(mimeType),\n ),\n )\n\n if (!isRouterAcceptSupported) {\n return json(\n {\n error: 'Only HTML requests are supported here',\n },\n {\n status: 500,\n },\n )\n }\n\n // If no Server Routes were found, so fallback to normal SSR matching using\n // the router\n\n await router.load()\n\n // If there was a redirect, skip rendering the page at all\n if (router.state.redirect) return router.state.redirect\n\n dehydrateRouter(router)\n\n const responseHeaders = getStartResponseHeaders({ router })\n const response = await cb({\n request,\n router,\n responseHeaders,\n })\n\n return response\n } catch (err) {\n if (err instanceof Response) {\n return err\n }\n\n throw err\n }\n })()\n\n if (isRedirect(response)) {\n if (\n response.options.to &&\n typeof response.options.to === 'string' &&\n !response.options.to.startsWith('/')\n ) {\n throw new Error(\n `Server side redirects must use absolute paths via the 'href' or 'to' options. Received: ${JSON.stringify(response.options)}`,\n )\n }\n\n if (\n ['params', 'search', 'hash'].some(\n (d) => typeof (response.options as any)[d] === 'function',\n )\n ) {\n throw new Error(\n `Server side redirects must use static search, params, and hash values and do not support functional values. Received functional values for: ${Object.keys(\n response.options,\n )\n .filter((d) => typeof (response.options as any)[d] === 'function')\n .map((d) => `\"${d}\"`)\n .join(', ')}`,\n )\n }\n\n const redirect = router.resolveRedirect(response)\n\n if (request.headers.get('x-tsr-redirect') === 'manual') {\n return json(\n {\n ...response.options,\n isSerializedRedirect: true,\n },\n {\n headers: redirect.headers,\n },\n )\n }\n\n return redirect\n }\n\n response.headers.append(\n 'Access-Control-Expose-Headers',\n tsrRedirectHeaderKey,\n )\n\n return response\n })\n }\n}\n\nasync function handleServerRoutes({\n routeTree,\n request,\n}: {\n routeTree: AnyServerRouteWithTypes\n request: Request\n}) {\n const { flatRoutes, routesById, routesByPath } = processRouteTree({\n routeTree,\n initRoute: (route, i) => {\n route.init({\n originalIndex: i,\n })\n },\n })\n\n const url = new URL(request.url)\n const pathname = url.pathname\n\n const history = createMemoryHistory({\n initialEntries: [pathname],\n })\n\n const { matchedRoutes, foundRoute, routeParams } =\n getMatchedRoutes<AnyServerRouteWithTypes>({\n pathname: history.location.pathname,\n basepath: '/',\n caseSensitive: true,\n routesByPath,\n routesById,\n flatRoutes,\n })\n\n let response: Response | undefined\n\n if (foundRoute && foundRoute.id !== rootRouteId) {\n // We've found a server route that matches the request, so we can call it.\n // TODO: Get the input type-signature correct\n // TODO: Perform the middlewares?\n // TODO: Error handling? What happens when its `throw redirect()` vs `throw new Error()`?\n\n const method = Object.keys(foundRoute.options.methods).find(\n (method) => method.toLowerCase() === request.method.toLowerCase(),\n )\n\n if (method) {\n const handler = foundRoute.options.methods[method]\n\n if (handler) {\n const middlewares = flattenMiddlewares(\n matchedRoutes.flatMap((r) => r.options.middleware).filter(Boolean),\n ).map((d) => d.options.server)\n\n middlewares.push(handlerToMiddleware(handler) as TODO)\n\n // TODO: This is starting to feel too much like a server function\n // Do generalize the existing middleware execution? Or do we need to\n // build a new middleware execution system for server routes?\n const ctx = await executeMiddleware(middlewares, {\n request,\n context: {},\n params: routeParams,\n pathname: history.location.pathname,\n })\n\n response = ctx.response\n }\n }\n }\n\n // We return the matched routes too so if\n // the app router happens to match the same path,\n // it can use any request middleware from server routes\n return [matchedRoutes, response] as const\n}\n\nfunction handlerToMiddleware(\n handler: AnyServerRouteWithTypes['options']['methods'][string],\n) {\n return async ({ next, ...rest }: TODO) => ({\n response: await handler(rest),\n })\n}\n\nfunction executeMiddleware(middlewares: TODO, ctx: TODO) {\n let index = -1\n\n const next = async (ctx: TODO) => {\n index++\n const middleware = middlewares[index]\n if (!middleware) return ctx\n\n const result = await middleware({\n ...ctx,\n // Allow the middleware to call the next middleware in the chain\n next: async (nextCtx: TODO) => {\n // Allow the caller to extend the context for the next middleware\n const nextResult = await next({ ...ctx, ...nextCtx })\n\n // Merge the result into the context\\\n return Object.assign(ctx, handleCtxResult(nextResult))\n },\n // Allow the middleware result to extend the return context\n }).catch((err: TODO) => {\n if (isSpecialResponse(err)) {\n return {\n response: err,\n }\n }\n\n throw err\n })\n\n // Merge the middleware result into the context, just in case it\n // returns a partial context\n return Object.assign(ctx, handleCtxResult(result))\n }\n\n return handleCtxResult(next(ctx))\n}\n\nfunction handleCtxResult(result: TODO) {\n if (isSpecialResponse(result)) {\n return {\n response: result,\n }\n }\n\n return result\n}\n\nfunction isSpecialResponse(err: TODO) {\n return err instanceof Response || isRedirect(err)\n}\n"],"names":["response","method","ctx"],"mappings":"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"}
@@ -0,0 +1,109 @@
1
+ import { H3Event, appendCorsHeaders as _appendCorsHeaders, appendCorsPreflightHeaders as _appendCorsPreflightHeaders, appendHeader as _appendHeader, appendResponseHeader as _appendResponseHeader, appendResponseHeaders as _appendResponseHeaders, assertMethod as _assertMethod, clearResponseHeaders as _clearResponseHeaders, clearSession as _clearSession, defaultContentType as _defaultContentType, deleteCookie as _deleteCookie, fetchWithEvent as _fetchWithEvent, getCookie as _getCookie, getProxyRequestHeaders as _getProxyRequestHeaders, getQuery as _getQuery, getRequestFingerprint as _getRequestFingerprint, getRequestHeader as _getRequestHeader, getRequestHeaders as _getRequestHeaders, getRequestHost as _getRequestHost, getRequestIP as _getRequestIP, getRequestProtocol as _getRequestProtocol, getRequestURL as _getRequestURL, getRequestWebStream as _getRequestWebStream, getResponseHeader as _getResponseHeader, getResponseHeaders as _getResponseHeaders, getResponseStatus as _getResponseStatus, getResponseStatusText as _getResponseStatusText, getRouterParam as _getRouterParam, getRouterParams as _getRouterParams, getSession as _getSession, getValidatedQuery as _getValidatedQuery, getValidatedRouterParams as _getValidatedRouterParams, handleCacheHeaders as _handleCacheHeaders, handleCors as _handleCors, isMethod as _isMethod, isPreflightRequest as _isPreflightRequest, parseCookies as _parseCookies, proxyRequest as _proxyRequest, readBody as _readBody, readFormData as _readFormData, readMultipartFormData as _readMultipartFormData, readRawBody as _readRawBody, readValidatedBody as _readValidatedBody, removeResponseHeader as _removeResponseHeader, sealSession as _sealSession, send as _send, sendError as _sendError, sendNoContent as _sendNoContent, sendProxy as _sendProxy, sendRedirect as _sendRedirect, sendStream as _sendStream, sendWebResponse as _sendWebResponse, setCookie as _setCookie, setHeader as _setHeader, setResponseHeader as _setResponseHeader, setResponseHeaders as _setResponseHeaders, setResponseStatus as _setResponseStatus, toWebRequest as _toWebRequest, unsealSession as _unsealSession, updateSession as _updateSession, useSession as _useSession, writeEarlyHints as _writeEarlyHints, Encoding, EventHandler, HTTPHeaderName, InferEventInput, _RequestMiddleware, _ResponseMiddleware } from 'h3';
2
+ declare function _setContext(event: H3Event, key: string, value: any): void;
3
+ declare function _getContext(event: H3Event, key: string): any;
4
+ export declare function defineMiddleware(options: {
5
+ onRequest?: _RequestMiddleware | Array<_RequestMiddleware>;
6
+ onBeforeResponse?: _ResponseMiddleware | Array<_ResponseMiddleware>;
7
+ }): {
8
+ onRequest?: _RequestMiddleware | Array<_RequestMiddleware>;
9
+ onBeforeResponse?: _ResponseMiddleware | Array<_ResponseMiddleware>;
10
+ };
11
+ export { H3Error, H3Event, MIMES, callNodeListener, createApp, createAppEventHandler, createEvent, createRouter, defineLazyEventHandler, defineNodeListener, defineNodeMiddleware, defineRequestMiddleware, defineResponseMiddleware, dynamicEventHandler, defineWebSocket, splitCookiesString, fromNodeMiddleware, fromPlainHandler, fromWebHandler, isError, isEventHandler, isWebResponse, lazyEventHandler, promisifyNodeListener, serveStatic, toEventHandler, toNodeListener, toPlainHandler, toWebHandler, toWebRequest, isCorsOriginAllowed, isStream, createError, sanitizeStatusCode, sanitizeStatusMessage, useBase, type AddRouteShortcuts, type App, type AppOptions, type AppUse, type CacheConditions, type CreateRouterOptions, type Duplex, type DynamicEventHandler, type Encoding, type EventHandler, type EventHandlerObject, type EventHandlerRequest, type EventHandlerResponse, type H3CorsOptions, type H3EventContext, type HTTPHeaderName, type HTTPMethod, type InferEventInput, type InputLayer, type InputStack, type Layer, type LazyEventHandler, type Matcher, type MultiPartData, type NodeEventContext, type NodeListener, type NodeMiddleware, type NodePromisifiedHandler, type PlainHandler, type PlainRequest, type PlainResponse, type ProxyOptions, type RequestFingerprintOptions, type RequestHeaders, type RouteNode, type Router, type RouterMethod, type RouterUse, type ServeStaticOptions, type Session, type SessionConfig, type SessionData, type Stack, type StaticAssetMeta, type ValidateFunction, type ValidateResult, type WebEventContext, type WebHandler, type _RequestMiddleware, type _ResponseMiddleware, } from 'h3';
12
+ export declare function defineEventHandler(handler: EventHandler): EventHandler<import('h3').EventHandlerRequest, Promise<any>>;
13
+ export declare function eventHandler(handler: EventHandler): EventHandler<import('h3').EventHandlerRequest, Promise<any>>;
14
+ export declare function runWithEvent<T>(event: H3Event, fn: () => T | Promise<T>): Promise<T>;
15
+ export declare function getEvent(): H3Event<import('h3').EventHandlerRequest>;
16
+ export declare const HTTPEventSymbol: unique symbol;
17
+ export declare function isEvent(obj: any): obj is H3Event | {
18
+ [HTTPEventSymbol]: H3Event;
19
+ };
20
+ type Tail<T> = T extends [any, ...infer U] ? U : never;
21
+ type PrependOverload<TOriginal extends (...args: Array<any>) => any, TOverload extends (...args: Array<any>) => any> = TOverload & TOriginal;
22
+ type WrapFunction<TFn extends (...args: Array<any>) => any> = PrependOverload<TFn, (...args: Parameters<TFn> extends [H3Event, ...infer TArgs] ? TArgs : Parameters<TFn>) => ReturnType<TFn>>;
23
+ type WrappedReadRawBody = <TEncoding extends Encoding = 'utf8'>(...args: Tail<Parameters<typeof _readRawBody<TEncoding>>>) => ReturnType<typeof _readRawBody<TEncoding>>;
24
+ export declare const readRawBody: PrependOverload<typeof _readRawBody, WrappedReadRawBody>;
25
+ type WrappedReadBody = <T, TEventInput = InferEventInput<'body', H3Event, T>>(...args: Tail<Parameters<typeof _readBody<T, H3Event, TEventInput>>>) => ReturnType<typeof _readBody<T, H3Event, TEventInput>>;
26
+ export declare const readBody: PrependOverload<typeof _readBody, WrappedReadBody>;
27
+ type WrappedGetQuery = <T, TEventInput = Exclude<InferEventInput<'query', H3Event, T>, undefined>>(...args: Tail<Parameters<typeof _getQuery<T, H3Event, TEventInput>>>) => ReturnType<typeof _getQuery<T, H3Event, TEventInput>>;
28
+ export declare const getQuery: PrependOverload<typeof _getQuery, WrappedGetQuery>;
29
+ export declare const isMethod: WrapFunction<typeof _isMethod>;
30
+ export declare const isPreflightRequest: WrapFunction<typeof _isPreflightRequest>;
31
+ type WrappedGetValidatedQuery = <T, TEventInput = InferEventInput<'query', H3Event, T>>(...args: Tail<Parameters<typeof _getValidatedQuery<T, H3Event, TEventInput>>>) => ReturnType<typeof _getValidatedQuery<T, H3Event, TEventInput>>;
32
+ export declare const getValidatedQuery: PrependOverload<typeof _getValidatedQuery, WrappedGetValidatedQuery>;
33
+ export declare const getRouterParams: WrapFunction<typeof _getRouterParams>;
34
+ export declare const getRouterParam: WrapFunction<typeof _getRouterParam>;
35
+ type WrappedGetValidatedRouterParams = <T, TEventInput = InferEventInput<'routerParams', H3Event, T>>(...args: Tail<Parameters<typeof _getValidatedRouterParams<T, H3Event, TEventInput>>>) => ReturnType<typeof _getValidatedRouterParams<T, H3Event, TEventInput>>;
36
+ export declare const getValidatedRouterParams: PrependOverload<typeof _getValidatedRouterParams, WrappedGetValidatedRouterParams>;
37
+ export declare const assertMethod: WrapFunction<typeof _assertMethod>;
38
+ export declare const getRequestHeaders: WrapFunction<typeof _getRequestHeaders>;
39
+ export declare const getRequestHeader: WrapFunction<typeof _getRequestHeader>;
40
+ export declare const getRequestURL: WrapFunction<typeof _getRequestURL>;
41
+ export declare const getRequestHost: WrapFunction<typeof _getRequestHost>;
42
+ export declare const getRequestProtocol: WrapFunction<typeof _getRequestProtocol>;
43
+ export declare const getRequestIP: WrapFunction<typeof _getRequestIP>;
44
+ export declare const send: WrapFunction<typeof _send>;
45
+ export declare const sendNoContent: WrapFunction<typeof _sendNoContent>;
46
+ export declare const setResponseStatus: WrapFunction<typeof _setResponseStatus>;
47
+ export declare const getResponseStatus: WrapFunction<typeof _getResponseStatus>;
48
+ export declare const getResponseStatusText: WrapFunction<typeof _getResponseStatusText>;
49
+ export declare const getResponseHeaders: WrapFunction<typeof _getResponseHeaders>;
50
+ export declare const getResponseHeader: WrapFunction<typeof _getResponseHeader>;
51
+ export declare const setResponseHeaders: WrapFunction<typeof _setResponseHeaders>;
52
+ type WrappedSetResponseHeader = <T extends HTTPHeaderName>(...args: Tail<Parameters<typeof _setResponseHeader<T>>>) => ReturnType<typeof _setResponseHeader<T>>;
53
+ export declare const setResponseHeader: PrependOverload<typeof _setResponseHeader, WrappedSetResponseHeader>;
54
+ export declare const appendResponseHeaders: WrapFunction<typeof _appendResponseHeaders>;
55
+ type WrappedAppendResponseHeader = <T extends HTTPHeaderName>(...args: Tail<Parameters<typeof _appendResponseHeader<T>>>) => ReturnType<typeof _appendResponseHeader<T>>;
56
+ export declare const appendResponseHeader: PrependOverload<typeof _appendResponseHeader, WrappedAppendResponseHeader>;
57
+ export declare const defaultContentType: WrapFunction<typeof _defaultContentType>;
58
+ export declare const sendRedirect: WrapFunction<typeof _sendRedirect>;
59
+ export declare const sendStream: WrapFunction<typeof _sendStream>;
60
+ export declare const writeEarlyHints: WrapFunction<typeof _writeEarlyHints>;
61
+ export declare const sendError: WrapFunction<typeof _sendError>;
62
+ export declare const sendProxy: WrapFunction<typeof _sendProxy>;
63
+ export declare const proxyRequest: WrapFunction<typeof _proxyRequest>;
64
+ type WrappedFetchWithEvent = <T = unknown, TResponse = any, TFetch extends (req: RequestInfo | URL, opts?: any) => any = typeof fetch>(...args: Tail<Parameters<typeof _fetchWithEvent<T, TResponse, TFetch>>>) => ReturnType<typeof _fetchWithEvent<T, TResponse, TFetch>>;
65
+ export declare const fetchWithEvent: PrependOverload<typeof _fetchWithEvent, WrappedFetchWithEvent>;
66
+ export declare const getProxyRequestHeaders: WrapFunction<typeof _getProxyRequestHeaders>;
67
+ export declare const parseCookies: WrapFunction<typeof _parseCookies>;
68
+ export declare const getCookie: WrapFunction<typeof _getCookie>;
69
+ export declare const setCookie: WrapFunction<typeof _setCookie>;
70
+ export declare const deleteCookie: WrapFunction<typeof _deleteCookie>;
71
+ type SessionDataT = Record<string, any>;
72
+ type WrappedUseSession = <T extends SessionDataT>(...args: Tail<Parameters<typeof _useSession<T>>>) => ReturnType<typeof _useSession<T>>;
73
+ export declare const useSession: PrependOverload<typeof _useSession, WrappedUseSession>;
74
+ type WrappedGetSession = <T extends SessionDataT>(...args: Tail<Parameters<typeof _getSession<T>>>) => ReturnType<typeof _getSession<T>>;
75
+ export declare const getSession: PrependOverload<typeof _getSession, WrappedGetSession>;
76
+ type WrappedUpdateSession = <T extends SessionDataT>(...args: Tail<Parameters<typeof _updateSession<T>>>) => ReturnType<typeof _updateSession<T>>;
77
+ export declare const updateSession: PrependOverload<typeof _updateSession, WrappedUpdateSession>;
78
+ type WrappedSealSession = <T extends SessionDataT>(...args: Tail<Parameters<typeof _sealSession<T>>>) => ReturnType<typeof _sealSession<T>>;
79
+ export declare const sealSession: PrependOverload<typeof _sealSession, WrappedSealSession>;
80
+ export declare const unsealSession: WrapFunction<typeof _unsealSession>;
81
+ export declare const clearSession: WrapFunction<typeof _clearSession>;
82
+ export declare const handleCacheHeaders: WrapFunction<typeof _handleCacheHeaders>;
83
+ export declare const handleCors: WrapFunction<typeof _handleCors>;
84
+ export declare const appendCorsHeaders: WrapFunction<typeof _appendCorsHeaders>;
85
+ export declare const appendCorsPreflightHeaders: WrapFunction<typeof _appendCorsPreflightHeaders>;
86
+ export declare const sendWebResponse: WrapFunction<typeof _sendWebResponse>;
87
+ type WrappedAppendHeader = <T extends HTTPHeaderName>(...args: Tail<Parameters<typeof _appendHeader<T>>>) => ReturnType<typeof _appendHeader<T>>;
88
+ export declare const appendHeader: PrependOverload<typeof _appendHeader, WrappedAppendHeader>;
89
+ export declare const appendHeaders: WrapFunction<typeof _appendResponseHeaders>;
90
+ type WrappedSetHeader = <T extends HTTPHeaderName>(...args: Tail<Parameters<typeof _setHeader<T>>>) => ReturnType<typeof _setHeader<T>>;
91
+ export declare const setHeader: PrependOverload<typeof _setHeader, WrappedSetHeader>;
92
+ export declare const setHeaders: WrapFunction<typeof _setResponseHeaders>;
93
+ export declare const getHeader: WrapFunction<typeof _getRequestHeader>;
94
+ export declare const getHeaders: WrapFunction<typeof _getRequestHeaders>;
95
+ export declare const getRequestFingerprint: WrapFunction<typeof _getRequestFingerprint>;
96
+ export declare const getRequestWebStream: WrapFunction<typeof _getRequestWebStream>;
97
+ export declare const readFormData: WrapFunction<typeof _readFormData>;
98
+ export declare const readMultipartFormData: WrapFunction<typeof _readMultipartFormData>;
99
+ type WrappedReadValidatedBody = <T, TEventInput = InferEventInput<'body', H3Event, T>>(...args: Tail<Parameters<typeof _readValidatedBody<T, H3Event, TEventInput>>>) => ReturnType<typeof _readValidatedBody<T, H3Event, TEventInput>>;
100
+ export declare const readValidatedBody: PrependOverload<typeof _readValidatedBody, WrappedReadValidatedBody>;
101
+ export declare const removeResponseHeader: WrapFunction<typeof _removeResponseHeader>;
102
+ export declare const getContext: WrapFunction<typeof _getContext>;
103
+ export declare const setContext: WrapFunction<typeof _setContext>;
104
+ export declare const clearResponseHeaders: WrapFunction<typeof _clearResponseHeaders>;
105
+ export declare const getWebRequest: WrapFunction<typeof _toWebRequest>;
106
+ export type RequestHandler = (ctx: {
107
+ request: Request;
108
+ }) => Promise<Response> | Response;
109
+ export declare function requestHandler(handler: RequestHandler): RequestHandler;