@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.
Files changed (90) hide show
  1. package/dist/cjs/libs/{render/cache/page-caches/index.js → hook-api/afterRenderForStream.js} +12 -14
  2. package/dist/cjs/libs/hook-api/index.js +12 -0
  3. package/dist/cjs/libs/render/index.js +4 -14
  4. package/dist/cjs/libs/render/ssr.js +15 -4
  5. package/dist/cjs/libs/render/{cache/page-caches/lru.js → ssrCache/cacheMod.js} +21 -31
  6. package/dist/cjs/libs/render/ssrCache/index.js +81 -0
  7. package/dist/cjs/libs/render/ssrCache/manager.js +104 -0
  8. package/dist/cjs/libs/render/static.js +5 -5
  9. package/dist/cjs/server/index.js +2 -0
  10. package/dist/cjs/server/modernServer.js +2 -9
  11. package/dist/esm/libs/hook-api/afterRenderForStream.js +33 -0
  12. package/dist/esm/libs/hook-api/index.js +10 -0
  13. package/dist/esm/libs/render/index.js +4 -14
  14. package/dist/esm/libs/render/ssr.js +19 -5
  15. package/dist/esm/libs/render/ssrCache/cacheMod.js +33 -0
  16. package/dist/esm/libs/render/ssrCache/index.js +146 -0
  17. package/dist/esm/libs/render/ssrCache/manager.js +159 -0
  18. package/dist/esm/libs/render/static.js +5 -5
  19. package/dist/esm/server/index.js +14 -4
  20. package/dist/esm/server/modernServer.js +32 -42
  21. package/dist/esm-node/libs/hook-api/afterRenderForStream.js +10 -0
  22. package/dist/esm-node/libs/hook-api/index.js +11 -0
  23. package/dist/esm-node/libs/render/index.js +4 -14
  24. package/dist/esm-node/libs/render/ssr.js +15 -4
  25. package/dist/esm-node/libs/render/ssrCache/cacheMod.js +22 -0
  26. package/dist/esm-node/libs/render/ssrCache/index.js +57 -0
  27. package/dist/esm-node/libs/render/ssrCache/manager.js +80 -0
  28. package/dist/esm-node/libs/render/static.js +5 -5
  29. package/dist/esm-node/server/index.js +2 -0
  30. package/dist/esm-node/server/modernServer.js +2 -9
  31. package/dist/types/libs/context/index.d.ts +2 -0
  32. package/dist/types/libs/hook-api/afterRenderForStream.d.ts +4 -0
  33. package/dist/types/libs/hook-api/index.d.ts +2 -1
  34. package/dist/types/libs/preload/flushServerHeader.d.ts +2 -0
  35. package/dist/types/libs/proxy.d.ts +2 -0
  36. package/dist/types/libs/render/ssr.d.ts +5 -5
  37. package/dist/types/libs/render/ssrCache/cacheMod.d.ts +8 -0
  38. package/dist/types/libs/render/ssrCache/index.d.ts +7 -0
  39. package/dist/types/libs/render/ssrCache/manager.d.ts +14 -0
  40. package/dist/types/renderHtml.d.ts +2 -0
  41. package/dist/types/server/index.d.ts +2 -0
  42. package/dist/types/server/modernServer.d.ts +2 -3
  43. package/dist/types/type.d.ts +2 -0
  44. package/package.json +8 -11
  45. package/dist/cjs/libs/render/cache/__tests__/cache.fun.test.js +0 -95
  46. package/dist/cjs/libs/render/cache/__tests__/cache.test.js +0 -223
  47. package/dist/cjs/libs/render/cache/__tests__/cacheable.js +0 -93
  48. package/dist/cjs/libs/render/cache/__tests__/error-configuration.js +0 -71
  49. package/dist/cjs/libs/render/cache/__tests__/matched-cache.js +0 -173
  50. package/dist/cjs/libs/render/cache/index.js +0 -92
  51. package/dist/cjs/libs/render/cache/spr.js +0 -247
  52. package/dist/cjs/libs/render/cache/type.js +0 -16
  53. package/dist/cjs/libs/render/cache/util.js +0 -121
  54. package/dist/cjs/libs/render/reader.js +0 -131
  55. package/dist/esm/libs/render/cache/__tests__/cache.fun.test.js +0 -124
  56. package/dist/esm/libs/render/cache/__tests__/cache.test.js +0 -612
  57. package/dist/esm/libs/render/cache/__tests__/cacheable.js +0 -69
  58. package/dist/esm/libs/render/cache/__tests__/error-configuration.js +0 -47
  59. package/dist/esm/libs/render/cache/__tests__/matched-cache.js +0 -149
  60. package/dist/esm/libs/render/cache/index.js +0 -204
  61. package/dist/esm/libs/render/cache/page-caches/index.js +0 -34
  62. package/dist/esm/libs/render/cache/page-caches/lru.js +0 -57
  63. package/dist/esm/libs/render/cache/spr.js +0 -345
  64. package/dist/esm/libs/render/cache/type.js +0 -0
  65. package/dist/esm/libs/render/cache/util.js +0 -105
  66. package/dist/esm/libs/render/reader.js +0 -196
  67. package/dist/esm-node/libs/render/cache/__tests__/cache.fun.test.js +0 -72
  68. package/dist/esm-node/libs/render/cache/__tests__/cache.test.js +0 -222
  69. package/dist/esm-node/libs/render/cache/__tests__/cacheable.js +0 -69
  70. package/dist/esm-node/libs/render/cache/__tests__/error-configuration.js +0 -47
  71. package/dist/esm-node/libs/render/cache/__tests__/matched-cache.js +0 -149
  72. package/dist/esm-node/libs/render/cache/index.js +0 -72
  73. package/dist/esm-node/libs/render/cache/page-caches/index.js +0 -12
  74. package/dist/esm-node/libs/render/cache/page-caches/lru.js +0 -32
  75. package/dist/esm-node/libs/render/cache/spr.js +0 -212
  76. package/dist/esm-node/libs/render/cache/type.js +0 -0
  77. package/dist/esm-node/libs/render/cache/util.js +0 -80
  78. package/dist/esm-node/libs/render/reader.js +0 -93
  79. package/dist/types/libs/render/cache/__tests__/cache.fun.test.d.ts +0 -1
  80. package/dist/types/libs/render/cache/__tests__/cache.test.d.ts +0 -1
  81. package/dist/types/libs/render/cache/__tests__/cacheable.d.ts +0 -62
  82. package/dist/types/libs/render/cache/__tests__/error-configuration.d.ts +0 -28
  83. package/dist/types/libs/render/cache/__tests__/matched-cache.d.ts +0 -124
  84. package/dist/types/libs/render/cache/index.d.ts +0 -6
  85. package/dist/types/libs/render/cache/page-caches/index.d.ts +0 -2
  86. package/dist/types/libs/render/cache/page-caches/lru.d.ts +0 -15
  87. package/dist/types/libs/render/cache/spr.d.ts +0 -22
  88. package/dist/types/libs/render/cache/type.d.ts +0 -48
  89. package/dist/types/libs/render/cache/util.d.ts +0 -18
  90. package/dist/types/libs/render/reader.d.ts +0 -20
