@modern-js/prod-server 2.4.1-beta.0 → 2.5.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 (134) hide show
  1. package/CHANGELOG.md +18 -3
  2. package/dist/{js/node → cjs}/constants.js +0 -0
  3. package/dist/{js/node → cjs}/index.js +0 -0
  4. package/dist/{js/node → cjs}/libs/context/context.js +0 -0
  5. package/dist/{js/node → cjs}/libs/context/index.js +0 -0
  6. package/dist/{js/node → cjs}/libs/hook-api/index.js +12 -25
  7. package/dist/{js/node → cjs}/libs/hook-api/route.js +0 -0
  8. package/dist/{js/node → cjs}/libs/hook-api/template.js +0 -0
  9. package/dist/{js/node → cjs}/libs/loadConfig.js +6 -21
  10. package/dist/{js/node → cjs}/libs/logger.js +5 -16
  11. package/dist/{js/node → cjs}/libs/metrics.js +0 -0
  12. package/dist/{js/node → cjs}/libs/proxy.js +6 -39
  13. package/dist/{js/node → cjs}/libs/render/cache/__tests__/cache.fun.test.js +12 -34
  14. package/dist/{js/node → cjs}/libs/render/cache/__tests__/cache.test.js +43 -78
  15. package/dist/{js/node → cjs}/libs/render/cache/__tests__/cacheable.js +0 -0
  16. package/dist/{js/node → cjs}/libs/render/cache/__tests__/error-configuration.js +0 -0
  17. package/dist/{js/node → cjs}/libs/render/cache/__tests__/matched-cache.js +0 -0
  18. package/dist/cjs/libs/render/cache/index.js +97 -0
  19. package/dist/cjs/libs/render/cache/page-caches/index.js +33 -0
  20. package/dist/{js/node → cjs}/libs/render/cache/page-caches/lru.js +0 -0
  21. package/dist/{js/node → cjs}/libs/render/cache/spr.js +69 -97
  22. package/dist/{js/node → cjs}/libs/render/cache/type.js +0 -0
  23. package/dist/{js/node → cjs}/libs/render/cache/util.js +19 -41
  24. package/dist/cjs/libs/render/index.js +93 -0
  25. package/dist/{js/node → cjs}/libs/render/measure.js +6 -21
  26. package/dist/{js/node → cjs}/libs/render/reader.js +24 -46
  27. package/dist/{js/node → cjs}/libs/render/ssr.js +3 -23
  28. package/dist/{js/node → cjs}/libs/render/static.js +22 -44
  29. package/dist/{js/node → cjs}/libs/render/type.js +0 -0
  30. package/dist/{js/node → cjs}/libs/route/index.js +0 -0
  31. package/dist/{js/node → cjs}/libs/route/matcher.js +0 -0
  32. package/dist/{js/node → cjs}/libs/route/route.js +0 -0
  33. package/dist/{js/node → cjs}/libs/serve-file.js +2 -22
  34. package/dist/{js/node → cjs}/server/index.js +56 -106
  35. package/dist/{js/node → cjs}/server/modern-server-split.js +9 -40
  36. package/dist/cjs/server/modern-server.js +490 -0
  37. package/dist/{js/node → cjs}/type.js +0 -0
  38. package/dist/{js/node → cjs}/utils.js +1 -15
  39. package/dist/{js/node → cjs}/worker-server.js +3 -23
  40. package/dist/{js/treeshaking → esm}/constants.js +0 -0
  41. package/dist/{js/treeshaking → esm}/index.js +0 -0
  42. package/dist/{js/treeshaking → esm}/libs/context/context.js +0 -0
  43. package/dist/{js/treeshaking → esm}/libs/context/index.js +0 -0
  44. package/dist/{js/treeshaking → esm}/libs/hook-api/index.js +0 -0
  45. package/dist/{js/treeshaking → esm}/libs/hook-api/route.js +0 -0
  46. package/dist/{js/treeshaking → esm}/libs/hook-api/template.js +0 -0
  47. package/dist/{js/treeshaking → esm}/libs/loadConfig.js +0 -0
  48. package/dist/{js/treeshaking → esm}/libs/logger.js +0 -0
  49. package/dist/{js/treeshaking → esm}/libs/metrics.js +0 -0
  50. package/dist/{js/treeshaking → esm}/libs/proxy.js +0 -0
  51. package/dist/{js/treeshaking → esm}/libs/render/cache/__tests__/cache.fun.test.js +0 -0
  52. package/dist/{js/treeshaking → esm}/libs/render/cache/__tests__/cache.test.js +0 -0
  53. package/dist/{js/treeshaking → esm}/libs/render/cache/__tests__/cacheable.js +0 -0
  54. package/dist/{js/treeshaking → esm}/libs/render/cache/__tests__/error-configuration.js +0 -0
  55. package/dist/{js/treeshaking → esm}/libs/render/cache/__tests__/matched-cache.js +0 -0
  56. package/dist/{js/treeshaking → esm}/libs/render/cache/index.js +0 -0
  57. package/dist/{js/treeshaking → esm}/libs/render/cache/page-caches/index.js +0 -0
  58. package/dist/{js/treeshaking → esm}/libs/render/cache/page-caches/lru.js +0 -0
  59. package/dist/{js/treeshaking → esm}/libs/render/cache/spr.js +0 -0
  60. package/dist/{js/treeshaking → esm}/libs/render/cache/type.js +0 -0
  61. package/dist/{js/treeshaking → esm}/libs/render/cache/util.js +0 -0
  62. package/dist/{js/treeshaking → esm}/libs/render/index.js +4 -3
  63. package/dist/{js/treeshaking → esm}/libs/render/measure.js +0 -0
  64. package/dist/{js/treeshaking → esm}/libs/render/reader.js +0 -0
  65. package/dist/{js/treeshaking → esm}/libs/render/ssr.js +0 -0
  66. package/dist/{js/treeshaking → esm}/libs/render/static.js +0 -0
  67. package/dist/{js/treeshaking → esm}/libs/render/type.js +0 -0
  68. package/dist/{js/treeshaking → esm}/libs/route/index.js +0 -0
  69. package/dist/{js/treeshaking → esm}/libs/route/matcher.js +0 -0
  70. package/dist/{js/treeshaking → esm}/libs/route/route.js +0 -0
  71. package/dist/{js/treeshaking → esm}/libs/serve-file.js +0 -0
  72. package/dist/{js/treeshaking → esm}/server/index.js +0 -0
  73. package/dist/{js/treeshaking → esm}/server/modern-server-split.js +0 -0
  74. package/dist/{js/treeshaking → esm}/server/modern-server.js +14 -8
  75. package/dist/{js/treeshaking → esm}/type.js +0 -0
  76. package/dist/{js/treeshaking → esm}/utils.js +0 -0
  77. package/dist/{js/treeshaking → esm}/worker-server.js +0 -0
  78. package/dist/{js/modern → esm-node}/constants.js +0 -0
  79. package/dist/{js/modern → esm-node}/index.js +0 -0
  80. package/dist/{js/modern → esm-node}/libs/context/context.js +0 -0
  81. package/dist/{js/modern → esm-node}/libs/context/index.js +0 -0
  82. package/dist/{js/modern → esm-node}/libs/hook-api/index.js +12 -27
  83. package/dist/{js/modern → esm-node}/libs/hook-api/route.js +0 -0
  84. package/dist/{js/modern → esm-node}/libs/hook-api/template.js +0 -0
  85. package/dist/esm-node/libs/loadConfig.js +45 -0
  86. package/dist/{js/modern → esm-node}/libs/logger.js +5 -18
  87. package/dist/{js/modern → esm-node}/libs/metrics.js +0 -0
  88. package/dist/{js/modern → esm-node}/libs/proxy.js +6 -41
  89. package/dist/esm-node/libs/render/cache/__tests__/cache.fun.test.js +83 -0
  90. package/dist/esm-node/libs/render/cache/__tests__/cache.test.js +210 -0
  91. package/dist/{js/modern → esm-node}/libs/render/cache/__tests__/cacheable.js +0 -0
  92. package/dist/{js/modern → esm-node}/libs/render/cache/__tests__/error-configuration.js +0 -0
  93. package/dist/{js/modern → esm-node}/libs/render/cache/__tests__/matched-cache.js +0 -0
  94. package/dist/esm-node/libs/render/cache/index.js +76 -0
  95. package/dist/esm-node/libs/render/cache/page-caches/index.js +10 -0
  96. package/dist/{js/modern → esm-node}/libs/render/cache/page-caches/lru.js +0 -0
  97. package/dist/{js/modern → esm-node}/libs/render/cache/spr.js +69 -97
  98. package/dist/{js/modern → esm-node}/libs/render/cache/type.js +0 -0
  99. package/dist/{js/modern → esm-node}/libs/render/cache/util.js +19 -41
  100. package/dist/esm-node/libs/render/index.js +64 -0
  101. package/dist/{js/modern → esm-node}/libs/render/measure.js +6 -23
  102. package/dist/esm-node/libs/render/reader.js +85 -0
  103. package/dist/{js/modern → esm-node}/libs/render/ssr.js +3 -23
  104. package/dist/esm-node/libs/render/static.js +38 -0
  105. package/dist/{js/modern → esm-node}/libs/render/type.js +0 -0
  106. package/dist/{js/modern → esm-node}/libs/route/index.js +0 -0
  107. package/dist/{js/modern → esm-node}/libs/route/matcher.js +0 -0
  108. package/dist/{js/modern → esm-node}/libs/route/route.js +0 -0
  109. package/dist/{js/modern → esm-node}/libs/serve-file.js +2 -22
  110. package/dist/esm-node/server/index.js +156 -0
  111. package/dist/esm-node/server/modern-server-split.js +43 -0
  112. package/dist/esm-node/server/modern-server.js +483 -0
  113. package/dist/{js/modern → esm-node}/type.js +0 -0
  114. package/dist/{js/modern → esm-node}/utils.js +1 -17
  115. package/dist/{js/modern → esm-node}/worker-server.js +3 -23
  116. package/dist/types/libs/context/context.d.ts +1 -1
  117. package/dist/types/libs/render/index.d.ts +3 -1
  118. package/dist/types/utils.d.ts +1 -1
  119. package/package.json +15 -16
  120. package/dist/js/modern/libs/loadConfig.js +0 -62
  121. package/dist/js/modern/libs/render/cache/__tests__/cache.fun.test.js +0 -114
  122. package/dist/js/modern/libs/render/cache/__tests__/cache.test.js +0 -254
  123. package/dist/js/modern/libs/render/cache/index.js +0 -115
  124. package/dist/js/modern/libs/render/cache/page-caches/index.js +0 -32
  125. package/dist/js/modern/libs/render/index.js +0 -84
  126. package/dist/js/modern/libs/render/reader.js +0 -107
  127. package/dist/js/modern/libs/render/static.js +0 -60
  128. package/dist/js/modern/server/index.js +0 -208
  129. package/dist/js/modern/server/modern-server-split.js +0 -74
  130. package/dist/js/modern/server/modern-server.js +0 -548
  131. package/dist/js/node/libs/render/cache/index.js +0 -134
  132. package/dist/js/node/libs/render/cache/page-caches/index.js +0 -55
  133. package/dist/js/node/libs/render/index.js +0 -113
  134. package/dist/js/node/server/modern-server.js +0 -553
