@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,90 +0,0 @@
|
|
|
1
|
-
import { _ as _define_property } from "@swc/helpers/_/_define_property";
|
|
2
|
-
import { _ as _instanceof } from "@swc/helpers/_/_instanceof";
|
|
3
|
-
import { _ as _object_spread } from "@swc/helpers/_/_object_spread";
|
|
4
|
-
import { _ as _object_spread_props } from "@swc/helpers/_/_object_spread_props";
|
|
5
|
-
import { _ as _sliced_to_array } from "@swc/helpers/_/_sliced_to_array";
|
|
6
|
-
import { isRouteErrorResponse } from "@modern-js/runtime-utils/remix-router";
|
|
7
|
-
function sanitizeError(error) {
|
|
8
|
-
if (_instanceof(error, Error) && process.env.NODE_ENV !== "development" && process.env.NODE_ENV !== "test") {
|
|
9
|
-
var sanitized = new Error(error.message || "Unexpected Server Error");
|
|
10
|
-
sanitized.stack = void 0;
|
|
11
|
-
return sanitized;
|
|
12
|
-
}
|
|
13
|
-
return error;
|
|
14
|
-
}
|
|
15
|
-
function sanitizeErrors(errors) {
|
|
16
|
-
return Object.entries(errors).reduce(function(acc, param) {
|
|
17
|
-
var _param = _sliced_to_array(param, 2), routeId = _param[0], error = _param[1];
|
|
18
|
-
return Object.assign(acc, _define_property({}, routeId, sanitizeError(error)));
|
|
19
|
-
}, {});
|
|
20
|
-
}
|
|
21
|
-
function serializeError(error) {
|
|
22
|
-
var sanitized = sanitizeError(error);
|
|
23
|
-
return {
|
|
24
|
-
message: sanitized.message,
|
|
25
|
-
stack: sanitized.stack
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
function serializeErrors(errors) {
|
|
29
|
-
if (!errors) {
|
|
30
|
-
return null;
|
|
31
|
-
}
|
|
32
|
-
var entries = Object.entries(errors);
|
|
33
|
-
var serialized = {};
|
|
34
|
-
var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = void 0;
|
|
35
|
-
try {
|
|
36
|
-
for (var _iterator = entries[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
|
37
|
-
var _step_value = _sliced_to_array(_step.value, 2), key = _step_value[0], val = _step_value[1];
|
|
38
|
-
if (isRouteErrorResponse(val)) {
|
|
39
|
-
serialized[key] = _object_spread_props(_object_spread({}, val), {
|
|
40
|
-
__type: "RouteErrorResponse"
|
|
41
|
-
});
|
|
42
|
-
} else if (_instanceof(val, Error)) {
|
|
43
|
-
var sanitized = sanitizeError(val);
|
|
44
|
-
serialized[key] = _object_spread({
|
|
45
|
-
message: sanitized.message,
|
|
46
|
-
stack: sanitized.stack,
|
|
47
|
-
__type: "Error"
|
|
48
|
-
}, sanitized.name !== "Error" ? {
|
|
49
|
-
__subType: sanitized.name
|
|
50
|
-
} : {});
|
|
51
|
-
} else {
|
|
52
|
-
serialized[key] = val;
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
} catch (err) {
|
|
56
|
-
_didIteratorError = true;
|
|
57
|
-
_iteratorError = err;
|
|
58
|
-
} finally {
|
|
59
|
-
try {
|
|
60
|
-
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
61
|
-
_iterator.return();
|
|
62
|
-
}
|
|
63
|
-
} finally {
|
|
64
|
-
if (_didIteratorError) {
|
|
65
|
-
throw _iteratorError;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
return serialized;
|
|
70
|
-
}
|
|
71
|
-
function errorResponseToJson(errorResponse) {
|
|
72
|
-
return Response.json(
|
|
73
|
-
// @ts-expect-error This is "private" from users but intended for internal use
|
|
74
|
-
serializeError(errorResponse.error || new Error("Unexpected Server Error")),
|
|
75
|
-
{
|
|
76
|
-
status: errorResponse.status,
|
|
77
|
-
statusText: errorResponse.statusText,
|
|
78
|
-
headers: {
|
|
79
|
-
"X-Modernjs-Error": "yes"
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
);
|
|
83
|
-
}
|
|
84
|
-
export {
|
|
85
|
-
errorResponseToJson,
|
|
86
|
-
sanitizeError,
|
|
87
|
-
sanitizeErrors,
|
|
88
|
-
serializeError,
|
|
89
|
-
serializeErrors
|
|
90
|
-
};
|
|
@@ -1,191 +0,0 @@
|
|
|
1
|
-
import { _ as _async_to_generator } from "@swc/helpers/_/_async_to_generator";
|
|
2
|
-
import { _ as _instanceof } from "@swc/helpers/_/_instanceof";
|
|
3
|
-
import { _ as _type_of } from "@swc/helpers/_/_type_of";
|
|
4
|
-
import { _ as _ts_generator } from "@swc/helpers/_/_ts_generator";
|
|
5
|
-
import { transformNestedRoutes } from "@modern-js/runtime-utils/browser";
|
|
6
|
-
import { createRequestContext, reporterCtx } from "@modern-js/runtime-utils/node";
|
|
7
|
-
import { storage } from "@modern-js/runtime-utils/node";
|
|
8
|
-
import { DEFERRED_SYMBOL, createStaticHandler, isRouteErrorResponse } from "@modern-js/runtime-utils/remix-router";
|
|
9
|
-
import { matchEntry } from "@modern-js/runtime-utils/server";
|
|
10
|
-
import { time } from "@modern-js/runtime-utils/time";
|
|
11
|
-
import { parseHeaders } from "@modern-js/runtime-utils/universal/request";
|
|
12
|
-
import { isPlainObject } from "@modern-js/utils/lodash";
|
|
13
|
-
import { LOADER_REPORTER_NAME } from "@modern-js/utils/universal/constants";
|
|
14
|
-
import { CONTENT_TYPE_DEFERRED, LOADER_ID_PARAM } from "../common/constants";
|
|
15
|
-
import { errorResponseToJson, serializeError } from "./errors";
|
|
16
|
-
import { createDeferredReadableStream } from "./response";
|
|
17
|
-
var redirectStatusCodes = /* @__PURE__ */ new Set([
|
|
18
|
-
301,
|
|
19
|
-
302,
|
|
20
|
-
303,
|
|
21
|
-
307,
|
|
22
|
-
308
|
|
23
|
-
]);
|
|
24
|
-
function isRedirectResponse(status) {
|
|
25
|
-
return redirectStatusCodes.has(status);
|
|
26
|
-
}
|
|
27
|
-
function isResponse(value) {
|
|
28
|
-
return value != null && typeof value.status === "number" && typeof value.statusText === "string" && _type_of(value.headers) === "object" && typeof value.body !== "undefined";
|
|
29
|
-
}
|
|
30
|
-
function convertModernRedirectResponse(headers, basename) {
|
|
31
|
-
var newHeaders = new Headers(headers);
|
|
32
|
-
var redirectUrl = headers.get("Location");
|
|
33
|
-
if (basename !== "/") {
|
|
34
|
-
redirectUrl = redirectUrl.replace(basename, "");
|
|
35
|
-
}
|
|
36
|
-
newHeaders.set("X-Modernjs-Redirect", redirectUrl);
|
|
37
|
-
newHeaders.delete("Location");
|
|
38
|
-
return new Response(null, {
|
|
39
|
-
status: 204,
|
|
40
|
-
headers: newHeaders
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
function hasFileExtension(pathname) {
|
|
44
|
-
var lastSegment = pathname.split("/").pop() || "";
|
|
45
|
-
var dotIndex = lastSegment.lastIndexOf(".");
|
|
46
|
-
if (dotIndex === -1) {
|
|
47
|
-
return false;
|
|
48
|
-
}
|
|
49
|
-
var extension = lastSegment.substring(dotIndex).toLowerCase();
|
|
50
|
-
return extension !== ".html";
|
|
51
|
-
}
|
|
52
|
-
var handleRequest = function() {
|
|
53
|
-
var _ref = _async_to_generator(function(param) {
|
|
54
|
-
var request, serverRoutes, routesConfig, context, onTiming, url, routeId, entry, basename, end, reporter, loaderContext, monitors, headersData, activeDeferreds;
|
|
55
|
-
return _ts_generator(this, function(_state) {
|
|
56
|
-
request = param.request, serverRoutes = param.serverRoutes, routesConfig = param.routes, context = param.context, onTiming = param.onTiming;
|
|
57
|
-
url = new URL(request.url);
|
|
58
|
-
routeId = url.searchParams.get(LOADER_ID_PARAM);
|
|
59
|
-
if (hasFileExtension(url.pathname)) {
|
|
60
|
-
return [
|
|
61
|
-
2
|
|
62
|
-
];
|
|
63
|
-
}
|
|
64
|
-
entry = matchEntry(url.pathname, serverRoutes);
|
|
65
|
-
if (!routeId || !entry) {
|
|
66
|
-
return [
|
|
67
|
-
2
|
|
68
|
-
];
|
|
69
|
-
}
|
|
70
|
-
basename = entry.urlPath;
|
|
71
|
-
end = time();
|
|
72
|
-
reporter = context.reporter, loaderContext = context.loaderContext, monitors = context.monitors;
|
|
73
|
-
headersData = parseHeaders(request);
|
|
74
|
-
activeDeferreds = /* @__PURE__ */ new Map();
|
|
75
|
-
return [
|
|
76
|
-
2,
|
|
77
|
-
storage.run({
|
|
78
|
-
headers: headersData,
|
|
79
|
-
monitors,
|
|
80
|
-
request,
|
|
81
|
-
activeDeferreds
|
|
82
|
-
}, /* @__PURE__ */ _async_to_generator(function() {
|
|
83
|
-
var routes, queryRoute, requestContext, response, deferredData, body, init, headers, cost, error, errorInstance;
|
|
84
|
-
return _ts_generator(this, function(_state2) {
|
|
85
|
-
switch (_state2.label) {
|
|
86
|
-
case 0:
|
|
87
|
-
routes = transformNestedRoutes(routesConfig);
|
|
88
|
-
queryRoute = createStaticHandler(routes, {
|
|
89
|
-
basename
|
|
90
|
-
}).queryRoute;
|
|
91
|
-
requestContext = createRequestContext(loaderContext);
|
|
92
|
-
requestContext.set(reporterCtx, reporter);
|
|
93
|
-
_state2.label = 1;
|
|
94
|
-
case 1:
|
|
95
|
-
_state2.trys.push([
|
|
96
|
-
1,
|
|
97
|
-
3,
|
|
98
|
-
,
|
|
99
|
-
4
|
|
100
|
-
]);
|
|
101
|
-
return [
|
|
102
|
-
4,
|
|
103
|
-
queryRoute(request, {
|
|
104
|
-
routeId,
|
|
105
|
-
requestContext
|
|
106
|
-
})
|
|
107
|
-
];
|
|
108
|
-
case 2:
|
|
109
|
-
response = _state2.sent();
|
|
110
|
-
if (isResponse(response) && isRedirectResponse(response.status)) {
|
|
111
|
-
response = convertModernRedirectResponse(response.headers, basename);
|
|
112
|
-
} else if (isPlainObject(response) && (DEFERRED_SYMBOL in response || activeDeferreds.get(routeId))) {
|
|
113
|
-
;
|
|
114
|
-
if (DEFERRED_SYMBOL in response) {
|
|
115
|
-
deferredData = response[DEFERRED_SYMBOL];
|
|
116
|
-
} else {
|
|
117
|
-
deferredData = activeDeferreds.get(routeId);
|
|
118
|
-
}
|
|
119
|
-
body = createDeferredReadableStream(
|
|
120
|
-
// @ts-ignore
|
|
121
|
-
deferredData,
|
|
122
|
-
request.signal
|
|
123
|
-
);
|
|
124
|
-
init = deferredData.init || {};
|
|
125
|
-
if (init.status && isRedirectResponse(init.status)) {
|
|
126
|
-
if (!init.headers) {
|
|
127
|
-
throw new Error("redirect response includes no headers");
|
|
128
|
-
}
|
|
129
|
-
response = convertModernRedirectResponse(new Headers(init.headers), basename);
|
|
130
|
-
} else {
|
|
131
|
-
headers = new Headers(init.headers);
|
|
132
|
-
headers.set("Content-Type", "".concat(CONTENT_TYPE_DEFERRED, "; charset=UTF-8"));
|
|
133
|
-
init.headers = headers;
|
|
134
|
-
response = new Response(body, init);
|
|
135
|
-
}
|
|
136
|
-
} else {
|
|
137
|
-
response = isResponse(response) ? response : new Response(JSON.stringify(response), {
|
|
138
|
-
headers: {
|
|
139
|
-
"Content-Type": "application/json; charset=utf-8"
|
|
140
|
-
}
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
cost = end();
|
|
144
|
-
response.headers.set("X-Modernjs-Response", "yes");
|
|
145
|
-
onTiming === null || onTiming === void 0 ? void 0 : onTiming("".concat(LOADER_REPORTER_NAME, "-navigation"), cost);
|
|
146
|
-
return [
|
|
147
|
-
3,
|
|
148
|
-
4
|
|
149
|
-
];
|
|
150
|
-
case 3:
|
|
151
|
-
error = _state2.sent();
|
|
152
|
-
if (isResponse(error)) {
|
|
153
|
-
error.headers.set("X-Modernjs-Catch", "yes");
|
|
154
|
-
response = error;
|
|
155
|
-
} else if (isRouteErrorResponse(error)) {
|
|
156
|
-
response = errorResponseToJson(error);
|
|
157
|
-
} else {
|
|
158
|
-
errorInstance = _instanceof(error, Error) || _instanceof(error, DOMException) ? error : new Error("Unexpected Server Error");
|
|
159
|
-
response = new Response(JSON.stringify(serializeError(errorInstance)), {
|
|
160
|
-
status: 500,
|
|
161
|
-
headers: {
|
|
162
|
-
"X-Modernjs-Error": "yes",
|
|
163
|
-
"Content-Type": "application/json"
|
|
164
|
-
}
|
|
165
|
-
});
|
|
166
|
-
}
|
|
167
|
-
return [
|
|
168
|
-
3,
|
|
169
|
-
4
|
|
170
|
-
];
|
|
171
|
-
case 4:
|
|
172
|
-
return [
|
|
173
|
-
2,
|
|
174
|
-
response
|
|
175
|
-
];
|
|
176
|
-
}
|
|
177
|
-
});
|
|
178
|
-
}))
|
|
179
|
-
];
|
|
180
|
-
});
|
|
181
|
-
});
|
|
182
|
-
return function handleRequest2(_) {
|
|
183
|
-
return _ref.apply(this, arguments);
|
|
184
|
-
};
|
|
185
|
-
}();
|
|
186
|
-
export {
|
|
187
|
-
handleRequest,
|
|
188
|
-
hasFileExtension,
|
|
189
|
-
isRedirectResponse,
|
|
190
|
-
isResponse
|
|
191
|
-
};
|
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
import { _ as _async_to_generator } from "@swc/helpers/_/_async_to_generator";
|
|
2
|
-
import { _ as _define_property } from "@swc/helpers/_/_define_property";
|
|
3
|
-
import { _ as _sliced_to_array } from "@swc/helpers/_/_sliced_to_array";
|
|
4
|
-
import { _ as _ts_generator } from "@swc/helpers/_/_ts_generator";
|
|
5
|
-
import { TextEncoder } from "util";
|
|
6
|
-
import { serializeJson } from "@modern-js/runtime-utils/node";
|
|
7
|
-
function isTrackedPromise(value) {
|
|
8
|
-
return value != null && typeof value.then === "function" && value._tracked === true;
|
|
9
|
-
}
|
|
10
|
-
var DEFERRED_VALUE_PLACEHOLDER_PREFIX = "__deferred_promise:";
|
|
11
|
-
function createDeferredReadableStream(deferredData, signal) {
|
|
12
|
-
var encoder = new TextEncoder();
|
|
13
|
-
var stream = new ReadableStream({
|
|
14
|
-
start: function start(controller) {
|
|
15
|
-
return _async_to_generator(function() {
|
|
16
|
-
var criticalData, preresolvedKeys, _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, _step_value, key, value, _iteratorNormalCompletion1, _didIteratorError1, _iteratorError1, _iterator1, _step1, preresolvedKey, unsubscribe;
|
|
17
|
-
return _ts_generator(this, function(_state) {
|
|
18
|
-
switch (_state.label) {
|
|
19
|
-
case 0:
|
|
20
|
-
criticalData = {};
|
|
21
|
-
preresolvedKeys = [];
|
|
22
|
-
_iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = void 0;
|
|
23
|
-
try {
|
|
24
|
-
for (_iterator = Object.entries(deferredData.data)[Symbol.iterator](); !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
|
25
|
-
_step_value = _sliced_to_array(_step.value, 2), key = _step_value[0], value = _step_value[1];
|
|
26
|
-
if (isTrackedPromise(value)) {
|
|
27
|
-
criticalData[key] = "".concat(DEFERRED_VALUE_PLACEHOLDER_PREFIX).concat(key);
|
|
28
|
-
if (typeof value._data !== "undefined" || typeof value._error !== "undefined") {
|
|
29
|
-
preresolvedKeys.push(key);
|
|
30
|
-
}
|
|
31
|
-
} else {
|
|
32
|
-
criticalData[key] = value;
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
} catch (err) {
|
|
36
|
-
_didIteratorError = true;
|
|
37
|
-
_iteratorError = err;
|
|
38
|
-
} finally {
|
|
39
|
-
try {
|
|
40
|
-
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
41
|
-
_iterator.return();
|
|
42
|
-
}
|
|
43
|
-
} finally {
|
|
44
|
-
if (_didIteratorError) {
|
|
45
|
-
throw _iteratorError;
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
controller.enqueue(encoder.encode("".concat(JSON.stringify(criticalData), "\n\n")));
|
|
50
|
-
_iteratorNormalCompletion1 = true, _didIteratorError1 = false, _iteratorError1 = void 0;
|
|
51
|
-
try {
|
|
52
|
-
for (_iterator1 = preresolvedKeys[Symbol.iterator](); !(_iteratorNormalCompletion1 = (_step1 = _iterator1.next()).done); _iteratorNormalCompletion1 = true) {
|
|
53
|
-
preresolvedKey = _step1.value;
|
|
54
|
-
enqueueTrackedPromise(controller, encoder, preresolvedKey, deferredData.data[preresolvedKey]);
|
|
55
|
-
}
|
|
56
|
-
} catch (err) {
|
|
57
|
-
_didIteratorError1 = true;
|
|
58
|
-
_iteratorError1 = err;
|
|
59
|
-
} finally {
|
|
60
|
-
try {
|
|
61
|
-
if (!_iteratorNormalCompletion1 && _iterator1.return != null) {
|
|
62
|
-
_iterator1.return();
|
|
63
|
-
}
|
|
64
|
-
} finally {
|
|
65
|
-
if (_didIteratorError1) {
|
|
66
|
-
throw _iteratorError1;
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
unsubscribe = deferredData.subscribe(function(aborted, settledKey) {
|
|
71
|
-
if (settledKey) {
|
|
72
|
-
enqueueTrackedPromise(controller, encoder, settledKey, deferredData.data[settledKey]);
|
|
73
|
-
}
|
|
74
|
-
});
|
|
75
|
-
return [
|
|
76
|
-
4,
|
|
77
|
-
deferredData.resolveData(signal)
|
|
78
|
-
];
|
|
79
|
-
case 1:
|
|
80
|
-
_state.sent();
|
|
81
|
-
unsubscribe();
|
|
82
|
-
controller.close();
|
|
83
|
-
return [
|
|
84
|
-
2
|
|
85
|
-
];
|
|
86
|
-
}
|
|
87
|
-
});
|
|
88
|
-
})();
|
|
89
|
-
}
|
|
90
|
-
});
|
|
91
|
-
return stream;
|
|
92
|
-
}
|
|
93
|
-
function enqueueTrackedPromise(controller, encoder, settledKey, promise) {
|
|
94
|
-
if ("_error" in promise) {
|
|
95
|
-
var _error = promise._error;
|
|
96
|
-
controller.enqueue(encoder.encode("error:".concat(serializeJson(_define_property({}, settledKey, {
|
|
97
|
-
message: _error.message,
|
|
98
|
-
stack: _error.stack
|
|
99
|
-
})), "\n\n")));
|
|
100
|
-
} else {
|
|
101
|
-
var _promise__data;
|
|
102
|
-
controller.enqueue(encoder.encode("data:".concat(JSON.stringify(_define_property({}, settledKey, (_promise__data = promise._data) !== null && _promise__data !== void 0 ? _promise__data : null)), "\n\n")));
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
export {
|
|
106
|
-
createDeferredReadableStream
|
|
107
|
-
};
|
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
import { redirect } from "@modern-js/runtime-utils/router";
|
|
2
|
-
import { compile } from "path-to-regexp";
|
|
3
|
-
import { CONTENT_TYPE_DEFERRED, DIRECT_PARAM, LOADER_ID_PARAM } from "../common/constants";
|
|
4
|
-
import { parseDeferredReadableStream } from "./data";
|
|
5
|
-
const getRequestUrl = ({ params, request, routeId }) => {
|
|
6
|
-
const url = new URL(request.url);
|
|
7
|
-
const toPath = compile(url.pathname, {
|
|
8
|
-
encode: encodeURIComponent
|
|
9
|
-
});
|
|
10
|
-
const newPathName = toPath(params);
|
|
11
|
-
url.pathname = newPathName;
|
|
12
|
-
url.searchParams.append(LOADER_ID_PARAM, routeId);
|
|
13
|
-
url.searchParams.append(DIRECT_PARAM, "true");
|
|
14
|
-
return url;
|
|
15
|
-
};
|
|
16
|
-
const handleRedirectResponse = (res) => {
|
|
17
|
-
const { headers } = res;
|
|
18
|
-
const location = headers.get("X-Modernjs-Redirect");
|
|
19
|
-
if (location) {
|
|
20
|
-
throw redirect(location);
|
|
21
|
-
}
|
|
22
|
-
return res;
|
|
23
|
-
};
|
|
24
|
-
const isDeferredResponse = (res) => {
|
|
25
|
-
var _res_headers_get;
|
|
26
|
-
return ((_res_headers_get = res.headers.get("Content-Type")) === null || _res_headers_get === void 0 ? void 0 : _res_headers_get.match(CONTENT_TYPE_DEFERRED)) && res.body;
|
|
27
|
-
};
|
|
28
|
-
const isRedirectResponse = (res) => {
|
|
29
|
-
return res.headers.get("X-Modernjs-Redirect") != null;
|
|
30
|
-
};
|
|
31
|
-
const isErrorResponse = (res) => {
|
|
32
|
-
return res.headers.get("X-Modernjs-Error") != null;
|
|
33
|
-
};
|
|
34
|
-
function isOtherErrorResponse(res) {
|
|
35
|
-
return res.status >= 400 && res.headers.get("X-Modernjs-Error") == null && res.headers.get("X-Modernjs-Catch") == null && res.headers.get("X-Modernjs-Response") == null;
|
|
36
|
-
}
|
|
37
|
-
const isCatchResponse = (res) => {
|
|
38
|
-
return res.headers.get("X-Modernjs-Catch") != null;
|
|
39
|
-
};
|
|
40
|
-
const handleErrorResponse = async (res) => {
|
|
41
|
-
const data = await res.json();
|
|
42
|
-
const error = new Error(data.message);
|
|
43
|
-
error.stack = data.stack;
|
|
44
|
-
throw error;
|
|
45
|
-
};
|
|
46
|
-
const handleNetworkErrorResponse = async (res) => {
|
|
47
|
-
const text = await res.text();
|
|
48
|
-
const error = new Error(text);
|
|
49
|
-
error.stack = void 0;
|
|
50
|
-
throw error;
|
|
51
|
-
};
|
|
52
|
-
const createRequest = (routeId, method = "get") => {
|
|
53
|
-
const isRouterV7 = process.env._MODERN_ROUTER_VERSION === "v7";
|
|
54
|
-
return async ({ params, request }) => {
|
|
55
|
-
const url = getRequestUrl({
|
|
56
|
-
params,
|
|
57
|
-
request,
|
|
58
|
-
routeId
|
|
59
|
-
});
|
|
60
|
-
let res;
|
|
61
|
-
res = await fetch(url, {
|
|
62
|
-
method,
|
|
63
|
-
signal: request.signal
|
|
64
|
-
}).catch((error) => {
|
|
65
|
-
throw error;
|
|
66
|
-
});
|
|
67
|
-
if (isRedirectResponse(res)) {
|
|
68
|
-
return handleRedirectResponse(res);
|
|
69
|
-
}
|
|
70
|
-
if (isErrorResponse(res)) {
|
|
71
|
-
return await handleErrorResponse(res);
|
|
72
|
-
}
|
|
73
|
-
if (isCatchResponse(res)) {
|
|
74
|
-
throw res;
|
|
75
|
-
}
|
|
76
|
-
if (isDeferredResponse(res)) {
|
|
77
|
-
const deferredData = await parseDeferredReadableStream(res.body);
|
|
78
|
-
return isRouterV7 ? deferredData.data : deferredData;
|
|
79
|
-
}
|
|
80
|
-
if (isOtherErrorResponse(res)) {
|
|
81
|
-
return await handleNetworkErrorResponse(res);
|
|
82
|
-
}
|
|
83
|
-
return res;
|
|
84
|
-
};
|
|
85
|
-
};
|
|
86
|
-
const createActionRequest = (routeId) => {
|
|
87
|
-
return async ({ params, request }) => {
|
|
88
|
-
const url = getRequestUrl({
|
|
89
|
-
params,
|
|
90
|
-
request,
|
|
91
|
-
routeId
|
|
92
|
-
});
|
|
93
|
-
const init = {
|
|
94
|
-
signal: request.signal
|
|
95
|
-
};
|
|
96
|
-
if (request.method !== "GET") {
|
|
97
|
-
init.method = request.method;
|
|
98
|
-
const contentType = request.headers.get("Content-Type");
|
|
99
|
-
if (contentType && /\bapplication\/json\b/.test(contentType)) {
|
|
100
|
-
init.headers = {
|
|
101
|
-
"Content-Type": contentType
|
|
102
|
-
};
|
|
103
|
-
init.body = JSON.stringify(await request.json());
|
|
104
|
-
} else if (contentType && /\btext\/plain\b/.test(contentType)) {
|
|
105
|
-
init.headers = {
|
|
106
|
-
"Content-Type": contentType
|
|
107
|
-
};
|
|
108
|
-
init.body = await request.text();
|
|
109
|
-
} else if (contentType && /\bapplication\/x-www-form-urlencoded\b/.test(contentType)) {
|
|
110
|
-
init.body = new URLSearchParams(await request.text());
|
|
111
|
-
} else {
|
|
112
|
-
init.body = await request.formData();
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
const res = await fetch(url, init);
|
|
116
|
-
if (!res.ok) {
|
|
117
|
-
throw res;
|
|
118
|
-
}
|
|
119
|
-
return res;
|
|
120
|
-
};
|
|
121
|
-
};
|
|
122
|
-
export {
|
|
123
|
-
createActionRequest,
|
|
124
|
-
createRequest,
|
|
125
|
-
getRequestUrl
|
|
126
|
-
};
|
|
@@ -1,140 +0,0 @@
|
|
|
1
|
-
import { AbortedDeferredError, DeferredData } from "@modern-js/runtime-utils/browser";
|
|
2
|
-
const DEFERRED_VALUE_PLACEHOLDER_PREFIX = "__deferred_promise:";
|
|
3
|
-
async function parseDeferredReadableStream(stream) {
|
|
4
|
-
if (!stream) {
|
|
5
|
-
throw new Error("parseDeferredReadableStream requires stream argument");
|
|
6
|
-
}
|
|
7
|
-
let deferredData;
|
|
8
|
-
const deferredResolvers = {};
|
|
9
|
-
try {
|
|
10
|
-
const sectionReader = readStreamSections(stream);
|
|
11
|
-
const initialSectionResult = await sectionReader.next();
|
|
12
|
-
const initialSection = initialSectionResult.value;
|
|
13
|
-
if (!initialSection) {
|
|
14
|
-
throw new Error("no critical data");
|
|
15
|
-
}
|
|
16
|
-
const criticalData = JSON.parse(initialSection);
|
|
17
|
-
if (typeof criticalData === "object" && criticalData !== null) {
|
|
18
|
-
for (const [eventKey, value] of Object.entries(criticalData)) {
|
|
19
|
-
if (typeof value !== "string" || !value.startsWith(DEFERRED_VALUE_PLACEHOLDER_PREFIX)) {
|
|
20
|
-
continue;
|
|
21
|
-
}
|
|
22
|
-
deferredData = deferredData || {};
|
|
23
|
-
deferredData[eventKey] = new Promise((resolve, reject) => {
|
|
24
|
-
deferredResolvers[eventKey] = {
|
|
25
|
-
resolve: (value2) => {
|
|
26
|
-
resolve(value2);
|
|
27
|
-
delete deferredResolvers[eventKey];
|
|
28
|
-
},
|
|
29
|
-
reject: (error) => {
|
|
30
|
-
reject(error);
|
|
31
|
-
delete deferredResolvers[eventKey];
|
|
32
|
-
}
|
|
33
|
-
};
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
(async () => {
|
|
38
|
-
try {
|
|
39
|
-
for await (const section of sectionReader) {
|
|
40
|
-
const [event, ...sectionDataStrings] = section.split(":");
|
|
41
|
-
const sectionDataString = sectionDataStrings.join(":");
|
|
42
|
-
const data = JSON.parse(sectionDataString);
|
|
43
|
-
if (event === "data") {
|
|
44
|
-
for (const [key, value] of Object.entries(data)) {
|
|
45
|
-
if (deferredResolvers[key]) {
|
|
46
|
-
deferredResolvers[key].resolve(value);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
} else if (event === "error") {
|
|
50
|
-
for (const [key, value] of Object.entries(data)) {
|
|
51
|
-
const err = new Error(value.message);
|
|
52
|
-
err.stack = value.stack;
|
|
53
|
-
if (deferredResolvers[key]) {
|
|
54
|
-
deferredResolvers[key].reject(err);
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
for (const [key, resolver] of Object.entries(deferredResolvers)) {
|
|
60
|
-
resolver.reject(new AbortedDeferredError(`Deferred ${key} will never resolved`));
|
|
61
|
-
}
|
|
62
|
-
} catch (error) {
|
|
63
|
-
for (const resolver of Object.values(deferredResolvers)) {
|
|
64
|
-
resolver.reject(error);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
})();
|
|
68
|
-
return new DeferredData({
|
|
69
|
-
...criticalData,
|
|
70
|
-
...deferredData
|
|
71
|
-
});
|
|
72
|
-
} catch (error) {
|
|
73
|
-
for (const resolver of Object.values(deferredResolvers)) {
|
|
74
|
-
resolver.reject(error);
|
|
75
|
-
}
|
|
76
|
-
throw error;
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
async function* readStreamSections(stream) {
|
|
80
|
-
const reader = stream.getReader();
|
|
81
|
-
let buffer = [];
|
|
82
|
-
let sections = [];
|
|
83
|
-
let closed = false;
|
|
84
|
-
const encoder = new TextEncoder();
|
|
85
|
-
const decoder = new TextDecoder();
|
|
86
|
-
const readStreamSection = async () => {
|
|
87
|
-
if (sections.length > 0) {
|
|
88
|
-
return sections.shift();
|
|
89
|
-
}
|
|
90
|
-
while (!closed && sections.length === 0) {
|
|
91
|
-
const chunk = await reader.read();
|
|
92
|
-
if (chunk.done) {
|
|
93
|
-
closed = true;
|
|
94
|
-
break;
|
|
95
|
-
}
|
|
96
|
-
buffer.push(chunk.value);
|
|
97
|
-
try {
|
|
98
|
-
const bufferedString = decoder.decode(mergeArrays(...buffer));
|
|
99
|
-
const splitSections = bufferedString.split("\n\n");
|
|
100
|
-
if (splitSections.length >= 2) {
|
|
101
|
-
sections.push(...splitSections.slice(0, -1));
|
|
102
|
-
buffer = [
|
|
103
|
-
encoder.encode(splitSections.slice(-1).join("\n\n"))
|
|
104
|
-
];
|
|
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(arrays.reduce((total, arr) => total + arr.length, 0));
|
|
131
|
-
let offset = 0;
|
|
132
|
-
for (const arr of arrays) {
|
|
133
|
-
out.set(arr, offset);
|
|
134
|
-
offset += arr.length;
|
|
135
|
-
}
|
|
136
|
-
return out;
|
|
137
|
-
}
|
|
138
|
-
export {
|
|
139
|
-
parseDeferredReadableStream
|
|
140
|
-
};
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import path from "path";
|
|
2
|
-
const generateClient = ({ inline, action, routeId }) => {
|
|
3
|
-
let requestCode = ``;
|
|
4
|
-
const requestCreatorPath = path.join(__dirname, "./createRequest").replace("/cjs/cli/", "/esm/cli/").replace(/\\/g, "/");
|
|
5
|
-
const importCode = `
|
|
6
|
-
import { createRequest, createActionRequest } from '${requestCreatorPath}';
|
|
7
|
-
`;
|
|
8
|
-
if (inline) {
|
|
9
|
-
if (action) {
|
|
10
|
-
requestCode = `
|
|
11
|
-
export const loader = createRequest('${routeId}');
|
|
12
|
-
export const action = createActionRequest('${routeId}')
|
|
13
|
-
`;
|
|
14
|
-
} else {
|
|
15
|
-
requestCode = `
|
|
16
|
-
export const loader = createRequest('${routeId}');
|
|
17
|
-
`;
|
|
18
|
-
}
|
|
19
|
-
} else {
|
|
20
|
-
requestCode = `
|
|
21
|
-
export default createRequest('${routeId}');
|
|
22
|
-
`;
|
|
23
|
-
}
|
|
24
|
-
const generatedCode = `
|
|
25
|
-
${importCode}
|
|
26
|
-
${requestCode}
|
|
27
|
-
`;
|
|
28
|
-
return generatedCode;
|
|
29
|
-
};
|
|
30
|
-
export {
|
|
31
|
-
generateClient
|
|
32
|
-
};
|