@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
|
@@ -1,238 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _spr = require("../spr");
|
|
4
|
-
|
|
5
|
-
var _errorConfiguration = require("./error-configuration");
|
|
6
|
-
|
|
7
|
-
var _cacheable = require("./cacheable");
|
|
8
|
-
|
|
9
|
-
var _matchedCache = require("./matched-cache");
|
|
10
|
-
|
|
11
|
-
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; }
|
|
12
|
-
|
|
13
|
-
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; }
|
|
14
|
-
|
|
15
|
-
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; }
|
|
16
|
-
|
|
17
|
-
const createCacheConfig = (config = {}) => _objectSpread({
|
|
18
|
-
excludes: null,
|
|
19
|
-
includes: null,
|
|
20
|
-
interval: 10,
|
|
21
|
-
staleLimit: false,
|
|
22
|
-
level: 0,
|
|
23
|
-
fallback: false,
|
|
24
|
-
matches: null
|
|
25
|
-
}, config);
|
|
26
|
-
|
|
27
|
-
jest.setTimeout(60000);
|
|
28
|
-
describe('cache', () => {
|
|
29
|
-
it('should cache correctly', async () => {
|
|
30
|
-
(0, _spr.destroyCache)();
|
|
31
|
-
const cache = (0, _spr.createCache)();
|
|
32
|
-
const context = {
|
|
33
|
-
entry: '',
|
|
34
|
-
pathname: '',
|
|
35
|
-
query: {},
|
|
36
|
-
headers: {}
|
|
37
|
-
};
|
|
38
|
-
const content = 'hello';
|
|
39
|
-
const cacheConfig = createCacheConfig();
|
|
40
|
-
await cache.set(context, content, cacheConfig, true);
|
|
41
|
-
const cacheResult = await cache.get(context);
|
|
42
|
-
expect(cacheResult).not.toBe(null);
|
|
43
|
-
expect(cacheResult === null || cacheResult === void 0 ? void 0 : cacheResult.content).toBe('hello');
|
|
44
|
-
});
|
|
45
|
-
it('should ignore cache set when cache config not exist', async () => {
|
|
46
|
-
(0, _spr.destroyCache)();
|
|
47
|
-
(0, _spr.destroyCache)();
|
|
48
|
-
const cache = (0, _spr.createCache)();
|
|
49
|
-
const context = {
|
|
50
|
-
entry: '',
|
|
51
|
-
pathname: '',
|
|
52
|
-
query: {},
|
|
53
|
-
headers: {}
|
|
54
|
-
};
|
|
55
|
-
const content = 'hello';
|
|
56
|
-
const shouldCache = await cache.set(context, content, null, true);
|
|
57
|
-
expect(shouldCache).toBe(false);
|
|
58
|
-
});
|
|
59
|
-
it('should calcual cache key error', async () => {
|
|
60
|
-
(0, _spr.destroyCache)();
|
|
61
|
-
const cache = (0, _spr.createCache)();
|
|
62
|
-
const content = 'hello';
|
|
63
|
-
|
|
64
|
-
for (const config of _errorConfiguration.errorConfiguration) {
|
|
65
|
-
const cacheConfig = createCacheConfig(config);
|
|
66
|
-
const tmpEntry = Math.random().toString();
|
|
67
|
-
const context = {
|
|
68
|
-
entry: tmpEntry,
|
|
69
|
-
pathname: '',
|
|
70
|
-
query: {},
|
|
71
|
-
headers: {}
|
|
72
|
-
};
|
|
73
|
-
const shouldCache = await cache.set(context, content, cacheConfig);
|
|
74
|
-
expect(shouldCache).toBe(false);
|
|
75
|
-
}
|
|
76
|
-
});
|
|
77
|
-
it('should get nothing for diff requestKey', async () => {
|
|
78
|
-
(0, _spr.destroyCache)();
|
|
79
|
-
const cache = (0, _spr.createCache)();
|
|
80
|
-
const context = {
|
|
81
|
-
entry: '',
|
|
82
|
-
pathname: '',
|
|
83
|
-
query: {},
|
|
84
|
-
headers: {}
|
|
85
|
-
};
|
|
86
|
-
const content = 'hello';
|
|
87
|
-
const cacheConfig = createCacheConfig({
|
|
88
|
-
level: 1,
|
|
89
|
-
includes: {
|
|
90
|
-
query: ['name']
|
|
91
|
-
}
|
|
92
|
-
});
|
|
93
|
-
await cache.set(context, content, cacheConfig, true);
|
|
94
|
-
const context_req = {
|
|
95
|
-
entry: '',
|
|
96
|
-
pathname: '/home',
|
|
97
|
-
query: {},
|
|
98
|
-
headers: {}
|
|
99
|
-
};
|
|
100
|
-
const cacheResult = await cache.get(context_req);
|
|
101
|
-
expect(cacheResult).toBe(null);
|
|
102
|
-
});
|
|
103
|
-
it('should get nothing for diff cacheHash', async () => {
|
|
104
|
-
(0, _spr.destroyCache)();
|
|
105
|
-
const cache = (0, _spr.createCache)();
|
|
106
|
-
const context = {
|
|
107
|
-
entry: '',
|
|
108
|
-
pathname: '',
|
|
109
|
-
query: {},
|
|
110
|
-
headers: {}
|
|
111
|
-
};
|
|
112
|
-
const content = 'hello';
|
|
113
|
-
const cacheConfig = createCacheConfig({
|
|
114
|
-
level: 1,
|
|
115
|
-
includes: {
|
|
116
|
-
query: ['name']
|
|
117
|
-
}
|
|
118
|
-
});
|
|
119
|
-
await cache.set(context, content, cacheConfig, true);
|
|
120
|
-
const context_req = {
|
|
121
|
-
entry: '',
|
|
122
|
-
pathname: '',
|
|
123
|
-
query: {
|
|
124
|
-
name: 'zll'
|
|
125
|
-
},
|
|
126
|
-
headers: {}
|
|
127
|
-
};
|
|
128
|
-
const cacheResult = await cache.get(context_req);
|
|
129
|
-
expect(cacheResult).toBe(null);
|
|
130
|
-
});
|
|
131
|
-
it('should get cache correctly', async () => {
|
|
132
|
-
(0, _spr.destroyCache)();
|
|
133
|
-
const cache = (0, _spr.createCache)();
|
|
134
|
-
|
|
135
|
-
for (const cacheable of _cacheable.cacheabelAry) {
|
|
136
|
-
const context = {
|
|
137
|
-
entry: '',
|
|
138
|
-
pathname: cacheable.requestOpt.url,
|
|
139
|
-
query: cacheable.requestOpt.query || {},
|
|
140
|
-
headers: cacheable.requestOpt.headers || {}
|
|
141
|
-
};
|
|
142
|
-
const cacheConfig = createCacheConfig(cacheable.cacheConfig || {});
|
|
143
|
-
await cache.set(context, cacheable.content, cacheConfig, true);
|
|
144
|
-
const cacheResult = await cache.get(context);
|
|
145
|
-
expect(cacheResult === null || cacheResult === void 0 ? void 0 : cacheResult.content).toBe(cacheable.content);
|
|
146
|
-
}
|
|
147
|
-
});
|
|
148
|
-
it('should match cache correctly', async () => {
|
|
149
|
-
(0, _spr.destroyCache)();
|
|
150
|
-
const cache = (0, _spr.createCache)();
|
|
151
|
-
|
|
152
|
-
for (const cacheable of _matchedCache.matchedCacheableAry) {
|
|
153
|
-
const [baseCacheable, matchOne, ...other] = cacheable;
|
|
154
|
-
const {
|
|
155
|
-
requestOpt = {},
|
|
156
|
-
cacheConfig,
|
|
157
|
-
content
|
|
158
|
-
} = baseCacheable;
|
|
159
|
-
const context = {
|
|
160
|
-
entry: '',
|
|
161
|
-
pathname: requestOpt.url,
|
|
162
|
-
query: requestOpt.query,
|
|
163
|
-
headers: requestOpt.headers
|
|
164
|
-
};
|
|
165
|
-
await cache.set(context, content, createCacheConfig(cacheConfig), true);
|
|
166
|
-
const matchContext = {
|
|
167
|
-
entry: '',
|
|
168
|
-
pathname: matchOne.url,
|
|
169
|
-
query: matchOne.query,
|
|
170
|
-
headers: matchOne.headers
|
|
171
|
-
};
|
|
172
|
-
const cacheResult = await cache.get(matchContext);
|
|
173
|
-
expect(cacheResult === null || cacheResult === void 0 ? void 0 : cacheResult.content).toBe(content);
|
|
174
|
-
|
|
175
|
-
for (const notMatch of other) {
|
|
176
|
-
const notMatchContext = {
|
|
177
|
-
entry: '',
|
|
178
|
-
pathname: notMatch.url,
|
|
179
|
-
query: notMatch.query,
|
|
180
|
-
headers: notMatch.headers
|
|
181
|
-
};
|
|
182
|
-
const nothing = await cache.get(notMatchContext);
|
|
183
|
-
expect(nothing).toBe(null);
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
});
|
|
187
|
-
it('should stale cache correctly', async () => {
|
|
188
|
-
(0, _spr.destroyCache)();
|
|
189
|
-
const cache = (0, _spr.createCache)();
|
|
190
|
-
const context = {
|
|
191
|
-
entry: '',
|
|
192
|
-
pathname: '',
|
|
193
|
-
query: {},
|
|
194
|
-
headers: {}
|
|
195
|
-
};
|
|
196
|
-
const config = createCacheConfig({
|
|
197
|
-
interval: 5
|
|
198
|
-
});
|
|
199
|
-
const content = 'hello';
|
|
200
|
-
const shouldCache = await cache.set(context, content, config, true);
|
|
201
|
-
expect(shouldCache.value).toBe(true);
|
|
202
|
-
const freshResult = await cache.get(context);
|
|
203
|
-
expect(freshResult === null || freshResult === void 0 ? void 0 : freshResult.isStale).toBe(false);
|
|
204
|
-
await new Promise(resolve => {
|
|
205
|
-
setTimeout(() => {
|
|
206
|
-
resolve();
|
|
207
|
-
}, 6000);
|
|
208
|
-
});
|
|
209
|
-
const staleResult = await cache.get(context);
|
|
210
|
-
expect(staleResult === null || staleResult === void 0 ? void 0 : staleResult.isStale).toBe(true);
|
|
211
|
-
});
|
|
212
|
-
it('should garbage cache correctly', async () => {
|
|
213
|
-
(0, _spr.destroyCache)();
|
|
214
|
-
const cache = (0, _spr.createCache)();
|
|
215
|
-
const context = {
|
|
216
|
-
entry: '',
|
|
217
|
-
pathname: '',
|
|
218
|
-
query: {},
|
|
219
|
-
headers: {}
|
|
220
|
-
};
|
|
221
|
-
const config = createCacheConfig({
|
|
222
|
-
interval: 3,
|
|
223
|
-
staleLimit: 8
|
|
224
|
-
});
|
|
225
|
-
const content = 'hello';
|
|
226
|
-
const shouldCache = await cache.set(context, content, config, true);
|
|
227
|
-
expect(shouldCache.value).toBe(true);
|
|
228
|
-
const freshResult = await cache.get(context);
|
|
229
|
-
expect(freshResult === null || freshResult === void 0 ? void 0 : freshResult.isGarbage).toBe(false);
|
|
230
|
-
await new Promise(resolve => {
|
|
231
|
-
setTimeout(() => {
|
|
232
|
-
resolve();
|
|
233
|
-
}, 10000);
|
|
234
|
-
});
|
|
235
|
-
const staleResult = await cache.get(context);
|
|
236
|
-
expect(staleResult === null || staleResult === void 0 ? void 0 : staleResult.isGarbage).toBe(true);
|
|
237
|
-
});
|
|
238
|
-
});
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.cacheabelAry = void 0;
|
|
7
|
-
const cacheabelAry = [{
|
|
8
|
-
requestOpt: {
|
|
9
|
-
url: '/'
|
|
10
|
-
},
|
|
11
|
-
cacheConfig: {},
|
|
12
|
-
content: 'level0'
|
|
13
|
-
}, {
|
|
14
|
-
requestOpt: {
|
|
15
|
-
url: '/level-one',
|
|
16
|
-
query: {
|
|
17
|
-
name: 'modern'
|
|
18
|
-
}
|
|
19
|
-
},
|
|
20
|
-
cacheConfig: {
|
|
21
|
-
level: 1,
|
|
22
|
-
includes: {
|
|
23
|
-
query: ['name']
|
|
24
|
-
}
|
|
25
|
-
},
|
|
26
|
-
content: 'level1'
|
|
27
|
-
}, {
|
|
28
|
-
requestOpt: {
|
|
29
|
-
url: '/level-two',
|
|
30
|
-
headers: {
|
|
31
|
-
age: '18'
|
|
32
|
-
}
|
|
33
|
-
},
|
|
34
|
-
cacheConfig: {
|
|
35
|
-
level: 2,
|
|
36
|
-
includes: {
|
|
37
|
-
header: ['age']
|
|
38
|
-
}
|
|
39
|
-
},
|
|
40
|
-
content: 'level2'
|
|
41
|
-
}, {
|
|
42
|
-
requestOpt: {
|
|
43
|
-
url: '/level-three',
|
|
44
|
-
query: {
|
|
45
|
-
name: 'modern'
|
|
46
|
-
},
|
|
47
|
-
headers: {
|
|
48
|
-
age: '18'
|
|
49
|
-
}
|
|
50
|
-
},
|
|
51
|
-
cacheConfig: {
|
|
52
|
-
level: 3,
|
|
53
|
-
includes: {
|
|
54
|
-
query: ['name'],
|
|
55
|
-
header: ['age']
|
|
56
|
-
}
|
|
57
|
-
},
|
|
58
|
-
content: 'level3'
|
|
59
|
-
}];
|
|
60
|
-
exports.cacheabelAry = cacheabelAry;
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.errorConfiguration = void 0;
|
|
7
|
-
const errorConfiguration = [{
|
|
8
|
-
level: 1
|
|
9
|
-
}, {
|
|
10
|
-
level: 1,
|
|
11
|
-
includes: {}
|
|
12
|
-
}, {
|
|
13
|
-
level: 1,
|
|
14
|
-
includes: {
|
|
15
|
-
query: []
|
|
16
|
-
}
|
|
17
|
-
}, {
|
|
18
|
-
level: 2,
|
|
19
|
-
includes: {}
|
|
20
|
-
}, {
|
|
21
|
-
level: 2,
|
|
22
|
-
includes: {
|
|
23
|
-
header: []
|
|
24
|
-
}
|
|
25
|
-
}, {
|
|
26
|
-
level: 3,
|
|
27
|
-
includes: {
|
|
28
|
-
header: []
|
|
29
|
-
}
|
|
30
|
-
}, {
|
|
31
|
-
level: 3,
|
|
32
|
-
includes: {
|
|
33
|
-
query: []
|
|
34
|
-
}
|
|
35
|
-
}, {
|
|
36
|
-
level: 3,
|
|
37
|
-
includes: {
|
|
38
|
-
query: [],
|
|
39
|
-
header: []
|
|
40
|
-
}
|
|
41
|
-
}];
|
|
42
|
-
exports.errorConfiguration = errorConfiguration;
|
|
@@ -1,128 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.matchedCacheableAry = void 0;
|
|
7
|
-
const matchedCacheableAry = [[{
|
|
8
|
-
requestOpt: {
|
|
9
|
-
url: '/level-one',
|
|
10
|
-
headers: {},
|
|
11
|
-
query: {
|
|
12
|
-
name: 'byted'
|
|
13
|
-
}
|
|
14
|
-
},
|
|
15
|
-
cacheConfig: {
|
|
16
|
-
level: 1,
|
|
17
|
-
includes: {
|
|
18
|
-
query: ['name']
|
|
19
|
-
},
|
|
20
|
-
matches: {
|
|
21
|
-
query: {
|
|
22
|
-
name: {
|
|
23
|
-
weixin: '^byted'
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
},
|
|
28
|
-
content: 'level1'
|
|
29
|
-
}, {
|
|
30
|
-
url: '/level-one',
|
|
31
|
-
headers: {},
|
|
32
|
-
query: {
|
|
33
|
-
name: 'byted_likely'
|
|
34
|
-
}
|
|
35
|
-
}, {
|
|
36
|
-
url: '/level-one',
|
|
37
|
-
headers: {},
|
|
38
|
-
query: {
|
|
39
|
-
name: 'not_byted'
|
|
40
|
-
}
|
|
41
|
-
}], [{
|
|
42
|
-
requestOpt: {
|
|
43
|
-
url: '/level-two',
|
|
44
|
-
query: {},
|
|
45
|
-
headers: {
|
|
46
|
-
age: '17'
|
|
47
|
-
}
|
|
48
|
-
},
|
|
49
|
-
cacheConfig: {
|
|
50
|
-
level: 2,
|
|
51
|
-
includes: {
|
|
52
|
-
header: ['age']
|
|
53
|
-
},
|
|
54
|
-
matches: {
|
|
55
|
-
header: {
|
|
56
|
-
age: {
|
|
57
|
-
one: '^1'
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
},
|
|
62
|
-
content: 'level2'
|
|
63
|
-
}, {
|
|
64
|
-
url: '/level-two',
|
|
65
|
-
query: {},
|
|
66
|
-
headers: {
|
|
67
|
-
age: '11'
|
|
68
|
-
}
|
|
69
|
-
}, {
|
|
70
|
-
url: '/level-two',
|
|
71
|
-
query: {},
|
|
72
|
-
headers: {
|
|
73
|
-
age: '22'
|
|
74
|
-
}
|
|
75
|
-
}], [{
|
|
76
|
-
requestOpt: {
|
|
77
|
-
url: '/level-three',
|
|
78
|
-
headers: {
|
|
79
|
-
age: '17'
|
|
80
|
-
},
|
|
81
|
-
query: {
|
|
82
|
-
name: 'byted'
|
|
83
|
-
}
|
|
84
|
-
},
|
|
85
|
-
cacheConfig: {
|
|
86
|
-
level: 3,
|
|
87
|
-
includes: {
|
|
88
|
-
query: ['name'],
|
|
89
|
-
header: ['age']
|
|
90
|
-
},
|
|
91
|
-
matches: {
|
|
92
|
-
query: {
|
|
93
|
-
name: {
|
|
94
|
-
weixin: '^byted'
|
|
95
|
-
}
|
|
96
|
-
},
|
|
97
|
-
header: {
|
|
98
|
-
age: {
|
|
99
|
-
one: '^1'
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
},
|
|
104
|
-
content: 'level3'
|
|
105
|
-
}, {
|
|
106
|
-
url: '/level-three',
|
|
107
|
-
query: {
|
|
108
|
-
name: 'byted_likely'
|
|
109
|
-
},
|
|
110
|
-
headers: {
|
|
111
|
-
age: '19'
|
|
112
|
-
}
|
|
113
|
-
}, {
|
|
114
|
-
url: '/level-three',
|
|
115
|
-
query: {
|
|
116
|
-
name: 'byted_likely'
|
|
117
|
-
},
|
|
118
|
-
headers: {}
|
|
119
|
-
}, {
|
|
120
|
-
url: '/level-three',
|
|
121
|
-
query: {
|
|
122
|
-
name: 'not_byted'
|
|
123
|
-
},
|
|
124
|
-
headers: {
|
|
125
|
-
age: '19'
|
|
126
|
-
}
|
|
127
|
-
}]];
|
|
128
|
-
exports.matchedCacheableAry = matchedCacheableAry;
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
|
|
8
|
-
var _constants = require("../../../constants");
|
|
9
|
-
|
|
10
|
-
var _spr = require("./spr");
|
|
11
|
-
|
|
12
|
-
var _util = require("./util");
|
|
13
|
-
|
|
14
|
-
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; }
|
|
15
|
-
|
|
16
|
-
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; }
|
|
17
|
-
|
|
18
|
-
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; }
|
|
19
|
-
|
|
20
|
-
var _default = (renderFn, ctx) => {
|
|
21
|
-
const sprCache = (0, _spr.createCache)();
|
|
22
|
-
|
|
23
|
-
const doRender = async context => {
|
|
24
|
-
const cacheContext = _objectSpread({
|
|
25
|
-
entry: context.entryName
|
|
26
|
-
}, context.request);
|
|
27
|
-
|
|
28
|
-
const cacheFile = await sprCache.get(cacheContext); // no cache, render sync
|
|
29
|
-
|
|
30
|
-
if (!cacheFile) {
|
|
31
|
-
const html = await renderFn(context);
|
|
32
|
-
const {
|
|
33
|
-
cacheConfig
|
|
34
|
-
} = context;
|
|
35
|
-
|
|
36
|
-
if (html && cacheConfig) {
|
|
37
|
-
await sprCache.set(cacheContext, html, cacheConfig);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
return html;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
const cacheHash = cacheFile === null || cacheFile === void 0 ? void 0 : cacheFile.hash; // completely expired
|
|
44
|
-
|
|
45
|
-
if (cacheFile.isGarbage) {
|
|
46
|
-
const html = await renderFn(context);
|
|
47
|
-
const {
|
|
48
|
-
cacheConfig
|
|
49
|
-
} = context;
|
|
50
|
-
|
|
51
|
-
if (html && cacheConfig) {
|
|
52
|
-
await sprCache.set(cacheContext, html, cacheConfig);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
return html;
|
|
56
|
-
} else if (cacheFile.isStale) {
|
|
57
|
-
// if file is stale, request async
|
|
58
|
-
const render = (0, _util.withCoalescedInvoke)(() => renderFn(context)).bind(null, (0, _util.namespaceHash)('render', cacheFile.hash), []);
|
|
59
|
-
render() // eslint-disable-next-line promise/prefer-await-to-then
|
|
60
|
-
.then(res => {
|
|
61
|
-
if (res.value && res.isOrigin) {
|
|
62
|
-
const {
|
|
63
|
-
cacheConfig
|
|
64
|
-
} = context;
|
|
65
|
-
|
|
66
|
-
if (cacheConfig) {
|
|
67
|
-
sprCache.set(cacheContext, res.value, cacheConfig);
|
|
68
|
-
} else {
|
|
69
|
-
sprCache.del(cacheContext, cacheHash);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
}) // eslint-disable-next-line promise/prefer-await-to-then
|
|
73
|
-
.catch(e => {
|
|
74
|
-
sprCache.del(cacheContext, cacheHash);
|
|
75
|
-
ctx.error(_constants.ERROR_DIGEST.ERENDER, e);
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
ctx.res.setHeader('x-modern-spr', '1');
|
|
80
|
-
return cacheFile.content;
|
|
81
|
-
};
|
|
82
|
-
|
|
83
|
-
return doRender;
|
|
84
|
-
};
|
|
85
|
-
|
|
86
|
-
exports.default = _default;
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.createPageCaches = createPageCaches;
|
|
7
|
-
|
|
8
|
-
var _lru = require("./lru");
|
|
9
|
-
|
|
10
|
-
async function createPageCaches(max) {
|
|
11
|
-
const constructorOptions = {
|
|
12
|
-
max
|
|
13
|
-
};
|
|
14
|
-
const cacheInstance = new _lru.LRUCaches(constructorOptions);
|
|
15
|
-
await cacheInstance.init();
|
|
16
|
-
return cacheInstance;
|
|
17
|
-
}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.LRUCaches = void 0;
|
|
7
|
-
|
|
8
|
-
var _lruCache = _interopRequireDefault(require("lru-cache"));
|
|
9
|
-
|
|
10
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
11
|
-
|
|
12
|
-
class LRUCaches {
|
|
13
|
-
constructor(options) {
|
|
14
|
-
this.caches = void 0;
|
|
15
|
-
this.max = void 0;
|
|
16
|
-
this.max = options.max;
|
|
17
|
-
this.caches = new _lruCache.default(this.max);
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
init() {
|
|
21
|
-
return Promise.resolve();
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
keys() {
|
|
25
|
-
return this.caches.keys();
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
get(key) {
|
|
29
|
-
return Promise.resolve(this.caches.get(key) || null);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
peek(key) {
|
|
33
|
-
return this.caches.peek(key) || null;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
set(key, cache) {
|
|
37
|
-
this.caches.set(key, cache);
|
|
38
|
-
return Promise.resolve();
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
del(key) {
|
|
42
|
-
this.caches.del(key);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
exports.LRUCaches = LRUCaches;
|