@@ -0,0 +1,490 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
21
+ mod
22
+ ));
23
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
24
+ var modern_server_exports = {};
25
+ __export(modern_server_exports, {
26
+ ModernServer: () => ModernServer
27
+ });
28
+ module.exports = __toCommonJS(modern_server_exports);
29
+ var import_http = require("http");
30
+ var import_path = __toESM(require("path"));
31
+ var import_utils = require("@modern-js/utils");
32
+ var import_route = require("../libs/route");
33
+ var import_render = require("../libs/render");
34
+ var import_serve_file = require("../libs/serve-file");
35
+ var import_utils2 = require("../utils");
36
+ var reader = __toESM(require("../libs/render/reader"));
37
+ var import_proxy = require("../libs/proxy");
38
+ var import_context = require("../libs/context");
39
+ var import_template = require("../libs/hook-api/template");
40
+ var import_constants = require("../constants");
41
+ var import_hook_api = require("../libs/hook-api");
42
+ const API_DIR = "./api";
43
+ const SERVER_DIR = "./server";
44
+ class ModernServer {
45
+ constructor({
46
+ pwd,
47
+ config,
48
+ routes,
49
+ staticGenerate,
50
+ logger,
51
+ metrics,
52
+ runMode,
53
+ proxyTarget
54
+ }) {
55
+ this.handlers = [];
56
+ this.reader = reader;
57
+ this.beforeRouteHandler = null;
58
+ this.frameWebHandler = null;
59
+ this.frameAPIHandler = null;
60
+ this.proxyHandler = null;
61
+ require("ignore-styles");
62
+ this.pwd = pwd;
63
+ this.distDir = import_path.default.join(pwd, config.output.path || "dist");
64
+ this.workDir = this.distDir;
65
+ this.conf = config;
66
+ (0, import_utils2.debug)("server conf", this.conf);
67
+ this.logger = logger;
68
+ this.metrics = metrics;
69
+ this.router = new import_route.RouteMatchManager();
70
+ this.presetRoutes = routes;
71
+ this.proxyTarget = proxyTarget;
72
+ this.staticGenerate = staticGenerate || false;
73
+ this.runMode = runMode || import_constants.RUN_MODE.FULL;
74
+ }
75
+ async onInit(runner, app) {
76
+ var _a, _b;
77
+ this.runner = runner;
78
+ const { distDir, staticGenerate, conf } = this;
79
+ (0, import_utils2.debug)("final server conf", this.conf);
80
+ this.proxyHandler = (0, import_proxy.createProxyHandler)((_a = conf.bff) == null ? void 0 : _a.proxy);
81
+ if (this.proxyHandler) {
82
+ this.proxyHandler.forEach((handler) => {
83
+ this.addHandler(handler);
84
+ });
85
+ }
86
+ this.reader.init();
87
+ app.on("close", () => {
88
+ this.reader.close();
89
+ });
90
+ const usageRoutes = this.filterRoutes(this.getRoutes());
91
+ this.router.reset(usageRoutes);
92
+ this.warmupSSRBundle();
93
+ await this.prepareFrameHandler();
94
+ await this.prepareBeforeRouteHandler(usageRoutes, distDir);
95
+ const staticPathRegExp = (0, import_utils2.getStaticReg)(
96
+ this.conf.output || {},
97
+ this.conf.html
98
+ );
99
+ this.staticFileHandler = (0, import_serve_file.createStaticFileHandler)(
100
+ [
101
+ {
102
+ path: staticPathRegExp,
103
+ target: distDir
104
+ }
105
+ ],
106
+ this.conf.output
107
+ );
108
+ const ssrConfig = (_b = this.conf.server) == null ? void 0 : _b.ssr;
109
+ const forceCSR = typeof ssrConfig === "object" ? ssrConfig.forceCSR : false;
110
+ this.routeRenderHandler = (0, import_render.createRenderHandler)({
111
+ distDir,
112
+ staticGenerate,
113
+ forceCSR
114
+ });
115
+ await this.setupBeforeProdMiddleware();
116
+ this.addHandler(this.staticFileHandler);
117
+ this.addHandler(import_serve_file.faviconFallbackHandler);
118
+ this.addBeforeRouteHandler();
119
+ this.addHandler(this.routeHandler.bind(this));
120
+ this.compose();
121
+ }
122
+ onRepack(_) {
123
+ }
124
+ addBeforeRouteHandler() {
125
+ this.addHandler(async (context, next) => {
126
+ if (this.beforeRouteHandler) {
127
+ await this.beforeRouteHandler(context);
128
+ if (this.isSend(context.res)) {
129
+ return;
130
+ }
131
+ }
132
+ return next();
133
+ });
134
+ }
135
+ onServerChange({ filepath }) {
136
+ const { pwd } = this;
137
+ const { api, server } = import_constants.AGGRED_DIR;
138
+ const apiPath = import_path.default.normalize(import_path.default.join(pwd, api));
139
+ const serverPath = import_path.default.normalize(import_path.default.join(pwd, server));
140
+ const onlyApi = filepath.startsWith(apiPath);
141
+ const onlyWeb = filepath.startsWith(serverPath);
142
+ this.prepareFrameHandler({ onlyWeb, onlyApi });
143
+ }
144
+ getRequestHandler() {
145
+ return this.requestHandler.bind(this);
146
+ }
147
+ async render(req, res, url) {
148
+ req.logger = req.logger || this.logger;
149
+ req.metrics = req.metrics || this.metrics;
150
+ const context = (0, import_context.createContext)(req, res);
151
+ const matched = this.router.match(url || context.path);
152
+ if (!matched) {
153
+ return null;
154
+ }
155
+ const route = matched.generate(context.url);
156
+ const result = await this.handleWeb(context, route);
157
+ if (!result) {
158
+ return null;
159
+ }
160
+ return result.content.toString();
161
+ }
162
+ async createHTTPServer(handler) {
163
+ return (0, import_http.createServer)(handler);
164
+ }
165
+ getRoutes() {
166
+ if (this.presetRoutes) {
167
+ return this.presetRoutes;
168
+ }
169
+ const file = import_path.default.join(this.distDir, import_utils.ROUTE_SPEC_FILE);
170
+ if (import_utils.fs.existsSync(file)) {
171
+ const content = import_utils.fs.readJSONSync(file);
172
+ return content.routes;
173
+ }
174
+ return [];
175
+ }
176
+ addHandler(handler) {
177
+ this.handlers.push(handler);
178
+ }
179
+ render404(context) {
180
+ context.error(import_constants.ERROR_DIGEST.ENOTF, "404 Not Found");
181
+ this.renderErrorPage(context, 404);
182
+ }
183
+ async prepareBeforeRouteHandler(specs, distDir) {
184
+ const { runner } = this;
185
+ const handler = await runner.preparebeforeRouteHandler(
186
+ {
187
+ serverRoutes: specs,
188
+ distDir
189
+ },
190
+ {
191
+ onLast: () => null
192
+ }
193
+ );
194
+ this.beforeRouteHandler = handler;
195
+ }
196
+ async prepareFrameHandler(options) {
197
+ const { workDir, runner } = this;
198
+ const { onlyApi, onlyWeb } = options || {};
199
+ const { getMiddlewares, ...collector } = (0, import_utils2.createMiddlewareCollecter)();
200
+ await runner.gather(collector);
201
+ const { api: pluginAPIExt, web: pluginWebExt } = getMiddlewares();
202
+ const apiDir = import_path.default.join(workDir, API_DIR);
203
+ const serverDir = import_path.default.join(workDir, SERVER_DIR);
204
+ if (await import_utils.fs.pathExists(import_path.default.join(serverDir)) && !onlyApi) {
205
+ const webExtension = (0, import_utils2.mergeExtension)(pluginWebExt);
206
+ this.frameWebHandler = await this.prepareWebHandler(webExtension);
207
+ }
208
+ if (import_utils.fs.existsSync(apiDir) && !onlyWeb) {
209
+ const apiExtension = (0, import_utils2.mergeExtension)(pluginAPIExt);
210
+ this.frameAPIHandler = await this.prepareAPIHandler(apiExtension);
211
+ }
212
+ }
213
+ async prepareWebHandler(extension) {
214
+ const { workDir, runner } = this;
215
+ const handler = await runner.prepareWebServer(
216
+ {
217
+ pwd: workDir,
218
+ config: extension
219
+ },
220
+ { onLast: () => null }
221
+ );
222
+ return handler;
223
+ }
224
+ async prepareAPIHandler(extension) {
225
+ const { workDir, runner, conf } = this;
226
+ const { bff } = conf;
227
+ const prefix = (bff == null ? void 0 : bff.prefix) || "/api";
228
+ return runner.prepareApiServer(
229
+ {
230
+ pwd: workDir,
231
+ config: extension,
232
+ prefix: Array.isArray(prefix) ? prefix[0] : prefix,
233
+ render: this.render.bind(this)
234
+ },
235
+ { onLast: () => null }
236
+ );
237
+ }
238
+ filterRoutes(routes) {
239
+ return routes;
240
+ }
241
+ async setupBeforeProdMiddleware() {
242
+ const { conf, runner } = this;
243
+ const preMiddleware = await runner.beforeProdServer(conf);
244
+ preMiddleware.flat().forEach((mid) => {
245
+ this.addHandler(mid);
246
+ });
247
+ }
248
+ async handleAPI(context) {
249
+ const { req, res } = context;
250
+ if (!this.frameAPIHandler) {
251
+ throw new Error("can not found api handler");
252
+ }
253
+ await this.frameAPIHandler(req, res);
254
+ }
255
+ async handleWeb(context, route) {
256
+ return this.routeRenderHandler({
257
+ ctx: context,
258
+ route,
259
+ runner: this.runner
260
+ });
261
+ }
262
+ async proxy() {
263
+ return null;
264
+ }
265
+ warmupSSRBundle() {
266
+ const { distDir } = this;
267
+ const bundles = this.router.getBundles();
268
+ bundles.forEach((bundle) => {
269
+ const filepath = import_path.default.join(distDir, bundle);
270
+ if (import_utils.fs.existsSync(filepath)) {
271
+ require(filepath);
272
+ }
273
+ });
274
+ }
275
+ createContext(req, res, options = {}) {
276
+ return (0, import_context.createContext)(req, res, options);
277
+ }
278
+ async routeHandler(context) {
279
+ const { res } = context;
280
+ const matched = this.router.match(context.path);
281
+ if (!matched) {
282
+ this.render404(context);
283
+ return;
284
+ }
285
+ let route = matched.generate(context.url);
286
+ if (route.isApi) {
287
+ await this.handleAPI(context);
288
+ return;
289
+ }
290
+ const afterMatchContext = (0, import_hook_api.createAfterMatchContext)(context, route.entryName);
291
+ if (this.runMode === import_constants.RUN_MODE.FULL) {
292
+ await this.runner.afterMatch(afterMatchContext, { onLast: import_utils2.noop });
293
+ }
294
+ if (this.isSend(res)) {
295
+ return;
296
+ }
297
+ const { current, url, status } = afterMatchContext.router;
298
+ if (url) {
299
+ this.redirect(res, url, status);
300
+ return;
301
+ }
302
+ if (route.entryName !== current) {
303
+ const matched2 = this.router.matchEntry(current);
304
+ if (!matched2) {
305
+ this.render404(context);
306
+ return;
307
+ }
308
+ route = matched2.generate(context.url);
309
+ }
310
+ context.setParams(route.params);
311
+ context.setServerData("router", {
312
+ baseUrl: route.urlPath,
313
+ params: route.params
314
+ });
315
+ if (this.frameWebHandler) {
316
+ res.locals = res.locals || {};
317
+ const middlewareContext = (0, import_hook_api.createMiddlewareContext)(context);
318
+ await this.frameWebHandler(middlewareContext);
319
+ res.locals = {
320
+ ...res.locals,
321
+ ...middlewareContext.response.locals
322
+ };
323
+ }
324
+ if (this.isSend(res)) {
325
+ return;
326
+ }
327
+ if (route.responseHeaders) {
328
+ Object.keys(route.responseHeaders).forEach((key) => {
329
+ const value = route.responseHeaders[key];
330
+ if (value) {
331
+ context.res.setHeader(key, value);
332
+ }
333
+ });
334
+ }
335
+ const renderResult = await this.handleWeb(context, route);
336
+ if (!renderResult) {
337
+ this.render404(context);
338
+ return;
339
+ }
340
+ if (renderResult.redirect) {
341
+ this.redirect(
342
+ res,
343
+ renderResult.content,
344
+ renderResult.statusCode
345
+ );
346
+ return;
347
+ }
348
+ if (this.isSend(res)) {
349
+ return;
350
+ }
351
+ res.setHeader("content-type", renderResult.contentType);
352
+ const { contentStream } = renderResult;
353
+ if (contentStream) {
354
+ contentStream.pipe(
355
+ (0, import_template.templateInjectableStream)({
356
+ prependHead: route.entryName ? `<script>window._SERVER_DATA=${JSON.stringify(
357
+ context.serverData
358
+ )}<\/script>` : void 0
359
+ })
360
+ ).pipe(res);
361
+ return;
362
+ }
363
+ let response = renderResult.content;
364
+ if (route.entryName) {
365
+ const afterRenderContext = (0, import_hook_api.createAfterRenderContext)(
366
+ context,
367
+ response.toString()
368
+ );
369
+ if (this.runMode === import_constants.RUN_MODE.FULL) {
370
+ await this.runner.afterRender(afterRenderContext, { onLast: import_utils2.noop });
371
+ }
372
+ if (this.isSend(res)) {
373
+ return;
374
+ }
375
+ afterRenderContext.template.prependHead(
376
+ `<script>window._SERVER_DATA=${JSON.stringify(
377
+ context.serverData
378
+ )}<\/script>`
379
+ );
380
+ response = afterRenderContext.template.get();
381
+ }
382
+ res.end(response);
383
+ }
384
+ isSend(res) {
385
+ if (res.headersSent) {
386
+ return true;
387
+ }
388
+ if (res.getHeader("Location") && (0, import_utils2.isRedirect)(res.statusCode)) {
389
+ res.end();
390
+ return true;
391
+ }
392
+ return false;
393
+ }
394
+ compose() {
395
+ const { handlers } = this;
396
+ if (!Array.isArray(handlers)) {
397
+ throw new TypeError("Middleware stack must be an array!");
398
+ }
399
+ for (const fn of handlers) {
400
+ if (typeof fn !== "function") {
401
+ throw new TypeError("Middleware must be composed of functions!");
402
+ }
403
+ }
404
+ this._handler = (context, next) => {
405
+ let i = 0;
406
+ const dispatch = (error) => {
407
+ if (error) {
408
+ return this.onError(context, error);
409
+ }
410
+ const handler = handlers[i++];
411
+ if (!handler) {
412
+ return next();
413
+ }
414
+ try {
415
+ const result = handler(context, dispatch);
416
+ if ((0, import_utils.isPromise)(result)) {
417
+ return result.catch(onError);
418
+ }
419
+ } catch (e) {
420
+ return onError(e);
421
+ }
422
+ };
423
+ const onError = (err) => {
424
+ this.onError(context, err);
425
+ };
426
+ return dispatch();
427
+ };
428
+ }
429
+ requestHandler(req, res, next = () => {
430
+ }) {
431
+ res.statusCode = 200;
432
+ req.logger = req.logger || this.logger;
433
+ req.metrics = req.metrics || this.metrics;
434
+ let context;
435
+ try {
436
+ context = this.createContext(req, res);
437
+ } catch (e) {
438
+ this.logger.error(e);
439
+ res.statusCode = 500;
440
+ res.setHeader("content-type", import_utils.mime.contentType("html"));
441
+ return res.end((0, import_utils2.createErrorDocument)(500, import_constants.ERROR_PAGE_TEXT[500]));
442
+ }
443
+ try {
444
+ return this._handler(context, next);
445
+ } catch (err) {
446
+ return this.onError(context, err);
447
+ }
448
+ }
449
+ redirect(res, url, status = 302) {
450
+ res.setHeader("Location", url);
451
+ res.statusCode = status;
452
+ res.end();
453
+ }
454
+ onError(context, err) {
455
+ context.error(import_constants.ERROR_DIGEST.EINTER, err);
456
+ this.renderErrorPage(context, 500);
457
+ }
458
+ async renderErrorPage(context, status) {
459
+ const { res } = context;
460
+ context.status = status;
461
+ res.setHeader("content-type", import_utils.mime.contentType("html"));
462
+ const statusPage = `/${status}`;
463
+ const customErrorPage = `/_error`;
464
+ const matched = this.router.match(statusPage) || this.router.match(customErrorPage);
465
+ if (matched) {
466
+ const route = matched.generate(context.url);
467
+ const { entryName } = route;
468
+ if (entryName === status.toString() || entryName === "_error") {
469
+ try {
470
+ const file = await this.routeRenderHandler({
471
+ route,
472
+ ctx: context,
473
+ runner: this.runner
474
+ });
475
+ if (file) {
476
+ context.res.end(file.content);
477
+ return;
478
+ }
479
+ } catch (e) {
480
+ }
481
+ }
482
+ }
483
+ const text = import_constants.ERROR_PAGE_TEXT[status] || import_constants.ERROR_PAGE_TEXT[500];
484
+ context.res.end((0, import_utils2.createErrorDocument)(status, text));
485
+ }
486
+ }
487
+ // Annotate the CommonJS export names for ESM import in node:
488
+ 0 && (module.exports = {
489
+ ModernServer
490
+ });
File without changes
@@ -1,21 +1,7 @@
1
1
  var __defProp = Object.defineProperty;
