@modern-js/server-core 2.48.4 → 2.48.5-alpha.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.
- package/dist/cjs/base/adapters/node/bff.js +69 -0
- package/dist/cjs/base/adapters/node/hono.js +63 -0
- package/dist/cjs/base/adapters/node/index.js +54 -0
- package/dist/cjs/base/adapters/node/loadServer.js +56 -0
- package/dist/cjs/base/adapters/node/middlewares/index.js +28 -0
- package/dist/cjs/base/adapters/node/middlewares/mock.js +113 -0
- package/dist/cjs/base/adapters/node/middlewares/serverManifest.js +82 -0
- package/dist/cjs/base/adapters/node/middlewares/serverPublic.js +67 -0
- package/dist/cjs/base/adapters/node/middlewares/serverStatic.js +109 -0
- package/dist/cjs/base/adapters/node/middlewares/templates.js +67 -0
- package/dist/cjs/base/adapters/node/node.js +127 -0
- package/dist/cjs/base/adapters/node/polyfills/index.js +24 -0
- package/dist/cjs/base/adapters/node/polyfills/install.js +72 -0
- package/dist/cjs/base/adapters/node/polyfills/stream.js +153 -0
- package/dist/cjs/base/constants.js +58 -0
- package/dist/cjs/base/index.js +47 -0
- package/dist/cjs/base/middlewares/customServer/base.js +154 -0
- package/dist/cjs/base/middlewares/customServer/context.js +73 -0
- package/dist/cjs/base/middlewares/customServer/index.js +130 -0
- package/dist/cjs/base/middlewares/customServer/routerApi.js +44 -0
- package/dist/cjs/base/middlewares/customServer/template.js +58 -0
- package/dist/cjs/base/middlewares/faviconFallback.js +34 -0
- package/dist/cjs/base/middlewares/index.js +28 -0
- package/dist/cjs/base/middlewares/logger.js +77 -0
- package/dist/cjs/base/middlewares/monitor.js +90 -0
- package/dist/cjs/base/middlewares/renderHandler/dataHandler.js +46 -0
- package/dist/cjs/base/middlewares/renderHandler/index.js +106 -0
- package/dist/cjs/base/middlewares/renderHandler/render.js +125 -0
- package/dist/cjs/base/middlewares/renderHandler/serverTiming.js +40 -0
- package/dist/cjs/base/middlewares/renderHandler/ssrCache.js +197 -0
- package/dist/cjs/base/middlewares/renderHandler/ssrRender.js +208 -0
- package/dist/cjs/base/serverBase.js +203 -0
- package/dist/cjs/base/utils/debug.js +29 -0
- package/dist/cjs/base/utils/entry.js +30 -0
- package/dist/cjs/base/utils/env.js +45 -0
- package/dist/cjs/base/utils/error.js +65 -0
- package/dist/cjs/base/utils/index.js +45 -0
- package/dist/cjs/base/utils/middlewareCollector.js +54 -0
- package/dist/cjs/base/utils/request.js +65 -0
- package/dist/cjs/base/utils/serverConfig.js +70 -0
- package/dist/cjs/base/utils/transformStream.js +61 -0
- package/dist/cjs/base/utils/warmup.js +43 -0
- package/dist/cjs/core/hono.js +16 -0
- package/dist/cjs/core/index.js +22 -0
- package/dist/cjs/{loadPlugins.js → core/loadPlugins.js} +4 -7
- package/dist/cjs/{plugin.js → core/plugin.js} +1 -3
- package/dist/cjs/core/render.js +16 -0
- package/dist/cjs/core/server.js +16 -0
- package/dist/cjs/index.js +6 -4
- package/dist/esm/base/adapters/node/bff.js +128 -0
- package/dist/esm/base/adapters/node/hono.js +83 -0
- package/dist/esm/base/adapters/node/index.js +19 -0
- package/dist/esm/base/adapters/node/loadServer.js +73 -0
- package/dist/esm/base/adapters/node/middlewares/index.js +4 -0
- package/dist/esm/base/adapters/node/middlewares/mock.js +198 -0
- package/dist/esm/base/adapters/node/middlewares/serverManifest.js +132 -0
- package/dist/esm/base/adapters/node/middlewares/serverPublic.js +85 -0
- package/dist/esm/base/adapters/node/middlewares/serverStatic.js +119 -0
- package/dist/esm/base/adapters/node/middlewares/templates.js +114 -0
- package/dist/esm/base/adapters/node/node.js +197 -0
- package/dist/esm/base/adapters/node/polyfills/index.js +2 -0
- package/dist/esm/base/adapters/node/polyfills/install.js +48 -0
- package/dist/esm/base/adapters/node/polyfills/stream.js +316 -0
- package/dist/esm/base/constants.js +31 -0
- package/dist/esm/base/index.js +15 -0
- package/dist/esm/base/middlewares/customServer/base.js +182 -0
- package/dist/esm/base/middlewares/customServer/context.js +68 -0
- package/dist/esm/base/middlewares/customServer/index.js +214 -0
- package/dist/esm/base/middlewares/customServer/routerApi.js +26 -0
- package/dist/esm/base/middlewares/customServer/template.js +47 -0
- package/dist/esm/base/middlewares/faviconFallback.js +28 -0
- package/dist/esm/base/middlewares/index.js +4 -0
- package/dist/esm/base/middlewares/logger.js +75 -0
- package/dist/esm/base/middlewares/monitor.js +157 -0
- package/dist/esm/base/middlewares/renderHandler/dataHandler.js +45 -0
- package/dist/esm/base/middlewares/renderHandler/index.js +165 -0
- package/dist/esm/base/middlewares/renderHandler/render.js +215 -0
- package/dist/esm/base/middlewares/renderHandler/serverTiming.js +21 -0
- package/dist/esm/base/middlewares/renderHandler/ssrCache.js +306 -0
- package/dist/esm/base/middlewares/renderHandler/ssrRender.js +265 -0
- package/dist/esm/base/serverBase.js +383 -0
- package/dist/esm/base/utils/debug.js +5 -0
- package/dist/esm/base/utils/entry.js +6 -0
- package/dist/esm/base/utils/env.js +20 -0
- package/dist/esm/base/utils/error.js +12 -0
- package/dist/esm/base/utils/index.js +13 -0
- package/dist/esm/base/utils/middlewareCollector.js +31 -0
- package/dist/esm/base/utils/request.js +39 -0
- package/dist/esm/base/utils/serverConfig.js +58 -0
- package/dist/esm/base/utils/transformStream.js +90 -0
- package/dist/esm/base/utils/warmup.js +9 -0
- package/dist/esm/core/hono.js +0 -0
- package/dist/esm/core/index.js +1 -0
- package/dist/esm/core/loadPlugins.js +26 -0
- package/dist/esm/core/plugin.js +98 -0
- package/dist/esm/core/render.js +0 -0
- package/dist/esm/core/server.js +0 -0
- package/dist/esm/index.js +3 -2
- package/dist/esm-node/base/adapters/node/bff.js +45 -0
- package/dist/esm-node/base/adapters/node/hono.js +38 -0
- package/dist/esm-node/base/adapters/node/index.js +19 -0
- package/dist/esm-node/base/adapters/node/loadServer.js +22 -0
- package/dist/esm-node/base/adapters/node/middlewares/index.js +4 -0
- package/dist/esm-node/base/adapters/node/middlewares/mock.js +79 -0
- package/dist/esm-node/base/adapters/node/middlewares/serverManifest.js +48 -0
- package/dist/esm-node/base/adapters/node/middlewares/serverPublic.js +33 -0
- package/dist/esm-node/base/adapters/node/middlewares/serverStatic.js +75 -0
- package/dist/esm-node/base/adapters/node/middlewares/templates.js +32 -0
- package/dist/esm-node/base/adapters/node/node.js +101 -0
- package/dist/esm-node/base/adapters/node/polyfills/index.js +2 -0
- package/dist/esm-node/base/adapters/node/polyfills/install.js +48 -0
- package/dist/esm-node/base/adapters/node/polyfills/stream.js +126 -0
- package/dist/esm-node/base/constants.js +31 -0
- package/dist/esm-node/base/index.js +15 -0
- package/dist/esm-node/base/middlewares/customServer/base.js +130 -0
- package/dist/esm-node/base/middlewares/customServer/context.js +46 -0
- package/dist/esm-node/base/middlewares/customServer/index.js +106 -0
- package/dist/esm-node/base/middlewares/customServer/routerApi.js +20 -0
- package/dist/esm-node/base/middlewares/customServer/template.js +34 -0
- package/dist/esm-node/base/middlewares/faviconFallback.js +10 -0
- package/dist/esm-node/base/middlewares/index.js +4 -0
- package/dist/esm-node/base/middlewares/logger.js +53 -0
- package/dist/esm-node/base/middlewares/monitor.js +63 -0
- package/dist/esm-node/base/middlewares/renderHandler/dataHandler.js +22 -0
- package/dist/esm-node/base/middlewares/renderHandler/index.js +71 -0
- package/dist/esm-node/base/middlewares/renderHandler/render.js +101 -0
- package/dist/esm-node/base/middlewares/renderHandler/serverTiming.js +16 -0
- package/dist/esm-node/base/middlewares/renderHandler/ssrCache.js +162 -0
- package/dist/esm-node/base/middlewares/renderHandler/ssrRender.js +173 -0
- package/dist/esm-node/base/serverBase.js +168 -0
- package/dist/esm-node/base/utils/debug.js +5 -0
- package/dist/esm-node/base/utils/entry.js +6 -0
- package/dist/esm-node/base/utils/env.js +20 -0
- package/dist/esm-node/base/utils/error.js +41 -0
- package/dist/esm-node/base/utils/index.js +13 -0
- package/dist/esm-node/base/utils/middlewareCollector.js +29 -0
- package/dist/esm-node/base/utils/request.js +38 -0
- package/dist/esm-node/base/utils/serverConfig.js +34 -0
- package/dist/esm-node/base/utils/transformStream.js +36 -0
- package/dist/esm-node/base/utils/warmup.js +9 -0
- package/dist/esm-node/core/hono.js +0 -0
- package/dist/esm-node/core/index.js +1 -0
- package/dist/{esm → esm-node/core}/loadPlugins.js +4 -7
- package/dist/{esm → esm-node/core}/plugin.js +1 -3
- package/dist/esm-node/core/render.js +0 -0
- package/dist/esm-node/core/server.js +0 -0
- package/dist/esm-node/index.js +5 -0
- package/dist/esm-node/types/config/bff.js +0 -0
- package/dist/esm-node/types/config/dev.js +0 -0
- package/dist/esm-node/types/config/html.js +0 -0
- package/dist/esm-node/types/config/index.js +6 -0
- package/dist/esm-node/types/config/output.js +0 -0
- package/dist/esm-node/types/config/security.js +0 -0
- package/dist/esm-node/types/config/server.js +0 -0
- package/dist/esm-node/types/config/share.js +0 -0
- package/dist/esm-node/types/config/source.js +0 -0
- package/dist/esm-node/types/config/tools.js +0 -0
- package/dist/types/base/adapters/node/bff.d.ts +4 -0
- package/dist/types/base/adapters/node/hono.d.ts +22 -0
- package/dist/types/base/adapters/node/index.d.ts +6 -0
- package/dist/types/base/adapters/node/loadServer.d.ts +3 -0
- package/dist/types/base/adapters/node/middlewares/index.d.ts +4 -0
- package/dist/types/base/adapters/node/middlewares/mock.d.ts +5 -0
- package/dist/types/base/adapters/node/middlewares/serverManifest.d.ts +3 -0
- package/dist/types/base/adapters/node/middlewares/serverPublic.d.ts +7 -0
- package/dist/types/base/adapters/node/middlewares/serverStatic.d.ts +11 -0
- package/dist/types/base/adapters/node/middlewares/templates.d.ts +4 -0
- package/dist/types/base/adapters/node/node.d.ts +13 -0
- package/dist/types/base/adapters/node/polyfills/index.d.ts +2 -0
- package/dist/types/base/adapters/node/polyfills/install.d.ts +1 -0
- package/dist/types/base/adapters/node/polyfills/stream.d.ts +18 -0
- package/dist/types/base/constants.d.ts +24 -0
- package/dist/types/base/index.d.ts +7 -0
- package/dist/types/base/middlewares/customServer/base.d.ts +3 -0
- package/dist/types/base/middlewares/customServer/context.d.ts +7 -0
- package/dist/types/base/middlewares/customServer/index.d.ts +13 -0
- package/dist/types/base/middlewares/customServer/routerApi.d.ts +9 -0
- package/dist/types/base/middlewares/customServer/template.d.ts +11 -0
- package/dist/types/base/middlewares/faviconFallback.d.ts +2 -0
- package/dist/types/base/middlewares/index.d.ts +4 -0
- package/dist/types/base/middlewares/logger.d.ts +2 -0
- package/dist/types/base/middlewares/monitor.d.ts +6 -0
- package/dist/types/base/middlewares/renderHandler/dataHandler.d.ts +5 -0
- package/dist/types/base/middlewares/renderHandler/index.d.ts +10 -0
- package/dist/types/base/middlewares/renderHandler/render.d.ts +12 -0
- package/dist/types/base/middlewares/renderHandler/serverTiming.d.ts +7 -0
- package/dist/types/base/middlewares/renderHandler/ssrCache.d.ts +29 -0
- package/dist/types/base/middlewares/renderHandler/ssrRender.d.ts +21 -0
- package/dist/types/base/serverBase.d.ts +52 -0
- package/dist/types/base/utils/debug.d.ts +1 -0
- package/dist/types/base/utils/entry.d.ts +2 -0
- package/dist/types/base/utils/env.d.ts +2 -0
- package/dist/types/base/utils/error.d.ts +1 -0
- package/dist/types/base/utils/index.d.ts +8 -0
- package/dist/types/base/utils/middlewareCollector.d.ts +12 -0
- package/dist/types/base/utils/request.d.ts +12 -0
- package/dist/types/base/utils/serverConfig.d.ts +14 -0
- package/dist/types/base/utils/transformStream.d.ts +5 -0
- package/dist/types/base/utils/warmup.d.ts +1 -0
- package/dist/types/core/hono.d.ts +1 -0
- package/dist/types/core/index.d.ts +1 -0
- package/dist/types/core/loadPlugins.d.ts +3 -0
- package/dist/types/{plugin.d.ts → core/plugin.d.ts} +32 -35
- package/dist/types/core/render.d.ts +15 -0
- package/dist/types/core/server.d.ts +106 -0
- package/dist/types/index.d.ts +3 -2
- package/package.json +40 -2
- package/dist/types/loadPlugins.d.ts +0 -5
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { Request as NodeRequest, Response as NodeResponse, Headers as NodeHeaders, FormData as NodeFormData } from "@web-std/fetch";
|
|
2
|
+
import { TransformStream as NodeTransformStream, ReadableStream as NodeReadableStream, WritableStream as NodeWritableStream } from "@web-std/stream";
|
|
3
|
+
import { File as NodeFile, Blob as NodeBlob } from "@web-std/file";
|
|
4
|
+
if (!Object.getOwnPropertyDescriptor(NodeHeaders.prototype, "getSetCookie")) {
|
|
5
|
+
Object.defineProperty(NodeHeaders.prototype, "getSetCookie", {
|
|
6
|
+
value: function getSetCookie() {
|
|
7
|
+
const cookies = [];
|
|
8
|
+
this.forEach((value, name) => {
|
|
9
|
+
if (name.toLowerCase() === "set-cookie") {
|
|
10
|
+
cookies.push(value);
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
return cookies;
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
const installGlobals = () => {
|
|
18
|
+
if (!global.Headers) {
|
|
19
|
+
global.Headers = NodeHeaders;
|
|
20
|
+
}
|
|
21
|
+
if (!global.Request) {
|
|
22
|
+
global.Request = NodeRequest;
|
|
23
|
+
}
|
|
24
|
+
if (!global.Response) {
|
|
25
|
+
global.Response = NodeResponse;
|
|
26
|
+
}
|
|
27
|
+
if (!global.FormData) {
|
|
28
|
+
global.FormData = NodeFormData;
|
|
29
|
+
}
|
|
30
|
+
if (!global.TransformStream) {
|
|
31
|
+
global.TransformStream = NodeTransformStream;
|
|
32
|
+
}
|
|
33
|
+
if (!global.ReadableStream) {
|
|
34
|
+
global.ReadableStream = NodeReadableStream;
|
|
35
|
+
}
|
|
36
|
+
if (!global.WritableStream) {
|
|
37
|
+
global.WritableStream = NodeWritableStream;
|
|
38
|
+
}
|
|
39
|
+
if (!global.File) {
|
|
40
|
+
global.File = NodeFile;
|
|
41
|
+
}
|
|
42
|
+
if (!global.Blob) {
|
|
43
|
+
global.Blob = NodeBlob;
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
export {
|
|
47
|
+
installGlobals
|
|
48
|
+
};
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { Stream } from "node:stream";
|
|
2
|
+
async function writeReadableStreamToWritable(stream, writable) {
|
|
3
|
+
const reader = stream.getReader();
|
|
4
|
+
const flushable = writable;
|
|
5
|
+
try {
|
|
6
|
+
while (true) {
|
|
7
|
+
const { done, value } = await reader.read();
|
|
8
|
+
if (done) {
|
|
9
|
+
writable.end();
|
|
10
|
+
break;
|
|
11
|
+
}
|
|
12
|
+
writable.write(value);
|
|
13
|
+
if (typeof flushable.flush === "function") {
|
|
14
|
+
flushable.flush();
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
} catch (error) {
|
|
18
|
+
writable.destroy(error);
|
|
19
|
+
throw error;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
async function writeAsyncIterableToWritable(iterable, writable) {
|
|
23
|
+
try {
|
|
24
|
+
for await (const chunk of iterable) {
|
|
25
|
+
writable.write(chunk);
|
|
26
|
+
}
|
|
27
|
+
writable.end();
|
|
28
|
+
} catch (error) {
|
|
29
|
+
writable.destroy(error);
|
|
30
|
+
throw error;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
async function readableStreamToString(stream, encoding) {
|
|
34
|
+
const reader = stream.getReader();
|
|
35
|
+
const chunks = [];
|
|
36
|
+
while (true) {
|
|
37
|
+
const { done, value } = await reader.read();
|
|
38
|
+
if (done) {
|
|
39
|
+
break;
|
|
40
|
+
}
|
|
41
|
+
if (value) {
|
|
42
|
+
chunks.push(value);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return Buffer.concat(chunks).toString(encoding);
|
|
46
|
+
}
|
|
47
|
+
const createReadableStreamFromReadable = (source) => {
|
|
48
|
+
const pump = new StreamPump(source);
|
|
49
|
+
const stream = new ReadableStream(pump, pump);
|
|
50
|
+
return stream;
|
|
51
|
+
};
|
|
52
|
+
class StreamPump {
|
|
53
|
+
size(chunk) {
|
|
54
|
+
return (chunk === null || chunk === void 0 ? void 0 : chunk.byteLength) || 0;
|
|
55
|
+
}
|
|
56
|
+
start(controller) {
|
|
57
|
+
this.controller = controller;
|
|
58
|
+
this.stream.on("data", this.enqueue);
|
|
59
|
+
this.stream.once("error", this.error);
|
|
60
|
+
this.stream.once("end", this.close);
|
|
61
|
+
this.stream.once("close", this.close);
|
|
62
|
+
}
|
|
63
|
+
pull() {
|
|
64
|
+
this.resume();
|
|
65
|
+
}
|
|
66
|
+
cancel(reason) {
|
|
67
|
+
if (this.stream.destroy) {
|
|
68
|
+
this.stream.destroy(reason);
|
|
69
|
+
}
|
|
70
|
+
this.stream.off("data", this.enqueue);
|
|
71
|
+
this.stream.off("error", this.error);
|
|
72
|
+
this.stream.off("end", this.close);
|
|
73
|
+
this.stream.off("close", this.close);
|
|
74
|
+
}
|
|
75
|
+
enqueue(chunk) {
|
|
76
|
+
if (this.controller) {
|
|
77
|
+
try {
|
|
78
|
+
const bytes = chunk instanceof Uint8Array ? chunk : Buffer.from(chunk);
|
|
79
|
+
const available = (this.controller.desiredSize || 0) - bytes.byteLength;
|
|
80
|
+
this.controller.enqueue(bytes);
|
|
81
|
+
if (available <= 0) {
|
|
82
|
+
this.pause();
|
|
83
|
+
}
|
|
84
|
+
} catch (error) {
|
|
85
|
+
this.controller.error(new Error("Could not create Buffer, chunk must be of type string or an instance of Buffer, ArrayBuffer, or Array or an Array-like Object"));
|
|
86
|
+
this.cancel();
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
pause() {
|
|
91
|
+
if (this.stream.pause) {
|
|
92
|
+
this.stream.pause();
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
resume() {
|
|
96
|
+
if (this.stream.readable && this.stream.resume) {
|
|
97
|
+
this.stream.resume();
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
close() {
|
|
101
|
+
if (this.controller) {
|
|
102
|
+
this.controller.close();
|
|
103
|
+
delete this.controller;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
error(error) {
|
|
107
|
+
if (this.controller) {
|
|
108
|
+
this.controller.error(error);
|
|
109
|
+
delete this.controller;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
constructor(stream) {
|
|
113
|
+
this.highWaterMark = stream.readableHighWaterMark || new Stream.Readable().readableHighWaterMark;
|
|
114
|
+
this.accumalatedSize = 0;
|
|
115
|
+
this.stream = stream;
|
|
116
|
+
this.enqueue = this.enqueue.bind(this);
|
|
117
|
+
this.error = this.error.bind(this);
|
|
118
|
+
this.close = this.close.bind(this);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
export {
|
|
122
|
+
createReadableStreamFromReadable,
|
|
123
|
+
readableStreamToString,
|
|
124
|
+
writeAsyncIterableToWritable,
|
|
125
|
+
writeReadableStreamToWritable
|
|
126
|
+
};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
const AGGRED_DIR = {
|
|
2
|
+
mock: "config/mock",
|
|
3
|
+
server: "server",
|
|
4
|
+
api: "api",
|
|
5
|
+
shared: "shared",
|
|
6
|
+
lambda: "lambda"
|
|
7
|
+
};
|
|
8
|
+
const REPLACE_REG = {
|
|
9
|
+
before: {
|
|
10
|
+
head: "<head[^>]*>",
|
|
11
|
+
body: "<body[^>]*>"
|
|
12
|
+
},
|
|
13
|
+
after: {
|
|
14
|
+
head: "</head>",
|
|
15
|
+
body: "</body>"
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
var ServerReportTimings;
|
|
19
|
+
(function(ServerReportTimings2) {
|
|
20
|
+
ServerReportTimings2["SERVER_HANDLE_REQUEST"] = "server-handle-request";
|
|
21
|
+
ServerReportTimings2["SERVER_MIDDLEWARE"] = "server-middleware";
|
|
22
|
+
ServerReportTimings2["SERVER_HOOK_AFTER_RENDER"] = "server-hook-after-render";
|
|
23
|
+
ServerReportTimings2["SERVER_HOOK_AFTER_MATCH"] = "server-hook-after-match";
|
|
24
|
+
})(ServerReportTimings || (ServerReportTimings = {}));
|
|
25
|
+
const X_RENDER_CACHE = "x-render-cache";
|
|
26
|
+
export {
|
|
27
|
+
AGGRED_DIR,
|
|
28
|
+
REPLACE_REG,
|
|
29
|
+
ServerReportTimings,
|
|
30
|
+
X_RENDER_CACHE
|
|
31
|
+
};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { createErrorHtml } from "./utils";
|
|
2
|
+
import { AGGRED_DIR } from "./constants";
|
|
3
|
+
import { favionFallbackMiddleware, injectReporter, injectLogger, getRenderHandler, bindRenderHandler, logHandler } from "./middlewares";
|
|
4
|
+
import { createServerBase } from "./serverBase";
|
|
5
|
+
export {
|
|
6
|
+
AGGRED_DIR,
|
|
7
|
+
bindRenderHandler,
|
|
8
|
+
createErrorHtml,
|
|
9
|
+
createServerBase,
|
|
10
|
+
favionFallbackMiddleware,
|
|
11
|
+
getRenderHandler,
|
|
12
|
+
injectLogger,
|
|
13
|
+
injectReporter,
|
|
14
|
+
logHandler
|
|
15
|
+
};
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { _ as _class_private_field_get } from "@swc/helpers/_/_class_private_field_get";
|
|
2
|
+
import { _ as _class_private_field_init } from "@swc/helpers/_/_class_private_field_init";
|
|
3
|
+
import { _ as _class_private_field_set } from "@swc/helpers/_/_class_private_field_set";
|
|
4
|
+
import { getCookie } from "hono/cookie";
|
|
5
|
+
import { getHost } from "../../utils";
|
|
6
|
+
function createBaseHookContext(c) {
|
|
7
|
+
const logger = c.get("logger");
|
|
8
|
+
const metrics = c.get("metrics");
|
|
9
|
+
return {
|
|
10
|
+
request: new BaseHookRequest(c),
|
|
11
|
+
response: new BaseHookResponse(c),
|
|
12
|
+
logger,
|
|
13
|
+
metrics
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
var _headers = /* @__PURE__ */ new WeakMap();
|
|
17
|
+
class BaseHookRequest {
|
|
18
|
+
get url() {
|
|
19
|
+
return this.req.path;
|
|
20
|
+
}
|
|
21
|
+
// TODO: remove next major version
|
|
22
|
+
set url(_u) {
|
|
23
|
+
}
|
|
24
|
+
get host() {
|
|
25
|
+
return getHost(this.req.raw);
|
|
26
|
+
}
|
|
27
|
+
// TODO: remove next major version
|
|
28
|
+
set host(_h) {
|
|
29
|
+
}
|
|
30
|
+
get pathname() {
|
|
31
|
+
return this.req.path;
|
|
32
|
+
}
|
|
33
|
+
// TODO: remove next major version
|
|
34
|
+
set pathname(_p) {
|
|
35
|
+
}
|
|
36
|
+
get query() {
|
|
37
|
+
return this.req.query();
|
|
38
|
+
}
|
|
39
|
+
// TODO: remove next major version
|
|
40
|
+
set query(_q) {
|
|
41
|
+
}
|
|
42
|
+
get headers() {
|
|
43
|
+
return _class_private_field_get(this, _headers);
|
|
44
|
+
}
|
|
45
|
+
// TODO: remove next major version
|
|
46
|
+
set headers(_h) {
|
|
47
|
+
}
|
|
48
|
+
get cookies() {
|
|
49
|
+
return {
|
|
50
|
+
// FIXME: ModernRequest Type Error
|
|
51
|
+
get: (key) => {
|
|
52
|
+
return getCookie(this.c, key);
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
get cookie() {
|
|
57
|
+
return this.req.header("cookie");
|
|
58
|
+
}
|
|
59
|
+
// TODO: remove next major version
|
|
60
|
+
set cookie(_c) {
|
|
61
|
+
}
|
|
62
|
+
constructor(c) {
|
|
63
|
+
_class_private_field_init(this, _headers, {
|
|
64
|
+
writable: true,
|
|
65
|
+
value: void 0
|
|
66
|
+
});
|
|
67
|
+
this.headersData = {};
|
|
68
|
+
this.c = c;
|
|
69
|
+
this.req = c.req;
|
|
70
|
+
const rawHeaders = this.req.raw.headers;
|
|
71
|
+
rawHeaders.forEach((value, key) => {
|
|
72
|
+
this.headersData[key] = value;
|
|
73
|
+
});
|
|
74
|
+
_class_private_field_set(this, _headers, new Proxy(this.headersData, {
|
|
75
|
+
get(target, p) {
|
|
76
|
+
return target[p];
|
|
77
|
+
},
|
|
78
|
+
set(target, p, newValue) {
|
|
79
|
+
target[p] = newValue;
|
|
80
|
+
rawHeaders.set(p, newValue);
|
|
81
|
+
return true;
|
|
82
|
+
}
|
|
83
|
+
}));
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
class BaseHookResponse {
|
|
87
|
+
get(key) {
|
|
88
|
+
return this.c.res.headers.get(key);
|
|
89
|
+
}
|
|
90
|
+
set(key, value) {
|
|
91
|
+
if ([
|
|
92
|
+
"set-cookie",
|
|
93
|
+
"Set-Cookie"
|
|
94
|
+
].includes(key)) {
|
|
95
|
+
this.c.header(key, value.toString(), {
|
|
96
|
+
append: true
|
|
97
|
+
});
|
|
98
|
+
} else {
|
|
99
|
+
this.c.header(key, value.toString());
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
status(code) {
|
|
103
|
+
this.c.status(code);
|
|
104
|
+
}
|
|
105
|
+
get cookies() {
|
|
106
|
+
const setCookie = (key, value) => {
|
|
107
|
+
this.c.header("set-cookie", `${key}=${value}`, {
|
|
108
|
+
append: true
|
|
109
|
+
});
|
|
110
|
+
};
|
|
111
|
+
const clearCookie = () => {
|
|
112
|
+
this.c.header("set-cookie", void 0);
|
|
113
|
+
};
|
|
114
|
+
return {
|
|
115
|
+
set: setCookie,
|
|
116
|
+
clear: clearCookie
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
raw(body, options) {
|
|
120
|
+
this.c.res = this.c.newResponse(body, options);
|
|
121
|
+
this.private_overrided = true;
|
|
122
|
+
}
|
|
123
|
+
constructor(c) {
|
|
124
|
+
this.private_overrided = false;
|
|
125
|
+
this.c = c;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
export {
|
|
129
|
+
createBaseHookContext
|
|
130
|
+
};
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { RouterAPI } from "./routerApi";
|
|
2
|
+
import { TemplateApi } from "./template";
|
|
3
|
+
import { createBaseHookContext } from "./base";
|
|
4
|
+
function getAfterMatchCtx(entryName, baseHookCtx) {
|
|
5
|
+
const afterMatchCtx = baseHookCtx;
|
|
6
|
+
afterMatchCtx.router = new RouterAPI(entryName);
|
|
7
|
+
return afterMatchCtx;
|
|
8
|
+
}
|
|
9
|
+
async function getAfterRenderCtx(c, baseHookCtx, route) {
|
|
10
|
+
const afterRenderCtx = baseHookCtx;
|
|
11
|
+
const resBody = await c.res.text();
|
|
12
|
+
afterRenderCtx.template = new TemplateApi(resBody);
|
|
13
|
+
afterRenderCtx.route = route;
|
|
14
|
+
return afterRenderCtx;
|
|
15
|
+
}
|
|
16
|
+
function createCustomMiddlewaresCtx(c, locals) {
|
|
17
|
+
var _c_env_node, _c_env_node1;
|
|
18
|
+
const baseContext = createBaseHookContext(c);
|
|
19
|
+
const reporter = c.get("reporter");
|
|
20
|
+
return {
|
|
21
|
+
...baseContext,
|
|
22
|
+
reporter,
|
|
23
|
+
response: {
|
|
24
|
+
...baseContext.response,
|
|
25
|
+
locals
|
|
26
|
+
},
|
|
27
|
+
source: {
|
|
28
|
+
req: (_c_env_node = c.env.node) === null || _c_env_node === void 0 ? void 0 : _c_env_node.req,
|
|
29
|
+
res: (_c_env_node1 = c.env.node) === null || _c_env_node1 === void 0 ? void 0 : _c_env_node1.res
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
function createAfterStreamingRenderContext(baseHookCtx, route) {
|
|
34
|
+
const streamingRenderCtx = baseHookCtx;
|
|
35
|
+
streamingRenderCtx.route = route;
|
|
36
|
+
return (chunk) => {
|
|
37
|
+
streamingRenderCtx.chunk = chunk;
|
|
38
|
+
return streamingRenderCtx;
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
export {
|
|
42
|
+
createAfterStreamingRenderContext,
|
|
43
|
+
createCustomMiddlewaresCtx,
|
|
44
|
+
getAfterMatchCtx,
|
|
45
|
+
getAfterRenderCtx
|
|
46
|
+
};
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { time } from "@modern-js/runtime-utils/time";
|
|
2
|
+
import { transformResponse } from "../../utils";
|
|
3
|
+
import { ServerReportTimings } from "../../constants";
|
|
4
|
+
import { getAfterMatchCtx, getAfterRenderCtx, createCustomMiddlewaresCtx, createAfterStreamingRenderContext } from "./context";
|
|
5
|
+
import { createBaseHookContext } from "./base";
|
|
6
|
+
const noop = () => {
|
|
7
|
+
};
|
|
8
|
+
const isHtmlResponse = (response) => {
|
|
9
|
+
const contentType = response.headers.get("content-type");
|
|
10
|
+
return contentType === null || contentType === void 0 ? void 0 : contentType.includes("text/html");
|
|
11
|
+
};
|
|
12
|
+
class CustomServer {
|
|
13
|
+
getHookMiddleware(entryName, routes) {
|
|
14
|
+
return async (c, next) => {
|
|
15
|
+
const routeInfo = routes.find((route) => route.entryName === entryName);
|
|
16
|
+
const reporter = c.get("reporter");
|
|
17
|
+
const baseHookCtx = createBaseHookContext(c);
|
|
18
|
+
const afterMatchCtx = getAfterMatchCtx(entryName, baseHookCtx);
|
|
19
|
+
const getCost = time();
|
|
20
|
+
await this.runner.afterMatch(afterMatchCtx, {
|
|
21
|
+
onLast: noop
|
|
22
|
+
});
|
|
23
|
+
const cost = getCost();
|
|
24
|
+
cost && (reporter === null || reporter === void 0 ? void 0 : reporter.reportTiming(ServerReportTimings.SERVER_HOOK_AFTER_MATCH, cost));
|
|
25
|
+
const { url, status } = afterMatchCtx.router;
|
|
26
|
+
if (url) {
|
|
27
|
+
return c.redirect(url, status);
|
|
28
|
+
}
|
|
29
|
+
const { current } = afterMatchCtx.router;
|
|
30
|
+
if (current !== entryName) {
|
|
31
|
+
const rewriteRoute = routes.find((route) => route.entryName === current);
|
|
32
|
+
if (rewriteRoute) {
|
|
33
|
+
return this.serverBase.request(rewriteRoute.urlPath);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
if (c.finalized) {
|
|
37
|
+
return void 0;
|
|
38
|
+
}
|
|
39
|
+
await next();
|
|
40
|
+
if (c.finalized && (!c.res.body || !isHtmlResponse(c.res))) {
|
|
41
|
+
return void 0;
|
|
42
|
+
}
|
|
43
|
+
if (routeInfo.isStream) {
|
|
44
|
+
const afterStreamingRenderContext = createAfterStreamingRenderContext(baseHookCtx, routeInfo);
|
|
45
|
+
c.res = transformResponse(c.res, (chunk) => {
|
|
46
|
+
const context = afterStreamingRenderContext(chunk);
|
|
47
|
+
return this.runner.afterStreamingRender(context, {
|
|
48
|
+
onLast: ({ chunk: chunk2 }) => chunk2
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
} else {
|
|
52
|
+
const afterRenderCtx = await getAfterRenderCtx(c, baseHookCtx, routeInfo);
|
|
53
|
+
const getCost2 = time();
|
|
54
|
+
await this.runner.afterRender(afterRenderCtx, {
|
|
55
|
+
onLast: noop
|
|
56
|
+
});
|
|
57
|
+
const cost2 = getCost2();
|
|
58
|
+
cost2 && (reporter === null || reporter === void 0 ? void 0 : reporter.reportTiming(ServerReportTimings.SERVER_HOOK_AFTER_RENDER, cost2));
|
|
59
|
+
if (afterRenderCtx.response.private_overrided) {
|
|
60
|
+
return void 0;
|
|
61
|
+
}
|
|
62
|
+
const newBody = afterRenderCtx.template.get();
|
|
63
|
+
c.res = c.body(newBody);
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
getServerMiddleware() {
|
|
68
|
+
return async (c, next) => {
|
|
69
|
+
var _c_env;
|
|
70
|
+
const serverMiddleware = await this.serverMiddlewarePromise;
|
|
71
|
+
if (!serverMiddleware) {
|
|
72
|
+
return next();
|
|
73
|
+
}
|
|
74
|
+
const reporter = c.get("reporter");
|
|
75
|
+
const locals = {};
|
|
76
|
+
const customMiddlewareCtx = createCustomMiddlewaresCtx(c, locals);
|
|
77
|
+
const getCost = time();
|
|
78
|
+
await serverMiddleware(customMiddlewareCtx);
|
|
79
|
+
const cost = getCost();
|
|
80
|
+
cost && (reporter === null || reporter === void 0 ? void 0 : reporter.reportTiming(ServerReportTimings.SERVER_MIDDLEWARE, cost));
|
|
81
|
+
c.set("locals", locals);
|
|
82
|
+
if ((_c_env = c.env) === null || _c_env === void 0 ? void 0 : _c_env.node.res.headersSent) {
|
|
83
|
+
return void 0;
|
|
84
|
+
}
|
|
85
|
+
if (!c.finalized) {
|
|
86
|
+
return next();
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
constructor(runner, serverBase, pwd) {
|
|
91
|
+
this.runner = runner;
|
|
92
|
+
this.serverBase = serverBase;
|
|
93
|
+
const webExtension = [];
|
|
94
|
+
this.serverMiddlewarePromise = runner.prepareWebServer({
|
|
95
|
+
pwd,
|
|
96
|
+
config: {
|
|
97
|
+
middleware: webExtension
|
|
98
|
+
}
|
|
99
|
+
}, {
|
|
100
|
+
onLast: () => null
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
export {
|
|
105
|
+
CustomServer
|
|
106
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
class RouterAPI {
|
|
2
|
+
redirect(url, status = 302) {
|
|
3
|
+
this.url = url;
|
|
4
|
+
this.status = status;
|
|
5
|
+
}
|
|
6
|
+
rewrite(entryName) {
|
|
7
|
+
this.current = entryName;
|
|
8
|
+
}
|
|
9
|
+
use(entryName) {
|
|
10
|
+
this.rewrite(entryName);
|
|
11
|
+
}
|
|
12
|
+
constructor(entryName) {
|
|
13
|
+
this.current = entryName;
|
|
14
|
+
this.status = 200;
|
|
15
|
+
this.url = "";
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
export {
|
|
19
|
+
RouterAPI
|
|
20
|
+
};
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { REPLACE_REG } from "../../constants";
|
|
2
|
+
class TemplateApi {
|
|
3
|
+
set(content) {
|
|
4
|
+
this.body = content;
|
|
5
|
+
}
|
|
6
|
+
get() {
|
|
7
|
+
return this.body;
|
|
8
|
+
}
|
|
9
|
+
prependHead(fragment) {
|
|
10
|
+
const { head } = REPLACE_REG.before;
|
|
11
|
+
this.replaceBody(new RegExp(head), (beforeHead) => `${beforeHead}${fragment}`);
|
|
12
|
+
}
|
|
13
|
+
appendHead(fragment) {
|
|
14
|
+
const { head } = REPLACE_REG.after;
|
|
15
|
+
this.replaceBody(head, () => `${fragment}${head}`);
|
|
16
|
+
}
|
|
17
|
+
prependBody(fragment) {
|
|
18
|
+
const { body } = REPLACE_REG.before;
|
|
19
|
+
this.replaceBody(new RegExp(body), (beforeBody) => `${beforeBody}${fragment}`);
|
|
20
|
+
}
|
|
21
|
+
appendBody(fragment) {
|
|
22
|
+
const { body } = REPLACE_REG.after;
|
|
23
|
+
this.replaceBody(body, () => `${fragment}${body}`);
|
|
24
|
+
}
|
|
25
|
+
replaceBody(searchValue, replaceCb) {
|
|
26
|
+
this.body = this.body.replace(searchValue, replaceCb);
|
|
27
|
+
}
|
|
28
|
+
constructor(body) {
|
|
29
|
+
this.body = body;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
export {
|
|
33
|
+
TemplateApi
|
|
34
|
+
};
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { getPathname } from "../utils";
|
|
2
|
+
var LogPrefix;
|
|
3
|
+
(function(LogPrefix2) {
|
|
4
|
+
LogPrefix2["Outgoing"] = "-->";
|
|
5
|
+
LogPrefix2["Incoming"] = "<--";
|
|
6
|
+
LogPrefix2["Error"] = "xxx";
|
|
7
|
+
})(LogPrefix || (LogPrefix = {}));
|
|
8
|
+
const humanize = (times) => {
|
|
9
|
+
const [delimiter, separator] = [
|
|
10
|
+
",",
|
|
11
|
+
"."
|
|
12
|
+
];
|
|
13
|
+
const orderTimes = times.map((v) => v.replace(/(\d)(?=(\d\d\d)+(?!\d))/g, `$1${delimiter}`));
|
|
14
|
+
return orderTimes.join(separator);
|
|
15
|
+
};
|
|
16
|
+
const time = (start) => {
|
|
17
|
+
const delta = Date.now() - start;
|
|
18
|
+
return humanize([
|
|
19
|
+
delta < 1e3 ? `${delta}ms` : `${Math.round(delta / 1e3)}s`
|
|
20
|
+
]);
|
|
21
|
+
};
|
|
22
|
+
const colorStatus = (status) => {
|
|
23
|
+
const out = {
|
|
24
|
+
7: `\x1B[35m${status}\x1B[0m`,
|
|
25
|
+
5: `\x1B[31m${status}\x1B[0m`,
|
|
26
|
+
4: `\x1B[33m${status}\x1B[0m`,
|
|
27
|
+
3: `\x1B[36m${status}\x1B[0m`,
|
|
28
|
+
2: `\x1B[32m${status}\x1B[0m`,
|
|
29
|
+
1: `\x1B[32m${status}\x1B[0m`,
|
|
30
|
+
0: `\x1B[33m${status}\x1B[0m`
|
|
31
|
+
};
|
|
32
|
+
const calculateStatus = Math.floor(status / 100);
|
|
33
|
+
return out[calculateStatus];
|
|
34
|
+
};
|
|
35
|
+
function log(fn, prefix, method, path, status = 0, elapsed) {
|
|
36
|
+
const out = prefix === "<--" ? ` ${prefix} ${method} ${path}` : ` ${prefix} ${method} ${path} ${colorStatus(status)} ${elapsed}`;
|
|
37
|
+
fn(out);
|
|
38
|
+
}
|
|
39
|
+
function logHandler() {
|
|
40
|
+
return async function logger(c, next) {
|
|
41
|
+
const { method } = c.req;
|
|
42
|
+
const logger2 = c.get("logger");
|
|
43
|
+
const path = getPathname(c.req.raw);
|
|
44
|
+
const logFn = logger2.info;
|
|
45
|
+
log(logFn, "<--", method, path);
|
|
46
|
+
const start = Date.now();
|
|
47
|
+
await next();
|
|
48
|
+
log(logFn, "-->", method, path, c.res.status, time(start));
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
export {
|
|
52
|
+
logHandler
|
|
53
|
+
};
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { time } from "@modern-js/runtime-utils/time";
|
|
2
|
+
import { ServerReportTimings } from "../constants";
|
|
3
|
+
const defaultReporter = {
|
|
4
|
+
init() {
|
|
5
|
+
},
|
|
6
|
+
reportError() {
|
|
7
|
+
},
|
|
8
|
+
reportTiming() {
|
|
9
|
+
},
|
|
10
|
+
reportInfo() {
|
|
11
|
+
},
|
|
12
|
+
reportWarn() {
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
function injectReporter() {
|
|
16
|
+
return async (c, next) => {
|
|
17
|
+
const reporter = c.get("reporter");
|
|
18
|
+
if (!reporter) {
|
|
19
|
+
c.set("reporter", defaultReporter);
|
|
20
|
+
}
|
|
21
|
+
await next();
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
function initReporter(entryName) {
|
|
25
|
+
return async (c, next) => {
|
|
26
|
+
const reporter = c.get("reporter");
|
|
27
|
+
if (!reporter) {
|
|
28
|
+
await next();
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
await reporter.init({
|
|
32
|
+
entryName
|
|
33
|
+
});
|
|
34
|
+
const getCost = time();
|
|
35
|
+
await next();
|
|
36
|
+
const cost = getCost();
|
|
37
|
+
reporter.reportTiming(ServerReportTimings.SERVER_HANDLE_REQUEST, cost);
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
function injectLogger(inputLogger) {
|
|
41
|
+
return async (c, next) => {
|
|
42
|
+
const logger = c.get("logger");
|
|
43
|
+
if (!logger && inputLogger) {
|
|
44
|
+
c.set("logger", inputLogger);
|
|
45
|
+
}
|
|
46
|
+
await next();
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
function injectMetrics(inputMetrics) {
|
|
50
|
+
return async (c, next) => {
|
|
51
|
+
const metrics = c.get("metrics");
|
|
52
|
+
if (!metrics) {
|
|
53
|
+
c.set("metrics", inputMetrics);
|
|
54
|
+
}
|
|
55
|
+
await next();
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
export {
|
|
59
|
+
initReporter,
|
|
60
|
+
injectLogger,
|
|
61
|
+
injectMetrics,
|
|
62
|
+
injectReporter
|
|
63
|
+
};
|