@modern-js/prod-server 2.42.2 → 2.44.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/libs/{render/cache/page-caches/index.js → hook-api/afterRenderForStream.js} +12 -14
- package/dist/cjs/libs/hook-api/index.js +12 -0
- package/dist/cjs/libs/render/index.js +4 -14
- package/dist/cjs/libs/render/ssr.js +15 -4
- package/dist/cjs/libs/render/{cache/page-caches/lru.js → ssrCache/cacheMod.js} +21 -31
- package/dist/cjs/libs/render/ssrCache/index.js +81 -0
- package/dist/cjs/libs/render/ssrCache/manager.js +104 -0
- package/dist/cjs/libs/render/static.js +5 -5
- package/dist/cjs/server/index.js +2 -0
- package/dist/cjs/server/modernServer.js +2 -9
- package/dist/esm/libs/hook-api/afterRenderForStream.js +33 -0
- package/dist/esm/libs/hook-api/index.js +10 -0
- package/dist/esm/libs/render/index.js +4 -14
- package/dist/esm/libs/render/ssr.js +19 -5
- package/dist/esm/libs/render/ssrCache/cacheMod.js +33 -0
- package/dist/esm/libs/render/ssrCache/index.js +146 -0
- package/dist/esm/libs/render/ssrCache/manager.js +159 -0
- package/dist/esm/libs/render/static.js +5 -5
- package/dist/esm/server/index.js +14 -4
- package/dist/esm/server/modernServer.js +32 -42
- package/dist/esm-node/libs/hook-api/afterRenderForStream.js +10 -0
- package/dist/esm-node/libs/hook-api/index.js +11 -0
- package/dist/esm-node/libs/render/index.js +4 -14
- package/dist/esm-node/libs/render/ssr.js +15 -4
- package/dist/esm-node/libs/render/ssrCache/cacheMod.js +22 -0
- package/dist/esm-node/libs/render/ssrCache/index.js +57 -0
- package/dist/esm-node/libs/render/ssrCache/manager.js +80 -0
- package/dist/esm-node/libs/render/static.js +5 -5
- package/dist/esm-node/server/index.js +2 -0
- package/dist/esm-node/server/modernServer.js +2 -9
- package/dist/types/libs/context/index.d.ts +2 -0
- package/dist/types/libs/hook-api/afterRenderForStream.d.ts +4 -0
- package/dist/types/libs/hook-api/index.d.ts +2 -1
- package/dist/types/libs/preload/flushServerHeader.d.ts +2 -0
- package/dist/types/libs/proxy.d.ts +2 -0
- package/dist/types/libs/render/ssr.d.ts +5 -5
- package/dist/types/libs/render/ssrCache/cacheMod.d.ts +8 -0
- package/dist/types/libs/render/ssrCache/index.d.ts +7 -0
- package/dist/types/libs/render/ssrCache/manager.d.ts +14 -0
- package/dist/types/renderHtml.d.ts +2 -0
- package/dist/types/server/index.d.ts +2 -0
- package/dist/types/server/modernServer.d.ts +2 -3
- package/dist/types/type.d.ts +2 -0
- package/package.json +8 -11
- package/dist/cjs/libs/render/cache/__tests__/cache.fun.test.js +0 -95
- package/dist/cjs/libs/render/cache/__tests__/cache.test.js +0 -223
- package/dist/cjs/libs/render/cache/__tests__/cacheable.js +0 -93
- package/dist/cjs/libs/render/cache/__tests__/error-configuration.js +0 -71
- package/dist/cjs/libs/render/cache/__tests__/matched-cache.js +0 -173
- package/dist/cjs/libs/render/cache/index.js +0 -92
- package/dist/cjs/libs/render/cache/spr.js +0 -247
- package/dist/cjs/libs/render/cache/type.js +0 -16
- package/dist/cjs/libs/render/cache/util.js +0 -121
- package/dist/cjs/libs/render/reader.js +0 -131
- package/dist/esm/libs/render/cache/__tests__/cache.fun.test.js +0 -124
- package/dist/esm/libs/render/cache/__tests__/cache.test.js +0 -612
- package/dist/esm/libs/render/cache/__tests__/cacheable.js +0 -69
- package/dist/esm/libs/render/cache/__tests__/error-configuration.js +0 -47
- package/dist/esm/libs/render/cache/__tests__/matched-cache.js +0 -149
- package/dist/esm/libs/render/cache/index.js +0 -204
- package/dist/esm/libs/render/cache/page-caches/index.js +0 -34
- package/dist/esm/libs/render/cache/page-caches/lru.js +0 -57
- package/dist/esm/libs/render/cache/spr.js +0 -345
- package/dist/esm/libs/render/cache/type.js +0 -0
- package/dist/esm/libs/render/cache/util.js +0 -105
- package/dist/esm/libs/render/reader.js +0 -196
- package/dist/esm-node/libs/render/cache/__tests__/cache.fun.test.js +0 -72
- package/dist/esm-node/libs/render/cache/__tests__/cache.test.js +0 -222
- package/dist/esm-node/libs/render/cache/__tests__/cacheable.js +0 -69
- package/dist/esm-node/libs/render/cache/__tests__/error-configuration.js +0 -47
- package/dist/esm-node/libs/render/cache/__tests__/matched-cache.js +0 -149
- package/dist/esm-node/libs/render/cache/index.js +0 -72
- package/dist/esm-node/libs/render/cache/page-caches/index.js +0 -12
- package/dist/esm-node/libs/render/cache/page-caches/lru.js +0 -32
- package/dist/esm-node/libs/render/cache/spr.js +0 -212
- package/dist/esm-node/libs/render/cache/type.js +0 -0
- package/dist/esm-node/libs/render/cache/util.js +0 -80
- package/dist/esm-node/libs/render/reader.js +0 -93
- package/dist/types/libs/render/cache/__tests__/cache.fun.test.d.ts +0 -1
- package/dist/types/libs/render/cache/__tests__/cache.test.d.ts +0 -1
- package/dist/types/libs/render/cache/__tests__/cacheable.d.ts +0 -62
- package/dist/types/libs/render/cache/__tests__/error-configuration.d.ts +0 -28
- package/dist/types/libs/render/cache/__tests__/matched-cache.d.ts +0 -124
- package/dist/types/libs/render/cache/index.d.ts +0 -6
- package/dist/types/libs/render/cache/page-caches/index.d.ts +0 -2
- package/dist/types/libs/render/cache/page-caches/lru.d.ts +0 -15
- package/dist/types/libs/render/cache/spr.d.ts +0 -22
- package/dist/types/libs/render/cache/type.d.ts +0 -48
- package/dist/types/libs/render/cache/util.d.ts +0 -18
- package/dist/types/libs/render/reader.d.ts +0 -20
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { Transform } from "stream";
|
|
2
|
+
import { createMemoryStorage } from "@modern-js/runtime-utils/storer";
|
|
3
|
+
import { cacheMod } from "./cacheMod";
|
|
4
|
+
import { CacheManager } from "./manager";
|
|
5
|
+
const cacheStorage = createMemoryStorage("__ssr__cache");
|
|
6
|
+
async function ssrCache(req, render, ssrContext) {
|
|
7
|
+
const { customContainer, cacheOption } = cacheMod;
|
|
8
|
+
const cacheControl = await matchCacheControl(req, cacheOption);
|
|
9
|
+
const cacheManager = new CacheManager(customContainer ? customContainer : cacheStorage);
|
|
10
|
+
if (cacheControl) {
|
|
11
|
+
return cacheManager.getCacheResult(req, cacheControl, render, ssrContext);
|
|
12
|
+
} else {
|
|
13
|
+
const renderResult = await render(ssrContext);
|
|
14
|
+
if (typeof renderResult === "string") {
|
|
15
|
+
return renderResult;
|
|
16
|
+
} else {
|
|
17
|
+
const stream = new Transform({
|
|
18
|
+
write(chunk, _, callback) {
|
|
19
|
+
this.push(chunk);
|
|
20
|
+
callback();
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
return renderResult(stream);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
async function matchCacheControl(req, cacheOption) {
|
|
28
|
+
if (!cacheOption) {
|
|
29
|
+
return void 0;
|
|
30
|
+
} else if (isCacheControl(cacheOption)) {
|
|
31
|
+
return cacheOption;
|
|
32
|
+
} else if (isCacheOptionProvider(cacheOption)) {
|
|
33
|
+
return cacheOption(req);
|
|
34
|
+
} else {
|
|
35
|
+
const url = req.url;
|
|
36
|
+
const options = Object.entries(cacheOption);
|
|
37
|
+
for (const [key, option] of options) {
|
|
38
|
+
if (key === "*" || new RegExp(key).test(url)) {
|
|
39
|
+
if (typeof option === "function") {
|
|
40
|
+
return option(req);
|
|
41
|
+
} else {
|
|
42
|
+
return option;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
return void 0;
|
|
47
|
+
}
|
|
48
|
+
function isCacheOptionProvider(option) {
|
|
49
|
+
return typeof option === "function";
|
|
50
|
+
}
|
|
51
|
+
function isCacheControl(option) {
|
|
52
|
+
return typeof option === "object" && option !== null && "maxAge" in option;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
export {
|
|
56
|
+
ssrCache
|
|
57
|
+
};
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { _ as _define_property } from "@swc/helpers/_/_define_property";
|
|
2
|
+
import { Transform } from "stream";
|
|
3
|
+
class CacheManager {
|
|
4
|
+
async getCacheResult(req, cacheControl, render, ssrContext) {
|
|
5
|
+
const key = this.computedKey(req, cacheControl);
|
|
6
|
+
const value = await this.container.get(key);
|
|
7
|
+
const { maxAge, staleWhileRevalidate } = cacheControl;
|
|
8
|
+
const ttl = maxAge + staleWhileRevalidate;
|
|
9
|
+
if (value) {
|
|
10
|
+
const cache = JSON.parse(value);
|
|
11
|
+
const interval = Date.now() - cache.cursor;
|
|
12
|
+
if (interval <= maxAge) {
|
|
13
|
+
return cache.val;
|
|
14
|
+
} else if (interval <= staleWhileRevalidate + maxAge) {
|
|
15
|
+
this.processCache(key, render, ssrContext, ttl);
|
|
16
|
+
return cache.val;
|
|
17
|
+
} else {
|
|
18
|
+
return this.processCache(key, render, ssrContext, ttl);
|
|
19
|
+
}
|
|
20
|
+
} else {
|
|
21
|
+
return this.processCache(key, render, ssrContext, ttl);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
async processCache(key, render, ssrContext, ttl) {
|
|
25
|
+
const renderResult = await render(ssrContext);
|
|
26
|
+
if (typeof renderResult === "string") {
|
|
27
|
+
const current = Date.now();
|
|
28
|
+
const cache = {
|
|
29
|
+
val: renderResult,
|
|
30
|
+
cursor: current
|
|
31
|
+
};
|
|
32
|
+
await this.container.set(key, JSON.stringify(cache), {
|
|
33
|
+
ttl
|
|
34
|
+
});
|
|
35
|
+
return renderResult;
|
|
36
|
+
} else {
|
|
37
|
+
let html;
|
|
38
|
+
const stream = new Transform({
|
|
39
|
+
write(chunk, _, callback) {
|
|
40
|
+
html += chunk.toString();
|
|
41
|
+
this.push(chunk);
|
|
42
|
+
callback();
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
stream.on("close", () => {
|
|
46
|
+
const current = Date.now();
|
|
47
|
+
const cache = {
|
|
48
|
+
val: html,
|
|
49
|
+
cursor: current
|
|
50
|
+
};
|
|
51
|
+
this.container.set(key, JSON.stringify(cache), {
|
|
52
|
+
ttl
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
return renderResult(stream);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
computedKey(req, cacheControl) {
|
|
59
|
+
const { url } = req;
|
|
60
|
+
const [pathname] = url.split("?");
|
|
61
|
+
const { customKey } = cacheControl;
|
|
62
|
+
const defaultKey = pathname.replace(/.+\/+$/, "");
|
|
63
|
+
if (customKey) {
|
|
64
|
+
if (typeof customKey === "string") {
|
|
65
|
+
return customKey;
|
|
66
|
+
} else {
|
|
67
|
+
return customKey(defaultKey);
|
|
68
|
+
}
|
|
69
|
+
} else {
|
|
70
|
+
return defaultKey;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
constructor(container) {
|
|
74
|
+
_define_property(this, "container", void 0);
|
|
75
|
+
this.container = container;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
export {
|
|
79
|
+
CacheManager
|
|
80
|
+
};
|
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
import path from "path";
|
|
2
2
|
import { mime } from "@modern-js/utils";
|
|
3
|
-
import {
|
|
3
|
+
import { fileReader } from "@modern-js/runtime-utils/fileReader";
|
|
4
4
|
async function handleDirectory(ctx, entryPath, urlPath) {
|
|
5
5
|
const { path: pathname } = ctx;
|
|
6
6
|
const filepath = path.join(entryPath, trimLeft(pathname, urlPath));
|
|
7
|
-
let content = await readFile(filepath);
|
|
7
|
+
let content = await fileReader.readFile(filepath);
|
|
8
8
|
let contentType = mime.contentType(path.extname(filepath) || "");
|
|
9
9
|
if (!content) {
|
|
10
10
|
if (pathname.endsWith("/")) {
|
|
11
|
-
content = await readFile(`${filepath}index.html`);
|
|
11
|
+
content = await fileReader.readFile(`${filepath}index.html`);
|
|
12
12
|
} else if (!pathname.includes(".")) {
|
|
13
|
-
content = await readFile(`${filepath}.html`);
|
|
13
|
+
content = await fileReader.readFile(`${filepath}.html`);
|
|
14
14
|
if (!content) {
|
|
15
|
-
content = await readFile(`${filepath}/index.html`);
|
|
15
|
+
content = await fileReader.readFile(`${filepath}/index.html`);
|
|
16
16
|
}
|
|
17
17
|
}
|
|
18
18
|
if (content) {
|
|
@@ -88,6 +88,8 @@ class Server {
|
|
|
88
88
|
});
|
|
89
89
|
}
|
|
90
90
|
async close() {
|
|
91
|
+
var _this_server_close, _this_server;
|
|
92
|
+
await ((_this_server_close = (_this_server = this.server).close) === null || _this_server_close === void 0 ? void 0 : _this_server_close.call(_this_server));
|
|
91
93
|
this.app.close();
|
|
92
94
|
}
|
|
93
95
|
listen(options, listener) {
|
|
@@ -7,11 +7,11 @@ import { RouteMatchManager } from "../libs/route";
|
|
|
7
7
|
import { createRenderHandler } from "../libs/render";
|
|
8
8
|
import { createStaticFileHandler, faviconFallbackHandler } from "../libs/serveFile";
|
|
9
9
|
import { createErrorDocument, createMiddlewareCollecter, getStaticReg, mergeExtension, noop, debug, isRedirect } from "../utils";
|
|
10
|
-
import * as reader from "../libs/render/reader";
|
|
11
10
|
import { createProxyHandler } from "../libs/proxy";
|
|
12
11
|
import { createContext } from "../libs/context";
|
|
13
12
|
import { AGGRED_DIR, ERROR_DIGEST, ERROR_PAGE_TEXT, RUN_MODE, ServerReportTimings } from "../constants";
|
|
14
13
|
import { createAfterMatchContext, createAfterRenderContext, createMiddlewareContext } from "../libs/hook-api";
|
|
14
|
+
import { cacheMod } from "../libs/render/ssrCache/cacheMod";
|
|
15
15
|
const SERVER_DIR = "./server";
|
|
16
16
|
class ModernServer {
|
|
17
17
|
// server prepare
|
|
@@ -19,7 +19,6 @@ class ModernServer {
|
|
|
19
19
|
var _conf_bff, _this_conf_output;
|
|
20
20
|
this.runner = runner;
|
|
21
21
|
const { distDir, conf } = this;
|
|
22
|
-
this.initReader();
|
|
23
22
|
debug("final server conf", this.conf);
|
|
24
23
|
if ((_conf_bff = conf.bff) === null || _conf_bff === void 0 ? void 0 : _conf_bff.proxy) {
|
|
25
24
|
const { handlers, handleUpgrade } = createProxyHandler(conf.bff.proxy);
|
|
@@ -28,12 +27,10 @@ class ModernServer {
|
|
|
28
27
|
this.addHandler(handler);
|
|
29
28
|
});
|
|
30
29
|
}
|
|
31
|
-
app === null || app === void 0 ? void 0 : app.on("close", () => {
|
|
32
|
-
this.reader.close();
|
|
33
|
-
});
|
|
34
30
|
const usageRoutes = this.filterRoutes(this.getRoutes());
|
|
35
31
|
this.router.reset(usageRoutes);
|
|
36
32
|
this.warmupSSRBundle();
|
|
33
|
+
cacheMod.loadServerCacheMod(this.pwd);
|
|
37
34
|
await this.prepareFrameHandler();
|
|
38
35
|
await this.prepareLoaderHandler(usageRoutes, distDir);
|
|
39
36
|
this.routeRenderHandler = this.getRenderHandler();
|
|
@@ -89,9 +86,6 @@ class ModernServer {
|
|
|
89
86
|
return createServer(handler);
|
|
90
87
|
}
|
|
91
88
|
/* —————————————————————— function will be overwrite —————————————————————— */
|
|
92
|
-
initReader() {
|
|
93
|
-
this.reader.init();
|
|
94
|
-
}
|
|
95
89
|
async onServerChange({ filepath }) {
|
|
96
90
|
const { pwd } = this;
|
|
97
91
|
const { api, server } = AGGRED_DIR;
|
|
@@ -475,7 +469,6 @@ class ModernServer {
|
|
|
475
469
|
_define_property(this, "logger", void 0);
|
|
476
470
|
_define_property(this, "metrics", void 0);
|
|
477
471
|
_define_property(this, "runMode", void 0);
|
|
478
|
-
_define_property(this, "reader", reader);
|
|
479
472
|
_define_property(this, "proxyTarget", void 0);
|
|
480
473
|
_define_property(this, "routeRenderHandler", void 0);
|
|
481
474
|
_define_property(this, "staticGenerate", void 0);
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
/// <reference path="../../type.d.ts" />
|
|
2
|
+
/// <reference types="node/http" />
|
|
1
3
|
import { IncomingMessage, ServerResponse } from 'http';
|
|
2
4
|
import { ModernServerContext, ContextOptions } from './context';
|
|
3
5
|
export declare const createContext: (req: IncomingMessage, res: ServerResponse, options?: ContextOptions) => ModernServerContext;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import type { ModernServerContext, HookContext, AfterMatchContext, AfterRenderContext, MiddlewareContext, ServerRoute } from '@modern-js/types';
|
|
1
|
+
import type { ModernServerContext, HookContext, AfterMatchContext, AfterRenderContext, MiddlewareContext, ServerRoute, AfterStreamingRenderContext } from '@modern-js/types';
|
|
2
2
|
export declare const base: (context: ModernServerContext) => HookContext;
|
|
3
3
|
export declare const createAfterMatchContext: (context: ModernServerContext, entryName: string) => AfterMatchContext;
|
|
4
4
|
export declare const createAfterRenderContext: (context: ModernServerContext, route: Partial<ServerRoute>, content: string) => AfterRenderContext;
|
|
5
|
+
export declare const createAfterStreamingRenderContext: (context: ModernServerContext, route: Partial<ServerRoute>) => (chunk: string) => AfterStreamingRenderContext;
|
|
5
6
|
export declare const createMiddlewareContext: (context: ModernServerContext) => MiddlewareContext;
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
+
/// <reference path="../../type.d.ts" />
|
|
1
2
|
/// <reference types="node" />
|
|
3
|
+
/// <reference types="node/http" />
|
|
2
4
|
import { OutgoingHttpHeaders } from 'http';
|
|
3
5
|
import { ServerOptions } from '@modern-js/server-core';
|
|
4
6
|
import { ModernServerContext } from '@modern-js/types';
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import type { ModernServerContext } from '@modern-js/types';
|
|
2
2
|
import { RenderResult, ServerHookRunner } from '../../type';
|
|
3
|
-
|
|
3
|
+
import type { ModernRoute } from '../route';
|
|
4
|
+
export type SSRRenderOptions = {
|
|
4
5
|
distDir: string;
|
|
5
|
-
bundle: string;
|
|
6
|
-
urlPath: string;
|
|
7
6
|
template: string;
|
|
8
|
-
|
|
7
|
+
route: ModernRoute;
|
|
9
8
|
staticGenerate: boolean;
|
|
10
9
|
enableUnsafeCtx?: boolean;
|
|
11
10
|
nonce?: string;
|
|
12
|
-
}
|
|
11
|
+
};
|
|
12
|
+
export declare const render: (ctx: ModernServerContext, renderOptions: SSRRenderOptions, runner: ServerHookRunner) => Promise<RenderResult>;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node/http" />
|
|
3
|
+
/// <reference types="dist/types/type" />
|
|
4
|
+
import { IncomingMessage } from 'http';
|
|
5
|
+
import { type Readable } from 'stream';
|
|
6
|
+
import { RenderFunction, SSRServerContext } from '../type';
|
|
7
|
+
export declare function ssrCache(req: IncomingMessage, render: RenderFunction, ssrContext: SSRServerContext): Promise<string | Readable>;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node/http" />
|
|
3
|
+
/// <reference types="dist/types/type" />
|
|
4
|
+
import { IncomingMessage } from 'http';
|
|
5
|
+
import { Readable } from 'stream';
|
|
6
|
+
import { CacheControl, Container } from '@modern-js/types';
|
|
7
|
+
import { RenderFunction, SSRServerContext } from '../type';
|
|
8
|
+
export declare class CacheManager {
|
|
9
|
+
private container;
|
|
10
|
+
constructor(container: Container<string, string>);
|
|
11
|
+
getCacheResult(req: IncomingMessage, cacheControl: CacheControl, render: RenderFunction, ssrContext: SSRServerContext): Promise<string | Readable>;
|
|
12
|
+
private processCache;
|
|
13
|
+
private computedKey;
|
|
14
|
+
}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
|
+
/// <reference path="../type.d.ts" />
|
|
1
2
|
/// <reference types="node" />
|
|
2
3
|
/// <reference types="node" />
|
|
3
4
|
/// <reference types="node" />
|
|
5
|
+
/// <reference types="node/http" />
|
|
4
6
|
import { IncomingMessage, ServerResponse } from 'http';
|
|
5
7
|
import type { ListenOptions } from 'net';
|
|
6
8
|
import { ModernServerOptions, ServerConstructor } from '../type';
|
|
@@ -1,5 +1,7 @@
|
|
|
1
|
+
/// <reference path="../type.d.ts" />
|
|
1
2
|
/// <reference types="node" />
|
|
2
3
|
/// <reference types="node" />
|
|
4
|
+
/// <reference types="node/http" />
|
|
3
5
|
import { IncomingMessage, ServerResponse, Server } from 'http';
|
|
4
6
|
import { Adapter, WebAdapter, APIServerStartInput, ServerOptions } from '@modern-js/server-core';
|
|
5
7
|
import { type ModernServerContext, type ServerRoute } from '@modern-js/types';
|
|
@@ -8,7 +10,6 @@ import { ModernServerOptions, NextFunction, ServerHookRunner, Metrics, Logger, M
|
|
|
8
10
|
import { RouteMatchManager, ModernRouteInterface, ModernRoute } from '../libs/route';
|
|
9
11
|
import { RenderHandler } from '../libs/render';
|
|
10
12
|
import { mergeExtension } from '../utils';
|
|
11
|
-
import * as reader from '../libs/render/reader';
|
|
12
13
|
type ModernServerAsyncHandler = (context: ModernServerContext, next: NextFunction) => Promise<void>;
|
|
13
14
|
export declare class ModernServer implements ModernServerInterface {
|
|
14
15
|
pwd: string;
|
|
@@ -22,7 +23,6 @@ export declare class ModernServer implements ModernServerInterface {
|
|
|
22
23
|
protected readonly logger: Logger;
|
|
23
24
|
protected readonly metrics: Metrics;
|
|
24
25
|
protected readonly runMode: string;
|
|
25
|
-
protected reader: typeof reader;
|
|
26
26
|
protected readonly proxyTarget: ModernServerOptions['proxyTarget'];
|
|
27
27
|
protected routeRenderHandler: RenderHandler;
|
|
28
28
|
protected readonly staticGenerate: boolean;
|
|
@@ -38,7 +38,6 @@ export declare class ModernServer implements ModernServerInterface {
|
|
|
38
38
|
getRequestHandler(): (req: IncomingMessage, res: ServerResponse, next?: () => void) => void | ServerResponse;
|
|
39
39
|
render(req: IncomingMessage, res: ServerResponse, url?: string): Promise<string | import("stream").Readable | null>;
|
|
40
40
|
createHTTPServer(handler: (req: IncomingMessage, res: ServerResponse, next?: () => void) => void): Promise<Server<typeof IncomingMessage, typeof ServerResponse>>;
|
|
41
|
-
protected initReader(): void;
|
|
42
41
|
protected onServerChange({ filepath }: {
|
|
43
42
|
filepath: string;
|
|
44
43
|
}): Promise<void>;
|
package/dist/types/type.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
2
|
/// <reference types="node" />
|
|
3
3
|
/// <reference types="node" />
|
|
4
|
+
/// <reference types="node/http" />
|
|
4
5
|
import { IncomingMessage, Server, ServerResponse } from 'http';
|
|
5
6
|
import { Readable } from 'stream';
|
|
6
7
|
import { serverManager, ServerOptions } from '@modern-js/server-core';
|
|
@@ -69,6 +70,7 @@ export interface ModernServerInterface {
|
|
|
69
70
|
getRequestHandler: () => (req: IncomingMessage, res: ServerResponse, next?: () => void) => void;
|
|
70
71
|
createHTTPServer: (handler: (req: IncomingMessage, res: ServerResponse, next?: () => void) => void) => Promise<Server>;
|
|
71
72
|
render: (req: IncomingMessage, res: ServerResponse, url?: string) => Promise<string | Readable | null>;
|
|
73
|
+
close?: () => Promise<void>;
|
|
72
74
|
}
|
|
73
75
|
export type ServerConstructor = (options: ModernServerOptions) => ModernServerInterface;
|
|
74
76
|
export type ModernServerHandler = (context: ModernServerContext, next: NextFunction) => Promise<void> | void;
|
package/package.json
CHANGED
|
@@ -15,7 +15,7 @@
|
|
|
15
15
|
"modern",
|
|
16
16
|
"modern.js"
|
|
17
17
|
],
|
|
18
|
-
"version": "2.
|
|
18
|
+
"version": "2.44.0",
|
|
19
19
|
"jsnext:source": "./src/index.ts",
|
|
20
20
|
"types": "./dist/types/index.d.ts",
|
|
21
21
|
"main": "./dist/cjs/index.js",
|
|
@@ -69,22 +69,20 @@
|
|
|
69
69
|
"fresh": "^0.5.2",
|
|
70
70
|
"http-proxy-middleware": "^2.0.4",
|
|
71
71
|
"ignore-styles": "^5.0.1",
|
|
72
|
-
"lru-cache": "^6.0.0",
|
|
73
72
|
"merge-deep": "^3.0.3",
|
|
74
73
|
"node-html-parser": "^6.1.5",
|
|
75
74
|
"path-to-regexp": "^6.2.0",
|
|
76
75
|
"serve-static": "^1.14.1",
|
|
77
|
-
"@modern-js/plugin": "2.
|
|
78
|
-
"@modern-js/server-core": "2.
|
|
79
|
-
"@modern-js/utils": "2.
|
|
80
|
-
"@modern-js/runtime-utils": "2.
|
|
76
|
+
"@modern-js/plugin": "2.44.0",
|
|
77
|
+
"@modern-js/server-core": "2.44.0",
|
|
78
|
+
"@modern-js/utils": "2.44.0",
|
|
79
|
+
"@modern-js/runtime-utils": "2.44.0"
|
|
81
80
|
},
|
|
82
81
|
"devDependencies": {
|
|
83
82
|
"@types/cookie": "0.5.1",
|
|
84
83
|
"@types/etag": "^1.8.1",
|
|
85
84
|
"@types/fresh": "^0.5.0",
|
|
86
85
|
"@types/jest": "^29",
|
|
87
|
-
"@types/lru-cache": "^5.1.1",
|
|
88
86
|
"@types/merge-deep": "^3.0.0",
|
|
89
87
|
"@types/node": "^14",
|
|
90
88
|
"@types/serve-static": "^1.13.10",
|
|
@@ -96,10 +94,9 @@
|
|
|
96
94
|
"portfinder": "^1.0.28",
|
|
97
95
|
"typescript": "^5",
|
|
98
96
|
"ws": "^8.13.0",
|
|
99
|
-
"@modern-js/
|
|
100
|
-
"@
|
|
101
|
-
"@scripts/
|
|
102
|
-
"@scripts/jest-config": "2.42.2"
|
|
97
|
+
"@modern-js/types": "2.44.0",
|
|
98
|
+
"@scripts/build": "2.44.0",
|
|
99
|
+
"@scripts/jest-config": "2.44.0"
|
|
103
100
|
},
|
|
104
101
|
"sideEffects": false,
|
|
105
102
|
"publishConfig": {
|
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __copyProps = (to, from, except, desc) => {
|
|
9
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
10
|
-
for (let key of __getOwnPropNames(from))
|
|
11
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
12
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
13
|
-
}
|
|
14
|
-
return to;
|
|
15
|
-
};
|
|
16
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
17
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
18
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
19
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
20
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
21
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
22
|
-
mod
|
|
23
|
-
));
|
|
24
|
-
var import_url = __toESM(require("url"));
|
|
25
|
-
var import_spr = require("../spr");
|
|
26
|
-
var import_util = require("../util");
|
|
27
|
-
describe("test spr util functions", () => {
|
|
28
|
-
it("should return value correctly", () => {
|
|
29
|
-
expect((0, import_util.connectFactor)("bar", "foo")).toBe("bar-foo");
|
|
30
|
-
expect((0, import_util.fname)(1)).toBe("f1");
|
|
31
|
-
expect((0, import_util.namespaceHash)("modern", "!@#$%^&")).toBe("modern/!@#$%^&");
|
|
32
|
-
});
|
|
33
|
-
it("should create or destroy instance correctly", () => {
|
|
34
|
-
const ins1 = (0, import_spr.createCache)();
|
|
35
|
-
const ins2 = (0, import_spr.createCache)();
|
|
36
|
-
expect(ins1 === ins2).toBe(true);
|
|
37
|
-
(0, import_spr.destroyCache)();
|
|
38
|
-
const ins3 = (0, import_spr.createCache)();
|
|
39
|
-
expect(ins1 === ins3).toBe(false);
|
|
40
|
-
expect(ins2 === ins3).toBe(false);
|
|
41
|
-
});
|
|
42
|
-
it("should return function correctly", () => {
|
|
43
|
-
const urlParams = (() => new import_url.default.URLSearchParams())();
|
|
44
|
-
urlParams.set("name", "modern");
|
|
45
|
-
const getParam = (0, import_util.valueFactory)(urlParams);
|
|
46
|
-
expect(getParam("name")).toBe("modern");
|
|
47
|
-
const headers = {
|
|
48
|
-
age: "12345"
|
|
49
|
-
};
|
|
50
|
-
const getHeader = (0, import_util.valueFactory)(headers);
|
|
51
|
-
expect(getHeader("age")).toBe("12345");
|
|
52
|
-
});
|
|
53
|
-
it("should add target html content", () => {
|
|
54
|
-
const contentNoHead = "<div>123</div>";
|
|
55
|
-
const html = (0, import_util.cacheAddition)(contentNoHead, Math.random().toString());
|
|
56
|
-
expect(html).toBe(contentNoHead);
|
|
57
|
-
const contentWithHead = "<head></head><div>123</div>";
|
|
58
|
-
const hash = Math.random().toString();
|
|
59
|
-
const htmlWithHead = (0, import_util.cacheAddition)(contentWithHead, hash);
|
|
60
|
-
expect(htmlWithHead).toBe(`<head><meta name="x-moden-spr" content="${hash}"></head><div>123</div>`);
|
|
61
|
-
});
|
|
62
|
-
it("should only invoke func one time", async () => {
|
|
63
|
-
let index = 0;
|
|
64
|
-
const fn = (0, import_util.withCoalescedInvoke)(async () => new Promise((resolve) => {
|
|
65
|
-
setTimeout(() => {
|
|
66
|
-
index += 1;
|
|
67
|
-
resolve(index);
|
|
68
|
-
}, 500);
|
|
69
|
-
}));
|
|
70
|
-
const key = "test";
|
|
71
|
-
const [res1, res2] = await Promise.all([
|
|
72
|
-
fn(key, []),
|
|
73
|
-
fn(key, [])
|
|
74
|
-
]);
|
|
75
|
-
expect(res1.isOrigin && res2.isOrigin).toBe(false);
|
|
76
|
-
expect(res1.isOrigin || res2.isOrigin).toBe(true);
|
|
77
|
-
expect(res1.value).toBe(1);
|
|
78
|
-
expect(res2.value).toBe(1);
|
|
79
|
-
});
|
|
80
|
-
it("should invoke sync or async", async () => {
|
|
81
|
-
const foo = "";
|
|
82
|
-
const async = await (0, import_util.maybeSync)(() => new Promise((resolve) => {
|
|
83
|
-
setTimeout(() => {
|
|
84
|
-
resolve(foo);
|
|
85
|
-
}, 100);
|
|
86
|
-
}))(false);
|
|
87
|
-
expect(async).toBeUndefined();
|
|
88
|
-
const sync = await (0, import_util.maybeSync)(() => new Promise((resolve) => {
|
|
89
|
-
setTimeout(() => {
|
|
90
|
-
resolve(foo);
|
|
91
|
-
}, 100);
|
|
92
|
-
}))(true);
|
|
93
|
-
expect(sync).toBe(foo);
|
|
94
|
-
});
|
|
95
|
-
});
|