2
2
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
3
  var __getOwnPropNames = Object.getOwnPropertyNames;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
4
  var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
5
  var __export = (target, all) => {
20
6
  for (var name in all)
21
7
  __defProp(target, name, { get: all[name], enumerable: true });
@@ -142,7 +128,7 @@ const prepareFavicons = (favicon, faviconByEntries) => {
142
128
  };
143
129
  const headersWithoutCookie = (headers) => {
144
130
  if (typeof headers.cookie !== "undefined") {
145
- const safeHeaders = __spreadValues({}, headers);
131
+ const safeHeaders = { ...headers };
146
132
  delete safeHeaders.cookie;
147
133
  return safeHeaders;
148
134
  }
@@ -15,26 +15,6 @@ var __copyProps = (to, from, except, desc) => {
15
15
  return to;
16
16
  };
17
17
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
- var __async = (__this, __arguments, generator) => {
19
- return new Promise((resolve, reject) => {
20
- var fulfilled = (value) => {
21
- try {
22
- step(generator.next(value));
23
- } catch (e) {
24
- reject(e);
25
- }
26
- };
27
- var rejected = (value) => {
28
- try {
29
- step(generator.throw(value));
30
- } catch (e) {
31
- reject(e);
32
- }
33
- };
34
- var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
35
- step((generator = generator.apply(__this, __arguments)).next());
36
- });
37
- };
38
18
  var worker_server_exports = {};
39
19
  __export(worker_server_exports, {
40
20
  createHandler: () => createHandler,
@@ -51,7 +31,7 @@ const createHandler = (manifest) => {
51
31
  const routeMgr = new import_route.RouteMatchManager();
52
32
  const { pages, routes } = manifest;
53
33
  routeMgr.reset(routes);
54
- return (ctx) => __async(void 0, null, function* () {
34
+ return async (ctx) => {
55
35
  var _a, _b, _c, _d, _e, _f;
56
36
  const pageMatch = routeMgr.match(ctx.url);
57
37
  if (!pageMatch) {
@@ -66,7 +46,7 @@ const createHandler = (manifest) => {
66
46
  const params = pageMatch.parseURLParams(ctx.url);
67
47
  if (page.serverRender) {
68
48
  try {
69
- ctx.body = yield page.serverRender({
49
+ ctx.body = await page.serverRender({
70
50
  entryName: page.entryName,
71
51
  template: page.template,
72
52
  query: ctx.query,
@@ -104,7 +84,7 @@ const createHandler = (manifest) => {
104
84
  }
105
85
  ctx.body = "404: not found";
106
86
  ctx.status = 404;
107
- });
87
+ };
108
88
  };
109
89
  // Annotate the CommonJS export names for ESM import in node:
110
90
  0 && (module.exports = {
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
@@ -129,10 +129,10 @@ import { handleDirectory } from "./static";
129
129
  import { readFile } from "./reader";
130
130
  import * as ssr from "./ssr";
131
131
  var createRenderHandler = function(param) {
132
- var distDir = param.distDir, staticGenerate = param.staticGenerate;
132
+ var distDir = param.distDir, staticGenerate = param.staticGenerate, forceCSR = param.forceCSR;
133
133
  return function() {
134
134
  var _render = _asyncToGenerator(function(param) {
135
- var ctx, route, runner, entryPath, urlPath, entry, result, templatePath, content, result1, err;
135
+ var ctx, route, runner, entryPath, urlPath, entry, result, templatePath, content, useCSR, result1, err;
136
136
  return __generator(this, function(_state) {
137
137
  switch(_state.label){
138
138
  case 0:
@@ -176,7 +176,8 @@ var createRenderHandler = function(param) {
176
176
  null
177
177
  ];
178
178
  }
179
- if (!route.isSSR) return [
179
+ useCSR = forceCSR && ctx.query.csr;
180
+ if (!(route.isSSR && !useCSR)) return [
180
181
  3,
181
182
  7
182
183
  ];
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes