@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.
Files changed (32) hide show
  1. package/dist/cjs/cli/{create-request.js → createRequest.js} +17 -6
  2. package/dist/cjs/cli/data.js +162 -0
  3. package/dist/cjs/cli/{generate-client.js → generateClient.js} +4 -4
  4. package/dist/cjs/cli/loader.js +2 -2
  5. package/dist/cjs/common/constants.js +3 -0
  6. package/dist/cjs/runtime/index.js +165 -0
  7. package/dist/cjs/runtime/response.js +102 -0
  8. package/dist/cjs/server/index.js +22 -181
  9. package/dist/esm/cli/{create-request.js → createRequest.js} +42 -3
  10. package/dist/esm/cli/data.js +820 -0
  11. package/dist/esm/cli/{generate-client.js → generateClient.js} +1 -1
  12. package/dist/esm/cli/loader.js +1 -1
  13. package/dist/esm/common/constants.js +2 -1
  14. package/dist/esm/runtime/index.js +427 -0
  15. package/dist/esm/runtime/response.js +284 -0
  16. package/dist/esm/server/index.js +38 -432
  17. package/dist/esm-node/cli/{create-request.js → createRequest.js} +19 -4
  18. package/dist/esm-node/cli/data.js +142 -0
  19. package/dist/esm-node/cli/{generate-client.js → generateClient.js} +1 -1
  20. package/dist/esm-node/cli/loader.js +1 -1
  21. package/dist/esm-node/common/constants.js +2 -0
  22. package/dist/esm-node/runtime/index.js +147 -0
  23. package/dist/esm-node/runtime/response.js +79 -0
  24. package/dist/esm-node/server/index.js +21 -181
  25. package/dist/types/cli/{create-request.d.ts → createRequest.d.ts} +2 -1
  26. package/dist/types/cli/data.d.ts +6 -0
  27. package/dist/types/common/constants.d.ts +2 -1
  28. package/dist/types/runtime/index.d.ts +15 -0
  29. package/dist/types/runtime/response.d.ts +2 -0
  30. package/dist/types/server/index.d.ts +0 -15
  31. package/package.json +19 -9
  32. /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,332 +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 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
- return [
561
- 2,
562
- handleRequest({
563
- serverRoutes: serverRoutes,
564
- distDir: distDir,
565
- context: context
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, 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
+ };
@@ -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, "./create-request").replace("/cjs/cli/", "/esm/cli/").replace(/\\/g, "/");
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
  `;