@modern-js/plugin-data-loader 2.6.1-alpha.0 → 2.8.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.
Files changed (48) hide show
  1. package/CHANGELOG.md +11 -0
  2. package/README.md +2 -2
  3. package/dist/cjs/cli/{create-request.js → createRequest.js} +17 -6
  4. package/dist/cjs/cli/data.js +162 -0
  5. package/dist/cjs/cli/{generate-client.js → generateClient.js} +4 -4
  6. package/dist/cjs/cli/loader.js +2 -2
  7. package/dist/cjs/common/constants.js +3 -0
  8. package/dist/cjs/runtime/index.js +180 -0
  9. package/dist/cjs/runtime/response.js +102 -0
  10. package/dist/cjs/server/index.js +22 -196
  11. package/dist/esm/cli/{create-request.js → createRequest.js} +42 -3
  12. package/dist/esm/cli/data.js +820 -0
  13. package/dist/esm/cli/{generate-client.js → generateClient.js} +1 -1
  14. package/dist/esm/cli/loader.js +1 -1
  15. package/dist/esm/common/constants.js +2 -1
  16. package/dist/{js/treeshaking/server → esm/runtime}/index.js +84 -220
  17. package/dist/esm/runtime/response.js +284 -0
  18. package/dist/esm/server/index.js +38 -447
  19. package/dist/esm-node/cli/{create-request.js → createRequest.js} +19 -4
  20. package/dist/esm-node/cli/data.js +142 -0
  21. package/dist/esm-node/cli/{generate-client.js → generateClient.js} +1 -1
  22. package/dist/esm-node/cli/loader.js +1 -1
  23. package/dist/esm-node/common/constants.js +2 -0
  24. package/dist/esm-node/runtime/index.js +162 -0
  25. package/dist/esm-node/runtime/response.js +79 -0
  26. package/dist/esm-node/server/index.js +21 -196
  27. package/dist/types/cli/{create-request.d.ts → createRequest.d.ts} +2 -1
  28. package/dist/types/cli/data.d.ts +6 -0
  29. package/dist/types/common/constants.d.ts +2 -1
  30. package/dist/types/runtime/index.d.ts +15 -0
  31. package/dist/types/runtime/response.d.ts +2 -0
  32. package/dist/types/server/index.d.ts +0 -15
  33. package/package.json +22 -12
  34. package/dist/js/modern/cli/create-request.js +0 -66
  35. package/dist/js/modern/cli/generate-client.js +0 -42
  36. package/dist/js/modern/cli/loader.js +0 -40
  37. package/dist/js/modern/common/constants.js +0 -6
  38. package/dist/js/modern/server/index.js +0 -237
  39. package/dist/js/node/cli/create-request.js +0 -90
  40. package/dist/js/node/cli/generate-client.js +0 -71
  41. package/dist/js/node/cli/loader.js +0 -61
  42. package/dist/js/node/common/constants.js +0 -30
  43. package/dist/js/node/server/index.js +0 -261
  44. package/dist/js/treeshaking/cli/create-request.js +0 -186
  45. package/dist/js/treeshaking/cli/generate-client.js +0 -45
  46. package/dist/js/treeshaking/cli/loader.js +0 -154
  47. package/dist/js/treeshaking/common/constants.js +0 -3
  48. /package/dist/types/cli/{generate-client.d.ts → generateClient.d.ts} +0 -0
@@ -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,347 +123,9 @@ var __generator = this && this.__generator || function(thisArg, body) {
221
123
  }
222
124
  };
223
125
  import path from "path";
