@modern-js/server 1.4.1 → 1.4.4
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/CHANGELOG.md +34 -0
- package/dist/js/modern/dev-tools/mock/index.js +1 -1
- package/dist/js/modern/dev-tools/socket-server.js +63 -46
- 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} +19 -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 +63 -47
- 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} +22 -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 -1
- 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 +5 -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} +5 -4
- 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 +8 -39
- package/tests/dev.test.ts +17 -0
- 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 -59
- 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 -69
- 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 -16
- 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/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,59 +0,0 @@
|
|
|
1
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
2
|
-
|
|
3
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
4
|
-
|
|
5
|
-
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
6
|
-
|
|
7
|
-
import { createProxyMiddleware } from 'http-proxy-middleware';
|
|
8
|
-
export const createProxyHandler = proxyOptions => {
|
|
9
|
-
if (!proxyOptions) {
|
|
10
|
-
return null;
|
|
11
|
-
} // If it is not an array, it may be an object that uses the context attribute
|
|
12
|
-
// or an object in the form of { source: ProxyDetail }
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
const formatedProxy = [];
|
|
16
|
-
|
|
17
|
-
if (!Array.isArray(proxyOptions)) {
|
|
18
|
-
if ('target' in proxyOptions) {
|
|
19
|
-
formatedProxy.push(proxyOptions);
|
|
20
|
-
} else {
|
|
21
|
-
Array.prototype.push.apply(formatedProxy, Object.keys(proxyOptions).reduce((total, source) => {
|
|
22
|
-
const option = proxyOptions[source];
|
|
23
|
-
total.push(_objectSpread({
|
|
24
|
-
context: source,
|
|
25
|
-
changeOrigin: true,
|
|
26
|
-
logLevel: 'warn'
|
|
27
|
-
}, typeof option === 'string' ? {
|
|
28
|
-
target: option
|
|
29
|
-
} : option));
|
|
30
|
-
return total;
|
|
31
|
-
}, []));
|
|
32
|
-
}
|
|
33
|
-
} else {
|
|
34
|
-
formatedProxy.push(...proxyOptions);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
const middlewares = formatedProxy.map(option => {
|
|
38
|
-
const middleware = createProxyMiddleware(option.context, option); // eslint-disable-next-line consistent-return
|
|
39
|
-
|
|
40
|
-
return async (ctx, next) => {
|
|
41
|
-
const {
|
|
42
|
-
req,
|
|
43
|
-
res
|
|
44
|
-
} = ctx;
|
|
45
|
-
const bypassUrl = typeof option.bypass === 'function' ? option.bypass(req, res, option) : null; // only false, no true
|
|
46
|
-
|
|
47
|
-
if (typeof bypassUrl === 'boolean') {
|
|
48
|
-
ctx.status = 404;
|
|
49
|
-
return next();
|
|
50
|
-
} else if (typeof bypassUrl === 'string') {
|
|
51
|
-
ctx.url = bypassUrl;
|
|
52
|
-
return next();
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
middleware(req, res, next);
|
|
56
|
-
};
|
|
57
|
-
});
|
|
58
|
-
return middlewares;
|
|
59
|
-
};
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
import url from 'url';
|
|
2
|
-
import { createCache, destroyCache } from "../spr";
|
|
3
|
-
import { cacheAddition, connectFactor, fname, maybeSync, namespaceHash, valueFactory, withCoalescedInvoke } from "../util";
|
|
4
|
-
describe('test spr util functions', () => {
|
|
5
|
-
it('should return value correctly', () => {
|
|
6
|
-
expect(connectFactor('bar', 'foo')).toBe('bar-foo');
|
|
7
|
-
expect(fname(1)).toBe('f1');
|
|
8
|
-
expect(namespaceHash('modern', '!@#$%^&')).toBe('modern/!@#$%^&');
|
|
9
|
-
});
|
|
10
|
-
it('should create or destroy instance correctly', () => {
|
|
11
|
-
const ins1 = createCache();
|
|
12
|
-
const ins2 = createCache();
|
|
13
|
-
expect(ins1 === ins2).toBe(true);
|
|
14
|
-
destroyCache();
|
|
15
|
-
const ins3 = createCache();
|
|
16
|
-
expect(ins1 === ins3).toBe(false);
|
|
17
|
-
expect(ins2 === ins3).toBe(false);
|
|
18
|
-
});
|
|
19
|
-
it('should return function correctly', () => {
|
|
20
|
-
const urlParams = (() => new url.URLSearchParams())();
|
|
21
|
-
|
|
22
|
-
urlParams.set('name', 'modern');
|
|
23
|
-
const getParam = valueFactory(urlParams);
|
|
24
|
-
expect(getParam('name')).toBe('modern');
|
|
25
|
-
const headers = {
|
|
26
|
-
age: '12345'
|
|
27
|
-
};
|
|
28
|
-
const getHeader = valueFactory(headers);
|
|
29
|
-
expect(getHeader('age')).toBe('12345');
|
|
30
|
-
});
|
|
31
|
-
it('should add target html content', () => {
|
|
32
|
-
const contentNoHead = '<div>123</div>';
|
|
33
|
-
const html = cacheAddition(contentNoHead, Math.random().toString());
|
|
34
|
-
expect(html).toBe(contentNoHead);
|
|
35
|
-
const contentWithHead = '<head></head><div>123</div>';
|
|
36
|
-
const hash = Math.random().toString();
|
|
37
|
-
const htmlWithHead = cacheAddition(contentWithHead, hash);
|
|
38
|
-
expect(htmlWithHead).toBe(`<head><meta name="x-moden-spr" content="${hash}"></head><div>123</div>`);
|
|
39
|
-
});
|
|
40
|
-
it('should only invoke func one time', async () => {
|
|
41
|
-
let index = 0;
|
|
42
|
-
const fn = withCoalescedInvoke(async () => new Promise(resolve => {
|
|
43
|
-
setTimeout(() => {
|
|
44
|
-
index += 1;
|
|
45
|
-
resolve(index);
|
|
46
|
-
}, 500);
|
|
47
|
-
}));
|
|
48
|
-
const key = 'test';
|
|
49
|
-
const [res1, res2] = await Promise.all([fn(key, []), fn(key, [])]);
|
|
50
|
-
expect(res1.isOrigin && res2.isOrigin).toBe(false);
|
|
51
|
-
expect(res1.isOrigin || res2.isOrigin).toBe(true);
|
|
52
|
-
expect(res1.value).toBe(1);
|
|
53
|
-
expect(res2.value).toBe(1);
|
|
54
|
-
});
|
|
55
|
-
it('should invoke sync or async', async () => {
|
|
56
|
-
const foo = '';
|
|
57
|
-
const async = await maybeSync(() => new Promise(resolve => {
|
|
58
|
-
setTimeout(() => {
|
|
59
|
-
resolve(foo);
|
|
60
|
-
}, 100);
|
|
61
|
-
}))(false);
|
|
62
|
-
expect(async).toBeUndefined();
|
|
63
|
-
const sync = await maybeSync(() => new Promise(resolve => {
|
|
64
|
-
setTimeout(() => {
|
|
65
|
-
resolve(foo);
|
|
66
|
-
}, 100);
|
|
67
|
-
}))(true);
|
|
68
|
-
expect(sync).toBe(foo);
|
|
69
|
-
});
|
|
70
|
-
});
|