@modern-js/server 1.4.3 → 1.4.4-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/js/modern/dev-tools/mock/index.js +1 -1
- package/dist/js/modern/dev-tools/socket-server.js +2 -2
- package/dist/js/modern/index.js +1 -1
- package/dist/js/modern/server/{dev-server/dev-server-split.js → dev-server-split.js} +0 -0
- package/dist/js/modern/server/{dev-server/dev-server.js → dev-server.js} +15 -14
- package/dist/js/modern/server/index.js +15 -138
- package/dist/js/modern/{libs/render/cache/type.js → types.js} +0 -0
- package/dist/js/node/dev-tools/mock/index.js +2 -2
- package/dist/js/node/dev-tools/socket-server.js +2 -3
- package/dist/js/node/index.js +2 -2
- package/dist/js/node/server/{dev-server/dev-server-split.js → dev-server-split.js} +0 -0
- package/dist/js/node/server/{dev-server/dev-server.js → dev-server.js} +18 -24
- package/dist/js/node/server/index.js +17 -152
- package/dist/js/node/{libs/render/cache/type.js → types.js} +0 -0
- package/dist/types/dev-tools/babel/register.d.ts +1 -2
- package/dist/types/dev-tools/dev-server-plugin.d.ts +1 -1
- package/dist/types/dev-tools/launch-editor/index.d.ts +1 -2
- package/dist/types/dev-tools/mock/getMockData.d.ts +1 -2
- package/dist/types/dev-tools/mock/index.d.ts +1 -2
- package/dist/types/dev-tools/socket-server.d.ts +1 -1
- package/dist/types/index.d.ts +4 -5
- package/dist/types/server/{dev-server/dev-server-split.d.ts → dev-server-split.d.ts} +6 -5
- package/dist/types/server/{dev-server/dev-server.d.ts → dev-server.d.ts} +4 -3
- package/dist/types/server/index.d.ts +4 -19
- package/dist/types/types.d.ts +28 -0
- package/modern.config.js +5 -1
- package/package.json +11 -41
- package/tests/server.test.ts +10 -3
- package/dist/js/modern/constants.js +0 -26
- package/dist/js/modern/libs/context/context.js +0 -180
- package/dist/js/modern/libs/context/index.js +0 -3
- package/dist/js/modern/libs/hook-api/route.js +0 -39
- package/dist/js/modern/libs/hook-api/template.js +0 -61
- package/dist/js/modern/libs/metrics.js +0 -12
- package/dist/js/modern/libs/proxy.js +0 -33
- package/dist/js/modern/libs/render/cache/__tests__/cache.fun.test.js +0 -70
- package/dist/js/modern/libs/render/cache/__tests__/cache.test.js +0 -233
- package/dist/js/modern/libs/render/cache/__tests__/cacheable.js +0 -53
- package/dist/js/modern/libs/render/cache/__tests__/error-configuration.js +0 -35
- package/dist/js/modern/libs/render/cache/__tests__/matched-cache.js +0 -121
- package/dist/js/modern/libs/render/cache/index.js +0 -74
- package/dist/js/modern/libs/render/cache/page-caches/index.js +0 -9
- package/dist/js/modern/libs/render/cache/page-caches/lru.js +0 -35
- package/dist/js/modern/libs/render/cache/spr.js +0 -280
- package/dist/js/modern/libs/render/cache/util.js +0 -79
- package/dist/js/modern/libs/render/index.js +0 -65
- package/dist/js/modern/libs/render/modern/browser-list.js +0 -7
- package/dist/js/modern/libs/render/modern/index.js +0 -42
- package/dist/js/modern/libs/render/reader.js +0 -112
- package/dist/js/modern/libs/render/ssr.js +0 -58
- package/dist/js/modern/libs/render/static.js +0 -46
- package/dist/js/modern/libs/render/type.js +0 -7
- package/dist/js/modern/libs/route/index.js +0 -68
- package/dist/js/modern/libs/route/matcher.js +0 -94
- package/dist/js/modern/libs/route/route.js +0 -24
- package/dist/js/modern/libs/serve-file.js +0 -28
- package/dist/js/modern/server/dev-server/index.js +0 -2
- package/dist/js/modern/server/modern-server-split.js +0 -81
- package/dist/js/modern/server/modern-server.js +0 -584
- package/dist/js/modern/type.js +0 -1
- package/dist/js/modern/utils.js +0 -112
- package/dist/js/node/constants.js +0 -36
- package/dist/js/node/libs/context/context.js +0 -194
- package/dist/js/node/libs/context/index.js +0 -18
- package/dist/js/node/libs/hook-api/route.js +0 -48
- package/dist/js/node/libs/hook-api/template.js +0 -69
- package/dist/js/node/libs/metrics.js +0 -18
- package/dist/js/node/libs/proxy.js +0 -44
- package/dist/js/node/libs/render/cache/__tests__/cache.fun.test.js +0 -77
- package/dist/js/node/libs/render/cache/__tests__/cache.test.js +0 -238
- package/dist/js/node/libs/render/cache/__tests__/cacheable.js +0 -60
- package/dist/js/node/libs/render/cache/__tests__/error-configuration.js +0 -42
- package/dist/js/node/libs/render/cache/__tests__/matched-cache.js +0 -128
- package/dist/js/node/libs/render/cache/index.js +0 -86
- package/dist/js/node/libs/render/cache/page-caches/index.js +0 -17
- package/dist/js/node/libs/render/cache/page-caches/lru.js +0 -47
- package/dist/js/node/libs/render/cache/spr.js +0 -298
- package/dist/js/node/libs/render/cache/util.js +0 -105
- package/dist/js/node/libs/render/index.js +0 -91
- package/dist/js/node/libs/render/modern/browser-list.js +0 -14
- package/dist/js/node/libs/render/modern/index.js +0 -58
- package/dist/js/node/libs/render/reader.js +0 -139
- package/dist/js/node/libs/render/ssr.js +0 -76
- package/dist/js/node/libs/render/static.js +0 -62
- package/dist/js/node/libs/render/type.js +0 -14
- package/dist/js/node/libs/route/index.js +0 -83
- package/dist/js/node/libs/route/matcher.js +0 -108
- package/dist/js/node/libs/route/route.js +0 -33
- package/dist/js/node/libs/serve-file.js +0 -41
- package/dist/js/node/server/dev-server/index.js +0 -27
- package/dist/js/node/server/modern-server-split.js +0 -97
- package/dist/js/node/server/modern-server.js +0 -622
- package/dist/js/node/type.js +0 -5
- package/dist/js/node/utils.js +0 -143
- package/dist/types/constants.d.ts +0 -20
- package/dist/types/libs/context/context.d.ts +0 -61
- package/dist/types/libs/context/index.d.ts +0 -4
- package/dist/types/libs/hook-api/route.d.ts +0 -14
- package/dist/types/libs/hook-api/template.d.ts +0 -14
- package/dist/types/libs/metrics.d.ts +0 -3
- package/dist/types/libs/proxy.d.ts +0 -4
- package/dist/types/libs/render/cache/__tests__/cache.fun.test.d.ts +0 -1
- package/dist/types/libs/render/cache/__tests__/cache.test.d.ts +0 -1
- package/dist/types/libs/render/cache/__tests__/cacheable.d.ts +0 -62
- package/dist/types/libs/render/cache/__tests__/error-configuration.d.ts +0 -28
- package/dist/types/libs/render/cache/__tests__/matched-cache.d.ts +0 -124
- package/dist/types/libs/render/cache/index.d.ts +0 -6
- package/dist/types/libs/render/cache/page-caches/index.d.ts +0 -2
- package/dist/types/libs/render/cache/page-caches/lru.d.ts +0 -15
- package/dist/types/libs/render/cache/spr.d.ts +0 -24
- package/dist/types/libs/render/cache/type.d.ts +0 -48
- package/dist/types/libs/render/cache/util.d.ts +0 -17
- package/dist/types/libs/render/index.d.ts +0 -18
- package/dist/types/libs/render/modern/browser-list.d.ts +0 -1
- package/dist/types/libs/render/modern/index.d.ts +0 -3
- package/dist/types/libs/render/reader.d.ts +0 -18
- package/dist/types/libs/render/ssr.d.ts +0 -10
- package/dist/types/libs/render/static.d.ts +0 -3
- package/dist/types/libs/render/type.d.ts +0 -34
- package/dist/types/libs/route/index.d.ts +0 -15
- package/dist/types/libs/route/matcher.d.ts +0 -15
- package/dist/types/libs/route/route.d.ts +0 -14
- package/dist/types/libs/serve-file.d.ts +0 -8
- package/dist/types/server/dev-server/index.d.ts +0 -2
- package/dist/types/server/modern-server-split.d.ts +0 -26
- package/dist/types/server/modern-server.d.ts +0 -72
- package/dist/types/type.d.ts +0 -80
- package/dist/types/utils.d.ts +0 -19
- package/tests/context.test.ts +0 -52
- package/tests/fixtures/hosting-files/static/index.js +0 -1
- package/tests/fixtures/reader/index.ts +0 -3
- package/tests/fixtures/route-spec/dynamic.json +0 -13
- package/tests/fixtures/route-spec/index.json +0 -29
- package/tests/fixtures/ssr/bundle.js +0 -5
- package/tests/fixtures/static-dir/bar.html +0 -11
- package/tests/fixtures/static-dir/baz/index.html +0 -11
- package/tests/fixtures/static-dir/foo/index.html +0 -11
- package/tests/helper.ts +0 -8
- package/tests/hook.test.ts +0 -44
- package/tests/middleware.test.ts +0 -179
- package/tests/render.test.ts +0 -102
- package/tests/route.test.ts +0 -77
- package/tests/utils.test.ts +0 -106
package/dist/types/index.d.ts
CHANGED
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
export type { SSRServerContext } from './libs/render/type';
|
|
1
|
+
import { DevServer as Server } from './server';
|
|
2
|
+
import { ModernDevServerOptions } from './types';
|
|
4
3
|
export { Server };
|
|
5
|
-
export type {
|
|
4
|
+
export type { ModernDevServerOptions };
|
|
6
5
|
|
|
7
|
-
declare const _default: (options:
|
|
6
|
+
declare const _default: (options: ModernDevServerOptions) => Promise<Server>;
|
|
8
7
|
|
|
9
8
|
export default _default;
|
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
import type { APIServerStartInput } from '@modern-js/server-core';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { ApiServerMode } from '../../constants';
|
|
2
|
+
import { ServerRoute as ModernRouteInterface } from '@modern-js/types';
|
|
3
|
+
import { ApiServerMode } from '@modern-js/prod-server';
|
|
5
4
|
import { ModernDevServer } from './dev-server';
|
|
6
5
|
export declare class ModernSSRDevServer extends ModernDevServer {
|
|
7
6
|
protected prepareAPIHandler(_m: ApiServerMode, _: APIServerStartInput['config']): any;
|
|
8
|
-
protected prepareWebHandler(extension:
|
|
7
|
+
protected prepareWebHandler(extension: {
|
|
8
|
+
middleware: any[];
|
|
9
|
+
}): Promise<any>;
|
|
9
10
|
protected filterRoutes(routes: ModernRouteInterface[]): ModernRouteInterface[];
|
|
10
11
|
}
|
|
11
12
|
export declare class ModernAPIDevServer extends ModernDevServer {
|
|
12
|
-
protected prepareAPIHandler(mode: ApiServerMode, extension: APIServerStartInput['config']): Promise<
|
|
13
|
+
protected prepareAPIHandler(mode: ApiServerMode, extension: APIServerStartInput['config']): Promise<any>;
|
|
13
14
|
protected filterRoutes(routes: ModernRouteInterface[]): ModernRouteInterface[];
|
|
14
15
|
protected preServerInit(): Promise<void>;
|
|
15
16
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
2
|
import http, { Server, IncomingMessage, ServerResponse } from 'http';
|
|
3
|
-
import { ModernServer } from '
|
|
4
|
-
import {
|
|
3
|
+
import { ServerHookRunner, ReadyOptions, ModernServer } from '@modern-js/prod-server';
|
|
4
|
+
import { ModernDevServerOptions } from '../types';
|
|
5
5
|
export declare class ModernDevServer extends ModernServer {
|
|
6
6
|
private devProxyHandler;
|
|
7
7
|
private mockHandler;
|
|
@@ -10,12 +10,13 @@ export declare class ModernDevServer extends ModernServer {
|
|
|
10
10
|
private socketServer;
|
|
11
11
|
private watcher;
|
|
12
12
|
private devMiddleware;
|
|
13
|
-
constructor(options:
|
|
13
|
+
constructor(options: ModernDevServerOptions);
|
|
14
14
|
init(runner: ServerHookRunner): Promise<void>;
|
|
15
15
|
ready(options?: ReadyOptions): void;
|
|
16
16
|
onListening(app: Server): void;
|
|
17
17
|
close(): Promise<void>;
|
|
18
18
|
createHTTPServer(handler: (req: IncomingMessage, res: ServerResponse, next?: () => void) => void): Promise<http.Server | import("https").Server>;
|
|
19
|
+
protected warmupSSRBundle(): void;
|
|
19
20
|
private setupCompiler;
|
|
20
21
|
private setupDevServerPlugin;
|
|
21
22
|
private setupHooks;
|
|
@@ -1,20 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
options: ModernServerOptions;
|
|
6
|
-
private server;
|
|
7
|
-
private app;
|
|
8
|
-
private runner;
|
|
9
|
-
constructor(options: ModernServerOptions);
|
|
10
|
-
getRequestHandler(): (req: IncomingMessage, res: ServerResponse, next?: (() => void) | undefined) => void;
|
|
11
|
-
ready(readyOptions?: ReadyOptions): void;
|
|
12
|
-
init(): Promise<this>;
|
|
13
|
-
listen(port: number | undefined, listener: any): void;
|
|
14
|
-
listener(app: httpServer): void;
|
|
15
|
-
close(): Promise<void>;
|
|
16
|
-
private createProdServer;
|
|
17
|
-
private createDevServer;
|
|
18
|
-
private createHookRunner;
|
|
19
|
-
private initAppContext;
|
|
1
|
+
import { Server } from '@modern-js/prod-server';
|
|
2
|
+
import { ModernDevServerOptions } from '../types';
|
|
3
|
+
export declare class DevServer extends Server {
|
|
4
|
+
constructor(options: ModernDevServerOptions);
|
|
20
5
|
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { ModernServerOptions } from '@modern-js/prod-server';
|
|
2
|
+
import type Webpack from 'webpack';
|
|
3
|
+
export declare type DevServerOptions = {
|
|
4
|
+
client: {
|
|
5
|
+
port: string;
|
|
6
|
+
overlay: boolean;
|
|
7
|
+
logging: string;
|
|
8
|
+
path: string;
|
|
9
|
+
host: string;
|
|
10
|
+
progress?: boolean;
|
|
11
|
+
};
|
|
12
|
+
dev: {
|
|
13
|
+
writeToDisk: boolean | ((filename: string) => boolean);
|
|
14
|
+
};
|
|
15
|
+
watch: boolean;
|
|
16
|
+
hot: boolean | string;
|
|
17
|
+
liveReload: boolean;
|
|
18
|
+
https?: boolean | {
|
|
19
|
+
key: string;
|
|
20
|
+
cert: string;
|
|
21
|
+
};
|
|
22
|
+
[propName: string]: any;
|
|
23
|
+
};
|
|
24
|
+
export declare type ExtraOptions = {
|
|
25
|
+
dev?: boolean | Partial<DevServerOptions>;
|
|
26
|
+
compiler?: Webpack.MultiCompiler | Webpack.Compiler | null;
|
|
27
|
+
};
|
|
28
|
+
export declare type ModernDevServerOptions = ModernServerOptions & ExtraOptions;
|
package/modern.config.js
CHANGED
package/package.json
CHANGED
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
"modern",
|
|
12
12
|
"modern.js"
|
|
13
13
|
],
|
|
14
|
-
"version": "1.4.
|
|
14
|
+
"version": "1.4.4-beta.0",
|
|
15
15
|
"jsnext:source": "./src/index.ts",
|
|
16
16
|
"types": "./dist/types/index.d.ts",
|
|
17
17
|
"main": "./dist/js/node/index.js",
|
|
@@ -28,70 +28,39 @@
|
|
|
28
28
|
}
|
|
29
29
|
},
|
|
30
30
|
"dependencies": {
|
|
31
|
-
"@babel/core": "7.16.7",
|
|
32
|
-
"@babel/compat-data": "^7.15.0",
|
|
33
|
-
"@babel/preset-env": "^7.15.0",
|
|
34
|
-
"@babel/preset-typescript": "^7.15.0",
|
|
35
31
|
"@babel/register": "^7.15.3",
|
|
36
|
-
"@
|
|
32
|
+
"@modern-js/bff-utils": "^1.2.2",
|
|
37
33
|
"@modern-js/hmr-client": "^1.2.2",
|
|
38
|
-
"@modern-js/server
|
|
34
|
+
"@modern-js/prod-server": "^1.0.0",
|
|
39
35
|
"@modern-js/server-utils": "^1.2.1",
|
|
40
|
-
"@modern-js/bff-utils": "^1.2.2",
|
|
41
36
|
"@modern-js/utils": "^1.3.2",
|
|
42
|
-
"axios": "^0.24.0",
|
|
43
|
-
"babel-plugin-module-resolver": "^4.1.0",
|
|
44
37
|
"chokidar": "^3.5.2",
|
|
45
|
-
"compare-versions": "^3.6.0",
|
|
46
38
|
"devcert": "^1.1.3",
|
|
47
|
-
"fs-extra": "^10.0.0",
|
|
48
|
-
"http-proxy-middleware": "^2.0.1",
|
|
49
|
-
"ignore-styles": "^5.0.1",
|
|
50
39
|
"launch-editor": "^2.2.1",
|
|
51
|
-
"lru-cache": "^6.0.0",
|
|
52
|
-
"mime-types": "^2.1.32",
|
|
53
40
|
"minimatch": "^3.0.4",
|
|
54
|
-
"parseurl": "^1.3.3",
|
|
55
41
|
"path-to-regexp": "^6.2.0",
|
|
56
|
-
"serialize-javascript": "^6.0.0",
|
|
57
|
-
"serve-static": "^1.14.1",
|
|
58
42
|
"tsconfig-paths": "^3.11.0",
|
|
59
|
-
"ua-parser-js": "^0.7.28",
|
|
60
43
|
"webpack-dev-middleware": "^5.0.0",
|
|
61
|
-
"ws": "^8.2.0"
|
|
62
|
-
"lodash.clone": "^4.5.0",
|
|
63
|
-
"cookie": "^0.4.2"
|
|
44
|
+
"ws": "^8.2.0"
|
|
64
45
|
},
|
|
65
46
|
"devDependencies": {
|
|
66
47
|
"@modern-js/core": "^1.4.3",
|
|
67
|
-
"@
|
|
48
|
+
"@modern-js/server-core": "^1.2.2",
|
|
68
49
|
"@modern-js/types": "^1.3.3",
|
|
50
|
+
"@scripts/build": "0.0.0",
|
|
51
|
+
"@scripts/jest-config": "0.0.0",
|
|
69
52
|
"@types/jest": "^26",
|
|
70
|
-
"@types/lru-cache": "^5.1.1",
|
|
71
|
-
"@types/mime-types": "^2.1.0",
|
|
72
53
|
"@types/minimatch": "^3.0.5",
|
|
73
54
|
"@types/node": "^14",
|
|
74
|
-
"@types/parseurl": "^1.3.1",
|
|
75
|
-
"@types/react": "^17",
|
|
76
|
-
"@types/react-dom": "^17",
|
|
77
|
-
"@types/serialize-javascript": "^5.0.1",
|
|
78
|
-
"@types/serve-static": "^1.13.10",
|
|
79
|
-
"@types/ua-parser-js": "^0.7.36",
|
|
80
55
|
"@types/webpack-dev-middleware": "^5.0.2",
|
|
81
56
|
"@types/ws": "^7.4.7",
|
|
82
|
-
"
|
|
83
|
-
"@types/cookie": "^0.4.1",
|
|
57
|
+
"jest": "^27",
|
|
84
58
|
"typescript": "^4",
|
|
85
59
|
"webpack": "^5.54.0",
|
|
86
|
-
"node-mocks-http": "^1.11.0",
|
|
87
|
-
"portfinder": "^1.0.28",
|
|
88
|
-
"jest": "^27",
|
|
89
|
-
"@scripts/jest-config": "0.0.0",
|
|
90
60
|
"websocket": "^1"
|
|
91
61
|
},
|
|
92
62
|
"peerDependencies": {
|
|
93
|
-
"webpack": "^5.54.0"
|
|
94
|
-
"@modern-js/core": "^1.4.3"
|
|
63
|
+
"webpack": "^5.54.0"
|
|
95
64
|
},
|
|
96
65
|
"sideEffects": false,
|
|
97
66
|
"modernConfig": {
|
|
@@ -101,7 +70,8 @@
|
|
|
101
70
|
},
|
|
102
71
|
"publishConfig": {
|
|
103
72
|
"registry": "https://registry.npmjs.org/",
|
|
104
|
-
"access": "public"
|
|
73
|
+
"access": "public",
|
|
74
|
+
"types": "./dist/types/index.d.ts"
|
|
105
75
|
},
|
|
106
76
|
"scripts": {
|
|
107
77
|
"new": "modern new",
|
package/tests/server.test.ts
CHANGED
|
@@ -2,7 +2,6 @@ import path from 'path';
|
|
|
2
2
|
import { defaultsConfig, NormalizedConfig } from '@modern-js/core';
|
|
3
3
|
import { ModernServerContext, NextFunction } from '@modern-js/types';
|
|
4
4
|
import createServer, { Server } from '../src';
|
|
5
|
-
import { ModernServer } from '../src/server/modern-server';
|
|
6
5
|
import Watcher from '../src/dev-tools/watcher';
|
|
7
6
|
|
|
8
7
|
describe('test server', () => {
|
|
@@ -21,8 +20,10 @@ describe('test server', () => {
|
|
|
21
20
|
const server = await createServer({
|
|
22
21
|
config: defaultsConfig as NormalizedConfig,
|
|
23
22
|
pwd: path.join(__dirname, './fixtures/pure'),
|
|
23
|
+
dev: true,
|
|
24
24
|
});
|
|
25
25
|
expect(server instanceof Server).toBe(true);
|
|
26
|
+
await server.close();
|
|
26
27
|
});
|
|
27
28
|
|
|
28
29
|
describe('shoule get production modern server instance', () => {
|
|
@@ -32,6 +33,7 @@ describe('test server', () => {
|
|
|
32
33
|
const server = await createServer({
|
|
33
34
|
config: defaultsConfig as NormalizedConfig,
|
|
34
35
|
pwd: appDirectory,
|
|
36
|
+
dev: true,
|
|
35
37
|
});
|
|
36
38
|
const modernServer = (server as any).server;
|
|
37
39
|
|
|
@@ -47,18 +49,20 @@ describe('test server', () => {
|
|
|
47
49
|
} = modernServer;
|
|
48
50
|
expect(pwd).toBe(appDirectory);
|
|
49
51
|
expect(distDir).toBe(path.join(appDirectory, 'dist'));
|
|
50
|
-
expect(workDir).toBe(
|
|
52
|
+
expect(workDir).toBe(appDirectory);
|
|
51
53
|
expect(conf).toBe(defaultsConfig);
|
|
52
54
|
expect(handlers).toBeDefined();
|
|
53
55
|
expect(isDev).toBeFalsy();
|
|
54
56
|
expect(staticGenerate).toBeFalsy();
|
|
55
57
|
expect(presetRoutes).toBeUndefined();
|
|
58
|
+
await server.close();
|
|
56
59
|
});
|
|
57
60
|
|
|
58
61
|
test('should add handler correctly', async () => {
|
|
59
62
|
const server = await createServer({
|
|
60
63
|
config: defaultsConfig as NormalizedConfig,
|
|
61
64
|
pwd: appDirectory,
|
|
65
|
+
dev: true,
|
|
62
66
|
});
|
|
63
67
|
const modernServer = (server as any).server;
|
|
64
68
|
|
|
@@ -86,17 +90,20 @@ describe('test server', () => {
|
|
|
86
90
|
|
|
87
91
|
expect(newLen + 1).toBe(nextLen);
|
|
88
92
|
expect(modernServer.handlers[nextLen - 1]).toBe(asyncHandler);
|
|
93
|
+
await server.close();
|
|
89
94
|
});
|
|
90
95
|
|
|
91
96
|
test('should get request handler correctly', async () => {
|
|
92
97
|
const server = await createServer({
|
|
93
98
|
config: defaultsConfig as NormalizedConfig,
|
|
94
99
|
pwd: appDirectory,
|
|
100
|
+
dev: true,
|
|
95
101
|
});
|
|
96
102
|
|
|
97
|
-
const modernServer:
|
|
103
|
+
const modernServer: any = (server as any).server;
|
|
98
104
|
const handler = modernServer.getRequestHandler();
|
|
99
105
|
expect(typeof handler === 'function').toBeTruthy();
|
|
106
|
+
await server.close();
|
|
100
107
|
});
|
|
101
108
|
});
|
|
102
109
|
});
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
export const AGGRED_DIR = {
|
|
2
|
-
mock: 'config/mock',
|
|
3
|
-
server: 'server',
|
|
4
|
-
api: 'api',
|
|
5
|
-
shared: 'shared',
|
|
6
|
-
lambda: 'lambda'
|
|
7
|
-
};
|
|
8
|
-
export let ApiServerMode;
|
|
9
|
-
|
|
10
|
-
(function (ApiServerMode) {
|
|
11
|
-
ApiServerMode["func"] = "function";
|
|
12
|
-
ApiServerMode["frame"] = "framework";
|
|
13
|
-
})(ApiServerMode || (ApiServerMode = {}));
|
|
14
|
-
|
|
15
|
-
export const ERROR_DIGEST = {
|
|
16
|
-
INIT: 'Server init error',
|
|
17
|
-
ENOTF: 'Page could not be found',
|
|
18
|
-
WARMUP: 'SSR warmup failed',
|
|
19
|
-
EINTER: 'Internal server error',
|
|
20
|
-
ERENDER: 'SSR render failed',
|
|
21
|
-
EMICROINJ: 'Get micro-frontend info failed'
|
|
22
|
-
};
|
|
23
|
-
export const ERROR_PAGE_TEXT = {
|
|
24
|
-
404: 'This page could not be found.',
|
|
25
|
-
500: 'Internal Server Error.'
|
|
26
|
-
};
|
|
@@ -1,180 +0,0 @@
|
|
|
1
|
-
import { URL } from 'url';
|
|
2
|
-
import qs from 'querystring';
|
|
3
|
-
import { toMessage } from "../../utils";
|
|
4
|
-
export class ModernServerContext {
|
|
5
|
-
/**
|
|
6
|
-
* http request
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* http response
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* url params
|
|
15
|
-
*/
|
|
16
|
-
constructor(req, res) {
|
|
17
|
-
this.req = void 0;
|
|
18
|
-
this.res = void 0;
|
|
19
|
-
this.params = {};
|
|
20
|
-
this.logger = void 0;
|
|
21
|
-
this.metrics = void 0;
|
|
22
|
-
this.serverData = void 0;
|
|
23
|
-
this.req = req;
|
|
24
|
-
this.res = res;
|
|
25
|
-
this.logger = req.logger;
|
|
26
|
-
this.metrics = req.metrics;
|
|
27
|
-
this.serverData = {};
|
|
28
|
-
this.bind();
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
bind() {
|
|
32
|
-
const {
|
|
33
|
-
req,
|
|
34
|
-
res
|
|
35
|
-
} = this;
|
|
36
|
-
|
|
37
|
-
req.get = key => this.getReqHeader(key);
|
|
38
|
-
|
|
39
|
-
res.set = (key, value) => this.res.setHeader(key, value);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
setParams(params) {
|
|
43
|
-
this.params = params;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
setServerData(key, value) {
|
|
47
|
-
this.serverData[key] = value;
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
getReqHeader(key) {
|
|
51
|
-
const {
|
|
52
|
-
req
|
|
53
|
-
} = this;
|
|
54
|
-
const field = key.toLowerCase();
|
|
55
|
-
|
|
56
|
-
switch (field) {
|
|
57
|
-
case 'referer':
|
|
58
|
-
case 'referrer':
|
|
59
|
-
return req.headers.referrer || req.headers.referer || '';
|
|
60
|
-
|
|
61
|
-
default:
|
|
62
|
-
return req.headers[field] || '';
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
/* request property */
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
get headers() {
|
|
69
|
-
return this.req.headers;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
get method() {
|
|
73
|
-
return this.req.method;
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
get url() {
|
|
77
|
-
return this.req.url || '';
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
set url(val) {
|
|
81
|
-
this.req.url = val;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
get host() {
|
|
85
|
-
let host = this.getReqHeader('X-Forwarded-Host');
|
|
86
|
-
|
|
87
|
-
if (!host) {
|
|
88
|
-
host = this.getReqHeader('Host');
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
return host.split(/\s*,\s*/, 1)[0] || '';
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
get protocol() {
|
|
95
|
-
if (this.req.socket.encrypted) {
|
|
96
|
-
return 'https';
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
const proto = this.getReqHeader('X-Forwarded-Proto');
|
|
100
|
-
return proto ? proto.split(/\s*,\s*/, 1)[0] : 'http';
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
get origin() {
|
|
104
|
-
return `${this.protocol}://${this.host}`;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
get href() {
|
|
108
|
-
return this.origin + this.url;
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
get parsedURL() {
|
|
112
|
-
const url = new URL(this.req.url, this.origin);
|
|
113
|
-
return url;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
get path() {
|
|
117
|
-
return this.parsedURL.pathname;
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
set path(p) {
|
|
121
|
-
const url = new URL(this.req.url, this.origin); // this should never happend
|
|
122
|
-
|
|
123
|
-
if (!url || !p) {
|
|
124
|
-
return;
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
if (url.pathname === p) {
|
|
128
|
-
return;
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
url.pathname = p;
|
|
132
|
-
this.url = url.toString();
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
get querystring() {
|
|
136
|
-
if (!this.req) {
|
|
137
|
-
return '';
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
return this.parsedURL.search.replace(/^\?/, '') || '';
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
get query() {
|
|
144
|
-
const str = this.querystring;
|
|
145
|
-
return qs.parse(str);
|
|
146
|
-
}
|
|
147
|
-
/* response property */
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
get status() {
|
|
151
|
-
return this.res.statusCode;
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
set status(statusCode) {
|
|
155
|
-
this.res.statusCode = statusCode;
|
|
156
|
-
}
|
|
157
|
-
/**
|
|
158
|
-
* 判断链接是否已经关闭
|
|
159
|
-
*/
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
resHasHandled() {
|
|
163
|
-
return this.res.writableEnded;
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
logInfo() {
|
|
167
|
-
return {
|
|
168
|
-
headers: this.headers,
|
|
169
|
-
href: this.href,
|
|
170
|
-
url: this.url
|
|
171
|
-
};
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
error(dig, err = '') {
|
|
175
|
-
const message = toMessage(dig, err);
|
|
176
|
-
const reqInfo = this.logInfo();
|
|
177
|
-
this.logger.error(`${reqInfo.url} - ${message}`, reqInfo);
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
class RouteAPI {
|
|
2
|
-
constructor(matched, router, url) {
|
|
3
|
-
this.router = void 0;
|
|
4
|
-
this.current = void 0;
|
|
5
|
-
this.url = void 0;
|
|
6
|
-
this.current = matched;
|
|
7
|
-
this.router = router;
|
|
8
|
-
this.url = url;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
cur() {
|
|
12
|
-
return this.current.generate(this.url);
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
get(entryName) {
|
|
16
|
-
const {
|
|
17
|
-
router
|
|
18
|
-
} = this;
|
|
19
|
-
const matched = router.matchEntry(entryName);
|
|
20
|
-
return matched ? matched.generate(this.url) : null;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
use(entryName) {
|
|
24
|
-
const {
|
|
25
|
-
router
|
|
26
|
-
} = this;
|
|
27
|
-
const matched = router.matchEntry(entryName);
|
|
28
|
-
|
|
29
|
-
if (matched) {
|
|
30
|
-
this.current = matched;
|
|
31
|
-
return true;
|
|
32
|
-
} else {
|
|
33
|
-
return false;
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
export const createRouteAPI = (matched, router, url) => new RouteAPI(matched, router, url);
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
const RegList = {
|
|
2
|
-
before: {
|
|
3
|
-
head: '<head>',
|
|
4
|
-
body: '<body>'
|
|
5
|
-
},
|
|
6
|
-
after: {
|
|
7
|
-
head: '</head>',
|
|
8
|
-
body: '</body>'
|
|
9
|
-
}
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
class TemplateAPI {
|
|
13
|
-
constructor(content) {
|
|
14
|
-
this.content = void 0;
|
|
15
|
-
this.content = content;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
get() {
|
|
19
|
-
return this.content;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
set(content) {
|
|
23
|
-
this.content = content;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
prependHead(fragment) {
|
|
27
|
-
const {
|
|
28
|
-
head
|
|
29
|
-
} = RegList.before;
|
|
30
|
-
return this.replace(head, `${head}${fragment}`);
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
appendHead(fragment) {
|
|
34
|
-
const {
|
|
35
|
-
head
|
|
36
|
-
} = RegList.after;
|
|
37
|
-
return this.replace(head, `${fragment}${head}`);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
prependBody(fragment) {
|
|
41
|
-
const {
|
|
42
|
-
body
|
|
43
|
-
} = RegList.before;
|
|
44
|
-
return this.replace(body, `${body}${fragment}`);
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
appendBody(fragment) {
|
|
48
|
-
const {
|
|
49
|
-
body
|
|
50
|
-
} = RegList.after;
|
|
51
|
-
return this.replace(body, `${fragment}${body}`);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
replace(reg, text) {
|
|
55
|
-
this.content = this.content.replace(reg, text);
|
|
56
|
-
return this;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
export const createTemplateAPI = content => new TemplateAPI(content);
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import { createProxyMiddleware } from 'http-proxy-middleware';
|
|
2
|
-
import { formatProxyOptions } from '@modern-js/utils';
|
|
3
|
-
export const createProxyHandler = proxyOptions => {
|
|
4
|
-
if (!proxyOptions) {
|
|
5
|
-
return null;
|
|
6
|
-
} // If it is not an array, it may be an object that uses the context attribute
|
|
7
|
-
// or an object in the form of { source: ProxyDetail }
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
const formatedProxy = formatProxyOptions(proxyOptions);
|
|
11
|
-
const middlewares = formatedProxy.map(option => {
|
|
12
|
-
const middleware = createProxyMiddleware(option.context, option); // eslint-disable-next-line consistent-return
|
|
13
|
-
|
|
14
|
-
return async (ctx, next) => {
|
|
15
|
-
const {
|
|
16
|
-
req,
|
|
17
|
-
res
|
|
18
|
-
} = ctx;
|
|
19
|
-
const bypassUrl = typeof option.bypass === 'function' ? option.bypass(req, res, option) : null; // only false, no true
|
|
20
|
-
|
|
21
|
-
if (typeof bypassUrl === 'boolean') {
|
|
22
|
-
ctx.status = 404;
|
|
23
|
-
return next();
|
|
24
|
-
} else if (typeof bypassUrl === 'string') {
|
|
25
|
-
ctx.url = bypassUrl;
|
|
26
|
-
return next();
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
middleware(req, res, next);
|
|
30
|
-
};
|
|
31
|
-
});
|
|
32
|
-
return middlewares;
|
|
33
|
-
};
|