224
- import { installGlobals, writeReadableStreamToWritable, Response as NodeResponse } from "@remix-run/node";
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 { LOADER_ID_PARAM } from "../common/constants";
228
- installGlobals();
229
- var redirectStatusCodes = /* @__PURE__ */ new Set([
230
- 301,
231
- 302,
232
- 303,
233
- 307,
234
- 308
235
- ]);
236
- function sortByUrlPath(entries) {
237
- entries.sort(function(a, b) {
238
- var length1 = a.urlPath.length;
239
- var length2 = b.urlPath.length;
240
- if (length1 < length2) {
241
- return 1;
242
- }
243
- if (length1 > length2) {
244
- return -1;
245
- }
246
- return 0;
247
- });
248
- return entries;
249
- }
250
- function isRedirectResponse(response) {
251
- return redirectStatusCodes.has(response.status);
252
- }
253
- function isResponse(value) {
254
- return value != null && typeof value.status === "number" && typeof value.statusText === "string" && typeof value.headers === "object" && typeof value.body !== "undefined";
255
- }
256
- var json = function(data) {
257
- var init = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
258
- var responseInit = typeof init === "number" ? {
259
- status: init
260
- } : init;
261
- var headers = new Headers(responseInit.headers);
262
- if (!headers.has("Content-Type")) {
263
- headers.set("Content-Type", "application/json; charset=utf-8");
264
- }
265
- return new NodeResponse(JSON.stringify(data), _objectSpreadProps(_objectSpread({}, responseInit), {
266
- headers: headers
267
- }));
268
- };
269
- var callRouteLoader = function() {
270
- var _ref = _asyncToGenerator(function(param) {
271
- var routeId, loader, params, request, // eslint-disable-next-line @typescript-eslint/no-unused-vars
272
- loadContext, result, error;
273
- return __generator(this, function(_state) {
274
- switch(_state.label){
275
- case 0:
276
- routeId = param.routeId, loader = param.loader, params = param.params, request = param.request, loadContext = param.loadContext;
277
- if (!loader) {
278
- 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.'));
279
- }
280
- _state.label = 1;
281
- case 1:
282
- _state.trys.push([
283
- 1,
284
- 3,
285
- ,
286
- 4
287
- ]);
288
- return [
289
- 4,
290
- loader({
291
- request: request,
292
- params: params
293
- })
294
- ];
295
- case 2:
296
- result = _state.sent();
297
- return [
298
- 3,
299
- 4
300
- ];
301
- case 3:
302
- error = _state.sent();
303
- if (!isResponse(error)) {
304
- throw error;
305
- }
306
- result = error;
307
- return [
308
- 3,
309
- 4
310
- ];
311
- case 4:
312
- if (result === void 0) {
313
- 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`."));
314
- }
315
- return [
316
- 2,
317
- isResponse(result) ? result : json(result)
318
- ];
319
- }
320
- });
321
- });
322
- return function callRouteLoader(_) {
323
- return _ref.apply(this, arguments);
324
- };
325
- }();
326
- var createLoaderHeaders = function(requestHeaders) {
327
- var headers = new Headers();
328
- var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
329
- try {
330
- for(var _iterator = Object.entries(requestHeaders)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
331
- var _step_value = _slicedToArray(_step.value, 2), key = _step_value[0], values = _step_value[1];
332
- if (values) {
333
- if (Array.isArray(values)) {
334
- var _iteratorNormalCompletion1 = true, _didIteratorError1 = false, _iteratorError1 = undefined;
335
- try {
336
- for(var _iterator1 = values[Symbol.iterator](), _step1; !(_iteratorNormalCompletion1 = (_step1 = _iterator1.next()).done); _iteratorNormalCompletion1 = true){
337
- var value = _step1.value;
338
- headers.append(key, value);
339
- }
340
- } catch (err) {
341
- _didIteratorError1 = true;
342
- _iteratorError1 = err;
343
- } finally{
344
- try {
345
- if (!_iteratorNormalCompletion1 && _iterator1.return != null) {
346
- _iterator1.return();
347
- }
348
- } finally{
349
- if (_didIteratorError1) {
350
- throw _iteratorError1;
351
- }
352
- }
353
- }
354
- } else {
355
- headers.set(key, values);
356
- }
357
- }
358
- }
359
- } catch (err) {
360
- _didIteratorError = true;
361
- _iteratorError = err;
362
- } finally{
363
- try {
364
- if (!_iteratorNormalCompletion && _iterator.return != null) {
365
- _iterator.return();
366
- }
367
- } finally{
368
- if (_didIteratorError) {
369
- throw _iteratorError;
370
- }
371
- }
372
- }
373
- return headers;
374
- };
375
- var createLoaderRequest = function(context) {
376
- var origin = "".concat(context.protocol, "://").concat(context.host);
377
- var url = new URL(context.url, origin);
378
- var controller = new AbortController();
379
- var init = {
380
- method: context.method,
381
- headers: createLoaderHeaders(context.headers),
382
- signal: controller.signal
383
- };
384
- return new Request(url.href, init);
385
- };
386
- var sendLoaderResponse = function() {
387
- var _ref = _asyncToGenerator(function(res, nodeResponse) {
388
- var _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, _step_value, key, value;
389
- return __generator(this, function(_state) {
390
- switch(_state.label){
391
- case 0:
392
- res.statusMessage = nodeResponse.statusText;
393
- res.statusCode = nodeResponse.status;
394
- _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
395
- try {
396
- for(_iterator = nodeResponse.headers.entries()[Symbol.iterator](); !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
397
- _step_value = _slicedToArray(_step.value, 2), key = _step_value[0], value = _step_value[1];
398
- res.setHeader(key, value);
399
- }
400
- } catch (err) {
401
- _didIteratorError = true;
402
- _iteratorError = err;
403
- } finally{
404
- try {
405
- if (!_iteratorNormalCompletion && _iterator.return != null) {
406
- _iterator.return();
407
- }
408
- } finally{
409
- if (_didIteratorError) {
410
- throw _iteratorError;
411
- }
412
- }
413
- }
414
- if (!nodeResponse.body) return [
415
- 3,
416
- 2
417
- ];
418
- return [
419
- 4,
420
- writeReadableStreamToWritable(nodeResponse.body, res)
421
- ];
422
- case 1:
423
- _state.sent();
424
- return [
425
- 3,
426
- 3
427
- ];
428
- case 2:
429
- res.end();
430
- _state.label = 3;
431
- case 3:
432
- return [
433
- 2
434
- ];
435
- }
436
- });
437
- });
438
- return function sendLoaderResponse(res, nodeResponse) {
439
- return _ref.apply(this, arguments);
440
- };
441
- }();
442
- var getPathWithoutEntry = function(pathname, entryPath) {
443
- if (entryPath === "/") {
444
- return pathname;
445
- }
446
- return pathname.replace(entryPath, "");
447
- };
448
- var matchEntry = function(pathname, entries) {
449
- var newEntries = sortByUrlPath(entries);
450
- return newEntries.find(function(entry) {
451
- return pathname.startsWith(entry.urlPath);
452
- });
453
- };
454
- var handleRequest = function() {
455
- var _ref = _asyncToGenerator(function(param) {
456
- var context, serverRoutes, distDir, method, query, routeId, entry, routesPath, routes, res, pathname, matches, match, request, response, headers, error, message;
457
- return __generator(this, function(_state) {
458
- switch(_state.label){
459
- case 0:
460
- context = param.context, serverRoutes = param.serverRoutes, distDir = param.distDir;
461
- method = context.method, query = context.query;
462
- routeId = query[LOADER_ID_PARAM];
463
- if (!routeId || method.toLowerCase() !== "get") {
464
- return [
465
- 2
466
- ];
467
- }
468
- entry = matchEntry(context.path, serverRoutes);
469
- if (!entry) {
470
- return [
471
- 2
472
- ];
473
- }
474
- routesPath = path.join(distDir, SERVER_BUNDLE_DIRECTORY, "".concat(entry.entryName || MAIN_ENTRY_NAME, "-server-loaders"));
475
- return [
476
- 4,
477
- import(routesPath)
478
- ];
479
- case 1:
480
- routes = _state.sent().routes;
481
- if (!routes) {
482
- return [
483
- 2
484
- ];
485
- }
486
- res = context.res;
487
- pathname = getPathWithoutEntry(context.path, entry.urlPath);
488
- matches = matchRoutes(routes, pathname);
489
- if (!matches) {
490
- res.statusCode = 403;
491
- res.end("Route ".concat(pathname, " was not matched"));
492
- return [
493
- 2
494
- ];
495
- }
496
- match = matches === null || matches === void 0 ? void 0 : matches.find(function(match2) {
497
- return match2.route.id === routeId;
498
- });
499
- if (!match) {
500
- res.statusCode = 403;
501
- res.end("Route ".concat(routeId, " does not match URL ").concat(context.path));
502
- return [
503
- 2
504
- ];
505
- }
506
- request = createLoaderRequest(context);
507
- _state.label = 2;
508
- case 2:
509
- _state.trys.push([
510
- 2,
511
- 4,
512
- ,
513
- 5
514
- ]);
515
- return [
516
- 4,
517
- callRouteLoader({
518
- loader: match.route.loader,
519
- routeId: match.route.id,
520
- params: match.params,
521
- request: request,
522
- loadContext: {}
523
- })
524
- ];
525
- case 3:
526
- response = _state.sent();
527
- if (isRedirectResponse(response)) {
528
- headers = new Headers(response.headers);
529
- headers.set("X-Modernjs-Redirect", headers.get("Location"));
530
- headers.delete("Location");
531
- response = new NodeResponse(null, {
532
- status: 204,
533
- headers: headers
534
- });
535
- }
536
- return [
537
- 3,
538
- 5
539
- ];
540
- case 4:
541
- error = _state.sent();
542
- message = String(error);
543
- response = new NodeResponse(message, {
544
- status: 500,
545
- headers: {
546
- "Content-Type": "text/plain"
547
- }
548
- });
549
- return [
550
- 3,
551
- 5
552
- ];
553
- case 5:
554
- sendLoaderResponse(res, response);
555
- return [
556
- 2
557
- ];
558
- }
559
- });
560
- });
561
- return function handleRequest(_) {
562
- return _ref.apply(this, arguments);
563
- };
564
- }();
128
+ import { matchEntry } from "../runtime";
565
129
  var server_default = function() {
566
130
  return {
567
131
  name: "@modern-js/plugin-data-loader",
@@ -571,15 +135,42 @@ var server_default = function() {
571
135
  var serverRoutes = param.serverRoutes, distDir = param.distDir;
572
136
  return function() {
573
137
  var _ref = _asyncToGenerator(function(context) {
138
+ var entry, routesPath, _ref, routes, handleRequest;
574
139
  return __generator(this, function(_state) {
575
- return [
576
- 2,
577
- handleRequest({
578
- serverRoutes: serverRoutes,
579
- distDir: distDir,
580
- context: context
581
- })
582
- ];
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
+ }
583
174
  });
584
175
  });
585
176
  return function(context) {
@@ -591,4 +182,4 @@ var server_default = function() {
591
182
  }
592
183
  };
593
184
  };
594
- export { server_default as default, getPathWithoutEntry, handleRequest, isRedirectResponse, isResponse };
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 { LOADER_ID_PARAM, DIRECT_PARAM } from "../common/constants";
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
- return redirect(location);
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
- const res = await fetch(url, {
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
- return handleRedirectResponse(res);
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
+ };