@modern-js/prod-server 1.21.5 → 2.0.0-beta.1

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 (120) hide show
  1. package/CHANGELOG.md +91 -10
  2. package/dist/js/modern/constants.js +0 -2
  3. package/dist/js/modern/index.js +0 -1
  4. package/dist/js/modern/libs/context/context.js +10 -56
  5. package/dist/js/modern/libs/hook-api/index.js +125 -0
  6. package/dist/js/modern/libs/hook-api/route.js +13 -36
  7. package/dist/js/modern/libs/hook-api/template.js +38 -15
  8. package/dist/js/modern/libs/loadConfig.js +3 -10
  9. package/dist/js/modern/libs/metrics.js +6 -6
  10. package/dist/js/modern/libs/proxy.js +7 -12
  11. package/dist/js/modern/libs/render/cache/__tests__/cache.fun.test.js +0 -1
  12. package/dist/js/modern/libs/render/cache/__tests__/cache.test.js +0 -9
  13. package/dist/js/modern/libs/render/cache/index.js +37 -28
  14. package/dist/js/modern/libs/render/cache/page-caches/lru.js +0 -10
  15. package/dist/js/modern/libs/render/cache/spr.js +12 -62
  16. package/dist/js/modern/libs/render/cache/util.js +0 -6
  17. package/dist/js/modern/libs/render/index.js +6 -11
  18. package/dist/js/modern/libs/render/measure.js +7 -10
  19. package/dist/js/modern/libs/render/modern/index.js +2 -13
  20. package/dist/js/modern/libs/render/reader.js +13 -24
  21. package/dist/js/modern/libs/render/ssr.js +24 -12
  22. package/dist/js/modern/libs/render/static.js +6 -9
  23. package/dist/js/modern/libs/render/type.js +0 -1
  24. package/dist/js/modern/libs/route/index.js +8 -19
  25. package/dist/js/modern/libs/route/matcher.js +21 -29
  26. package/dist/js/modern/libs/route/route.js +0 -13
  27. package/dist/js/modern/libs/serve-file.js +13 -6
  28. package/dist/js/modern/server/index.js +27 -43
  29. package/dist/js/modern/server/modern-server-split.js +5 -55
  30. package/dist/js/modern/server/modern-server.js +179 -250
  31. package/dist/js/modern/utils.js +2 -21
  32. package/dist/js/modern/worker-server.js +34 -0
  33. package/dist/js/node/constants.js +0 -2
  34. package/dist/js/node/index.js +0 -10
  35. package/dist/js/node/libs/context/context.js +10 -65
  36. package/dist/js/node/libs/context/index.js +0 -3
  37. package/dist/js/node/libs/hook-api/index.js +136 -0
  38. package/dist/js/node/libs/hook-api/route.js +13 -38
  39. package/dist/js/node/libs/hook-api/template.js +40 -18
  40. package/dist/js/node/libs/loadConfig.js +3 -22
  41. package/dist/js/node/libs/metrics.js +6 -6
  42. package/dist/js/node/libs/proxy.js +7 -17
  43. package/dist/js/node/libs/render/cache/__tests__/cache.fun.test.js +0 -5
  44. package/dist/js/node/libs/render/cache/__tests__/cache.test.js +0 -12
  45. package/dist/js/node/libs/render/cache/index.js +37 -33
  46. package/dist/js/node/libs/render/cache/page-caches/index.js +0 -2
  47. package/dist/js/node/libs/render/cache/page-caches/lru.js +0 -14
  48. package/dist/js/node/libs/render/cache/spr.js +12 -71
  49. package/dist/js/node/libs/render/cache/util.js +0 -18
  50. package/dist/js/node/libs/render/index.js +6 -26
  51. package/dist/js/node/libs/render/measure.js +5 -15
  52. package/dist/js/node/libs/render/modern/index.js +2 -20
  53. package/dist/js/node/libs/render/reader.js +12 -39
  54. package/dist/js/node/libs/render/ssr.js +23 -22
  55. package/dist/js/node/libs/render/static.js +6 -18
  56. package/dist/js/node/libs/render/type.js +0 -1
  57. package/dist/js/node/libs/route/index.js +8 -22
  58. package/dist/js/node/libs/route/matcher.js +18 -34
  59. package/dist/js/node/libs/route/route.js +0 -15
  60. package/dist/js/node/libs/serve-file.js +15 -12
  61. package/dist/js/node/server/index.js +26 -62
  62. package/dist/js/node/server/modern-server-split.js +5 -58
  63. package/dist/js/node/server/modern-server.js +178 -280
  64. package/dist/js/node/utils.js +3 -46
  65. package/dist/js/node/worker-server.js +41 -0
  66. package/dist/js/treeshaking/constants.js +28 -0
  67. package/dist/js/treeshaking/index.js +13 -0
  68. package/dist/js/treeshaking/libs/context/context.js +243 -0
  69. package/dist/js/treeshaking/libs/context/index.js +5 -0
  70. package/dist/js/treeshaking/libs/hook-api/index.js +157 -0
  71. package/dist/js/treeshaking/libs/hook-api/route.js +33 -0
  72. package/dist/js/treeshaking/libs/hook-api/template.js +91 -0
  73. package/dist/js/treeshaking/libs/loadConfig.js +39 -0
  74. package/dist/js/treeshaking/libs/metrics.js +12 -0
  75. package/dist/js/treeshaking/libs/proxy.js +80 -0
  76. package/dist/js/treeshaking/libs/render/cache/__tests__/cache.fun.test.js +124 -0
  77. package/dist/js/treeshaking/libs/render/cache/__tests__/cache.test.js +464 -0
  78. package/dist/js/treeshaking/libs/render/cache/__tests__/cacheable.js +53 -0
  79. package/dist/js/treeshaking/libs/render/cache/__tests__/error-configuration.js +35 -0
  80. package/dist/js/treeshaking/libs/render/cache/__tests__/matched-cache.js +121 -0
  81. package/dist/js/treeshaking/libs/render/cache/index.js +184 -0
  82. package/dist/js/treeshaking/libs/render/cache/page-caches/index.js +30 -0
  83. package/dist/js/treeshaking/libs/render/cache/page-caches/lru.js +46 -0
  84. package/dist/js/treeshaking/libs/render/cache/spr.js +362 -0
  85. package/dist/js/treeshaking/libs/render/cache/type.js +1 -0
  86. package/dist/js/treeshaking/libs/render/cache/util.js +101 -0
  87. package/dist/js/treeshaking/libs/render/index.js +100 -0
  88. package/dist/js/treeshaking/libs/render/measure.js +61 -0
  89. package/dist/js/treeshaking/libs/render/modern/browser-list.js +7 -0
  90. package/dist/js/treeshaking/libs/render/modern/index.js +39 -0
  91. package/dist/js/treeshaking/libs/render/reader.js +191 -0
  92. package/dist/js/treeshaking/libs/render/ssr.js +98 -0
  93. package/dist/js/treeshaking/libs/render/static.js +84 -0
  94. package/dist/js/treeshaking/libs/render/type.js +6 -0
  95. package/dist/js/treeshaking/libs/route/index.js +94 -0
  96. package/dist/js/treeshaking/libs/route/matcher.js +113 -0
  97. package/dist/js/treeshaking/libs/route/route.js +26 -0
  98. package/dist/js/treeshaking/libs/serve-file.js +75 -0
  99. package/dist/js/treeshaking/server/index.js +343 -0
  100. package/dist/js/treeshaking/server/modern-server-split.js +152 -0
  101. package/dist/js/treeshaking/server/modern-server.js +945 -0
  102. package/dist/js/treeshaking/type.js +1 -0
  103. package/dist/js/treeshaking/utils.js +87 -0
  104. package/dist/js/treeshaking/worker-server.js +56 -0
  105. package/dist/types/index.d.ts +0 -2
  106. package/dist/types/libs/context/context.d.ts +0 -3
  107. package/dist/types/libs/hook-api/index.d.ts +5 -0
  108. package/dist/types/libs/hook-api/route.d.ts +9 -14
  109. package/dist/types/libs/hook-api/template.d.ts +19 -9
  110. package/dist/types/libs/loadConfig.d.ts +0 -1
  111. package/dist/types/libs/render/cache/index.d.ts +4 -4
  112. package/dist/types/libs/render/cache/spr.d.ts +0 -2
  113. package/dist/types/libs/render/type.d.ts +3 -1
  114. package/dist/types/libs/serve-file.d.ts +2 -1
  115. package/dist/types/server/index.d.ts +2 -3
  116. package/dist/types/server/modern-server.d.ts +11 -11
  117. package/dist/types/type.d.ts +8 -10
  118. package/dist/types/utils.d.ts +0 -1
  119. package/dist/types/worker-server.d.ts +16 -0
  120. package/package.json +28 -35
