one 1.1.345-1734464750388 → 1.1.346
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.
- package/dist/cjs/cli.cjs +5 -1
- package/dist/cjs/cli.js +5 -1
- package/dist/cjs/cli.js.map +1 -1
- package/dist/cjs/cli.native.js +5 -1
- package/dist/cjs/cli.native.js.map +2 -2
- package/dist/cjs/config.cjs +6 -6
- package/dist/cjs/config.js +3 -3
- package/dist/cjs/config.js.map +1 -1
- package/dist/cjs/config.native.js +3 -3
- package/dist/cjs/config.native.js.map +2 -2
- package/dist/cjs/serve-worker.cjs +34 -0
- package/dist/cjs/serve-worker.js +26 -0
- package/dist/cjs/serve-worker.js.map +6 -0
- package/dist/cjs/serve-worker.native.js +31 -0
- package/dist/cjs/serve-worker.native.js.map +6 -0
- package/dist/cjs/serve.cjs +17 -142
- package/dist/cjs/serve.js +9 -139
- package/dist/cjs/serve.js.map +2 -2
- package/dist/cjs/serve.native.js +8 -148
- package/dist/cjs/serve.native.js.map +2 -2
- package/dist/cjs/server/oneServe.cjs +173 -0
- package/dist/cjs/server/oneServe.js +160 -0
- package/dist/cjs/server/oneServe.js.map +6 -0
- package/dist/cjs/server/oneServe.native.js +174 -0
- package/dist/cjs/server/oneServe.native.js.map +6 -0
- package/dist/cjs/server/setupBuildOptions.cjs +28 -0
- package/dist/cjs/server/setupBuildOptions.js +23 -0
- package/dist/cjs/server/setupBuildOptions.js.map +6 -0
- package/dist/cjs/server/setupBuildOptions.native.js +29 -0
- package/dist/cjs/server/setupBuildOptions.native.js.map +6 -0
- package/dist/cjs/utils/ensureExists.cjs +28 -0
- package/dist/cjs/utils/ensureExists.js +24 -0
- package/dist/cjs/utils/ensureExists.js.map +6 -0
- package/dist/cjs/utils/ensureExists.native.js +29 -0
- package/dist/cjs/utils/ensureExists.native.js.map +6 -0
- package/dist/cjs/vite/build.cjs +38 -18
- package/dist/cjs/vite/build.js +38 -14
- package/dist/cjs/vite/build.js.map +1 -1
- package/dist/cjs/vite/build.native.js +29 -15
- package/dist/cjs/vite/build.native.js.map +2 -2
- package/dist/cjs/vite/one.cjs +4 -4
- package/dist/cjs/vite/one.js +3 -2
- package/dist/cjs/vite/one.js.map +1 -1
- package/dist/cjs/vite/one.native.js +3 -2
- package/dist/cjs/vite/one.native.js.map +2 -2
- package/dist/esm/cli.js +5 -1
- package/dist/esm/cli.js.map +1 -1
- package/dist/esm/cli.mjs +5 -1
- package/dist/esm/cli.mjs.map +1 -1
- package/dist/esm/cli.native.js +5 -1
- package/dist/esm/cli.native.js.map +2 -2
- package/dist/esm/config.js +3 -3
- package/dist/esm/config.js.map +1 -1
- package/dist/esm/config.mjs +6 -6
- package/dist/esm/config.mjs.map +1 -1
- package/dist/esm/config.native.js +3 -3
- package/dist/esm/config.native.js.map +2 -2
- package/dist/esm/serve-worker.js +13 -0
- package/dist/esm/serve-worker.js.map +6 -0
- package/dist/esm/serve-worker.mjs +11 -0
- package/dist/esm/serve-worker.mjs.map +1 -0
- package/dist/esm/serve-worker.native.js +13 -0
- package/dist/esm/serve-worker.native.js.map +6 -0
- package/dist/esm/serve.js +10 -140
- package/dist/esm/serve.js.map +2 -2
- package/dist/esm/serve.mjs +17 -142
- package/dist/esm/serve.mjs.map +1 -1
- package/dist/esm/serve.native.js +9 -149
- package/dist/esm/serve.native.js.map +2 -2
- package/dist/esm/server/oneServe.js +137 -0
- package/dist/esm/server/oneServe.js.map +6 -0
- package/dist/esm/server/oneServe.mjs +139 -0
- package/dist/esm/server/oneServe.mjs.map +1 -0
- package/dist/esm/server/oneServe.native.js +146 -0
- package/dist/esm/server/oneServe.native.js.map +6 -0
- package/dist/esm/server/setupBuildOptions.js +7 -0
- package/dist/esm/server/setupBuildOptions.js.map +6 -0
- package/dist/esm/server/setupBuildOptions.mjs +5 -0
- package/dist/esm/server/setupBuildOptions.mjs.map +1 -0
- package/dist/esm/server/setupBuildOptions.native.js +8 -0
- package/dist/esm/server/setupBuildOptions.native.js.map +6 -0
- package/dist/esm/utils/ensureExists.js +8 -0
- package/dist/esm/utils/ensureExists.js.map +6 -0
- package/dist/esm/utils/ensureExists.mjs +5 -0
- package/dist/esm/utils/ensureExists.mjs.map +1 -0
- package/dist/esm/utils/ensureExists.native.js +8 -0
- package/dist/esm/utils/ensureExists.native.js.map +6 -0
- package/dist/esm/vite/build.js +38 -14
- package/dist/esm/vite/build.js.map +1 -1
- package/dist/esm/vite/build.mjs +38 -18
- package/dist/esm/vite/build.mjs.map +1 -1
- package/dist/esm/vite/build.native.js +29 -15
- package/dist/esm/vite/build.native.js.map +2 -2
- package/dist/esm/vite/one.js +3 -2
- package/dist/esm/vite/one.js.map +1 -1
- package/dist/esm/vite/one.mjs +4 -4
- package/dist/esm/vite/one.mjs.map +1 -1
- package/dist/esm/vite/one.native.js +3 -2
- package/dist/esm/vite/one.native.js.map +2 -2
- package/package.json +14 -9
- package/src/cli.ts +4 -0
- package/src/config.ts +2 -3
- package/src/serve-worker.ts +19 -0
- package/src/serve.ts +13 -217
- package/src/server/oneServe.ts +216 -0
- package/src/server/setupBuildOptions.ts +7 -0
- package/src/utils/ensureExists.ts +5 -0
- package/src/vite/build.ts +43 -23
- package/src/vite/one.ts +2 -3
- package/src/vite/types.ts +2 -3
- package/types/config.d.ts.map +1 -1
- package/types/serve-worker.d.ts +3 -0
- package/types/serve-worker.d.ts.map +1 -0
- package/types/serve.d.ts +1 -1
- package/types/serve.d.ts.map +1 -1
- package/types/server/oneServe.d.ts +5 -0
- package/types/server/oneServe.d.ts.map +1 -0
- package/types/server/setupBuildOptions.d.ts +3 -0
- package/types/server/setupBuildOptions.d.ts.map +1 -0
- package/types/utils/ensureExists.d.ts +2 -0
- package/types/utils/ensureExists.d.ts.map +1 -0
- package/types/vite/build.d.ts.map +1 -1
- package/types/vite/one.d.ts.map +1 -1
- package/types/vite/types.d.ts +2 -2
- package/types/vite/types.d.ts.map +1 -1
package/dist/esm/serve.js
CHANGED
@@ -1,17 +1,15 @@
|
|
1
1
|
import "./polyfills-server";
|
2
2
|
import FSExtra from "fs-extra";
|
3
|
-
import {
|
4
|
-
import {
|
3
|
+
import { setupBuildInfo } from "./server/setupBuildOptions";
|
4
|
+
import { ensureExists } from "./utils/ensureExists";
|
5
5
|
process.on("uncaughtException", (err) => {
|
6
6
|
console.error("[one] Uncaught exception", err?.stack || err);
|
7
7
|
});
|
8
8
|
async function serve(args = {}) {
|
9
|
-
const buildInfo = await FSExtra.readJSON("dist/buildInfo.json");
|
10
|
-
|
11
|
-
const { labelProcess } = await import("./cli/label-process"), { removeUndefined } = await import("./utils/removeUndefined"), {
|
12
|
-
labelProcess("serve"), loadEnv("production")
|
13
|
-
const oneOptions = await loadUserOneOptions("serve");
|
14
|
-
return process.env.VXRN_REACT_19 = "1", await vxrnServe({
|
9
|
+
const buildInfo = await FSExtra.readJSON("dist/buildInfo.json"), { oneOptions } = buildInfo;
|
10
|
+
setupBuildInfo(buildInfo), ensureExists(oneOptions);
|
11
|
+
const { labelProcess } = await import("./cli/label-process"), { removeUndefined } = await import("./utils/removeUndefined"), { loadEnv, serve: vxrnServe } = await import("vxrn/serve"), { oneServe } = await import("./server/oneServe");
|
12
|
+
return labelProcess("serve"), args.loadEnv && await loadEnv("production"), process.env.VXRN_REACT_19 = "1", await vxrnServe({
|
15
13
|
server: {
|
16
14
|
// fallback to one plugin
|
17
15
|
...oneOptions.server,
|
@@ -22,141 +20,13 @@ async function serve(args = {}) {
|
|
22
20
|
compress: args.compress,
|
23
21
|
platform: args.platform,
|
24
22
|
cacheHeaders: args.cacheHeaders
|
25
|
-
})
|
26
|
-
|
27
|
-
|
28
|
-
|
23
|
+
})
|
24
|
+
},
|
25
|
+
async beforeStart(options, app) {
|
26
|
+
await oneServe(oneOptions, options, buildInfo, app);
|
29
27
|
}
|
30
28
|
});
|
31
29
|
}
|
32
|
-
async function oneServe(options, vxrnOptions, buildInfo, app) {
|
33
|
-
const { createHandleRequest } = await import("./createHandleRequest"), { isResponse } = await import("./utils/isResponse"), { isStatusRedirect } = await import("./utils/isStatus"), { resolveAPIRequest } = await import("./vite/resolveAPIRequest"), isAPIRequest = /* @__PURE__ */ new WeakMap(), root = vxrnOptions.root || ".", redirects = options.web?.redirects;
|
34
|
-
if (redirects)
|
35
|
-
for (const redirect of redirects)
|
36
|
-
app.get(redirect.source, (context) => {
|
37
|
-
const destinationUrl = redirect.destination.replace(/:\w+/g, (param) => {
|
38
|
-
const paramName = param.substring(1);
|
39
|
-
return context.req.param(paramName) || "";
|
40
|
-
});
|
41
|
-
return context.redirect(destinationUrl, redirect.permanent ? 301 : 302);
|
42
|
-
});
|
43
|
-
if (!buildInfo)
|
44
|
-
throw new Error("No build info found, have you run build?");
|
45
|
-
const { routeMap, builtRoutes } = buildInfo, routeToBuildInfo = {};
|
46
|
-
for (const route of builtRoutes) {
|
47
|
-
routeToBuildInfo[route.cleanPath] = route;
|
48
|
-
const bracketRoutePath = route.cleanPath.split("/").map((part) => part[0] === ":" ? `[${part.slice(1)}]` : part).join("/");
|
49
|
-
routeToBuildInfo[bracketRoutePath] = route;
|
50
|
-
}
|
51
|
-
const serverOptions = {
|
52
|
-
...options,
|
53
|
-
root
|
54
|
-
}, render = (await import(getServerEntry(serverOptions))).default.render, apiCJS = options.build?.api?.outputFormat === "cjs", handleRequest = createHandleRequest(
|
55
|
-
{},
|
56
|
-
{
|
57
|
-
async handleAPI({ route, request, loaderProps }) {
|
58
|
-
const apiFile = join(
|
59
|
-
process.cwd(),
|
60
|
-
"dist",
|
61
|
-
"api",
|
62
|
-
route.page.replace("[", "_").replace("]", "_") + (apiCJS ? ".cjs" : ".js")
|
63
|
-
);
|
64
|
-
return isAPIRequest.set(request, !0), resolveAPIRequest(
|
65
|
-
async () => {
|
66
|
-
try {
|
67
|
-
return await import(apiFile);
|
68
|
-
} catch (err) {
|
69
|
-
return console.error(`
|
70
|
-
[one] Error importing API route at ${apiFile}:
|
71
|
-
|
72
|
-
${err}
|
73
|
-
|
74
|
-
If this is an import error, you can likely fix this by adding this dependency to
|
75
|
-
the "optimizeDeps.include" array in your vite.config.ts.
|
76
|
-
|
77
|
-
\u{1F41E} For a better error message run "node" and enter:
|
78
|
-
|
79
|
-
import('${apiFile}')
|
80
|
-
|
81
|
-
`), {};
|
82
|
-
}
|
83
|
-
},
|
84
|
-
request,
|
85
|
-
loaderProps?.params || {}
|
86
|
-
);
|
87
|
-
},
|
88
|
-
async handleSSR({ route, url, loaderProps }) {
|
89
|
-
if (route.type === "ssr") {
|
90
|
-
const buildInfo2 = routeToBuildInfo[route.page];
|
91
|
-
if (!buildInfo2)
|
92
|
-
throw new Error(
|
93
|
-
`No buildinfo found for ${url}, route: ${route.page}, in keys: ${Object.keys(routeToBuildInfo)}`
|
94
|
-
);
|
95
|
-
try {
|
96
|
-
const loaderData = await (await import(buildInfo2.serverJsPath)).loader?.(loaderProps), preloads = buildInfo2.preloads, headers = new Headers();
|
97
|
-
return headers.set("content-type", "text/html"), new Response(
|
98
|
-
await render({
|
99
|
-
loaderData,
|
100
|
-
loaderProps,
|
101
|
-
path: loaderProps?.path || "/",
|
102
|
-
preloads
|
103
|
-
}),
|
104
|
-
{
|
105
|
-
headers
|
106
|
-
}
|
107
|
-
);
|
108
|
-
} catch (err) {
|
109
|
-
console.error(`[one] Error rendering SSR route ${route.page}
|
110
|
-
|
111
|
-
${err?.stack ?? err}
|
112
|
-
|
113
|
-
url: ${url}`);
|
114
|
-
}
|
115
|
-
}
|
116
|
-
}
|
117
|
-
}
|
118
|
-
), htmlFiles = {};
|
119
|
-
for (const key in routeMap)
|
120
|
-
routeToBuildInfo[key]?.type !== "ssr" && (htmlFiles[key] = await FSExtra.readFile(join("dist/client", routeMap[key]), "utf-8"));
|
121
|
-
app.use(async (context, next) => {
|
122
|
-
const html = htmlFiles[context.req.path];
|
123
|
-
if (html)
|
124
|
-
return context.html(html);
|
125
|
-
try {
|
126
|
-
const request = context.req.raw, response = await handleRequest.handler(request);
|
127
|
-
if (response) {
|
128
|
-
if (isResponse(response)) {
|
129
|
-
if (isStatusRedirect(response.status)) {
|
130
|
-
const location = `${response.headers.get("location") || ""}`;
|
131
|
-
return response.headers.forEach((value, key) => {
|
132
|
-
context.header(key, value);
|
133
|
-
}), context.redirect(location, response.status);
|
134
|
-
}
|
135
|
-
if (isAPIRequest.get(request))
|
136
|
-
try {
|
137
|
-
response.headers.set("Cache-Control", "no-store");
|
138
|
-
} catch (err) {
|
139
|
-
console.info(
|
140
|
-
`Error udpating cache header on api route "${context.req.path}" to no-store, it is ${response.headers.get("cache-control")}, continue`,
|
141
|
-
err
|
142
|
-
);
|
143
|
-
}
|
144
|
-
return response;
|
145
|
-
}
|
146
|
-
return context.json(
|
147
|
-
response,
|
148
|
-
200,
|
149
|
-
isAPIRequest.get(request) ? {
|
150
|
-
"Cache-Control": "no-store"
|
151
|
-
} : void 0
|
152
|
-
);
|
153
|
-
}
|
154
|
-
} catch (err) {
|
155
|
-
console.error(` [one] Error handling request: ${err.stack}`);
|
156
|
-
}
|
157
|
-
await next();
|
158
|
-
});
|
159
|
-
}
|
160
30
|
export {
|
161
31
|
serve
|
162
32
|
};
|
package/dist/esm/serve.js.map
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"version": 3,
|
3
3
|
"sources": ["../../src/serve.ts"],
|
4
|
-
"mappings": "AAAA,OAAO;AAEP,OAAO,aAAa;AAEpB,SAAS,
|
5
|
-
"names": [
|
4
|
+
"mappings": "AAAA,OAAO;AAEP,OAAO,aAAa;AAEpB,SAAS,sBAAsB;AAC/B,SAAS,oBAAoB;AAG7B,QAAQ,GAAG,qBAAqB,CAAC,QAAQ;AACvC,UAAQ,MAAM,4BAA4B,KAAK,SAAS,GAAG;AAC7D,CAAC;AAED,eAAsB,MAAM,OAA8B,CAAC,GAAG;AAC5D,QAAM,YAAa,MAAM,QAAQ,SAAS,qBAAqB,GACzD,EAAE,WAAW,IAAI;AAEvB,iBAAe,SAAS,GACxB,aAAa,UAAU;AAGvB,QAAM,EAAE,aAAa,IAAI,MAAM,OAAO,qBAAqB,GACrD,EAAE,gBAAgB,IAAI,MAAM,OAAO,yBAAyB,GAC5D,EAAE,SAAS,OAAO,UAAU,IAAI,MAAM,OAAO,YAAY,GACzD,EAAE,SAAS,IAAI,MAAM,OAAO,mBAAmB;AAErD,sBAAa,OAAO,GAEhB,KAAK,WACP,MAAM,QAAQ,YAAY,GAI5B,QAAQ,IAAI,gBAAgB,KAErB,MAAM,UAAU;AAAA,IACrB,QAAQ;AAAA;AAAA,MAEN,GAAG,WAAW;AAAA;AAAA,MAEd,GAAG,gBAAgB;AAAA,QACjB,MAAM,KAAK,OAAO,CAAC,KAAK,OAAO;AAAA,QAC/B,MAAM,KAAK;AAAA,QACX,UAAU,KAAK;AAAA,QACf,UAAU,KAAK;AAAA,QACf,cAAc,KAAK;AAAA,MACrB,CAAC;AAAA,IACH;AAAA,IAEA,MAAM,YAAY,SAAS,KAAK;AAC9B,YAAM,SAAS,YAAY,SAAS,WAAW,GAAG;AAAA,IACpD;AAAA,EACF,CAAC;AACH;",
|
5
|
+
"names": []
|
6
6
|
}
|
package/dist/esm/serve.mjs
CHANGED
@@ -1,13 +1,16 @@
|
|
1
1
|
import "./polyfills-server.mjs";
|
2
2
|
import FSExtra from "fs-extra";
|
3
|
-
import {
|
4
|
-
import {
|
3
|
+
import { setupBuildInfo } from "./server/setupBuildOptions.mjs";
|
4
|
+
import { ensureExists } from "./utils/ensureExists.mjs";
|
5
5
|
process.on("uncaughtException", err => {
|
6
6
|
console.error("[one] Uncaught exception", err?.stack || err);
|
7
7
|
});
|
8
8
|
async function serve(args = {}) {
|
9
|
-
const buildInfo = await FSExtra.readJSON("dist/buildInfo.json")
|
10
|
-
|
9
|
+
const buildInfo = await FSExtra.readJSON("dist/buildInfo.json"),
|
10
|
+
{
|
11
|
+
oneOptions
|
12
|
+
} = buildInfo;
|
13
|
+
setupBuildInfo(buildInfo), ensureExists(oneOptions);
|
11
14
|
const {
|
12
15
|
labelProcess
|
13
16
|
} = await import("./cli/label-process.mjs"),
|
@@ -15,11 +18,13 @@ async function serve(args = {}) {
|
|
15
18
|
removeUndefined
|
16
19
|
} = await import("./utils/removeUndefined.mjs"),
|
17
20
|
{
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
21
|
+
loadEnv,
|
22
|
+
serve: vxrnServe
|
23
|
+
} = await import("vxrn/serve"),
|
24
|
+
{
|
25
|
+
oneServe
|
26
|
+
} = await import("./server/oneServe.mjs");
|
27
|
+
return labelProcess("serve"), args.loadEnv && (await loadEnv("production")), process.env.VXRN_REACT_19 = "1", await vxrnServe({
|
23
28
|
server: {
|
24
29
|
// fallback to one plugin
|
25
30
|
...oneOptions.server,
|
@@ -30,141 +35,11 @@ async function serve(args = {}) {
|
|
30
35
|
compress: args.compress,
|
31
36
|
platform: args.platform,
|
32
37
|
cacheHeaders: args.cacheHeaders
|
33
|
-
})
|
34
|
-
async beforeStart(options, app) {
|
35
|
-
await oneOptions.server?.beforeStart?.(options, app), await oneServe(oneOptions, options, buildInfo, app);
|
36
|
-
}
|
37
|
-
}
|
38
|
-
});
|
39
|
-
}
|
40
|
-
async function oneServe(options, vxrnOptions, buildInfo, app) {
|
41
|
-
const {
|
42
|
-
createHandleRequest
|
43
|
-
} = await import("./createHandleRequest.mjs"),
|
44
|
-
{
|
45
|
-
isResponse
|
46
|
-
} = await import("./utils/isResponse.mjs"),
|
47
|
-
{
|
48
|
-
isStatusRedirect
|
49
|
-
} = await import("./utils/isStatus.mjs"),
|
50
|
-
{
|
51
|
-
resolveAPIRequest
|
52
|
-
} = await import("./vite/resolveAPIRequest.mjs"),
|
53
|
-
isAPIRequest = /* @__PURE__ */new WeakMap(),
|
54
|
-
root = vxrnOptions.root || ".",
|
55
|
-
redirects = options.web?.redirects;
|
56
|
-
if (redirects) for (const redirect of redirects) app.get(redirect.source, context => {
|
57
|
-
const destinationUrl = redirect.destination.replace(/:\w+/g, param => {
|
58
|
-
const paramName = param.substring(1);
|
59
|
-
return context.req.param(paramName) || "";
|
60
|
-
});
|
61
|
-
return context.redirect(destinationUrl, redirect.permanent ? 301 : 302);
|
62
|
-
});
|
63
|
-
if (!buildInfo) throw new Error("No build info found, have you run build?");
|
64
|
-
const {
|
65
|
-
routeMap,
|
66
|
-
builtRoutes
|
67
|
-
} = buildInfo,
|
68
|
-
routeToBuildInfo = {};
|
69
|
-
for (const route of builtRoutes) {
|
70
|
-
routeToBuildInfo[route.cleanPath] = route;
|
71
|
-
const bracketRoutePath = route.cleanPath.split("/").map(part => part[0] === ":" ? `[${part.slice(1)}]` : part).join("/");
|
72
|
-
routeToBuildInfo[bracketRoutePath] = route;
|
73
|
-
}
|
74
|
-
const serverOptions = {
|
75
|
-
...options,
|
76
|
-
root
|
38
|
+
})
|
77
39
|
},
|
78
|
-
|
79
|
-
|
80
|
-
handleRequest = createHandleRequest({}, {
|
81
|
-
async handleAPI({
|
82
|
-
route,
|
83
|
-
request,
|
84
|
-
loaderProps
|
85
|
-
}) {
|
86
|
-
const apiFile = join(process.cwd(), "dist", "api", route.page.replace("[", "_").replace("]", "_") + (apiCJS ? ".cjs" : ".js"));
|
87
|
-
return isAPIRequest.set(request, !0), resolveAPIRequest(async () => {
|
88
|
-
try {
|
89
|
-
return await import(apiFile);
|
90
|
-
} catch (err) {
|
91
|
-
return console.error(`
|
92
|
-
[one] Error importing API route at ${apiFile}:
|
93
|
-
|
94
|
-
${err}
|
95
|
-
|
96
|
-
If this is an import error, you can likely fix this by adding this dependency to
|
97
|
-
the "optimizeDeps.include" array in your vite.config.ts.
|
98
|
-
|
99
|
-
\u{1F41E} For a better error message run "node" and enter:
|
100
|
-
|
101
|
-
import('${apiFile}')
|
102
|
-
|
103
|
-
`), {};
|
104
|
-
}
|
105
|
-
}, request, loaderProps?.params || {});
|
106
|
-
},
|
107
|
-
async handleSSR({
|
108
|
-
route,
|
109
|
-
url,
|
110
|
-
loaderProps
|
111
|
-
}) {
|
112
|
-
if (route.type === "ssr") {
|
113
|
-
const buildInfo2 = routeToBuildInfo[route.page];
|
114
|
-
if (!buildInfo2) throw new Error(`No buildinfo found for ${url}, route: ${route.page}, in keys: ${Object.keys(routeToBuildInfo)}`);
|
115
|
-
try {
|
116
|
-
const loaderData = await (await import(buildInfo2.serverJsPath)).loader?.(loaderProps),
|
117
|
-
preloads = buildInfo2.preloads,
|
118
|
-
headers = new Headers();
|
119
|
-
return headers.set("content-type", "text/html"), new Response(await render({
|
120
|
-
loaderData,
|
121
|
-
loaderProps,
|
122
|
-
path: loaderProps?.path || "/",
|
123
|
-
preloads
|
124
|
-
}), {
|
125
|
-
headers
|
126
|
-
});
|
127
|
-
} catch (err) {
|
128
|
-
console.error(`[one] Error rendering SSR route ${route.page}
|
129
|
-
|
130
|
-
${err?.stack ?? err}
|
131
|
-
|
132
|
-
url: ${url}`);
|
133
|
-
}
|
134
|
-
}
|
135
|
-
}
|
136
|
-
}),
|
137
|
-
htmlFiles = {};
|
138
|
-
for (const key in routeMap) routeToBuildInfo[key]?.type !== "ssr" && (htmlFiles[key] = await FSExtra.readFile(join("dist/client", routeMap[key]), "utf-8"));
|
139
|
-
app.use(async (context, next) => {
|
140
|
-
const html = htmlFiles[context.req.path];
|
141
|
-
if (html) return context.html(html);
|
142
|
-
try {
|
143
|
-
const request = context.req.raw,
|
144
|
-
response = await handleRequest.handler(request);
|
145
|
-
if (response) {
|
146
|
-
if (isResponse(response)) {
|
147
|
-
if (isStatusRedirect(response.status)) {
|
148
|
-
const location = `${response.headers.get("location") || ""}`;
|
149
|
-
return response.headers.forEach((value, key) => {
|
150
|
-
context.header(key, value);
|
151
|
-
}), context.redirect(location, response.status);
|
152
|
-
}
|
153
|
-
if (isAPIRequest.get(request)) try {
|
154
|
-
response.headers.set("Cache-Control", "no-store");
|
155
|
-
} catch (err) {
|
156
|
-
console.info(`Error udpating cache header on api route "${context.req.path}" to no-store, it is ${response.headers.get("cache-control")}, continue`, err);
|
157
|
-
}
|
158
|
-
return response;
|
159
|
-
}
|
160
|
-
return context.json(response, 200, isAPIRequest.get(request) ? {
|
161
|
-
"Cache-Control": "no-store"
|
162
|
-
} : void 0);
|
163
|
-
}
|
164
|
-
} catch (err) {
|
165
|
-
console.error(` [one] Error handling request: ${err.stack}`);
|
40
|
+
async beforeStart(options, app) {
|
41
|
+
await oneServe(oneOptions, options, buildInfo, app);
|
166
42
|
}
|
167
|
-
await next();
|
168
43
|
});
|
169
44
|
}
|
170
45
|
export { serve };
|
package/dist/esm/serve.mjs.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["FSExtra","
|
1
|
+
{"version":3,"names":["FSExtra","setupBuildInfo","ensureExists","process","on","err","console","error","stack","serve","args","buildInfo","readJSON","oneOptions","labelProcess","removeUndefined","loadEnv","vxrnServe","oneServe","env","VXRN_REACT_19","server","port","host","compress","platform","cacheHeaders","beforeStart","options","app"],"sources":["../../src/serve.ts"],"sourcesContent":[null],"mappings":"AAAA,OAAO;AAEP,OAAOA,OAAA,MAAa;AAEpB,SAASC,cAAA,QAAsB;AAC/B,SAASC,YAAA,QAAoB;AAG7BC,OAAA,CAAQC,EAAA,CAAG,qBAAsBC,GAAA,IAAQ;EACvCC,OAAA,CAAQC,KAAA,CAAM,4BAA4BF,GAAA,EAAKG,KAAA,IAASH,GAAG;AAC7D,CAAC;AAED,eAAsBI,MAAMC,IAAA,GAA8B,CAAC,GAAG;EAC5D,MAAMC,SAAA,GAAa,MAAMX,OAAA,CAAQY,QAAA,CAAS,qBAAqB;IACzD;MAAEC;IAAW,IAAIF,SAAA;EAEvBV,cAAA,CAAeU,SAAS,GACxBT,YAAA,CAAaW,UAAU;EAGvB,MAAM;MAAEC;IAAa,IAAI,MAAM,OAAO,yBAAqB;IACrD;MAAEC;IAAgB,IAAI,MAAM,OAAO,6BAAyB;IAC5D;MAAEC,OAAA;MAASP,KAAA,EAAOQ;IAAU,IAAI,MAAM,OAAO,YAAY;IACzD;MAAEC;IAAS,IAAI,MAAM,OAAO,uBAAmB;EAErD,OAAAJ,YAAA,CAAa,OAAO,GAEhBJ,IAAA,CAAKM,OAAA,KACP,MAAMA,OAAA,CAAQ,YAAY,IAI5Bb,OAAA,CAAQgB,GAAA,CAAIC,aAAA,GAAgB,KAErB,MAAMH,SAAA,CAAU;IACrBI,MAAA,EAAQ;MAAA;MAEN,GAAGR,UAAA,CAAWQ,MAAA;MAAA;MAEd,GAAGN,eAAA,CAAgB;QACjBO,IAAA,EAAMZ,IAAA,CAAKY,IAAA,GAAO,CAACZ,IAAA,CAAKY,IAAA,GAAO;QAC/BC,IAAA,EAAMb,IAAA,CAAKa,IAAA;QACXC,QAAA,EAAUd,IAAA,CAAKc,QAAA;QACfC,QAAA,EAAUf,IAAA,CAAKe,QAAA;QACfC,YAAA,EAAchB,IAAA,CAAKgB;MACrB,CAAC;IACH;IAEA,MAAMC,YAAYC,OAAA,EAASC,GAAA,EAAK;MAC9B,MAAMX,QAAA,CAASL,UAAA,EAAYe,OAAA,EAASjB,SAAA,EAAWkB,GAAG;IACpD;EACF,CAAC;AACH","ignoreList":[]}
|
package/dist/esm/serve.native.js
CHANGED
@@ -1,17 +1,15 @@
|
|
1
1
|
import "./polyfills-server";
|
2
2
|
import FSExtra from "fs-extra";
|
3
|
-
import {
|
4
|
-
import {
|
3
|
+
import { setupBuildInfo } from "./server/setupBuildOptions";
|
4
|
+
import { ensureExists } from "./utils/ensureExists";
|
5
5
|
process.on("uncaughtException", function(err) {
|
6
6
|
console.error("[one] Uncaught exception", err?.stack || err);
|
7
7
|
});
|
8
8
|
async function serve() {
|
9
|
-
var args = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, buildInfo = await FSExtra.readJSON("dist/buildInfo.json");
|
10
|
-
|
11
|
-
var { labelProcess } = await import("./cli/label-process"), { removeUndefined } = await import("./utils/removeUndefined"), {
|
12
|
-
labelProcess("serve"), loadEnv("production")
|
13
|
-
var oneOptions = await loadUserOneOptions("serve");
|
14
|
-
return process.env.VXRN_REACT_19 = "1", await vxrnServe({
|
9
|
+
var args = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, buildInfo = await FSExtra.readJSON("dist/buildInfo.json"), { oneOptions } = buildInfo;
|
10
|
+
setupBuildInfo(buildInfo), ensureExists(oneOptions);
|
11
|
+
var { labelProcess } = await import("./cli/label-process"), { removeUndefined } = await import("./utils/removeUndefined"), { loadEnv, serve: vxrnServe } = await import("vxrn/serve"), { oneServe } = await import("./server/oneServe");
|
12
|
+
return labelProcess("serve"), args.loadEnv && await loadEnv("production"), process.env.VXRN_REACT_19 = "1", await vxrnServe({
|
15
13
|
server: {
|
16
14
|
// fallback to one plugin
|
17
15
|
...oneOptions.server,
|
@@ -22,149 +20,11 @@ async function serve() {
|
|
22
20
|
compress: args.compress,
|
23
21
|
platform: args.platform,
|
24
22
|
cacheHeaders: args.cacheHeaders
|
25
|
-
})
|
26
|
-
async beforeStart(options, app) {
|
27
|
-
var _oneOptions_server_beforeStart, _oneOptions_server;
|
28
|
-
await ((_oneOptions_server = oneOptions.server) === null || _oneOptions_server === void 0 || (_oneOptions_server_beforeStart = _oneOptions_server.beforeStart) === null || _oneOptions_server_beforeStart === void 0 ? void 0 : _oneOptions_server_beforeStart.call(_oneOptions_server, options, app)), await oneServe(oneOptions, options, buildInfo, app);
|
29
|
-
}
|
30
|
-
}
|
31
|
-
});
|
32
|
-
}
|
33
|
-
async function oneServe(options, vxrnOptions, buildInfo, app) {
|
34
|
-
var _options_web, _options_build_api, _options_build, { createHandleRequest } = await import("./createHandleRequest"), { isResponse } = await import("./utils/isResponse"), { isStatusRedirect } = await import("./utils/isStatus"), { resolveAPIRequest } = await import("./vite/resolveAPIRequest"), isAPIRequest = /* @__PURE__ */ new WeakMap(), root = vxrnOptions.root || ".", redirects = (_options_web = options.web) === null || _options_web === void 0 ? void 0 : _options_web.redirects;
|
35
|
-
if (redirects) {
|
36
|
-
var _iteratorNormalCompletion = !0, _didIteratorError = !1, _iteratorError = void 0;
|
37
|
-
try {
|
38
|
-
for (var _loop = function() {
|
39
|
-
var redirect = _step.value;
|
40
|
-
app.get(redirect.source, function(context) {
|
41
|
-
var destinationUrl = redirect.destination.replace(/:\w+/g, function(param) {
|
42
|
-
var paramName = param.substring(1);
|
43
|
-
return context.req.param(paramName) || "";
|
44
|
-
});
|
45
|
-
return context.redirect(destinationUrl, redirect.permanent ? 301 : 302);
|
46
|
-
});
|
47
|
-
}, _iterator = redirects[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = !0) _loop();
|
48
|
-
} catch (err) {
|
49
|
-
_didIteratorError = !0, _iteratorError = err;
|
50
|
-
} finally {
|
51
|
-
try {
|
52
|
-
!_iteratorNormalCompletion && _iterator.return != null && _iterator.return();
|
53
|
-
} finally {
|
54
|
-
if (_didIteratorError)
|
55
|
-
throw _iteratorError;
|
56
|
-
}
|
57
|
-
}
|
58
|
-
}
|
59
|
-
if (!buildInfo)
|
60
|
-
throw new Error("No build info found, have you run build?");
|
61
|
-
var { routeMap, builtRoutes } = buildInfo, routeToBuildInfo = {}, _iteratorNormalCompletion1 = !0, _didIteratorError1 = !1, _iteratorError1 = void 0;
|
62
|
-
try {
|
63
|
-
for (var _iterator1 = builtRoutes[Symbol.iterator](), _step1; !(_iteratorNormalCompletion1 = (_step1 = _iterator1.next()).done); _iteratorNormalCompletion1 = !0) {
|
64
|
-
var route = _step1.value;
|
65
|
-
routeToBuildInfo[route.cleanPath] = route;
|
66
|
-
var bracketRoutePath = route.cleanPath.split("/").map(function(part) {
|
67
|
-
return part[0] === ":" ? `[${part.slice(1)}]` : part;
|
68
|
-
}).join("/");
|
69
|
-
routeToBuildInfo[bracketRoutePath] = route;
|
70
|
-
}
|
71
|
-
} catch (err) {
|
72
|
-
_didIteratorError1 = !0, _iteratorError1 = err;
|
73
|
-
} finally {
|
74
|
-
try {
|
75
|
-
!_iteratorNormalCompletion1 && _iterator1.return != null && _iterator1.return();
|
76
|
-
} finally {
|
77
|
-
if (_didIteratorError1)
|
78
|
-
throw _iteratorError1;
|
79
|
-
}
|
80
|
-
}
|
81
|
-
var serverOptions = {
|
82
|
-
...options,
|
83
|
-
root
|
84
|
-
}, entryServer = getServerEntry(serverOptions), entry = await import(entryServer), render = entry.default.render, apiCJS = ((_options_build = options.build) === null || _options_build === void 0 || (_options_build_api = _options_build.api) === null || _options_build_api === void 0 ? void 0 : _options_build_api.outputFormat) === "cjs", handleRequest = createHandleRequest({}, {
|
85
|
-
async handleAPI(param) {
|
86
|
-
var { route: route2, request, loaderProps } = param, apiFile = join(process.cwd(), "dist", "api", route2.page.replace("[", "_").replace("]", "_") + (apiCJS ? ".cjs" : ".js"));
|
87
|
-
return isAPIRequest.set(request, !0), resolveAPIRequest(async function() {
|
88
|
-
try {
|
89
|
-
return await import(apiFile);
|
90
|
-
} catch (err) {
|
91
|
-
return console.error(`
|
92
|
-
[one] Error importing API route at ${apiFile}:
|
93
|
-
|
94
|
-
${err}
|
95
|
-
|
96
|
-
If this is an import error, you can likely fix this by adding this dependency to
|
97
|
-
the "optimizeDeps.include" array in your vite.config.ts.
|
98
|
-
|
99
|
-
\u{1F41E} For a better error message run "node" and enter:
|
100
|
-
|
101
|
-
import('${apiFile}')
|
102
|
-
|
103
|
-
`), {};
|
104
|
-
}
|
105
|
-
}, request, loaderProps?.params || {});
|
23
|
+
})
|
106
24
|
},
|
107
|
-
async
|
108
|
-
|
109
|
-
if (route2.type === "ssr") {
|
110
|
-
var _$buildInfo = routeToBuildInfo[route2.page];
|
111
|
-
if (!_$buildInfo)
|
112
|
-
throw new Error(`No buildinfo found for ${url}, route: ${route2.page}, in keys: ${Object.keys(routeToBuildInfo)}`);
|
113
|
-
try {
|
114
|
-
var _exported_loader, exported = await import(_$buildInfo.serverJsPath), loaderData = await ((_exported_loader = exported.loader) === null || _exported_loader === void 0 ? void 0 : _exported_loader.call(exported, loaderProps)), preloads = _$buildInfo.preloads, headers = new Headers();
|
115
|
-
return headers.set("content-type", "text/html"), new Response(await render({
|
116
|
-
loaderData,
|
117
|
-
loaderProps,
|
118
|
-
path: loaderProps?.path || "/",
|
119
|
-
preloads
|
120
|
-
}), {
|
121
|
-
headers
|
122
|
-
});
|
123
|
-
} catch (err) {
|
124
|
-
var _err_stack;
|
125
|
-
console.error(`[one] Error rendering SSR route ${route2.page}
|
126
|
-
|
127
|
-
${(_err_stack = err?.stack) !== null && _err_stack !== void 0 ? _err_stack : err}
|
128
|
-
|
129
|
-
url: ${url}`);
|
130
|
-
}
|
131
|
-
}
|
132
|
-
}
|
133
|
-
}), htmlFiles = {};
|
134
|
-
for (var key in routeMap) {
|
135
|
-
var info = routeToBuildInfo[key];
|
136
|
-
info?.type !== "ssr" && (htmlFiles[key] = await FSExtra.readFile(join("dist/client", routeMap[key]), "utf-8"));
|
137
|
-
}
|
138
|
-
app.use(async function(context, next) {
|
139
|
-
var html = htmlFiles[context.req.path];
|
140
|
-
if (html)
|
141
|
-
return context.html(html);
|
142
|
-
try {
|
143
|
-
var request = context.req.raw, response = await handleRequest.handler(request);
|
144
|
-
if (response) {
|
145
|
-
if (isResponse(response)) {
|
146
|
-
if (isStatusRedirect(response.status)) {
|
147
|
-
var location = `${response.headers.get("location") || ""}`;
|
148
|
-
return response.headers.forEach(function(value, key2) {
|
149
|
-
context.header(key2, value);
|
150
|
-
}), context.redirect(location, response.status);
|
151
|
-
}
|
152
|
-
if (isAPIRequest.get(request))
|
153
|
-
try {
|
154
|
-
response.headers.set("Cache-Control", "no-store");
|
155
|
-
} catch (err) {
|
156
|
-
console.info(`Error udpating cache header on api route "${context.req.path}" to no-store, it is ${response.headers.get("cache-control")}, continue`, err);
|
157
|
-
}
|
158
|
-
return response;
|
159
|
-
}
|
160
|
-
return context.json(response, 200, isAPIRequest.get(request) ? {
|
161
|
-
"Cache-Control": "no-store"
|
162
|
-
} : void 0);
|
163
|
-
}
|
164
|
-
} catch (err) {
|
165
|
-
console.error(` [one] Error handling request: ${err.stack}`);
|
25
|
+
async beforeStart(options, app) {
|
26
|
+
await oneServe(oneOptions, options, buildInfo, app);
|
166
27
|
}
|
167
|
-
await next();
|
168
28
|
});
|
169
29
|
}
|
170
30
|
export {
|
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"version": 3,
|
3
3
|
"sources": ["../../src/Users/n8/one/packages/one/src/serve.ts"],
|
4
|
-
"mappings": "AAAA,OAAO;AAEP,OAAOA,aAAa;AAEpB,SAASC,
|
5
|
-
"names": ["FSExtra", "
|
4
|
+
"mappings": "AAAA,OAAO;AAEP,OAAOA,aAAa;AAEpB,SAASC,sBAAsB;AAC/B,SAASC,oBAAoB;AAG7BC,QAAQC,GAAG,qBAAqB,SAACC,KAAAA;AAC/BC,UAAQC,MAAM,4BAA4BF,KAAKG,SAASH,GAAAA;AAC1D,CAAA;AAEA,eAAsBI,QAAAA;MAAMC,OAAAA,UAAAA,SAAAA,KAAAA,UAAAA,CAAAA,MAAAA,SAAAA,UAAAA,CAAAA,IAA8B,CAAC,GACnDC,YAAa,MAAMX,QAAQY,SAAS,qBAAqB,GACzD,EAAEC,WAAU,IAAKF;AAEvBV,iBAAeU,SAAAA,GACfT,aAAaW,UAAAA;AAGb,MAAM,EAAEC,aAAY,IAAK,MAAM,OAAO,qBAAA,GAChC,EAAEC,gBAAe,IAAK,MAAM,OAAO,yBAAA,GACnC,EAAEC,SAASP,OAAOQ,UAAS,IAAK,MAAM,OAAO,YAAA,GAC7C,EAAEC,SAAQ,IAAK,MAAM,OAAO,mBAAA;AAElCJ,sBAAa,OAAA,GAETJ,KAAKM,WACP,MAAMA,QAAQ,YAAA,GAIhBb,QAAQgB,IAAIC,gBAAgB,KAErB,MAAMH,UAAU;IACrBI,QAAQ;;MAEN,GAAGR,WAAWQ;;MAEd,GAAGN,gBAAgB;QACjBO,MAAMZ,KAAKY,OAAO,CAACZ,KAAKY,OAAOC;QAC/BC,MAAMd,KAAKc;QACXC,UAAUf,KAAKe;QACfC,UAAUhB,KAAKgB;QACfC,cAAcjB,KAAKiB;MACrB,CAAA;IACF;IAEA,MAAMC,YAAYC,SAASC,KAAG;AAC5B,YAAMZ,SAASL,YAAYgB,SAASlB,WAAWmB,GAAAA;IACjD;EACF,CAAA;AACF;",
|
5
|
+
"names": ["FSExtra", "setupBuildInfo", "ensureExists", "process", "on", "err", "console", "error", "stack", "serve", "args", "buildInfo", "readJSON", "oneOptions", "labelProcess", "removeUndefined", "loadEnv", "vxrnServe", "oneServe", "env", "VXRN_REACT_19", "server", "port", "undefined", "host", "compress", "platform", "cacheHeaders", "beforeStart", "options", "app"]
|
6
6
|
}
|