@modern-js/plugin-data-loader 2.69.5 → 3.0.0-alpha.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/createRequest.js +122 -141
- package/dist/cjs/cli/data.js +129 -148
- package/dist/cjs/cli/generateClient.js +52 -52
- package/dist/cjs/cli/loader.js +63 -62
- package/dist/cjs/common/constants.js +41 -31
- package/dist/cjs/runtime/errors.js +84 -89
- package/dist/cjs/runtime/index.js +143 -155
- package/dist/cjs/runtime/response.js +66 -77
- package/dist/esm/cli/createRequest.mjs +93 -0
- package/dist/esm/cli/data.mjs +111 -0
- package/dist/esm/cli/generateClient.mjs +22 -0
- package/dist/esm/cli/loader.mjs +34 -0
- package/dist/esm/common/constants.mjs +4 -0
- package/dist/esm/runtime/errors.mjs +52 -0
- package/dist/esm/runtime/index.mjs +114 -0
- package/dist/esm/runtime/response.mjs +42 -0
- package/dist/esm-node/cli/createRequest.mjs +93 -0
- package/dist/esm-node/cli/data.mjs +111 -0
- package/dist/esm-node/cli/generateClient.mjs +22 -0
- package/dist/esm-node/cli/loader.mjs +34 -0
- package/dist/esm-node/common/constants.mjs +4 -0
- package/dist/esm-node/runtime/errors.mjs +52 -0
- package/dist/esm-node/runtime/index.mjs +114 -0
- package/dist/esm-node/runtime/response.mjs +42 -0
- package/dist/types/cli/createRequest.d.ts +1 -2
- package/dist/types/cli/loader.d.ts +2 -2
- package/dist/types/runtime/errors.d.ts +1 -1
- package/dist/types/runtime/response.d.ts +1 -1
- package/package.json +22 -26
- package/rslib.config.mts +4 -0
- package/rstest.config.ts +18 -0
- package/dist/esm/cli/createRequest.js +0 -297
- package/dist/esm/cli/data.js +0 -491
- package/dist/esm/cli/generateClient.js +0 -21
- package/dist/esm/cli/loader.js +0 -93
- package/dist/esm/common/constants.js +0 -8
- package/dist/esm/runtime/errors.js +0 -90
- package/dist/esm/runtime/index.js +0 -191
- package/dist/esm/runtime/response.js +0 -107
- package/dist/esm-node/cli/createRequest.js +0 -126
- package/dist/esm-node/cli/data.js +0 -140
- package/dist/esm-node/cli/generateClient.js +0 -32
- package/dist/esm-node/cli/loader.js +0 -47
- package/dist/esm-node/common/constants.js +0 -8
- package/dist/esm-node/runtime/errors.js +0 -75
- package/dist/esm-node/runtime/index.js +0 -142
- package/dist/esm-node/runtime/response.js +0 -63
|
@@ -1,152 +1,133 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
var
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
};
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
createActionRequest: ()=>createActionRequest,
|
|
28
|
+
getRequestUrl: ()=>getRequestUrl,
|
|
29
|
+
createRequest: ()=>createRequest
|
|
24
30
|
});
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
const
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
return url;
|
|
40
|
-
};
|
|
41
|
-
const handleRedirectResponse = (res) => {
|
|
42
|
-
const { headers } = res;
|
|
43
|
-
const location = headers.get("X-Modernjs-Redirect");
|
|
44
|
-
if (location) {
|
|
45
|
-
throw (0, import_router.redirect)(location);
|
|
46
|
-
}
|
|
47
|
-
return res;
|
|
48
|
-
};
|
|
49
|
-
const isDeferredResponse = (res) => {
|
|
50
|
-
var _res_headers_get;
|
|
51
|
-
return ((_res_headers_get = res.headers.get("Content-Type")) === null || _res_headers_get === void 0 ? void 0 : _res_headers_get.match(import_constants.CONTENT_TYPE_DEFERRED)) && res.body;
|
|
52
|
-
};
|
|
53
|
-
const isRedirectResponse = (res) => {
|
|
54
|
-
return res.headers.get("X-Modernjs-Redirect") != null;
|
|
31
|
+
const router_namespaceObject = require("@modern-js/runtime-utils/router");
|
|
32
|
+
const external_path_to_regexp_namespaceObject = require("path-to-regexp");
|
|
33
|
+
const constants_js_namespaceObject = require("../common/constants.js");
|
|
34
|
+
const external_data_js_namespaceObject = require("./data.js");
|
|
35
|
+
const getRequestUrl = ({ params, request, routeId })=>{
|
|
36
|
+
const url = new URL(request.url);
|
|
37
|
+
const toPath = (0, external_path_to_regexp_namespaceObject.compile)(url.pathname, {
|
|
38
|
+
encode: encodeURIComponent
|
|
39
|
+
});
|
|
40
|
+
const newPathName = toPath(params);
|
|
41
|
+
url.pathname = newPathName;
|
|
42
|
+
url.searchParams.append(constants_js_namespaceObject.LOADER_ID_PARAM, routeId);
|
|
43
|
+
url.searchParams.append(constants_js_namespaceObject.DIRECT_PARAM, 'true');
|
|
44
|
+
return url;
|
|
55
45
|
};
|
|
56
|
-
const
|
|
57
|
-
|
|
46
|
+
const handleRedirectResponse = (res)=>{
|
|
47
|
+
const { headers } = res;
|
|
48
|
+
const location = headers.get('X-Modernjs-Redirect');
|
|
49
|
+
if (location) throw (0, router_namespaceObject.redirect)(location);
|
|
50
|
+
return res;
|
|
58
51
|
};
|
|
52
|
+
const isDeferredResponse = (res)=>res.headers.get('Content-Type')?.match(constants_js_namespaceObject.CONTENT_TYPE_DEFERRED) && res.body;
|
|
53
|
+
const isRedirectResponse = (res)=>null != res.headers.get('X-Modernjs-Redirect');
|
|
54
|
+
const isErrorResponse = (res)=>null != res.headers.get('X-Modernjs-Error');
|
|
59
55
|
function isOtherErrorResponse(res) {
|
|
60
|
-
|
|
56
|
+
return res.status >= 400 && null == res.headers.get('X-Modernjs-Error') && null == res.headers.get('X-Modernjs-Catch') && null == res.headers.get('X-Modernjs-Response');
|
|
61
57
|
}
|
|
62
|
-
const isCatchResponse = (res)
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
const
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
error.stack = data.stack;
|
|
69
|
-
throw error;
|
|
58
|
+
const isCatchResponse = (res)=>null != res.headers.get('X-Modernjs-Catch');
|
|
59
|
+
const handleErrorResponse = async (res)=>{
|
|
60
|
+
const data = await res.json();
|
|
61
|
+
const error = new Error(data.message);
|
|
62
|
+
error.stack = data.stack;
|
|
63
|
+
throw error;
|
|
70
64
|
};
|
|
71
|
-
const handleNetworkErrorResponse = async (res)
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
65
|
+
const handleNetworkErrorResponse = async (res)=>{
|
|
66
|
+
const text = await res.text();
|
|
67
|
+
const error = new Error(text);
|
|
68
|
+
error.stack = void 0;
|
|
69
|
+
throw error;
|
|
76
70
|
};
|
|
77
|
-
const createRequest = (routeId, method =
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
throw res;
|
|
100
|
-
}
|
|
101
|
-
if (isDeferredResponse(res)) {
|
|
102
|
-
const deferredData = await (0, import_data.parseDeferredReadableStream)(res.body);
|
|
103
|
-
return isRouterV7 ? deferredData.data : deferredData;
|
|
104
|
-
}
|
|
105
|
-
if (isOtherErrorResponse(res)) {
|
|
106
|
-
return await handleNetworkErrorResponse(res);
|
|
107
|
-
}
|
|
108
|
-
return res;
|
|
109
|
-
};
|
|
110
|
-
};
|
|
111
|
-
const createActionRequest = (routeId) => {
|
|
112
|
-
return async ({ params, request }) => {
|
|
113
|
-
const url = getRequestUrl({
|
|
114
|
-
params,
|
|
115
|
-
request,
|
|
116
|
-
routeId
|
|
117
|
-
});
|
|
118
|
-
const init = {
|
|
119
|
-
signal: request.signal
|
|
71
|
+
const createRequest = (routeId, method = 'get')=>async ({ params, request })=>{
|
|
72
|
+
const url = getRequestUrl({
|
|
73
|
+
params,
|
|
74
|
+
request,
|
|
75
|
+
routeId
|
|
76
|
+
});
|
|
77
|
+
let res;
|
|
78
|
+
res = await fetch(url, {
|
|
79
|
+
method,
|
|
80
|
+
signal: request.signal
|
|
81
|
+
}).catch((error)=>{
|
|
82
|
+
throw error;
|
|
83
|
+
});
|
|
84
|
+
if (isRedirectResponse(res)) return handleRedirectResponse(res);
|
|
85
|
+
if (isErrorResponse(res)) return await handleErrorResponse(res);
|
|
86
|
+
if (isCatchResponse(res)) throw res;
|
|
87
|
+
if (isDeferredResponse(res)) {
|
|
88
|
+
const deferredData = await (0, external_data_js_namespaceObject.parseDeferredReadableStream)(res.body);
|
|
89
|
+
return deferredData.data;
|
|
90
|
+
}
|
|
91
|
+
if (isOtherErrorResponse(res)) return await handleNetworkErrorResponse(res);
|
|
92
|
+
return res;
|
|
120
93
|
};
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
94
|
+
const createActionRequest = (routeId)=>async ({ params, request })=>{
|
|
95
|
+
const url = getRequestUrl({
|
|
96
|
+
params,
|
|
97
|
+
request,
|
|
98
|
+
routeId
|
|
99
|
+
});
|
|
100
|
+
const init = {
|
|
101
|
+
signal: request.signal
|
|
127
102
|
};
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
103
|
+
if ('GET' !== request.method) {
|
|
104
|
+
init.method = request.method;
|
|
105
|
+
const contentType = request.headers.get('Content-Type');
|
|
106
|
+
if (contentType && /\bapplication\/json\b/.test(contentType)) {
|
|
107
|
+
init.headers = {
|
|
108
|
+
'Content-Type': contentType
|
|
109
|
+
};
|
|
110
|
+
init.body = JSON.stringify(await request.json());
|
|
111
|
+
} else if (contentType && /\btext\/plain\b/.test(contentType)) {
|
|
112
|
+
init.headers = {
|
|
113
|
+
'Content-Type': contentType
|
|
114
|
+
};
|
|
115
|
+
init.body = await request.text();
|
|
116
|
+
} else if (contentType && /\bapplication\/x-www-form-urlencoded\b/.test(contentType)) init.body = new URLSearchParams(await request.text());
|
|
117
|
+
else init.body = await request.formData();
|
|
118
|
+
}
|
|
119
|
+
const res = await fetch(url, init);
|
|
120
|
+
if (!res.ok) throw res;
|
|
121
|
+
return res;
|
|
122
|
+
};
|
|
123
|
+
exports.createActionRequest = __webpack_exports__.createActionRequest;
|
|
124
|
+
exports.createRequest = __webpack_exports__.createRequest;
|
|
125
|
+
exports.getRequestUrl = __webpack_exports__.getRequestUrl;
|
|
126
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
127
|
+
"createActionRequest",
|
|
128
|
+
"createRequest",
|
|
129
|
+
"getRequestUrl"
|
|
130
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
131
|
+
Object.defineProperty(exports, '__esModule', {
|
|
132
|
+
value: true
|
|
152
133
|
});
|
package/dist/cjs/cli/data.js
CHANGED
|
@@ -1,164 +1,145 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
var
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
};
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
parseDeferredReadableStream: ()=>parseDeferredReadableStream
|
|
22
28
|
});
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
const DEFERRED_VALUE_PLACEHOLDER_PREFIX = "__deferred_promise:";
|
|
29
|
+
const browser_namespaceObject = require("@modern-js/runtime-utils/browser");
|
|
30
|
+
const DEFERRED_VALUE_PLACEHOLDER_PREFIX = '__deferred_promise:';
|
|
26
31
|
async function parseDeferredReadableStream(stream) {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
32
|
+
if (!stream) throw new Error('parseDeferredReadableStream requires stream argument');
|
|
33
|
+
let deferredData;
|
|
34
|
+
const deferredResolvers = {};
|
|
35
|
+
try {
|
|
36
|
+
const sectionReader = readStreamSections(stream);
|
|
37
|
+
const initialSectionResult = await sectionReader.next();
|
|
38
|
+
const initialSection = initialSectionResult.value;
|
|
39
|
+
if (!initialSection) throw new Error('no critical data');
|
|
40
|
+
const criticalData = JSON.parse(initialSection);
|
|
41
|
+
if ('object' == typeof criticalData && null !== criticalData) {
|
|
42
|
+
for (const [eventKey, value] of Object.entries(criticalData))if ('string' == typeof value && value.startsWith(DEFERRED_VALUE_PLACEHOLDER_PREFIX)) {
|
|
43
|
+
deferredData = deferredData || {};
|
|
44
|
+
deferredData[eventKey] = new Promise((resolve, reject)=>{
|
|
45
|
+
deferredResolvers[eventKey] = {
|
|
46
|
+
resolve: (value)=>{
|
|
47
|
+
resolve(value);
|
|
48
|
+
delete deferredResolvers[eventKey];
|
|
49
|
+
},
|
|
50
|
+
reject: (error)=>{
|
|
51
|
+
reject(error);
|
|
52
|
+
delete deferredResolvers[eventKey];
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
});
|
|
56
|
+
}
|
|
44
57
|
}
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
58
|
+
(async ()=>{
|
|
59
|
+
try {
|
|
60
|
+
for await (const section of sectionReader){
|
|
61
|
+
const [event, ...sectionDataStrings] = section.split(':');
|
|
62
|
+
const sectionDataString = sectionDataStrings.join(':');
|
|
63
|
+
const data = JSON.parse(sectionDataString);
|
|
64
|
+
if ('data' === event) {
|
|
65
|
+
for (const [key, value] of Object.entries(data))if (deferredResolvers[key]) deferredResolvers[key].resolve(value);
|
|
66
|
+
} else if ('error' === event) for (const [key, value] of Object.entries(data)){
|
|
67
|
+
const err = new Error(value.message);
|
|
68
|
+
err.stack = value.stack;
|
|
69
|
+
if (deferredResolvers[key]) deferredResolvers[key].reject(err);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
for (const [key, resolver] of Object.entries(deferredResolvers))resolver.reject(new browser_namespaceObject.AbortedDeferredError(`Deferred ${key} will never resolved`));
|
|
73
|
+
} catch (error) {
|
|
74
|
+
for (const resolver of Object.values(deferredResolvers))resolver.reject(error);
|
|
55
75
|
}
|
|
56
|
-
|
|
76
|
+
})();
|
|
77
|
+
return new browser_namespaceObject.DeferredData({
|
|
78
|
+
...criticalData,
|
|
79
|
+
...deferredData
|
|
57
80
|
});
|
|
58
|
-
|
|
81
|
+
} catch (error) {
|
|
82
|
+
for (const resolver of Object.values(deferredResolvers))resolver.reject(error);
|
|
83
|
+
throw error;
|
|
59
84
|
}
|
|
60
|
-
(async () => {
|
|
61
|
-
try {
|
|
62
|
-
for await (const section of sectionReader) {
|
|
63
|
-
const [event, ...sectionDataStrings] = section.split(":");
|
|
64
|
-
const sectionDataString = sectionDataStrings.join(":");
|
|
65
|
-
const data = JSON.parse(sectionDataString);
|
|
66
|
-
if (event === "data") {
|
|
67
|
-
for (const [key, value] of Object.entries(data)) {
|
|
68
|
-
if (deferredResolvers[key]) {
|
|
69
|
-
deferredResolvers[key].resolve(value);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
} else if (event === "error") {
|
|
73
|
-
for (const [key, value] of Object.entries(data)) {
|
|
74
|
-
const err = new Error(value.message);
|
|
75
|
-
err.stack = value.stack;
|
|
76
|
-
if (deferredResolvers[key]) {
|
|
77
|
-
deferredResolvers[key].reject(err);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
for (const [key, resolver] of Object.entries(deferredResolvers)) {
|
|
83
|
-
resolver.reject(new import_browser.AbortedDeferredError(`Deferred ${key} will never resolved`));
|
|
84
|
-
}
|
|
85
|
-
} catch (error) {
|
|
86
|
-
for (const resolver of Object.values(deferredResolvers)) {
|
|
87
|
-
resolver.reject(error);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
})();
|
|
91
|
-
return new import_browser.DeferredData({
|
|
92
|
-
...criticalData,
|
|
93
|
-
...deferredData
|
|
94
|
-
});
|
|
95
|
-
} catch (error) {
|
|
96
|
-
for (const resolver of Object.values(deferredResolvers)) {
|
|
97
|
-
resolver.reject(error);
|
|
98
|
-
}
|
|
99
|
-
throw error;
|
|
100
|
-
}
|
|
101
85
|
}
|
|
102
86
|
async function* readStreamSections(stream) {
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
87
|
+
const reader = stream.getReader();
|
|
88
|
+
let buffer = [];
|
|
89
|
+
let sections = [];
|
|
90
|
+
let closed = false;
|
|
91
|
+
const encoder = new TextEncoder();
|
|
92
|
+
const decoder = new TextDecoder();
|
|
93
|
+
const readStreamSection = async ()=>{
|
|
94
|
+
if (sections.length > 0) return sections.shift();
|
|
95
|
+
while(!closed && 0 === sections.length){
|
|
96
|
+
const chunk = await reader.read();
|
|
97
|
+
if (chunk.done) {
|
|
98
|
+
closed = true;
|
|
99
|
+
break;
|
|
100
|
+
}
|
|
101
|
+
buffer.push(chunk.value);
|
|
102
|
+
try {
|
|
103
|
+
const bufferedString = decoder.decode(mergeArrays(...buffer));
|
|
104
|
+
const splitSections = bufferedString.split('\n\n');
|
|
105
|
+
if (splitSections.length >= 2) {
|
|
106
|
+
sections.push(...splitSections.slice(0, -1));
|
|
107
|
+
buffer = [
|
|
108
|
+
encoder.encode(splitSections.slice(-1).join('\n\n'))
|
|
109
|
+
];
|
|
110
|
+
}
|
|
111
|
+
if (sections.length > 0) break;
|
|
112
|
+
} catch {
|
|
113
|
+
continue;
|
|
114
|
+
}
|
|
128
115
|
}
|
|
129
|
-
if (sections.length > 0)
|
|
130
|
-
|
|
116
|
+
if (sections.length > 0) return sections.shift();
|
|
117
|
+
if (buffer.length > 0) {
|
|
118
|
+
const bufferedString = decoder.decode(mergeArrays(...buffer));
|
|
119
|
+
sections = bufferedString.split('\n\n').filter((s)=>s);
|
|
120
|
+
buffer = [];
|
|
131
121
|
}
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
122
|
+
return sections.shift();
|
|
123
|
+
};
|
|
124
|
+
let section = await readStreamSection();
|
|
125
|
+
while(section){
|
|
126
|
+
yield section;
|
|
127
|
+
section = await readStreamSection();
|
|
138
128
|
}
|
|
139
|
-
if (buffer.length > 0) {
|
|
140
|
-
const bufferedString = decoder.decode(mergeArrays(...buffer));
|
|
141
|
-
sections = bufferedString.split("\n\n").filter((s) => s);
|
|
142
|
-
buffer = [];
|
|
143
|
-
}
|
|
144
|
-
return sections.shift();
|
|
145
|
-
};
|
|
146
|
-
let section = await readStreamSection();
|
|
147
|
-
while (section) {
|
|
148
|
-
yield section;
|
|
149
|
-
section = await readStreamSection();
|
|
150
|
-
}
|
|
151
129
|
}
|
|
152
130
|
function mergeArrays(...arrays) {
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
131
|
+
const out = new Uint8Array(arrays.reduce((total, arr)=>total + arr.length, 0));
|
|
132
|
+
let offset = 0;
|
|
133
|
+
for (const arr of arrays){
|
|
134
|
+
out.set(arr, offset);
|
|
135
|
+
offset += arr.length;
|
|
136
|
+
}
|
|
137
|
+
return out;
|
|
160
138
|
}
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
139
|
+
exports.parseDeferredReadableStream = __webpack_exports__.parseDeferredReadableStream;
|
|
140
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
141
|
+
"parseDeferredReadableStream"
|
|
142
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
143
|
+
Object.defineProperty(exports, '__esModule', {
|
|
144
|
+
value: true
|
|
164
145
|
});
|