@@ -0,0 +1 @@
1
+ import { IncomingMessage } from 'http';
@@ -0,0 +1,87 @@
1
+ import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
2
+ import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
3
+ import { createDebugger, isProd } from '@modern-js/utils';
4
+ export var debug = createDebugger('prod-server');
5
+ export var mergeExtension = function mergeExtension(users) {
6
+ var output = [];
7
+ return {
8
+ middleware: output.concat(users)
9
+ };
10
+ };
11
+ export var noop = function noop() {
12
+ // noop
13
+ };
14
+ export var createErrorDocument = function createErrorDocument(status, text) {
15
+ var title = "".concat(status, ": ").concat(text);
16
+ return "<!DOCTYPE html>\n <html lang=\"en\">\n <head>\n <meta charset=\"utf-8\">\n <meta name=\"viewport\" content=\"width=device-width\">\n <title>".concat(title, "</title>\n <style>\n html,body {\n margin: 0;\n }\n\n .page-container {\n color: #000;\n background: #fff;\n height: 100vh;\n text-align: center;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n }\n </style>\n </head>\n <body>\n <div class=\"page-container\">\n <h1>").concat(status, "</h1>\n <div>").concat(text, "</div>\n </body>\n </html>\n ");
17
+ };
18
+ export var createMiddlewareCollecter = function createMiddlewareCollecter() {
19
+ var webMiddlewares = [];
20
+ var apiMiddlewares = [];
21
+ var addWebMiddleware = function addWebMiddleware(input) {
22
+ webMiddlewares.push(input);
23
+ };
24
+ var addAPIMiddleware = function addAPIMiddleware(input) {
25
+ apiMiddlewares.push(input);
26
+ };
27
+ var getMiddlewares = function getMiddlewares() {
28
+ return {
29
+ web: webMiddlewares,
30
+ api: apiMiddlewares
31
+ };
32
+ };
33
+ return {
34
+ getMiddlewares: getMiddlewares,
35
+ addWebMiddleware: addWebMiddleware,
36
+ addAPIMiddleware: addAPIMiddleware
37
+ };
38
+ };
39
+ export var useLocalPrefix = function useLocalPrefix(url) {
40
+ return isProd() && !url.includes('.');
41
+ };
42
+ export var getStaticReg = function getStaticReg() {
43
+ var output = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
44
+ var favicon = output.favicon,
45
+ faviconByEntries = output.faviconByEntries,
46
+ cssPath = output.cssPath,
47
+ jsPath = output.jsPath,
48
+ mediaPath = output.mediaPath,
49
+ _output$assetPrefix = output.assetPrefix,
50
+ assetPrefix = _output$assetPrefix === void 0 ? '/' : _output$assetPrefix;
51
+ var prefix = useLocalPrefix(assetPrefix) ? assetPrefix : '';
52
+ var favicons = prepareFavicons(favicon, faviconByEntries);
53
+ var staticFiles = [cssPath, jsPath, mediaPath].filter(function (v) {
54
+ return Boolean(v);
55
+ });
56
+ var staticReg = ['static/', 'upload/'].concat(_toConsumableArray(staticFiles));
57
+ var iconReg = ['favicon.ico', 'icon.png'].concat(_toConsumableArray(favicons));
58
+ var regPrefix = prefix.endsWith('/') ? prefix : "".concat(prefix, "/");
59
+ var staticPathRegExp = new RegExp("^".concat(regPrefix, "(").concat([].concat(_toConsumableArray(staticReg), _toConsumableArray(iconReg)).join('|'), ")"));
60
+ return staticPathRegExp;
61
+ };
62
+ export var prepareFavicons = function prepareFavicons(favicon, faviconByEntries) {
63
+ var faviconNames = [];
64
+ if (favicon) {
65
+ faviconNames.push(favicon.substring(favicon.lastIndexOf('/') + 1));
66
+ }
67
+ if (faviconByEntries) {
68
+ Object.keys(faviconByEntries).forEach(function (f) {
69
+ var curFavicon = faviconByEntries[f];
70
+ if (curFavicon) {
71
+ faviconNames.push(curFavicon.substring(curFavicon.lastIndexOf('/') + 1));
72
+ }
73
+ });
74
+ }
75
+ return faviconNames;
76
+ };
77
+ export var headersWithoutCookie = function headersWithoutCookie(headers) {
78
+ if (typeof headers.cookie !== 'undefined') {
79
+ var safeHeaders = _objectSpread({}, headers);
80
+ delete safeHeaders.cookie;
81
+ return safeHeaders;
82
+ }
83
+ return headers;
84
+ };
85
+ export var isRedirect = function isRedirect(code) {
86
+ return [301, 302, 307, 308].includes(code);
87
+ };
@@ -0,0 +1,56 @@
1
+ import _regeneratorRuntime from "@babel/runtime/helpers/esm/regeneratorRuntime";
2
+ import _asyncToGenerator from "@babel/runtime/helpers/esm/asyncToGenerator";
3
+ import { RouteMatchManager } from "./libs/route";
4
+ export var createHandler = function createHandler(manifest) {
5
+ var routeMgr = new RouteMatchManager();
6
+ var pages = manifest.pages,
7
+ routes = manifest.routes;
8
+ routeMgr.reset(routes);
9
+ return /*#__PURE__*/function () {
10
+ var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(ctx) {
11
+ var _ctx$request, _ctx$request$query, _ctx$request2, _ctx$request2$pathnam, _ctx$request3, _ctx$request3$params;
12
+ var pageMatch, page, params;
13
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
14
+ while (1) {
15
+ switch (_context.prev = _context.next) {
16
+ case 0:
17
+ pageMatch = routeMgr.match(ctx.url);
18
+ if (pageMatch) {
19
+ _context.next = 5;
20
+ break;
21
+ }
22
+ ctx.body = '404: Page not found';
23
+ ctx.status = 404;
24
+ return _context.abrupt("return");
25
+ case 5:
26
+ page = pages[pageMatch.spec.urlPath];
27
+ (_ctx$request$query = (_ctx$request = ctx.request).query) !== null && _ctx$request$query !== void 0 ? _ctx$request$query : _ctx$request.query = ctx.query;
28
+ (_ctx$request2$pathnam = (_ctx$request2 = ctx.request).pathname) !== null && _ctx$request2$pathnam !== void 0 ? _ctx$request2$pathnam : _ctx$request2.pathname = ctx.pathname;
29
+ (_ctx$request3$params = (_ctx$request3 = ctx.request).params) !== null && _ctx$request3$params !== void 0 ? _ctx$request3$params : _ctx$request3.params = ctx.params;
30
+ params = pageMatch.parseURLParams(ctx.url);
31
+ _context.next = 12;
32
+ return page.serverRender({
33
+ template: page.template,
34
+ query: ctx.query,
35
+ request: ctx.request,
36
+ response: ctx.response,
37
+ pathname: ctx.pathname,
38
+ req: ctx.request,
39
+ res: ctx.response,
40
+ params: ctx.params || params || {}
41
+ });
42
+ case 12:
43
+ ctx.body = _context.sent;
44
+ ctx.status = 200;
45
+ case 14:
46
+ case "end":
47
+ return _context.stop();
48
+ }
49
+ }
50
+ }, _callee);
51
+ }));
52
+ return function (_x) {
53
+ return _ref.apply(this, arguments);
54
+ };
55
+ }();
56
+ };
@@ -6,7 +6,5 @@ export { ModernServer } from './server/modern-server';
6
6
  export { createProxyHandler } from './libs/proxy';
