@modern-js/plugin-data-loader 2.6.0 → 2.7.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/cjs/cli/{create-request.js → createRequest.js} +17 -6
- package/dist/cjs/cli/data.js +162 -0
- package/dist/cjs/cli/{generate-client.js → generateClient.js} +4 -4
- package/dist/cjs/cli/loader.js +2 -2
- package/dist/cjs/common/constants.js +3 -0
- package/dist/cjs/runtime/index.js +165 -0
- package/dist/cjs/runtime/response.js +102 -0
- package/dist/cjs/server/index.js +22 -181
- package/dist/esm/cli/{create-request.js → createRequest.js} +42 -3
- package/dist/esm/cli/data.js +820 -0
- package/dist/esm/cli/{generate-client.js → generateClient.js} +1 -1
- package/dist/esm/cli/loader.js +1 -1
- package/dist/esm/common/constants.js +2 -1
- package/dist/esm/runtime/index.js +427 -0
- package/dist/esm/runtime/response.js +284 -0
- package/dist/esm/server/index.js +38 -432
- package/dist/esm-node/cli/{create-request.js → createRequest.js} +19 -4
- package/dist/esm-node/cli/data.js +142 -0
- package/dist/esm-node/cli/{generate-client.js → generateClient.js} +1 -1
- package/dist/esm-node/cli/loader.js +1 -1
- package/dist/esm-node/common/constants.js +2 -0
- package/dist/esm-node/runtime/index.js +147 -0
- package/dist/esm-node/runtime/response.js +79 -0
- package/dist/esm-node/server/index.js +21 -181
- package/dist/types/cli/{create-request.d.ts → createRequest.d.ts} +2 -1
- package/dist/types/cli/data.d.ts +6 -0
- package/dist/types/common/constants.d.ts +2 -1
- package/dist/types/runtime/index.d.ts +15 -0
- package/dist/types/runtime/response.d.ts +2 -0
- package/dist/types/server/index.d.ts +0 -15
- package/package.json +19 -9
- /package/dist/types/cli/{generate-client.d.ts → generateClient.d.ts} +0 -0
package/dist/esm/server/index.js
CHANGED
|
@@ -1,11 +1,3 @@
|
|
|
1
|
-
function _arrayLikeToArray(arr, len) {
|
|
2
|
-
if (len == null || len > arr.length) len = arr.length;
|
|
3
|
-
for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
|
|
4
|
-
return arr2;
|
|
5
|
-
}
|
|
6
|
-
function _arrayWithHoles(arr) {
|
|
7
|
-
if (Array.isArray(arr)) return arr;
|
|
8
|
-
}
|
|
9
1
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
10
2
|
try {
|
|
11
3
|
var info = gen[key](arg);
|
|
@@ -35,96 +27,6 @@ function _asyncToGenerator(fn) {
|
|
|
35
27
|
});
|
|
36
28
|
};
|
|
37
29
|
}
|
|
38
|
-
function _defineProperty(obj, key, value) {
|
|
39
|
-
if (key in obj) {
|
|
40
|
-
Object.defineProperty(obj, key, {
|
|
41
|
-
value: value,
|
|
42
|
-
enumerable: true,
|
|
43
|
-
configurable: true,
|
|
44
|
-
writable: true
|
|
45
|
-
});
|
|
46
|
-
} else {
|
|
47
|
-
obj[key] = value;
|
|
48
|
-
}
|
|
49
|
-
return obj;
|
|
50
|
-
}
|
|
51
|
-
function _iterableToArrayLimit(arr, i) {
|
|
52
|
-
var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
|
|
53
|
-
if (_i == null) return;
|
|
54
|
-
var _arr = [];
|
|
55
|
-
var _n = true;
|
|
56
|
-
var _d = false;
|
|
57
|
-
var _s, _e;
|
|
58
|
-
try {
|
|
59
|
-
for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
|
|
60
|
-
_arr.push(_s.value);
|
|
61
|
-
if (i && _arr.length === i) break;
|
|
62
|
-
}
|
|
63
|
-
} catch (err) {
|
|
64
|
-
_d = true;
|
|
65
|
-
_e = err;
|
|
66
|
-
} finally{
|
|
67
|
-
try {
|
|
68
|
-
if (!_n && _i["return"] != null) _i["return"]();
|
|
69
|
-
} finally{
|
|
70
|
-
if (_d) throw _e;
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
return _arr;
|
|
74
|
-
}
|
|
75
|
-
function _nonIterableRest() {
|
|
76
|
-
throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
77
|
-
}
|
|
78
|
-
function _objectSpread(target) {
|
|
79
|
-
for(var i = 1; i < arguments.length; i++){
|
|
80
|
-
var source = arguments[i] != null ? arguments[i] : {};
|
|
81
|
-
var ownKeys = Object.keys(source);
|
|
82
|
-
if (typeof Object.getOwnPropertySymbols === "function") {
|
|
83
|
-
ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
|
|
84
|
-
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
|
|
85
|
-
}));
|
|
86
|
-
}
|
|
87
|
-
ownKeys.forEach(function(key) {
|
|
88
|
-
_defineProperty(target, key, source[key]);
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
return target;
|
|
92
|
-
}
|
|
93
|
-
function ownKeys(object, enumerableOnly) {
|
|
94
|
-
var keys = Object.keys(object);
|
|
95
|
-
if (Object.getOwnPropertySymbols) {
|
|
96
|
-
var symbols = Object.getOwnPropertySymbols(object);
|
|
97
|
-
if (enumerableOnly) {
|
|
98
|
-
symbols = symbols.filter(function(sym) {
|
|
99
|
-
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
|
|
100
|
-
});
|
|
101
|
-
}
|
|
102
|
-
keys.push.apply(keys, symbols);
|
|
103
|
-
}
|
|
104
|
-
return keys;
|
|
105
|
-
}
|
|
106
|
-
function _objectSpreadProps(target, source) {
|
|
107
|
-
source = source != null ? source : {};
|
|
108
|
-
if (Object.getOwnPropertyDescriptors) {
|
|
109
|
-
Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
|
|
110
|
-
} else {
|
|
111
|
-
ownKeys(Object(source)).forEach(function(key) {
|
|
112
|
-
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
|
|
113
|
-
});
|
|
114
|
-
}
|
|
115
|
-
return target;
|
|
116
|
-
}
|
|
117
|
-
function _slicedToArray(arr, i) {
|
|
118
|
-
return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();
|
|
119
|
-
}
|
|
120
|
-
function _unsupportedIterableToArray(o, minLen) {
|
|
121
|
-
if (!o) return;
|
|
122
|
-
if (typeof o === "string") return _arrayLikeToArray(o, minLen);
|
|
123
|
-
var n = Object.prototype.toString.call(o).slice(8, -1);
|
|
124
|
-
if (n === "Object" && o.constructor) n = o.constructor.name;
|
|
125
|
-
if (n === "Map" || n === "Set") return Array.from(n);
|
|
126
|
-
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
|
|
127
|
-
}
|
|
128
30
|
var __generator = this && this.__generator || function(thisArg, body) {
|
|
129
31
|
var f, y, t, g, _ = {
|
|
130
32
|
label: 0,
|
|
@@ -221,332 +123,9 @@ var __generator = this && this.__generator || function(thisArg, body) {
|
|
|
221
123
|
}
|
|
222
124
|
};
|
|
223
125
|
import path from "path";
|
|
224
|
-
import
|
|
225
|
-
import { matchRoutes } from "react-router-dom";
|
|
126
|
+
import fs from "fs";
|
|
226
127
|
import { MAIN_ENTRY_NAME, SERVER_BUNDLE_DIRECTORY } from "@modern-js/utils";
|
|
227
|
-
import {
|
|
228
|
-
installGlobals();
|
|
229
|
-
var redirectStatusCodes = /* @__PURE__ */ new Set([
|
|
230
|
-
301,
|
|
231
|
-
302,
|
|
232
|
-
303,
|
|
233
|
-
307,
|
|
234
|
-
308
|
|
235
|
-
]);
|
|
236
|
-
function isRedirectResponse(response) {
|
|
237
|
-
return redirectStatusCodes.has(response.status);
|
|
238
|
-
}
|
|
239
|
-
function isResponse(value) {
|
|
240
|
-
return value != null && typeof value.status === "number" && typeof value.statusText === "string" && typeof value.headers === "object" && typeof value.body !== "undefined";
|
|
241
|
-
}
|
|
242
|
-
var json = function(data) {
|
|
243
|
-
var init = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
|
|
244
|
-
var responseInit = typeof init === "number" ? {
|
|
245
|
-
status: init
|
|
246
|
-
} : init;
|
|
247
|
-
var headers = new Headers(responseInit.headers);
|
|
248
|
-
if (!headers.has("Content-Type")) {
|
|
249
|
-
headers.set("Content-Type", "application/json; charset=utf-8");
|
|
250
|
-
}
|
|
251
|
-
return new NodeResponse(JSON.stringify(data), _objectSpreadProps(_objectSpread({}, responseInit), {
|
|
252
|
-
headers: headers
|
|
253
|
-
}));
|
|
254
|
-
};
|
|
255
|
-
var callRouteLoader = function() {
|
|
256
|
-
var _ref = _asyncToGenerator(function(param) {
|
|
257
|
-
var routeId, loader, params, request, // eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
258
|
-
loadContext, result, error;
|
|
259
|
-
return __generator(this, function(_state) {
|
|
260
|
-
switch(_state.label){
|
|
261
|
-
case 0:
|
|
262
|
-
routeId = param.routeId, loader = param.loader, params = param.params, request = param.request, loadContext = param.loadContext;
|
|
263
|
-
if (!loader) {
|
|
264
|
-
throw new Error("You made a ".concat(request.method, " request to ").concat(request.url, ' but did not provide a default component or `loader` for route "').concat(routeId, '", so there is no way to handle the request.'));
|
|
265
|
-
}
|
|
266
|
-
_state.label = 1;
|
|
267
|
-
case 1:
|
|
268
|
-
_state.trys.push([
|
|
269
|
-
1,
|
|
270
|
-
3,
|
|
271
|
-
,
|
|
272
|
-
4
|
|
273
|
-
]);
|
|
274
|
-
return [
|
|
275
|
-
4,
|
|
276
|
-
loader({
|
|
277
|
-
request: request,
|
|
278
|
-
params: params
|
|
279
|
-
})
|
|
280
|
-
];
|
|
281
|
-
case 2:
|
|
282
|
-
result = _state.sent();
|
|
283
|
-
return [
|
|
284
|
-
3,
|
|
285
|
-
4
|
|
286
|
-
];
|
|
287
|
-
case 3:
|
|
288
|
-
error = _state.sent();
|
|
289
|
-
if (!isResponse(error)) {
|
|
290
|
-
throw error;
|
|
291
|
-
}
|
|
292
|
-
result = error;
|
|
293
|
-
return [
|
|
294
|
-
3,
|
|
295
|
-
4
|
|
296
|
-
];
|
|
297
|
-
case 4:
|
|
298
|
-
if (result === void 0) {
|
|
299
|
-
throw new Error('You defined a loader for route "'.concat(routeId, "\" but didn't return anything from your `loader` function. Please return a value or `null`."));
|
|
300
|
-
}
|
|
301
|
-
return [
|
|
302
|
-
2,
|
|
303
|
-
isResponse(result) ? result : json(result)
|
|
304
|
-
];
|
|
305
|
-
}
|
|
306
|
-
});
|
|
307
|
-
});
|
|
308
|
-
return function callRouteLoader(_) {
|
|
309
|
-
return _ref.apply(this, arguments);
|
|
310
|
-
};
|
|
311
|
-
}();
|
|
312
|
-
var createLoaderHeaders = function(requestHeaders) {
|
|
313
|
-
var headers = new Headers();
|
|
314
|
-
var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
|
|
315
|
-
try {
|
|
316
|
-
for(var _iterator = Object.entries(requestHeaders)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
|
|
317
|
-
var _step_value = _slicedToArray(_step.value, 2), key = _step_value[0], values = _step_value[1];
|
|
318
|
-
if (values) {
|
|
319
|
-
if (Array.isArray(values)) {
|
|
320
|
-
var _iteratorNormalCompletion1 = true, _didIteratorError1 = false, _iteratorError1 = undefined;
|
|
321
|
-
try {
|
|
322
|
-
for(var _iterator1 = values[Symbol.iterator](), _step1; !(_iteratorNormalCompletion1 = (_step1 = _iterator1.next()).done); _iteratorNormalCompletion1 = true){
|
|
323
|
-
var value = _step1.value;
|
|
324
|
-
headers.append(key, value);
|
|
325
|
-
}
|
|
326
|
-
} catch (err) {
|
|
327
|
-
_didIteratorError1 = true;
|
|
328
|
-
_iteratorError1 = err;
|
|
329
|
-
} finally{
|
|
330
|
-
try {
|
|
331
|
-
if (!_iteratorNormalCompletion1 && _iterator1.return != null) {
|
|
332
|
-
_iterator1.return();
|
|
333
|
-
}
|
|
334
|
-
} finally{
|
|
335
|
-
if (_didIteratorError1) {
|
|
336
|
-
throw _iteratorError1;
|
|
337
|
-
}
|
|
338
|
-
}
|
|
339
|
-
}
|
|
340
|
-
} else {
|
|
341
|
-
headers.set(key, values);
|
|
342
|
-
}
|
|
343
|
-
}
|
|
344
|
-
}
|
|
345
|
-
} catch (err) {
|
|
346
|
-
_didIteratorError = true;
|
|
347
|
-
_iteratorError = err;
|
|
348
|
-
} finally{
|
|
349
|
-
try {
|
|
350
|
-
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
351
|
-
_iterator.return();
|
|
352
|
-
}
|
|
353
|
-
} finally{
|
|
354
|
-
if (_didIteratorError) {
|
|
355
|
-
throw _iteratorError;
|
|
356
|
-
}
|
|
357
|
-
}
|
|
358
|
-
}
|
|
359
|
-
return headers;
|
|
360
|
-
};
|
|
361
|
-
var createLoaderRequest = function(context) {
|
|
362
|
-
var origin = "".concat(context.protocol, "://").concat(context.host);
|
|
363
|
-
var url = new URL(context.url, origin);
|
|
364
|
-
var controller = new AbortController();
|
|
365
|
-
var init = {
|
|
366
|
-
method: context.method,
|
|
367
|
-
headers: createLoaderHeaders(context.headers),
|
|
368
|
-
signal: controller.signal
|
|
369
|
-
};
|
|
370
|
-
return new Request(url.href, init);
|
|
371
|
-
};
|
|
372
|
-
var sendLoaderResponse = function() {
|
|
373
|
-
var _ref = _asyncToGenerator(function(res, nodeResponse) {
|
|
374
|
-
var _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, _step_value, key, value;
|
|
375
|
-
return __generator(this, function(_state) {
|
|
376
|
-
switch(_state.label){
|
|
377
|
-
case 0:
|
|
378
|
-
res.statusMessage = nodeResponse.statusText;
|
|
379
|
-
res.statusCode = nodeResponse.status;
|
|
380
|
-
_iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
|
|
381
|
-
try {
|
|
382
|
-
for(_iterator = nodeResponse.headers.entries()[Symbol.iterator](); !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
|
|
383
|
-
_step_value = _slicedToArray(_step.value, 2), key = _step_value[0], value = _step_value[1];
|
|
384
|
-
res.setHeader(key, value);
|
|
385
|
-
}
|
|
386
|
-
} catch (err) {
|
|
387
|
-
_didIteratorError = true;
|
|
388
|
-
_iteratorError = err;
|
|
389
|
-
} finally{
|
|
390
|
-
try {
|
|
391
|
-
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
392
|
-
_iterator.return();
|
|
393
|
-
}
|
|
394
|
-
} finally{
|
|
395
|
-
if (_didIteratorError) {
|
|
396
|
-
throw _iteratorError;
|
|
397
|
-
}
|
|
398
|
-
}
|
|
399
|
-
}
|
|
400
|
-
if (!nodeResponse.body) return [
|
|
401
|
-
3,
|
|
402
|
-
2
|
|
403
|
-
];
|
|
404
|
-
return [
|
|
405
|
-
4,
|
|
406
|
-
writeReadableStreamToWritable(nodeResponse.body, res)
|
|
407
|
-
];
|
|
408
|
-
case 1:
|
|
409
|
-
_state.sent();
|
|
410
|
-
return [
|
|
411
|
-
3,
|
|
412
|
-
3
|
|
413
|
-
];
|
|
414
|
-
case 2:
|
|
415
|
-
res.end();
|
|
416
|
-
_state.label = 3;
|
|
417
|
-
case 3:
|
|
418
|
-
return [
|
|
419
|
-
2
|
|
420
|
-
];
|
|
421
|
-
}
|
|
422
|
-
});
|
|
423
|
-
});
|
|
424
|
-
return function sendLoaderResponse(res, nodeResponse) {
|
|
425
|
-
return _ref.apply(this, arguments);
|
|
426
|
-
};
|
|
427
|
-
}();
|
|
428
|
-
var getPathWithoutEntry = function(pathname, entryPath) {
|
|
429
|
-
if (entryPath === "/") {
|
|
430
|
-
return pathname;
|
|
431
|
-
}
|
|
432
|
-
return pathname.replace(entryPath, "");
|
|
433
|
-
};
|
|
434
|
-
var matchEntry = function(pathname, entries) {
|
|
435
|
-
return entries.find(function(entry) {
|
|
436
|
-
return pathname.startsWith(entry.urlPath);
|
|
437
|
-
});
|
|
438
|
-
};
|
|
439
|
-
var handleRequest = function() {
|
|
440
|
-
var _ref = _asyncToGenerator(function(param) {
|
|
441
|
-
var context, serverRoutes, distDir, method, query, routeId, entry, routesPath, routes, res, pathname, matches, match, request, response, headers, error, message;
|
|
442
|
-
return __generator(this, function(_state) {
|
|
443
|
-
switch(_state.label){
|
|
444
|
-
case 0:
|
|
445
|
-
context = param.context, serverRoutes = param.serverRoutes, distDir = param.distDir;
|
|
446
|
-
method = context.method, query = context.query;
|
|
447
|
-
routeId = query[LOADER_ID_PARAM];
|
|
448
|
-
if (!routeId || method.toLowerCase() !== "get") {
|
|
449
|
-
return [
|
|
450
|
-
2
|
|
451
|
-
];
|
|
452
|
-
}
|
|
453
|
-
entry = matchEntry(context.path, serverRoutes);
|
|
454
|
-
if (!entry) {
|
|
455
|
-
return [
|
|
456
|
-
2
|
|
457
|
-
];
|
|
458
|
-
}
|
|
459
|
-
routesPath = path.join(distDir, SERVER_BUNDLE_DIRECTORY, "".concat(entry.entryName || MAIN_ENTRY_NAME, "-server-loaders"));
|
|
460
|
-
return [
|
|
461
|
-
4,
|
|
462
|
-
import(routesPath)
|
|
463
|
-
];
|
|
464
|
-
case 1:
|
|
465
|
-
routes = _state.sent().routes;
|
|
466
|
-
if (!routes) {
|
|
467
|
-
return [
|
|
468
|
-
2
|
|
469
|
-
];
|
|
470
|
-
}
|
|
471
|
-
res = context.res;
|
|
472
|
-
pathname = getPathWithoutEntry(context.path, entry.urlPath);
|
|
473
|
-
matches = matchRoutes(routes, pathname);
|
|
474
|
-
if (!matches) {
|
|
475
|
-
res.statusCode = 403;
|
|
476
|
-
res.end("Route ".concat(pathname, " was not matched"));
|
|
477
|
-
return [
|
|
478
|
-
2
|
|
479
|
-
];
|
|
480
|
-
}
|
|
481
|
-
match = matches === null || matches === void 0 ? void 0 : matches.find(function(match2) {
|
|
482
|
-
return match2.route.id === routeId;
|
|
483
|
-
});
|
|
484
|
-
if (!match) {
|
|
485
|
-
res.statusCode = 403;
|
|
486
|
-
res.end("Route ".concat(routeId, " does not match URL ").concat(context.path));
|
|
487
|
-
return [
|
|
488
|
-
2
|
|
489
|
-
];
|
|
490
|
-
}
|
|
491
|
-
request = createLoaderRequest(context);
|
|
492
|
-
_state.label = 2;
|
|
493
|
-
case 2:
|
|
494
|
-
_state.trys.push([
|
|
495
|
-
2,
|
|
496
|
-
4,
|
|
497
|
-
,
|
|
498
|
-
5
|
|
499
|
-
]);
|
|
500
|
-
return [
|
|
501
|
-
4,
|
|
502
|
-
callRouteLoader({
|
|
503
|
-
loader: match.route.loader,
|
|
504
|
-
routeId: match.route.id,
|
|
505
|
-
params: match.params,
|
|
506
|
-
request: request,
|
|
507
|
-
loadContext: {}
|
|
508
|
-
})
|
|
509
|
-
];
|
|
510
|
-
case 3:
|
|
511
|
-
response = _state.sent();
|
|
512
|
-
if (isRedirectResponse(response)) {
|
|
513
|
-
headers = new Headers(response.headers);
|
|
514
|
-
headers.set("X-Modernjs-Redirect", headers.get("Location"));
|
|
515
|
-
headers.delete("Location");
|
|
516
|
-
response = new NodeResponse(null, {
|
|
517
|
-
status: 204,
|
|
518
|
-
headers: headers
|
|
519
|
-
});
|
|
520
|
-
}
|
|
521
|
-
return [
|
|
522
|
-
3,
|
|
523
|
-
5
|
|
524
|
-
];
|
|
525
|
-
case 4:
|
|
526
|
-
error = _state.sent();
|
|
527
|
-
message = String(error);
|
|
528
|
-
response = new NodeResponse(message, {
|
|
529
|
-
status: 500,
|
|
530
|
-
headers: {
|
|
531
|
-
"Content-Type": "text/plain"
|
|
532
|
-
}
|
|
533
|
-
});
|
|
534
|
-
return [
|
|
535
|
-
3,
|
|
536
|
-
5
|
|
537
|
-
];
|
|
538
|
-
case 5:
|
|
539
|
-
sendLoaderResponse(res, response);
|
|
540
|
-
return [
|
|
541
|
-
2
|
|
542
|
-
];
|
|
543
|
-
}
|
|
544
|
-
});
|
|
545
|
-
});
|
|
546
|
-
return function handleRequest(_) {
|
|
547
|
-
return _ref.apply(this, arguments);
|
|
548
|
-
};
|
|
549
|
-
}();
|
|
128
|
+
import { matchEntry } from "../runtime";
|
|
550
129
|
var server_default = function() {
|
|
551
130
|
return {
|
|
552
131
|
name: "@modern-js/plugin-data-loader",
|
|
@@ -556,15 +135,42 @@ var server_default = function() {
|
|
|
556
135
|
var serverRoutes = param.serverRoutes, distDir = param.distDir;
|
|
557
136
|
return function() {
|
|
558
137
|
var _ref = _asyncToGenerator(function(context) {
|
|
138
|
+
var entry, routesPath, _ref, routes, handleRequest;
|
|
559
139
|
return __generator(this, function(_state) {
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
140
|
+
switch(_state.label){
|
|
141
|
+
case 0:
|
|
142
|
+
entry = matchEntry(context.path, serverRoutes);
|
|
143
|
+
if (!entry) {
|
|
144
|
+
return [
|
|
145
|
+
2
|
|
146
|
+
];
|
|
147
|
+
}
|
|
148
|
+
routesPath = path.join(distDir, SERVER_BUNDLE_DIRECTORY, "".concat(entry.entryName || MAIN_ENTRY_NAME, "-server-loaders.js"));
|
|
149
|
+
if (!fs.existsSync(routesPath)) {
|
|
150
|
+
return [
|
|
151
|
+
2
|
|
152
|
+
];
|
|
153
|
+
}
|
|
154
|
+
return [
|
|
155
|
+
4,
|
|
156
|
+
import(routesPath)
|
|
157
|
+
];
|
|
158
|
+
case 1:
|
|
159
|
+
_ref = _state.sent(), routes = _ref.routes, handleRequest = _ref.handleRequest;
|
|
160
|
+
if (!routes) {
|
|
161
|
+
return [
|
|
162
|
+
2
|
|
163
|
+
];
|
|
164
|
+
}
|
|
165
|
+
return [
|
|
166
|
+
2,
|
|
167
|
+
handleRequest({
|
|
168
|
+
serverRoutes: serverRoutes,
|
|
169
|
+
context: context,
|
|
170
|
+
routes: routes
|
|
171
|
+
})
|
|
172
|
+
];
|
|
173
|
+
}
|
|
568
174
|
});
|
|
569
175
|
});
|
|
570
176
|
return function(context) {
|
|
@@ -576,4 +182,4 @@ var server_default = function() {
|
|
|
576
182
|
}
|
|
577
183
|
};
|
|
578
184
|
};
|
|
579
|
-
export { server_default as default
|
|
185
|
+
export { server_default as default };
|
|
@@ -1,6 +1,11 @@
|
|
|
1
1
|
import { compile } from "path-to-regexp";
|
|
2
2
|
import { redirect } from "react-router-dom";
|
|
3
|
-
import {
|
|
3
|
+
import {
|
|
4
|
+
LOADER_ID_PARAM,
|
|
5
|
+
DIRECT_PARAM,
|
|
6
|
+
CONTENT_TYPE_DEFERRED
|
|
7
|
+
} from "../common/constants";
|
|
8
|
+
import { parseDeferredReadableStream } from "./data";
|
|
4
9
|
const getRequestUrl = ({
|
|
5
10
|
params,
|
|
6
11
|
request,
|
|
@@ -20,7 +25,14 @@ const handleRedirectResponse = (res) => {
|
|
|
20
25
|
const { headers } = res;
|
|
21
26
|
const location = headers.get("X-Modernjs-Redirect");
|
|
22
27
|
if (location) {
|
|
23
|
-
|
|
28
|
+
throw redirect(location);
|
|
29
|
+
}
|
|
30
|
+
return res;
|
|
31
|
+
};
|
|
32
|
+
const handleDeferredResponse = async (res) => {
|
|
33
|
+
var _a;
|
|
34
|
+
if (((_a = res.headers.get("Content-Type")) == null ? void 0 : _a.match(CONTENT_TYPE_DEFERRED)) && res.body) {
|
|
35
|
+
return await parseDeferredReadableStream(res.body);
|
|
24
36
|
}
|
|
25
37
|
return res;
|
|
26
38
|
};
|
|
@@ -30,14 +42,17 @@ const createRequest = (routeId, method = "get") => {
|
|
|
30
42
|
request
|
|
31
43
|
}) => {
|
|
32
44
|
const url = getRequestUrl({ params, request, routeId });
|
|
33
|
-
|
|
45
|
+
let res;
|
|
46
|
+
res = await fetch(url, {
|
|
34
47
|
method,
|
|
35
48
|
signal: request.signal
|
|
36
49
|
});
|
|
37
50
|
if (!res.ok) {
|
|
38
51
|
throw res;
|
|
39
52
|
}
|
|
40
|
-
|
|
53
|
+
res = handleRedirectResponse(res);
|
|
54
|
+
res = await handleDeferredResponse(res);
|
|
55
|
+
return res;
|
|
41
56
|
};
|
|
42
57
|
};
|
|
43
58
|
export {
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import {
|
|
2
|
+
UNSAFE_DeferredData as DeferredData,
|
|
3
|
+
AbortedDeferredError
|
|
4
|
+
} from "@modern-js/utils/remix-router";
|
|
5
|
+
const DEFERRED_VALUE_PLACEHOLDER_PREFIX = "__deferred_promise:";
|
|
6
|
+
async function parseDeferredReadableStream(stream) {
|
|
7
|
+
if (!stream) {
|
|
8
|
+
throw new Error("parseDeferredReadableStream requires stream argument");
|
|
9
|
+
}
|
|
10
|
+
let deferredData;
|
|
11
|
+
const deferredResolvers = {};
|
|
12
|
+
try {
|
|
13
|
+
const sectionReader = readStreamSections(stream);
|
|
14
|
+
const initialSectionResult = await sectionReader.next();
|
|
15
|
+
const initialSection = initialSectionResult.value;
|
|
16
|
+
if (!initialSection) {
|
|
17
|
+
throw new Error("no critical data");
|
|
18
|
+
}
|
|
19
|
+
const criticalData = JSON.parse(initialSection);
|
|
20
|
+
if (typeof criticalData === "object" && criticalData !== null) {
|
|
21
|
+
for (const [eventKey, value] of Object.entries(criticalData)) {
|
|
22
|
+
if (typeof value !== "string" || !value.startsWith(DEFERRED_VALUE_PLACEHOLDER_PREFIX)) {
|
|
23
|
+
continue;
|
|
24
|
+
}
|
|
25
|
+
deferredData = deferredData || {};
|
|
26
|
+
deferredData[eventKey] = new Promise((resolve, reject) => {
|
|
27
|
+
deferredResolvers[eventKey] = {
|
|
28
|
+
resolve: (value2) => {
|
|
29
|
+
resolve(value2);
|
|
30
|
+
delete deferredResolvers[eventKey];
|
|
31
|
+
},
|
|
32
|
+
reject: (error) => {
|
|
33
|
+
reject(error);
|
|
34
|
+
delete deferredResolvers[eventKey];
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
(async () => {
|
|
41
|
+
try {
|
|
42
|
+
for await (const section of sectionReader) {
|
|
43
|
+
const [event, ...sectionDataStrings] = section.split(":");
|
|
44
|
+
const sectionDataString = sectionDataStrings.join(":");
|
|
45
|
+
const data = JSON.parse(sectionDataString);
|
|
46
|
+
if (event === "data") {
|
|
47
|
+
for (const [key, value] of Object.entries(data)) {
|
|
48
|
+
if (deferredResolvers[key]) {
|
|
49
|
+
deferredResolvers[key].resolve(value);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
} else if (event === "error") {
|
|
53
|
+
for (const [key, value] of Object.entries(data)) {
|
|
54
|
+
const err = new Error(value.message);
|
|
55
|
+
err.stack = value.stack;
|
|
56
|
+
if (deferredResolvers[key]) {
|
|
57
|
+
deferredResolvers[key].reject(err);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
for (const [key, resolver] of Object.entries(deferredResolvers)) {
|
|
63
|
+
resolver.reject(
|
|
64
|
+
new AbortedDeferredError(`Deferred ${key} will never resolved`)
|
|
65
|
+
);
|
|
66
|
+
}
|
|
67
|
+
} catch (error) {
|
|
68
|
+
for (const resolver of Object.values(deferredResolvers)) {
|
|
69
|
+
resolver.reject(error);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
})();
|
|
73
|
+
return new DeferredData({ ...criticalData, ...deferredData });
|
|
74
|
+
} catch (error) {
|
|
75
|
+
for (const resolver of Object.values(deferredResolvers)) {
|
|
76
|
+
resolver.reject(error);
|
|
77
|
+
}
|
|
78
|
+
throw error;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
async function* readStreamSections(stream) {
|
|
82
|
+
const reader = stream.getReader();
|
|
83
|
+
let buffer = [];
|
|
84
|
+
let sections = [];
|
|
85
|
+
let closed = false;
|
|
86
|
+
const encoder = new TextEncoder();
|
|
87
|
+
const decoder = new TextDecoder();
|
|
88
|
+
const readStreamSection = async () => {
|
|
89
|
+
if (sections.length > 0) {
|
|
90
|
+
return sections.shift();
|
|
91
|
+
}
|
|
92
|
+
while (!closed && sections.length === 0) {
|
|
93
|
+
const chunk = await reader.read();
|
|
94
|
+
if (chunk.done) {
|
|
95
|
+
closed = true;
|
|
96
|
+
break;
|
|
97
|
+
}
|
|
98
|
+
buffer.push(chunk.value);
|
|
99
|
+
try {
|
|
100
|
+
const bufferedString = decoder.decode(mergeArrays(...buffer));
|
|
101
|
+
const splitSections = bufferedString.split("\n\n");
|
|
102
|
+
if (splitSections.length >= 2) {
|
|
103
|
+
sections.push(...splitSections.slice(0, -1));
|
|
104
|
+
buffer = [encoder.encode(splitSections.slice(-1).join("\n\n"))];
|
|
105
|
+
}
|
|
106
|
+
if (sections.length > 0) {
|
|
107
|
+
break;
|
|
108
|
+
}
|
|
109
|
+
} catch {
|
|
110
|
+
continue;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
if (sections.length > 0) {
|
|
114
|
+
return sections.shift();
|
|
115
|
+
}
|
|
116
|
+
if (buffer.length > 0) {
|
|
117
|
+
const bufferedString = decoder.decode(mergeArrays(...buffer));
|
|
118
|
+
sections = bufferedString.split("\n\n").filter((s) => s);
|
|
119
|
+
buffer = [];
|
|
120
|
+
}
|
|
121
|
+
return sections.shift();
|
|
122
|
+
};
|
|
123
|
+
let section = await readStreamSection();
|
|
124
|
+
while (section) {
|
|
125
|
+
yield section;
|
|
126
|
+
section = await readStreamSection();
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
function mergeArrays(...arrays) {
|
|
130
|
+
const out = new Uint8Array(
|
|
131
|
+
arrays.reduce((total, arr) => total + arr.length, 0)
|
|
132
|
+
);
|
|
133
|
+
let offset = 0;
|
|
134
|
+
for (const arr of arrays) {
|
|
135
|
+
out.set(arr, offset);
|
|
136
|
+
offset += arr.length;
|
|
137
|
+
}
|
|
138
|
+
return out;
|
|
139
|
+
}
|
|
140
|
+
export {
|
|
141
|
+
parseDeferredReadableStream
|
|
142
|
+
};
|
|
@@ -7,7 +7,7 @@ const generateClient = ({
|
|
|
7
7
|
const loadersMap = require(mapFile);
|
|
8
8
|
let requestCode = ``;
|
|
9
9
|
let exportsCode = ``;
|
|
10
|
-
const requestCreatorPath = path.join(__dirname, "./
|
|
10
|
+
const requestCreatorPath = path.join(__dirname, "./createRequest").replace("/cjs/cli/", "/esm/cli/").replace(/\\/g, "/");
|
|
11
11
|
const importCode = `
|
|
12
12
|
import { createRequest } from '${requestCreatorPath}';
|
|
13
13
|
`;
|