@@ -16,21 +16,19 @@ var __copyProps = (to, from, except, desc) => {
16
16
  return to;
17
17
  };
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var page_caches_exports = {};
20
- __export(page_caches_exports, {
21
- createPageCaches: () => createPageCaches
19
+ var afterRenderForStream_exports = {};
20
+ __export(afterRenderForStream_exports, {
21
+ afterRenderInjectableStream: () => afterRenderInjectableStream
22
+ });
23
+ module.exports = __toCommonJS(afterRenderForStream_exports);
24
+ var import_stream = require("stream");
25
+ const afterRenderInjectableStream = (fn) => new import_stream.Transform({
26
+ async write(chunk, _, callback) {
27
+ this.push(await fn(chunk.toString()));
28
+ callback();
29
+ }
22
30
  });
23
- module.exports = __toCommonJS(page_caches_exports);
24
- var import_lru = require("./lru");
25
- async function createPageCaches(max) {
26
- const constructorOptions = {
27
- max
28
- };
29
- const cacheInstance = new import_lru.LRUCaches(constructorOptions);
30
- await cacheInstance.init();
31
- return cacheInstance;
32
- }
33
31
  // Annotate the CommonJS export names for ESM import in node:
34
32
  0 && (module.exports = {
35
- createPageCaches
33
+ afterRenderInjectableStream
36
34
  });
@@ -21,6 +21,7 @@ __export(hook_api_exports, {
21
21
  base: () => base,
22
22
  createAfterMatchContext: () => createAfterMatchContext,
23
23
  createAfterRenderContext: () => createAfterRenderContext,
24
+ createAfterStreamingRenderContext: () => createAfterStreamingRenderContext,
24
25
  createMiddlewareContext: () => createMiddlewareContext
25
26
  });
26
27
  module.exports = __toCommonJS(hook_api_exports);
@@ -51,6 +52,16 @@ const createAfterRenderContext = (context, route, content) => {
51
52
  template: new import_template.TemplateAPI(content)
52
53
  };
53
54
  };
55
+ const createAfterStreamingRenderContext = (context, route) => {
56
+ const baseContext = base(context);
57
+ return (chunk) => {
58
+ return {
59
+ ...baseContext,
60
+ route,
61
+ chunk
62
+ };
63
+ };
64
+ };
54
65
  const createMiddlewareContext = (context) => {
55
66
  const baseContext = base(context);
56
67
  baseContext.response.locals = context.res.locals || {};
@@ -69,5 +80,6 @@ const createMiddlewareContext = (context) => {
69
80
  base,
70
81
  createAfterMatchContext,
71
82
  createAfterRenderContext,
83
+ createAfterStreamingRenderContext,
72
84
  createMiddlewareContext
73
85
  });
@@ -33,10 +33,10 @@ __export(render_exports, {
33
33
  module.exports = __toCommonJS(render_exports);
34
34
  var import_path = __toESM(require("path"));
35
35
  var import_utils = require("@modern-js/utils");
36
+ var import_fileReader = require("@modern-js/runtime-utils/fileReader");
36
37
  var import_constants = require("../../constants");
37
38
  var import_shouldFlushServerHeader = require("../preload/shouldFlushServerHeader");
38
39
  var import_static = require("./static");
39
- var import_reader = require("./reader");
40
40
  var ssr = __toESM(require("./ssr"));
41
41
  var import_utils2 = require("./utils");
42
42
  const calcFallback = (metaName) => `x-${(0, import_utils.cutNameByHyphen)(metaName)}-ssr-fallback`;
@@ -51,7 +51,7 @@ const createRenderHandler = ({ distDir, staticGenerate, conf, forceCSR, nonce, s
51
51
  return result;
52
52
  }
53
53
  const templatePath = entry;
54
- const content = await (0, import_reader.readFile)(templatePath);
54
+ const content = await import_fileReader.fileReader.readFile(templatePath);
55
55
  if (!content) {
56
56
  return null;
57
57
  }
@@ -74,22 +74,12 @@ const createRenderHandler = ({ distDir, staticGenerate, conf, forceCSR, nonce, s
74
74
  }
75
75
  const ssrRenderOptions = {
76
76
  distDir,
77
- entryName: route.entryName,
78
- urlPath: route.urlPath,
79
- bundle: route.bundle,
77
+ route,
80
78
  template: content.toString(),
81
79
  staticGenerate,
82
80
  nonce
83
81
  };
84
- const result = await (ssrRender ? ssrRender(ctx, ssrRenderOptions, runner) : ssr.render(ctx, {
85
- distDir,
86
- entryName: route.entryName,
87
- urlPath: route.urlPath,
88
- bundle: route.bundle,
89
- template: content.toString(),
90
- staticGenerate,
91
- nonce
92
- }, runner));
82
+ const result = await (ssrRender ? ssrRender(ctx, ssrRenderOptions, runner) : ssr.render(ctx, ssrRenderOptions, runner));
93
83
  return result;
94
84
  } catch (err) {
95
85
  ctx.error(import_constants.ERROR_DIGEST.ERENDER, err.stack || err.message);
@@ -33,12 +33,15 @@ __export(ssr_exports, {
33
33
  module.exports = __toCommonJS(ssr_exports);
34
34
  var import_path = __toESM(require("path"));
35
35
  var import_utils = require("@modern-js/utils");
36
- var import_cache = __toESM(require("./cache"));
36
+ var import_hook_api = require("../hook-api");
37
+ var import_afterRenderForStream = require("../hook-api/afterRenderForStream");
37
38
  var import_measure = require("./measure");
38
39
  var import_utils2 = require("./utils");
40
+ var import_ssrCache = require("./ssrCache");
39
41
  const render = async (ctx, renderOptions, runner) => {
40
42
  var _ctx_res;
41
- const { urlPath, bundle, distDir, template, entryName, staticGenerate, enableUnsafeCtx = false, nonce } = renderOptions;
43
+ const { distDir, route, template, staticGenerate, enableUnsafeCtx = false, nonce } = renderOptions;
44
+ const { urlPath, bundle, entryName } = route;
42
45
  const bundleJS = import_path.default.join(distDir, bundle);
43
46
  const loadableUri = import_path.default.join(distDir, import_utils.LOADABLE_STATS_FILE);
44
47
  const loadableStats = import_utils.fs.existsSync(loadableUri) ? require(loadableUri) : "";
@@ -83,7 +86,7 @@ const render = async (ctx, renderOptions, runner) => {
83
86
  runner.extendSSRContext(context);
84
87
  const bundleJSContent = await Promise.resolve(require(bundleJS));
85
88
  const serverRender = bundleJSContent[import_utils.SERVER_RENDER_FUNCTION_NAME];
86
- const content = await (0, import_cache.default)(serverRender, ctx)(context);
89
+ const content = await (0, import_ssrCache.ssrCache)(ctx.req, serverRender, context);
87
90
  const { url, status = 302 } = context.redirection;
88
91
  if (url) {
89
92
  return {
@@ -99,9 +102,17 @@ const render = async (ctx, renderOptions, runner) => {
99
102
  contentType: import_utils.mime.contentType("html")
100
103
  };
101
104
  } else {
105
+ let contentStream = (0, import_utils2.injectServerDataStream)(content, ctx);
106
+ const afterStreamingRenderContext = (0, import_hook_api.createAfterStreamingRenderContext)(ctx, route);
107
+ contentStream = contentStream.pipe((0, import_afterRenderForStream.afterRenderInjectableStream)((chunk) => {
108
+ const context2 = afterStreamingRenderContext(chunk);
109
+ return runner.afterStreamingRender(context2, {
110
+ onLast: ({ chunk: chunk2 }) => chunk2
111
+ });
112
+ }));
102
113
  return {
103
114
  content: "",
104
- contentStream: (0, import_utils2.injectServerDataStream)(content, ctx),
115
+ contentStream,
105
116
  contentType: import_utils.mime.contentType("html")
106
117
  };
107
118
  }
@@ -26,41 +26,31 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
26
26
  mod
27
27
  ));
28
28
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
- var lru_exports = {};
30
- __export(lru_exports, {
31
- LRUCaches: () => LRUCaches
29
+ var cacheMod_exports = {};
30
+ __export(cacheMod_exports, {
31
+ cacheMod: () => cacheMod
32
32
  });
33
- module.exports = __toCommonJS(lru_exports);
33
+ module.exports = __toCommonJS(cacheMod_exports);
34
34
  var import_define_property = require("@swc/helpers/_/_define_property");
35
- var import_lru_cache = __toESM(require("lru-cache"));
36
- class LRUCaches {
37
- init() {
38
- return Promise.resolve();
39
- }
40
- keys() {
41
- return this.caches.keys();
42
- }
43
- get(key) {
44
- return Promise.resolve(this.caches.get(key) || null);
45
- }
46
- peek(key) {
47
- return this.caches.peek(key) || null;
48
- }
49
- set(key, cache) {
50
- this.caches.set(key, cache);
51
- return Promise.resolve();
52
- }
53
- del(key) {
54
- this.caches.del(key);
55
- }
56
- constructor(options) {
57
- (0, import_define_property._)(this, "caches", void 0);
58
- (0, import_define_property._)(this, "max", void 0);
59
- this.max = options.max;
60
- this.caches = new import_lru_cache.default(this.max);
35
+ var import_path = __toESM(require("path"));
36
+ var import_utils = require("@modern-js/utils");
37
+ const CACHE_FILENAME = "cache";
38
+ class ServerCacheMod {
39
+ loadServerCacheMod(pwd = process.cwd()) {
40
+ const serverCacheFilepath = import_path.default.resolve(pwd, import_utils.SERVER_DIR, CACHE_FILENAME);
41
+ const mod = (0, import_utils.requireExistModule)(serverCacheFilepath, {
42
+ interop: false
43
+ });
44
+ this.customContainer = mod === null || mod === void 0 ? void 0 : mod.customContainer;
45
+ this.cacheOption = mod === null || mod === void 0 ? void 0 : mod.cacheOption;
46
+ }
47
+ constructor() {
48
+ (0, import_define_property._)(this, "customContainer", void 0);
49
+ (0, import_define_property._)(this, "cacheOption", void 0);
61
50
  }
62
51
  }
52
+ const cacheMod = new ServerCacheMod();
63
53
  // Annotate the CommonJS export names for ESM import in node:
64
54
  0 && (module.exports = {
65
- LRUCaches
55
+ cacheMod
66
56
  });
@@ -0,0 +1,81 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var ssrCache_exports = {};
20
+ __export(ssrCache_exports, {
21
+ ssrCache: () => ssrCache
22
+ });
23
+ module.exports = __toCommonJS(ssrCache_exports);
24
+ var import_stream = require("stream");
25
+ var import_storer = require("@modern-js/runtime-utils/storer");
26
+ var import_cacheMod = require("./cacheMod");
27
+ var import_manager = require("./manager");
28
+ const cacheStorage = (0, import_storer.createMemoryStorage)("__ssr__cache");
29
+ async function ssrCache(req, render, ssrContext) {
30
+ const { customContainer, cacheOption } = import_cacheMod.cacheMod;
31
+ const cacheControl = await matchCacheControl(req, cacheOption);
32
+ const cacheManager = new import_manager.CacheManager(customContainer ? customContainer : cacheStorage);
33
+ if (cacheControl) {
34
+ return cacheManager.getCacheResult(req, cacheControl, render, ssrContext);
35
+ } else {
36
+ const renderResult = await render(ssrContext);
37
+ if (typeof renderResult === "string") {
38
+ return renderResult;
39
+ } else {
40
+ const stream = new import_stream.Transform({
41
+ write(chunk, _, callback) {
42
+ this.push(chunk);
43
+ callback();
44
+ }
45
+ });
46
+ return renderResult(stream);
47
+ }
48
+ }
49
+ }
50
+ async function matchCacheControl(req, cacheOption) {
51
+ if (!cacheOption) {
52
+ return void 0;
53
+ } else if (isCacheControl(cacheOption)) {
54
+ return cacheOption;
55
+ } else if (isCacheOptionProvider(cacheOption)) {
56
+ return cacheOption(req);
57
+ } else {
58
+ const url = req.url;
59
+ const options = Object.entries(cacheOption);
60
+ for (const [key, option] of options) {
61
+ if (key === "*" || new RegExp(key).test(url)) {
62
+ if (typeof option === "function") {
63
+ return option(req);
64
+ } else {
65
+ return option;
66
+ }
67
+ }
68
+ }
69
+ return void 0;
70
+ }
71
+ function isCacheOptionProvider(option) {
72
+ return typeof option === "function";
73
+ }
74
+ function isCacheControl(option) {
75
+ return typeof option === "object" && option !== null && "maxAge" in option;
76
+ }
77
+ }
78
+ // Annotate the CommonJS export names for ESM import in node:
79
+ 0 && (module.exports = {
80
+ ssrCache
81
+ });
@@ -0,0 +1,104 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var manager_exports = {};
20
+ __export(manager_exports, {
21
+ CacheManager: () => CacheManager
22
+ });
23
+ module.exports = __toCommonJS(manager_exports);
24
+ var import_define_property = require("@swc/helpers/_/_define_property");
25
+ var import_stream = require("stream");
26
+ class CacheManager {
27
+ async getCacheResult(req, cacheControl, render, ssrContext) {
28
+ const key = this.computedKey(req, cacheControl);
29
+ const value = await this.container.get(key);
30
+ const { maxAge, staleWhileRevalidate } = cacheControl;
31
+ const ttl = maxAge + staleWhileRevalidate;
32
+ if (value) {
33
+ const cache = JSON.parse(value);
34
+ const interval = Date.now() - cache.cursor;
35
+ if (interval <= maxAge) {
36
+ return cache.val;
37
+ } else if (interval <= staleWhileRevalidate + maxAge) {
38
+ this.processCache(key, render, ssrContext, ttl);
39
+ return cache.val;
40
+ } else {
41
+ return this.processCache(key, render, ssrContext, ttl);
42
+ }
43
+ } else {
44
+ return this.processCache(key, render, ssrContext, ttl);
45
+ }
46
+ }
47
+ async processCache(key, render, ssrContext, ttl) {
48
+ const renderResult = await render(ssrContext);
49
+ if (typeof renderResult === "string") {
50
+ const current = Date.now();
51
+ const cache = {
52
+ val: renderResult,
53
+ cursor: current
54
+ };
55
+ await this.container.set(key, JSON.stringify(cache), {
56
+ ttl
57
+ });
58
+ return renderResult;
59
+ } else {
60
+ let html;
61
+ const stream = new import_stream.Transform({
62
+ write(chunk, _, callback) {
63
+ html += chunk.toString();
64
+ this.push(chunk);
65
+ callback();
66
+ }
67
+ });
68
+ stream.on("close", () => {
69
+ const current = Date.now();
70
+ const cache = {
71
+ val: html,
72
+ cursor: current
73
+ };
74
+ this.container.set(key, JSON.stringify(cache), {
75
+ ttl
76
+ });
77
+ });
78
+ return renderResult(stream);
79
+ }
80
+ }
81
+ computedKey(req, cacheControl) {
82
+ const { url } = req;
83
+ const [pathname] = url.split("?");
84
+ const { customKey } = cacheControl;
85
+ const defaultKey = pathname.replace(/.+\/+$/, "");
86
+ if (customKey) {
87
+ if (typeof customKey === "string") {
88
+ return customKey;
89
+ } else {
90
+ return customKey(defaultKey);
91
+ }
92
+ } else {
93
+ return defaultKey;
94
+ }
95
+ }
96
+ constructor(container) {
97
+ (0, import_define_property._)(this, "container", void 0);
98
+ this.container = container;
99
+ }
100
+ }
101
+ // Annotate the CommonJS export names for ESM import in node:
102
+ 0 && (module.exports = {
103
+ CacheManager
104
+ });
@@ -33,19 +33,19 @@ __export(static_exports, {
33
33
  module.exports = __toCommonJS(static_exports);
34
34
  var import_path = __toESM(require("path"));
35
35
  var import_utils = require("@modern-js/utils");
36
- var import_reader = require("./reader");
36
+ var import_fileReader = require("@modern-js/runtime-utils/fileReader");
37
37
  async function handleDirectory(ctx, entryPath, urlPath) {
38
38
  const { path: pathname } = ctx;
39
39
  const filepath = import_path.default.join(entryPath, trimLeft(pathname, urlPath));
40
- let content = await (0, import_reader.readFile)(filepath);
40
+ let content = await import_fileReader.fileReader.readFile(filepath);
41
41
  let contentType = import_utils.mime.contentType(import_path.default.extname(filepath) || "");
42
42
  if (!content) {
43
43
  if (pathname.endsWith("/")) {
44
- content = await (0, import_reader.readFile)(`${filepath}index.html`);
44
+ content = await import_fileReader.fileReader.readFile(`${filepath}index.html`);
45
45
  } else if (!pathname.includes(".")) {
46
- content = await (0, import_reader.readFile)(`${filepath}.html`);
46
+ content = await import_fileReader.fileReader.readFile(`${filepath}.html`);
47
47
  if (!content) {
48
- content = await (0, import_reader.readFile)(`${filepath}/index.html`);
48
+ content = await import_fileReader.fileReader.readFile(`${filepath}/index.html`);
49
49
  }
50
50
  }
51
51
  if (content) {
@@ -121,6 +121,8 @@ class Server {
121
121
  });
122
122
  }
123
123
  async close() {
124
+ var _this_server_close, _this_server;
125
+ await ((_this_server_close = (_this_server = this.server).close) === null || _this_server_close === void 0 ? void 0 : _this_server_close.call(_this_server));
124
126
  this.app.close();
125
127
  }
126
128
  listen(options, listener) {
@@ -40,11 +40,11 @@ var import_route = require("../libs/route");
40
40
  var import_render = require("../libs/render");
41
41
  var import_serveFile = require("../libs/serveFile");
42
42
  var import_utils2 = require("../utils");
43
- var reader = __toESM(require("../libs/render/reader"));
44
43
  var import_proxy = require("../libs/proxy");
45
44
  var import_context = require("../libs/context");
46
45
  var import_constants = require("../constants");
47
46
  var import_hook_api = require("../libs/hook-api");
47
+ var import_cacheMod = require("../libs/render/ssrCache/cacheMod");
48
48
  const SERVER_DIR = "./server";
49
49
  class ModernServer {
50
50
  // server prepare
@@ -52,7 +52,6 @@ class ModernServer {
52
52
  var _conf_bff, _this_conf_output;
53
53
  this.runner = runner;
54
54
  const { distDir, conf } = this;
55
- this.initReader();
56
55
  (0, import_utils2.debug)("final server conf", this.conf);
57
56
  if ((_conf_bff = conf.bff) === null || _conf_bff === void 0 ? void 0 : _conf_bff.proxy) {
58
57
  const { handlers, handleUpgrade } = (0, import_proxy.createProxyHandler)(conf.bff.proxy);
@@ -61,12 +60,10 @@ class ModernServer {
61
60
  this.addHandler(handler);
62
61
  });
63
62
  }
64
- app === null || app === void 0 ? void 0 : app.on("close", () => {
65
- this.reader.close();
66
- });
67
63
  const usageRoutes = this.filterRoutes(this.getRoutes());
68
64
  this.router.reset(usageRoutes);
69
65
  this.warmupSSRBundle();
66
+ import_cacheMod.cacheMod.loadServerCacheMod(this.pwd);
70
67
  await this.prepareFrameHandler();
71
68
  await this.prepareLoaderHandler(usageRoutes, distDir);
72
69
  this.routeRenderHandler = this.getRenderHandler();
@@ -122,9 +119,6 @@ class ModernServer {
122
119
  return (0, import_http.createServer)(handler);
123
120
  }
124
121
  /* —————————————————————— function will be overwrite —————————————————————— */
125
- initReader() {
126
- this.reader.init();
127
- }
128
122
  async onServerChange({ filepath }) {
129
123
  const { pwd } = this;
130
124
  const { api, server } = import_constants.AGGRED_DIR;
@@ -508,7 +502,6 @@ class ModernServer {
508
502
  (0, import_define_property._)(this, "logger", void 0);
509
503
  (0, import_define_property._)(this, "metrics", void 0);
510
504
  (0, import_define_property._)(this, "runMode", void 0);
511
- (0, import_define_property._)(this, "reader", reader);
512
505
  (0, import_define_property._)(this, "proxyTarget", void 0);
513
506
  (0, import_define_property._)(this, "routeRenderHandler", void 0);
514
507
  (0, import_define_property._)(this, "staticGenerate", void 0);
@@ -0,0 +1,33 @@
1
+ import { _ as _async_to_generator } from "@swc/helpers/_/_async_to_generator";
2
+ import { _ as _ts_generator } from "@swc/helpers/_/_ts_generator";
3
+ import { Transform } from "stream";
4
+ var afterRenderInjectableStream = function(fn) {
5
+ return new Transform({
6
+ write: function write(chunk, _, callback) {
7
+ return _async_to_generator(function() {
8
+ var _2, _1;
9
+ return _ts_generator(this, function(_state) {
10
+ switch (_state.label) {
11
+ case 0:
12
+ _1 = (_2 = this).push;
13
+ return [
14
+ 4,
15
+ fn(chunk.toString())
16
+ ];
17
+ case 1:
18
+ _1.apply(_2, [
19
+ _state.sent()
20
+ ]);
21
+ callback();
22
+ return [
23
+ 2
24
+ ];
25
+ }
26
+ });
27
+ }).apply(this);
28
+ }
29
+ });
30
+ };
31
+ export {
32
+ afterRenderInjectableStream
33
+ };
@@ -25,6 +25,15 @@ var createAfterRenderContext = function(context, route, content) {
25
25
  template: new TemplateAPI(content)
26
26
  });
27
27
  };
28
+ var createAfterStreamingRenderContext = function(context, route) {
29
+ var baseContext = base(context);
30
+ return function(chunk) {
31
+ return _object_spread_props(_object_spread({}, baseContext), {
32
+ route,
33
+ chunk
34
+ });
35
+ };
36
+ };
28
37
  var createMiddlewareContext = function(context) {
29
38
  var baseContext = base(context);
30
39
  baseContext.response.locals = context.res.locals || {};
@@ -41,5 +50,6 @@ export {
41
50
  base,
42
51
  createAfterMatchContext,
43
52
  createAfterRenderContext,
53
+ createAfterStreamingRenderContext,
44
54
  createMiddlewareContext
45
55
  };
@@ -2,10 +2,10 @@ import { _ as _async_to_generator } from "@swc/helpers/_/_async_to_generator";
2
2
  import { _ as _ts_generator } from "@swc/helpers/_/_ts_generator";
3
3
  import path from "path";
4
4
  import { cutNameByHyphen, mime } from "@modern-js/utils";
5
+ import { fileReader } from "@modern-js/runtime-utils/fileReader";
5
6
  import { ERROR_DIGEST } from "../../constants";
6
7
  import { shouldFlushServerHeader } from "../preload/shouldFlushServerHeader";
7
8
  import { handleDirectory } from "./static";
8
- import { readFile } from "./reader";
9
9
  import * as ssr from "./ssr";
10
10
  import { injectServerData } from "./utils";
11
11
  var calcFallback = function(metaName) {
@@ -47,7 +47,7 @@ var createRenderHandler = function(param) {
47
47
  templatePath = entry;
48
48
  return [
49
49
  4,
50
- readFile(templatePath)
50
+ fileReader.readFile(templatePath)
51
51
  ];
52
52
  case 3:
53
53
  content = _state.sent();
@@ -97,24 +97,14 @@ var createRenderHandler = function(param) {
97
97
  case 6:
98
98
  ssrRenderOptions = {
99
99
  distDir,
100
- entryName: route.entryName,
101
- urlPath: route.urlPath,
102
- bundle: route.bundle,
100
+ route,
103
101
  template: content.toString(),
104
102
  staticGenerate,
105
103
  nonce
106
104
  };
107
105
  return [
108
106
  4,
109
- ssrRender ? ssrRender(ctx, ssrRenderOptions, runner) : ssr.render(ctx, {
110
- distDir,
111
- entryName: route.entryName,
112
- urlPath: route.urlPath,
113
- bundle: route.bundle,
114
- template: content.toString(),
115
- staticGenerate,
116
- nonce
117
- }, runner)
107
+ ssrRender ? ssrRender(ctx, ssrRenderOptions, runner) : ssr.render(ctx, ssrRenderOptions, runner)
118
108
  ];
119
109
  case 7:
120
110
  result1 = _state.sent();
@@ -2,16 +2,19 @@ import { _ as _async_to_generator } from "@swc/helpers/_/_async_to_generator";
2
2
  import { _ as _ts_generator } from "@swc/helpers/_/_ts_generator";
3
3
  import path from "path";
4
4
  import { fs, mime, LOADABLE_STATS_FILE, ROUTE_MANIFEST_FILE, SERVER_RENDER_FUNCTION_NAME } from "@modern-js/utils";
5
- import cache from "./cache";
5
+ import { createAfterStreamingRenderContext } from "../hook-api";
6
+ import { afterRenderInjectableStream } from "../hook-api/afterRenderForStream";
6
7
  import { createLogger, createMetrics } from "./measure";
7
8
  import { injectServerDataStream, injectServerData } from "./utils";
9
+ import { ssrCache } from "./ssrCache";
8
10
  var render = function() {
9
11
  var _ref = _async_to_generator(function(ctx, renderOptions, runner) {
10
- var _ctx_res, urlPath, bundle, distDir, template, entryName, staticGenerate, _renderOptions_enableUnsafeCtx, enableUnsafeCtx, nonce, bundleJS, loadableUri, loadableStats, routesManifestUri, routeManifest, context, bundleJSContent, serverRender, content, _context_redirection, url, _context_redirection_status, status;
12
+ var _ctx_res, distDir, route, template, staticGenerate, _renderOptions_enableUnsafeCtx, enableUnsafeCtx, nonce, urlPath, bundle, entryName, bundleJS, loadableUri, loadableStats, routesManifestUri, routeManifest, context, bundleJSContent, serverRender, content, _context_redirection, url, _context_redirection_status, status, contentStream, afterStreamingRenderContext;
11
13
  return _ts_generator(this, function(_state) {
12
14
  switch (_state.label) {
13
15
  case 0:
14
- urlPath = renderOptions.urlPath, bundle = renderOptions.bundle, distDir = renderOptions.distDir, template = renderOptions.template, entryName = renderOptions.entryName, staticGenerate = renderOptions.staticGenerate, _renderOptions_enableUnsafeCtx = renderOptions.enableUnsafeCtx, enableUnsafeCtx = _renderOptions_enableUnsafeCtx === void 0 ? false : _renderOptions_enableUnsafeCtx, nonce = renderOptions.nonce;
16
+ distDir = renderOptions.distDir, route = renderOptions.route, template = renderOptions.template, staticGenerate = renderOptions.staticGenerate, _renderOptions_enableUnsafeCtx = renderOptions.enableUnsafeCtx, enableUnsafeCtx = _renderOptions_enableUnsafeCtx === void 0 ? false : _renderOptions_enableUnsafeCtx, nonce = renderOptions.nonce;
17
+ urlPath = route.urlPath, bundle = route.bundle, entryName = route.entryName;
15
18
  bundleJS = path.join(distDir, bundle);
16
19
  loadableUri = path.join(distDir, LOADABLE_STATS_FILE);
17
20
  loadableStats = fs.existsSync(loadableUri) ? require(loadableUri) : "";
@@ -63,7 +66,7 @@ var render = function() {
63
66
  serverRender = bundleJSContent[SERVER_RENDER_FUNCTION_NAME];
64
67
  return [
65
68
  4,
66
- cache(serverRender, ctx)(context)
69
+ ssrCache(ctx.req, serverRender, context)
67
70
  ];
68
71
  case 2:
69
72
  content = _state.sent();
@@ -88,11 +91,22 @@ var render = function() {
88
91
  }
89
92
  ];
90
93
  } else {
94
+ contentStream = injectServerDataStream(content, ctx);
95
+ afterStreamingRenderContext = createAfterStreamingRenderContext(ctx, route);
96
+ contentStream = contentStream.pipe(afterRenderInjectableStream(function(chunk) {
97
+ var context2 = afterStreamingRenderContext(chunk);
98
+ return runner.afterStreamingRender(context2, {
99
+ onLast: function(param) {
100
+ var _$chunk = param.chunk;
101
+ return _$chunk;
102
+ }
103
+ });
104
+ }));
91
105
  return [
92
106
  2,
93
107
  {
94
108
  content: "",
95
- contentStream: injectServerDataStream(content, ctx),
109
+ contentStream,
96
110
  contentType: mime.contentType("html")
97
111
  }
98
112
  ];