7
7
  export * from './type';
8
8
  export * from './constants';
9
-
10
9
  declare const _default: (options: ModernServerOptions) => Promise<Server>;
11
-
12
10
  export default _default;
@@ -20,12 +20,10 @@ export declare class ModernServerContext implements ModernServerContextInterface
20
20
  /**
21
21
  * http response
22
22
  */
23
-
24
23
  res: ServerResponse;
25
24
  /**
26
25
  * url params
27
26
  */
28
-
29
27
  params: Record<string, string>;
30
28
  get logger(): import("@modern-js/types").Logger;
31
29
  get metrics(): import("@modern-js/types").Metrics;
@@ -56,7 +54,6 @@ export declare class ModernServerContext implements ModernServerContextInterface
56
54
  /**
57
55
  * 判断链接是否已经关闭
58
56
  */
59
-
60
57
  resHasHandled(): boolean;
61
58
  error(dig: string, e?: Error | string): void;
62
59
  }
@@ -0,0 +1,5 @@
1
+ import type { ModernServerContext, HookContext, AfterMatchContext, AfterRenderContext, MiddlewareContext } from '@modern-js/types';
2
+ export declare const base: (context: ModernServerContext) => HookContext;
3
+ export declare const createAfterMatchContext: (context: ModernServerContext, entryName: string) => AfterMatchContext;
4
+ export declare const createAfterRenderContext: (context: ModernServerContext, content: string) => AfterRenderContext;
5
+ export declare const createMiddlewareContext: (context: ModernServerContext) => MiddlewareContext;
@@ -1,14 +1,9 @@
1
- import { RouteMatchManager, RouteMatcher } from '../route';
2
-
3
- declare class RouteAPI {
4
- private readonly router;
5
- private current;
6
- private readonly url;
7
- constructor(matched: RouteMatcher, router: RouteMatchManager, url: string);
8
- cur(): import("../route").ModernRoute;
9
- get(entryName: string): import("../route").ModernRoute | null;
10
- use(entryName: string): boolean;
11
- }
12
-
13
- export declare const createRouteAPI: (matched: RouteMatcher, router: RouteMatchManager, url: string) => RouteAPI;
14
- export {};
1
+ export declare class RouteAPI {
2
+ current: string;
3
+ status: number;
4
+ url: string;
5
+ constructor(entryName: string);
6
+ redirect(url: string, status?: number): void;
7
+ rewrite(entryName: string): void;
8
+ use(entryName: string): void;
9
+ }
@@ -1,14 +1,24 @@
1
- declare class TemplateAPI {
1
+ /// <reference types="node" />
2
+ import { Transform } from 'stream';
3
+ export declare class TemplateAPI {
2
4
  private content;
3
5
  constructor(content: string);
4
6
  get(): string;
5
7
  set(content: string): void;
6
- prependHead(fragment: string): this;
7
- appendHead(fragment: string): this;
8
- prependBody(fragment: string): this;
9
- appendBody(fragment: string): this;
10
- replace(reg: RegExp | string, text: string): this;
8
+ prependHead(fragment: string): void;
9
+ appendHead(fragment: string): void;
10
+ prependBody(fragment: string): void;
11
+ appendBody(fragment: string): void;
12
+ private replace;
11
13
  }
12
-
13
- export declare const createTemplateAPI: (content: string) => TemplateAPI;
14
- export {};
14
+ export declare const templateInjectableStream: ({
15
+ prependHead,
16
+ appendHead,
17
+ prependBody,
18
+ appendBody
19
+ }: {
20
+ prependHead?: string | undefined;
21
+ appendHead?: string | undefined;
22
+ prependBody?: string | undefined;
23
+ appendBody?: string | undefined;
24
+ }) => Transform;
@@ -6,7 +6,6 @@ export declare const requireConfig: (serverConfigPath: string) => any;
6
6
  * 生产环境下,resolvedConfig 与 serverConfig 进行深合并
7
7
  * resolvedConfigPath: 构建序列化后的 modern.config.js 文件路径
8
8
  */
9
-
10
9
  export declare const loadConfig: ({
11
10
  cliConfig,
12
11
  serverConfig,
@@ -1,6 +1,6 @@
1
+ /// <reference types="node" />
2
+ import { Readable } from 'stream';
1
3
  import type { ModernServerContext } from '@modern-js/types';
2
- import { RenderFunction } from '../type';
3
-
4
- declare const _default: (renderFn: RenderFunction, ctx: ModernServerContext) => RenderFunction;
5
-
4
+ import { RenderFunction, SSRServerContext } from '../type';
5
+ declare const _default: (renderFn: RenderFunction, ctx: ModernServerContext) => (context: SSRServerContext) => Promise<string | Readable>;
6
6
  export default _default;
@@ -1,6 +1,5 @@
1
1
  import LRUCache from 'lru-cache';
2
2
  import { CacheContent, CacheManagerOptions, CacheResult, CacheContext, CacheConfig } from './type';
3
-
4
3
  declare class CacheManager {
5
4
  cache: LRUCache<string, CacheContent>;
6
5
  cacheOptions: CacheManagerOptions;
@@ -18,7 +17,6 @@ declare class CacheManager {
18
17
  set(context: CacheContext, html: string, cacheConfig: CacheConfig, sync?: boolean): Promise<any>;
19
18
  del(context: CacheContext, cacheHash: string): Promise<void>;
20
19
  }
21
-
22
20
  export declare function createCache(): CacheManager;
23
21
  export declare function destroyCache(): void;
24
22
  export {};
@@ -1,4 +1,6 @@
1
1
  /// <reference types="react" />
2
+ /// <reference types="node" />
3
+ import { Writable, Readable } from 'stream';
2
4
  import { BaseSSRServerContext } from '@modern-js/types';
3
5
  declare type MetaKeyMap = {
4
6
  header?: string[];
@@ -30,5 +32,5 @@ export declare type ModernSSRReactComponent = React.ComponentType<any> & {
30
32
  init: (context: SSRServerContext) => Promise<void>;
31
33
  prefetch: (context: SSRServerContext) => Promise<Record<string, any>>;
32
34
  };
33
- export declare type RenderFunction = (context: SSRServerContext) => Promise<string>;
35
+ export declare type RenderFunction = (context: SSRServerContext) => Promise<string | ((writable: Writable) => Promise<Readable>)>;
34
36
  export {};
@@ -1,9 +1,10 @@
1
1
  import { ServerOptions } from '@modern-js/server-core';
2
2
  import type { ModernServerContext } from '@modern-js/types';
3
- import { NextFunction } from '../type';
3
+ import { NextFunction, ModernServerHandler } from '../type';
4
4
  declare type Rule = {
5
5
  path: string | RegExp;
6
6
  target: string;
7
7
  };
8
+ export declare const faviconFallbackHandler: ModernServerHandler;
8
9
  export declare const createStaticFileHandler: (rules: Rule[], output?: ServerOptions['output']) => (context: ModernServerContext, next: NextFunction) => Promise<void>;
9
10
  export {};
@@ -1,4 +1,5 @@
1
1
  /// <reference types="node" />
2
+ /// <reference types="node" />
2
3
  import { IncomingMessage, ServerResponse } from 'http';
3
4
  import type { ListenOptions } from 'net';
4
5
  import { ModernServerOptions, ServerConstructor } from '../type';
@@ -24,14 +25,12 @@ export declare class Server {
24
25
  * - 执行 prepare hook
25
26
  * - 执行 server init
26
27
  */
27
-
28
28
  init(): Promise<this>;
29
29
  /**
30
30
  * Execute config hooks
31
31
  * @param runner
32
32
  * @param options
33
33
  */
34
-
35
34
  private runConfigHook;
36
35
  private runPrepareHook;
37
36
  private initServerConfig;
@@ -39,11 +38,11 @@ export declare class Server {
39
38
  *
40
39
  * merge cliConfig and serverConfig
41
40
  */
42
-
43
41
  private initConfig;
44
42
  close(): Promise<void>;
45
43
  listen<T extends number | ListenOptions | undefined>(options: T, listener: any): void;
46
44
  getRequestHandler(): (req: IncomingMessage, res: ServerResponse, next?: () => void) => void;
45
+ render(req: IncomingMessage, res: ServerResponse, url?: string): Promise<string | null>;
47
46
  private createHookRunner;
48
47
  private injectContext;
49
48
  private initAppContext;
@@ -1,9 +1,9 @@
1
1
  /// <reference types="node" />
2
2
  import { IncomingMessage, ServerResponse, Server } from 'http';
3
- import { Adapter, APIServerStartInput, ServerOptions } from '@modern-js/server-core';
4
- import type { ModernServerContext } from '@modern-js/types';
3
+ import { Adapter, WebAdapter, APIServerStartInput, ServerOptions } from '@modern-js/server-core';
4
+ import type { ModernServerContext, ServerRoute } from '@modern-js/types';
5
5
  import type { ContextOptions } from '../libs/context';
6
- import { ModernServerOptions, NextFunction, ServerHookRunner, Metrics, Logger, ModernServerInterface, HookNames, BuildOptions, ModernServerHandler } from '../type';
6
+ import { ModernServerOptions, NextFunction, ServerHookRunner, Metrics, Logger, ModernServerInterface, BuildOptions, ModernServerHandler } from '../type';
7
7
  import { RouteMatchManager, ModernRouteInterface, ModernRoute } from '../libs/route';
8
8
  import { mergeExtension } from '../utils';
9
9
  import * as reader from '../libs/render/reader';
@@ -24,6 +24,7 @@ export declare class ModernServer implements ModernServerInterface {
24
24
  protected readonly proxyTarget: ModernServerOptions['proxyTarget'];
25
25
  private staticFileHandler;
26
26
  private routeRenderHandler;
27
+ private beforeRouteHandler;
27
28
  private frameWebHandler;
28
29
  private frameAPIHandler;
29
30
  private proxyHandler;
@@ -41,27 +42,26 @@ export declare class ModernServer implements ModernServerInterface {
41
42
  }: ModernServerOptions);
42
43
  onInit(runner: ServerHookRunner, app: Server): Promise<void>;
43
44
  onRepack(_: BuildOptions): void;
45
+ addBeforeRouteHandler(): void;
44
46
  protected onServerChange({
45
47
  filepath
46
48
  }: {
47
49
  filepath: string;
48
50
  }): void;
49
51
  getRequestHandler(): (req: IncomingMessage, res: ServerResponse, next?: () => void) => void | ServerResponse;
52
+ render(req: IncomingMessage, res: ServerResponse, url?: string): Promise<string | null>;
50
53
  createHTTPServer(handler: (req: IncomingMessage, res: ServerResponse, next?: () => void) => void): Promise<Server>;
51
- protected getRoutes(): ModernRouteInterface[];
54
+ protected getRoutes(): ServerRoute[];
52
55
  protected addHandler(handler: ModernServerHandler): void;
53
56
  protected render404(context: ModernServerContext): void;
57
+ protected prepareBeforeRouteHandler(specs: ServerRoute[], distDir: string): Promise<void>;
54
58
  protected prepareFrameHandler(options?: {
55
59
  onlyApi: boolean;
56
60
  onlyWeb: boolean;
57
61
  }): Promise<void>;
58
- protected prepareWebHandler(extension: ReturnType<typeof mergeExtension>): Promise<Adapter>;
62
+ protected prepareWebHandler(extension: ReturnType<typeof mergeExtension>): Promise<WebAdapter>;
59
63
  protected prepareAPIHandler(extension: APIServerStartInput['config']): Promise<Adapter>;
60
- protected filterRoutes(routes: ModernRouteInterface[]): ModernRouteInterface[];
61
- protected emitRouteHook(eventName: HookNames, input: {
62
- context: ModernServerContext;
63
- [propsName: string]: any;
64
- }): Promise<any>;
64
+ protected filterRoutes(routes: ModernRouteInterface[]): ServerRoute[];
65
65
  protected setupBeforeProdMiddleware(): Promise<void>;
66
66
  protected handleAPI(context: ModernServerContext): Promise<void>;
67
67
  protected handleWeb(context: ModernServerContext, route: ModernRoute): Promise<import("../type").RenderResult | null>;
@@ -70,9 +70,9 @@ export declare class ModernServer implements ModernServerInterface {
70
70
  protected createContext(req: IncomingMessage, res: ServerResponse, options?: ContextOptions): import("../libs/context").ModernServerContext;
71
71
  private routeHandler;
72
72
  private isSend;
73
- private injectMicroFE;
74
73
  private compose;
75
74
  private requestHandler;
75
+ private redirect;
76
76
  private onError;
77
77
  private renderErrorPage;
78
78
  }
@@ -1,9 +1,11 @@
1
1
  /// <reference types="node" />
2
2
  /// <reference types="node" />
3
+ /// <reference types="node" />
3
4
  import { IncomingMessage, Server, ServerResponse } from 'http';
5
+ import { Readable } from 'stream';
4
6
  import { serverManager, ServerOptions } from '@modern-js/server-core';
5
7
  import type { ServerPlugin } from '@modern-js/server-core';
6
- import type { Metrics, Logger, NextFunction, ModernServerContext } from '@modern-js/types';
8
+ import type { Metrics, Logger, NextFunction, ModernServerContext, InternalPlugins } from '@modern-js/types';
7
9
  import type { ModernRouteInterface } from './libs/route';
8
10
  declare module 'http' {
9
11
  interface IncomingMessage {
@@ -11,30 +13,25 @@ declare module 'http' {
11
13
  metrics: Metrics;
12
14
  }
13
15
  }
14
- declare type Plugin = string | [string, any] | ServerPlugin;
15
16
  export declare type ModernServerOptions = {
16
17
  pwd: string;
17
18
  config: ServerOptions;
18
- plugins?: Plugin[];
19
+ plugins?: ServerPlugin[];
20
+ internalPlugins?: InternalPlugins;
19
21
  routes?: ModernRouteInterface[];
20
22
  staticGenerate?: boolean;
21
- loggerOptions?: Record<string, string>;
22
- metricsOptions?: Record<string, string>;
23
23
  logger?: Logger;
24
24
  metrics?: Metrics;
25
25
  apiOnly?: boolean;
26
26
  ssrOnly?: boolean;
27
27
  webOnly?: boolean;
28
- proxyTarget?: {
29
- ssr?: string;
30
- api?: string;
31
- };
32
28
  runMode?: string;
33
29
  [propName: string]: any;
34
30
  };
35
31
  export declare type RenderResult = {
36
32
  content: string | Buffer;
37
33
  contentType: string;
34
+ contentStream?: Readable;
38
35
  statusCode?: number;
39
36
  redirect?: boolean;
40
37
  };
@@ -49,7 +46,7 @@ export declare type BuildOptions = {
49
46
  routes?: ModernRouteInterface[];
50
47
  };
51
48
  export type { Metrics, Logger, NextFunction };
52
- export declare type HookNames = 'beforeMatch' | 'afterMatch' | 'beforeRender' | 'afterRender';
49
+ export declare type HookNames = 'afterMatch' | 'afterRender';
53
50
  export interface ModernServerInterface {
54
51
  pwd: string;
55
52
  distDir: string;
@@ -57,6 +54,7 @@ export interface ModernServerInterface {
57
54
  onRepack: (options: BuildOptions) => void;
58
55
  getRequestHandler: () => (req: IncomingMessage, res: ServerResponse, next?: () => void) => void;
59
56
  createHTTPServer: (handler: (req: IncomingMessage, res: ServerResponse, next?: () => void) => void) => Promise<Server>;
57
+ render: (req: IncomingMessage, res: ServerResponse, url?: string) => Promise<string | null>;
60
58
  }
61
59
  export declare type ServerConstructor = (options: ModernServerOptions) => ModernServerInterface;
62
60
  export declare type ModernServerHandler = (context: ModernServerContext, next: NextFunction) => Promise<void> | void;
@@ -18,7 +18,6 @@ export declare const createMiddlewareCollecter: () => {
18
18
  addWebMiddleware: (input: any) => void;
19
19
  addAPIMiddleware: (input: any) => void;
20
20
  };
21
- export declare const toPath: (reg: string, params: Record<string, any>) => string;
22
21
  export declare const useLocalPrefix: (url: string) => boolean;
23
22
  export declare const getStaticReg: (output?: NormalizedConfig['output']) => RegExp;
24
23
  export declare const prepareFavicons: (favicon: string | undefined, faviconByEntries?: Record<string, string | undefined>) => string[];
@@ -0,0 +1,16 @@
1
+ import { ModernRouteInterface } from './libs/route';
2
+ export declare type Context = Record<string, any>;
3
+ export interface UrlQuery {
4
+ [key: string]: string;
5
+ }
6
+ export declare type Manifest = {
7
+ pages: Record<string,
8
+ // path
9
+ {
10
+ entryName: string;
11
+ template: string;
12
+ serverRender: (ctx: Record<string, any>) => Promise<string>;
13
+ }>;
14
+ routes: ModernRouteInterface[];
15
+ };
16
+ export declare const createHandler: (manifest: Manifest) => (ctx: Context) => Promise<void>;
package/package.json CHANGED
@@ -11,7 +11,7 @@
11
11
  "modern",
12
12
  "modern.js"
13
13
  ],
14
- "version": "1.21.5",
14
+ "version": "2.0.0-beta.1",
15
15
  "jsnext:source": "./src/index.ts",
16
16
  "types": "./dist/types/index.d.ts",
17
17
  "main": "./dist/js/node/index.js",
@@ -25,6 +25,24 @@
25
25
  "require": "./dist/js/node/index.js"
26
26
  },
27
27
  "default": "./dist/js/treeshaking/index.js"
28
+ },
29
+ "./worker": {
30
+ "node": {
31
+ "jsnext:source": "./src/worker-server.ts",
32
+ "import": "./dist/js/modern/worker-server.js",
33
+ "require": "./dist/js/node/worker-server.js"
34
+ },
35
+ "default": "./dist/js/treeshaking/worker-server.js"
36
+ }
37
+ },
38
+ "typesVersions": {
39
+ "*": {
40
+ ".": [
41
+ "./dist/types/index.d.ts"
42
+ ],
43
+ "worker": [
44
+ "./dist/types/worker-server.d.ts"
45
+ ]
28
46
  }
29
47
  },
30
48
  "dependencies": {
@@ -41,8 +59,8 @@
41
59
  "path-to-regexp": "^6.2.0",
42
60
  "serve-static": "^1.14.1",
43
61
  "ua-parser-js": "^0.7.28",
44
- "@modern-js/utils": "1.21.5",
45
- "@modern-js/server-core": "1.21.5"
62
+ "@modern-js/utils": "2.0.0-beta.1",
63
+ "@modern-js/server-core": "2.0.0-beta.1"
46
64
  },
47
65
  "devDependencies": {
48
66
  "@types/cookie": "^0.4.1",
@@ -58,48 +76,23 @@
58
76
  "node-mocks-http": "^1.11.0",
59
77
  "portfinder": "^1.0.28",
60
78
  "typescript": "^4",
61
- "@modern-js/types": "1.21.5",
62
- "@modern-js/core": "1.21.5",
63
- "@scripts/jest-config": "1.21.5",
64
- "@scripts/build": "1.21.5"
79
+ "@modern-js/types": "2.0.0-beta.1",
80
+ "@modern-js/core": "2.0.0-beta.1",
81
+ "@scripts/jest-config": "2.0.0-beta.1",
82
+ "@scripts/build": "2.0.0-beta.1"
65
83
  },
66
84
  "sideEffects": false,
67
85
  "modernConfig": {
68
- "output": {
69
- "packageMode": "node-js"
70
- }
86
+ "output": {}
71
87
  },
72
88
  "publishConfig": {
73
89
  "access": "public",
74
90
  "registry": "https://registry.npmjs.org/"
75
91
  },
76
- "wireit": {
77
- "build": {
78
- "command": "modern build",
79
- "files": [
80
- "src/**/*",
81
- "tsconfig.json",
82
- "package.json"
83
- ],
84
- "output": [
85
- "dist/**/*"
86
- ]
87
- },
88
- "test": {
89
- "command": "jest",
90
- "files": [
91
- "src/**/*",
92
- "tsconfig.json",
93
- "package.json",
94
- "tests/**/*"
95
- ],
96
- "output": []
97
- }
98
- },
99
92
  "scripts": {
100
93
  "new": "modern new",
101
- "build": "wireit",
94
+ "build": "modern build",
102
95
  "dev": "modern build --watch",
103
- "test": "wireit"
96
+ "test": "jest"
104
97
  }
105
98
  }