@bleedingdev/modern-js-create-request 3.2.0-ultramodern.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/LICENSE +21 -0
- package/README.md +26 -0
- package/dist/cjs/browser.js +489 -0
- package/dist/cjs/handleRes.js +49 -0
- package/dist/cjs/node.js +531 -0
- package/dist/cjs/qs.js +39 -0
- package/dist/cjs/requestContext.js +94 -0
- package/dist/cjs/transport.js +213 -0
- package/dist/cjs/types.js +53 -0
- package/dist/cjs/utiles.js +52 -0
- package/dist/esm/browser.mjs +366 -0
- package/dist/esm/handleRes.mjs +15 -0
- package/dist/esm/node.mjs +405 -0
- package/dist/esm/qs.mjs +1 -0
- package/dist/esm/requestContext.mjs +51 -0
- package/dist/esm/transport.mjs +179 -0
- package/dist/esm/types.mjs +10 -0
- package/dist/esm/utiles.mjs +18 -0
- package/dist/esm-node/browser.mjs +367 -0
- package/dist/esm-node/handleRes.mjs +16 -0
- package/dist/esm-node/node.mjs +406 -0
- package/dist/esm-node/qs.mjs +2 -0
- package/dist/esm-node/requestContext.mjs +52 -0
- package/dist/esm-node/transport.mjs +180 -0
- package/dist/esm-node/types.mjs +11 -0
- package/dist/esm-node/utiles.mjs +19 -0
- package/dist/types/browser.d.ts +28 -0
- package/dist/types/handleRes.d.ts +2 -0
- package/dist/types/node.d.ts +29 -0
- package/dist/types/qs.d.ts +1 -0
- package/dist/types/requestContext.d.ts +18 -0
- package/dist/types/transport.d.ts +12 -0
- package/dist/types/types.d.ts +167 -0
- package/dist/types/utiles.d.ts +5 -0
- package/package.json +86 -0
package/dist/cjs/node.js
ADDED
|
@@ -0,0 +1,531 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_modules__ = {
|
|
3
|
+
"./handleRes" (module) {
|
|
4
|
+
module.exports = require("./handleRes.js");
|
|
5
|
+
},
|
|
6
|
+
"./requestContext" (module) {
|
|
7
|
+
module.exports = require("./requestContext.js");
|
|
8
|
+
},
|
|
9
|
+
"./transport" (module) {
|
|
10
|
+
module.exports = require("./transport.js");
|
|
11
|
+
},
|
|
12
|
+
"./types" (module) {
|
|
13
|
+
module.exports = require("./types.js");
|
|
14
|
+
},
|
|
15
|
+
"./utiles" (module) {
|
|
16
|
+
module.exports = require("./utiles.js");
|
|
17
|
+
},
|
|
18
|
+
"@modern-js/runtime-utils/node" (module) {
|
|
19
|
+
module.exports = require("@modern-js/runtime-utils/node");
|
|
20
|
+
},
|
|
21
|
+
"path-to-regexp" (module) {
|
|
22
|
+
module.exports = require("path-to-regexp");
|
|
23
|
+
},
|
|
24
|
+
qs (module) {
|
|
25
|
+
module.exports = require("qs");
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
var __webpack_module_cache__ = {};
|
|
29
|
+
function __webpack_require__(moduleId) {
|
|
30
|
+
var cachedModule = __webpack_module_cache__[moduleId];
|
|
31
|
+
if (void 0 !== cachedModule) return cachedModule.exports;
|
|
32
|
+
var module = __webpack_module_cache__[moduleId] = {
|
|
33
|
+
exports: {}
|
|
34
|
+
};
|
|
35
|
+
__webpack_modules__[moduleId](module, module.exports, __webpack_require__);
|
|
36
|
+
return module.exports;
|
|
37
|
+
}
|
|
38
|
+
(()=>{
|
|
39
|
+
__webpack_require__.n = (module)=>{
|
|
40
|
+
var getter = module && module.__esModule ? ()=>module['default'] : ()=>module;
|
|
41
|
+
__webpack_require__.d(getter, {
|
|
42
|
+
a: getter
|
|
43
|
+
});
|
|
44
|
+
return getter;
|
|
45
|
+
};
|
|
46
|
+
})();
|
|
47
|
+
(()=>{
|
|
48
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
49
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
50
|
+
enumerable: true,
|
|
51
|
+
get: definition[key]
|
|
52
|
+
});
|
|
53
|
+
};
|
|
54
|
+
})();
|
|
55
|
+
(()=>{
|
|
56
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
57
|
+
})();
|
|
58
|
+
(()=>{
|
|
59
|
+
__webpack_require__.r = (exports1)=>{
|
|
60
|
+
if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
61
|
+
value: 'Module'
|
|
62
|
+
});
|
|
63
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
64
|
+
value: true
|
|
65
|
+
});
|
|
66
|
+
};
|
|
67
|
+
})();
|
|
68
|
+
var __webpack_exports__ = {};
|
|
69
|
+
(()=>{
|
|
70
|
+
__webpack_require__.r(__webpack_exports__);
|
|
71
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
72
|
+
CrossOriginEnvelopePolicyError: ()=>CrossOriginEnvelopePolicyError,
|
|
73
|
+
IdentityBindingViolationError: ()=>IdentityBindingViolationError,
|
|
74
|
+
OperationContractViolationError: ()=>OperationContractViolationError,
|
|
75
|
+
ProducerClientNotInitializedError: ()=>ProducerClientNotInitializedError,
|
|
76
|
+
ProducerDomainNotConfiguredError: ()=>ProducerDomainNotConfiguredError,
|
|
77
|
+
configure: ()=>configure,
|
|
78
|
+
createRequest: ()=>createRequest,
|
|
79
|
+
createUploader: ()=>createUploader
|
|
80
|
+
});
|
|
81
|
+
var _modern_js_runtime_utils_node__rspack_import_0 = __webpack_require__("@modern-js/runtime-utils/node");
|
|
82
|
+
var path_to_regexp__rspack_import_1 = __webpack_require__("path-to-regexp");
|
|
83
|
+
var qs__rspack_import_2 = __webpack_require__("qs");
|
|
84
|
+
var _handleRes__rspack_import_3 = __webpack_require__("./handleRes");
|
|
85
|
+
var _transport__rspack_import_4 = __webpack_require__("./transport");
|
|
86
|
+
var _types__rspack_import_5 = __webpack_require__("./types");
|
|
87
|
+
var _utiles__rspack_import_6 = __webpack_require__("./utiles");
|
|
88
|
+
var _requestContext__rspack_import_7 = __webpack_require__("./requestContext");
|
|
89
|
+
var __rspack_reexport = {};
|
|
90
|
+
for(const __rspack_import_key in _requestContext__rspack_import_7)if ([
|
|
91
|
+
"IdentityBindingViolationError",
|
|
92
|
+
"configure",
|
|
93
|
+
"OperationContractViolationError",
|
|
94
|
+
"default",
|
|
95
|
+
"ProducerClientNotInitializedError",
|
|
96
|
+
"ProducerDomainNotConfiguredError",
|
|
97
|
+
"createUploader",
|
|
98
|
+
"CrossOriginEnvelopePolicyError",
|
|
99
|
+
"createRequest"
|
|
100
|
+
].indexOf(__rspack_import_key) < 0) __rspack_reexport[__rspack_import_key] = ()=>_requestContext__rspack_import_7[__rspack_import_key];
|
|
101
|
+
__webpack_require__.d(__webpack_exports__, __rspack_reexport);
|
|
102
|
+
var __rspack_reexport = {};
|
|
103
|
+
for(const __rspack_import_key in _types__rspack_import_5)if ([
|
|
104
|
+
"IdentityBindingViolationError",
|
|
105
|
+
"configure",
|
|
106
|
+
"OperationContractViolationError",
|
|
107
|
+
"default",
|
|
108
|
+
"ProducerClientNotInitializedError",
|
|
109
|
+
"ProducerDomainNotConfiguredError",
|
|
110
|
+
"createUploader",
|
|
111
|
+
"CrossOriginEnvelopePolicyError",
|
|
112
|
+
"createRequest"
|
|
113
|
+
].indexOf(__rspack_import_key) < 0) __rspack_reexport[__rspack_import_key] = ()=>_types__rspack_import_5[__rspack_import_key];
|
|
114
|
+
__webpack_require__.d(__webpack_exports__, __rspack_reexport);
|
|
115
|
+
const realRequest = new Map();
|
|
116
|
+
const realAllowedHeaders = new Map();
|
|
117
|
+
const realResolveHeaders = new Map();
|
|
118
|
+
const realRequireEnvelope = new Map();
|
|
119
|
+
const realAllowCrossOriginEnvelope = new Map();
|
|
120
|
+
const realTransportResilience = new Map();
|
|
121
|
+
const realIdentityBinding = new Map();
|
|
122
|
+
const realOperationContract = new Map();
|
|
123
|
+
const domainMap = new Map();
|
|
124
|
+
const isEmptyDomain = (domain)=>'string' != typeof domain || '' === domain.trim();
|
|
125
|
+
const TRACEPARENT_HEADER = 'traceparent';
|
|
126
|
+
const OPERATION_CONTEXT_DETAIL_HEADER = _types__rspack_import_5.BFF_OPERATION_CONTEXT_DETAIL_HEADER;
|
|
127
|
+
const TRACEPARENT_REGEX = /^00-([0-9a-f]{32})-([0-9a-f]{16})-[0-9a-f]{2}$/i;
|
|
128
|
+
const isStrictDefaultRequestIdEnabled = ()=>'true' === process.env.MODERN_BFF_STRICT_DEFAULT_REQUEST_ID;
|
|
129
|
+
const isSecuredRequestId = (requestId)=>'default' !== requestId || isStrictDefaultRequestIdEnabled();
|
|
130
|
+
const firstHeaderValue = (value)=>Array.isArray(value) ? value[0] : value;
|
|
131
|
+
const findHeaderKey = (headers, header)=>{
|
|
132
|
+
const normalized = header.toLowerCase();
|
|
133
|
+
return Object.keys(headers).find((key)=>key.toLowerCase() === normalized);
|
|
134
|
+
};
|
|
135
|
+
const readHeader = (headers, header)=>{
|
|
136
|
+
const key = findHeaderKey(headers, header);
|
|
137
|
+
return 'string' == typeof key ? headers[key] : void 0;
|
|
138
|
+
};
|
|
139
|
+
const writeHeader = (headers, header, value)=>{
|
|
140
|
+
if (void 0 === value) return;
|
|
141
|
+
const key = findHeaderKey(headers, header);
|
|
142
|
+
if ('string' == typeof key && key !== header) delete headers[key];
|
|
143
|
+
headers[header] = value;
|
|
144
|
+
};
|
|
145
|
+
const deleteHeader = (headers, header)=>{
|
|
146
|
+
const key = findHeaderKey(headers, header);
|
|
147
|
+
if ('string' == typeof key) delete headers[key];
|
|
148
|
+
};
|
|
149
|
+
const toOrigin = (value)=>{
|
|
150
|
+
if (!value) return;
|
|
151
|
+
try {
|
|
152
|
+
return new URL(value).origin;
|
|
153
|
+
} catch (error) {
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
};
|
|
157
|
+
const parseTraceparent = (value)=>{
|
|
158
|
+
const traceparent = firstHeaderValue(value);
|
|
159
|
+
if ('string' != typeof traceparent) return;
|
|
160
|
+
const match = traceparent.trim().match(TRACEPARENT_REGEX);
|
|
161
|
+
if (!match) return;
|
|
162
|
+
const [, traceId, spanId] = match;
|
|
163
|
+
if (!traceId || !spanId) return;
|
|
164
|
+
return {
|
|
165
|
+
traceId: traceId.toLowerCase(),
|
|
166
|
+
spanId: spanId.toLowerCase()
|
|
167
|
+
};
|
|
168
|
+
};
|
|
169
|
+
const resolveSourceOrigin = (headers)=>{
|
|
170
|
+
const origin = toOrigin(firstHeaderValue(headers.origin));
|
|
171
|
+
if (origin) return origin;
|
|
172
|
+
const referer = toOrigin(firstHeaderValue(headers.referer));
|
|
173
|
+
if (referer) return referer;
|
|
174
|
+
const host = firstHeaderValue(headers.host);
|
|
175
|
+
if (!host) return;
|
|
176
|
+
const proto = firstHeaderValue(headers['x-forwarded-proto']) || 'http';
|
|
177
|
+
return `${proto}://${host}`;
|
|
178
|
+
};
|
|
179
|
+
const extractPathParamNames = (path)=>Array.from(path.matchAll(/:([A-Za-z0-9_]+)/g)).map(([, key])=>key);
|
|
180
|
+
const originFetch = (...params)=>{
|
|
181
|
+
const [, init] = params;
|
|
182
|
+
if (init?.method?.toLowerCase() === 'get') init.body = void 0;
|
|
183
|
+
return fetch(...params).then(_handleRes__rspack_import_3.handleRes);
|
|
184
|
+
};
|
|
185
|
+
const buildOperationContext = ({ requestId, method, path, operationContext, traceparent })=>{
|
|
186
|
+
const routePath = operationContext?.routePath || path;
|
|
187
|
+
const operationMethod = (operationContext?.method || method || 'GET').toUpperCase();
|
|
188
|
+
const rawOperationId = operationContext?.operationId || `${operationMethod}:${routePath}`;
|
|
189
|
+
const operationId = rawOperationId.startsWith(`${requestId}:`) ? rawOperationId : `${requestId}:${rawOperationId}`;
|
|
190
|
+
const traceparentValue = operationContext?.traceparent || ('string' == typeof firstHeaderValue(traceparent) ? String(firstHeaderValue(traceparent)) : void 0);
|
|
191
|
+
const parsedTraceContext = operationContext?.traceId && operationContext?.spanId ? {
|
|
192
|
+
traceId: operationContext.traceId,
|
|
193
|
+
spanId: operationContext.spanId
|
|
194
|
+
} : parseTraceparent(traceparentValue);
|
|
195
|
+
return {
|
|
196
|
+
requestId,
|
|
197
|
+
operationId,
|
|
198
|
+
routePath,
|
|
199
|
+
method: operationMethod,
|
|
200
|
+
...operationContext?.schemaHash ? {
|
|
201
|
+
schemaHash: operationContext.schemaHash
|
|
202
|
+
} : {},
|
|
203
|
+
...'number' == typeof operationContext?.operationVersion ? {
|
|
204
|
+
operationVersion: operationContext.operationVersion
|
|
205
|
+
} : {},
|
|
206
|
+
...traceparentValue ? {
|
|
207
|
+
traceparent: traceparentValue
|
|
208
|
+
} : {},
|
|
209
|
+
...parsedTraceContext ? {
|
|
210
|
+
traceId: parsedTraceContext.traceId,
|
|
211
|
+
spanId: parsedTraceContext.spanId
|
|
212
|
+
} : {}
|
|
213
|
+
};
|
|
214
|
+
};
|
|
215
|
+
class ProducerClientNotInitializedError extends Error {
|
|
216
|
+
constructor(requestId){
|
|
217
|
+
super(`Producer client "${requestId}" is not initialized. Call initProducerClient() (or configure()) before using generated APIs for this requestId.`), this.code = 'BFF_PRODUCER_CLIENT_NOT_INITIALIZED';
|
|
218
|
+
this.name = 'ProducerClientNotInitializedError';
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
class ProducerDomainNotConfiguredError extends Error {
|
|
222
|
+
constructor(requestId){
|
|
223
|
+
super(`Producer client "${requestId}" must provide setDomain() during configure().`), this.code = 'BFF_PRODUCER_DOMAIN_NOT_CONFIGURED';
|
|
224
|
+
this.name = 'ProducerDomainNotConfiguredError';
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
class CrossOriginEnvelopePolicyError extends Error {
|
|
228
|
+
constructor(requestId, sourceOrigin, targetOrigin){
|
|
229
|
+
super(`Cross-origin envelope is not allowed for producer "${requestId}" (${sourceOrigin || 'unknown-origin'} -> ${targetOrigin || 'unknown-origin'}). Configure allowCrossOriginEnvelope to explicitly allow this flow.`), this.code = 'BFF_CROSS_ORIGIN_ENVELOPE_NOT_ALLOWED';
|
|
230
|
+
this.name = 'CrossOriginEnvelopePolicyError';
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
class IdentityBindingViolationError extends Error {
|
|
234
|
+
constructor(violation){
|
|
235
|
+
super(`Identity header "${violation.header}" for producer "${violation.requestId}" was rejected by server-derived identity binding.`), this.code = 'BFF_IDENTITY_BINDING_VIOLATION';
|
|
236
|
+
this.name = 'IdentityBindingViolationError';
|
|
237
|
+
this.violation = violation;
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
class OperationContractViolationError extends Error {
|
|
241
|
+
constructor(violation){
|
|
242
|
+
super(`Operation contract violation "${violation.reason}" for producer "${violation.requestId}" operation "${violation.operationId}".`), this.code = 'BFF_OPERATION_CONTRACT_VIOLATION';
|
|
243
|
+
this.name = 'OperationContractViolationError';
|
|
244
|
+
this.violation = violation;
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
const validateOperationContract = (requestId, contextPayload)=>{
|
|
248
|
+
const operationContract = realOperationContract.get(requestId);
|
|
249
|
+
const operationContractEnabled = operationContract?.enabled ?? isSecuredRequestId(requestId);
|
|
250
|
+
if (!operationContractEnabled) return;
|
|
251
|
+
const strict = operationContract?.strict ?? true;
|
|
252
|
+
const requireSchemaHash = operationContract?.requireSchemaHash ?? true;
|
|
253
|
+
const requireOperationVersion = operationContract?.requireOperationVersion ?? true;
|
|
254
|
+
const maybeReportViolation = (reason)=>{
|
|
255
|
+
const violation = {
|
|
256
|
+
requestId,
|
|
257
|
+
target: 'server',
|
|
258
|
+
operationId: contextPayload.operationId,
|
|
259
|
+
routePath: contextPayload.routePath,
|
|
260
|
+
method: contextPayload.method,
|
|
261
|
+
schemaHash: 'string' == typeof contextPayload.schemaHash ? contextPayload.schemaHash : void 0,
|
|
262
|
+
operationVersion: 'number' == typeof contextPayload.operationVersion ? contextPayload.operationVersion : void 0,
|
|
263
|
+
reason
|
|
264
|
+
};
|
|
265
|
+
operationContract?.onViolation?.(violation);
|
|
266
|
+
if (strict) throw new OperationContractViolationError(violation);
|
|
267
|
+
};
|
|
268
|
+
if (requireSchemaHash && 'string' != typeof contextPayload.schemaHash) maybeReportViolation('missing_schema_hash');
|
|
269
|
+
if (requireOperationVersion && 'number' != typeof contextPayload.operationVersion) maybeReportViolation('missing_operation_version');
|
|
270
|
+
};
|
|
271
|
+
const getConfiguredRequest = (requestId, fallback)=>{
|
|
272
|
+
const configuredRequest = realRequest.get(requestId);
|
|
273
|
+
if (configuredRequest) return configuredRequest;
|
|
274
|
+
if ('default' !== requestId) throw new ProducerClientNotInitializedError(requestId);
|
|
275
|
+
return fallback;
|
|
276
|
+
};
|
|
277
|
+
const configure = (options)=>{
|
|
278
|
+
const { request, interceptor, allowedHeaders, resolveHeaders, transport, requireEnvelope, allowCrossOriginEnvelope, identityBinding, operationContract, setDomain, requestId = 'default' } = options;
|
|
279
|
+
const hasExistingDomain = domainMap.has(requestId);
|
|
280
|
+
if ('default' !== requestId && !setDomain && !hasExistingDomain) throw new ProducerDomainNotConfiguredError(requestId);
|
|
281
|
+
let configuredRequest = request || originFetch;
|
|
282
|
+
if (interceptor && !request) configuredRequest = interceptor(fetch);
|
|
283
|
+
if (Array.isArray(allowedHeaders)) realAllowedHeaders.set(requestId, allowedHeaders);
|
|
284
|
+
if ('function' == typeof resolveHeaders) realResolveHeaders.set(requestId, resolveHeaders);
|
|
285
|
+
if (transport && 'object' == typeof transport) realTransportResilience.set(requestId, transport);
|
|
286
|
+
if (identityBinding && 'object' == typeof identityBinding) realIdentityBinding.set(requestId, identityBinding);
|
|
287
|
+
if (operationContract && 'object' == typeof operationContract) realOperationContract.set(requestId, operationContract);
|
|
288
|
+
if ('boolean' == typeof requireEnvelope) realRequireEnvelope.set(requestId, requireEnvelope);
|
|
289
|
+
if ('boolean' == typeof allowCrossOriginEnvelope || 'function' == typeof allowCrossOriginEnvelope) realAllowCrossOriginEnvelope.set(requestId, allowCrossOriginEnvelope);
|
|
290
|
+
if (setDomain) {
|
|
291
|
+
const resolvedDomain = setDomain({
|
|
292
|
+
target: 'server',
|
|
293
|
+
requestId
|
|
294
|
+
});
|
|
295
|
+
if ('default' !== requestId && isEmptyDomain(resolvedDomain)) throw new ProducerDomainNotConfiguredError(requestId);
|
|
296
|
+
if ('string' == typeof resolvedDomain) domainMap.set(requestId, resolvedDomain);
|
|
297
|
+
}
|
|
298
|
+
realRequest.set(requestId, configuredRequest);
|
|
299
|
+
};
|
|
300
|
+
const normalizeRequestOptions = (...args)=>{
|
|
301
|
+
if ('object' == typeof args[0] && null !== args[0]) return args[0];
|
|
302
|
+
const [path, method, port, httpMethodDecider, fetch1, requestId, operationContext] = args;
|
|
303
|
+
return {
|
|
304
|
+
path,
|
|
305
|
+
method,
|
|
306
|
+
port,
|
|
307
|
+
httpMethodDecider,
|
|
308
|
+
fetch: fetch1,
|
|
309
|
+
requestId,
|
|
310
|
+
operationContext
|
|
311
|
+
};
|
|
312
|
+
};
|
|
313
|
+
const createRequest = (...args)=>{
|
|
314
|
+
const { path, method, port, httpMethodDecider = 'functionName', fetch: fetch1 = originFetch, requestId = 'default', operationContext } = normalizeRequestOptions(...args);
|
|
315
|
+
const getFinalPath = (0, path_to_regexp__rspack_import_1.compile)(path, {
|
|
316
|
+
encode: encodeURIComponent
|
|
317
|
+
});
|
|
318
|
+
const keyNames = extractPathParamNames(path);
|
|
319
|
+
const sender = (...args)=>{
|
|
320
|
+
const fetcher = getConfiguredRequest(requestId, fetch1);
|
|
321
|
+
let webRequestHeaders = {};
|
|
322
|
+
try {
|
|
323
|
+
webRequestHeaders = _modern_js_runtime_utils_node__rspack_import_0.storage.useContext().headers || {};
|
|
324
|
+
} catch (error) {
|
|
325
|
+
webRequestHeaders = {};
|
|
326
|
+
}
|
|
327
|
+
let body;
|
|
328
|
+
let headers;
|
|
329
|
+
let url;
|
|
330
|
+
if ('inputParams' === httpMethodDecider) {
|
|
331
|
+
const configDomain = domainMap.get(requestId);
|
|
332
|
+
if ('default' !== requestId && isEmptyDomain(configDomain)) throw new ProducerDomainNotConfiguredError(requestId);
|
|
333
|
+
url = `${configDomain || `http://127.0.0.1:${port}`}${path}`;
|
|
334
|
+
body = args;
|
|
335
|
+
headers = {
|
|
336
|
+
'Content-Type': 'application/json'
|
|
337
|
+
};
|
|
338
|
+
} else {
|
|
339
|
+
const payload = 'object' == typeof args[args.length - 1] ? args[args.length - 1] : {};
|
|
340
|
+
payload.params = payload.params || {};
|
|
341
|
+
const requestParams = args[0];
|
|
342
|
+
if ('object' == typeof requestParams && requestParams.params) {
|
|
343
|
+
const { params } = requestParams;
|
|
344
|
+
keyNames.forEach((keyName)=>{
|
|
345
|
+
payload.params[keyName] = params[keyName];
|
|
346
|
+
});
|
|
347
|
+
} else keyNames.forEach((keyName, index)=>{
|
|
348
|
+
payload.params[keyName] = args[index];
|
|
349
|
+
});
|
|
350
|
+
const plainPath = getFinalPath(payload.params);
|
|
351
|
+
const finalPath = payload.query ? `${plainPath}?${(0, qs__rspack_import_2.stringify)(payload.query)}` : plainPath;
|
|
352
|
+
headers = payload.headers ? {
|
|
353
|
+
...payload.headers
|
|
354
|
+
} : {};
|
|
355
|
+
const identityBinding = realIdentityBinding.get(requestId);
|
|
356
|
+
const identityBindingEnabled = identityBinding?.enabled ?? isSecuredRequestId(requestId);
|
|
357
|
+
const identityBindingStrict = identityBinding?.strict ?? isSecuredRequestId(requestId);
|
|
358
|
+
const protectedIdentityHeaders = (identityBinding?.protectedHeaders || _types__rspack_import_5.BFF_DEFAULT_PROTECTED_IDENTITY_HEADERS).map((header)=>header.toLowerCase());
|
|
359
|
+
const targetAllowedHeaders = realAllowedHeaders.get(requestId) || [];
|
|
360
|
+
const forwardedHeaders = {};
|
|
361
|
+
for (const key of targetAllowedHeaders)if (void 0 !== webRequestHeaders[key]) forwardedHeaders[key] = webRequestHeaders[key];
|
|
362
|
+
if (identityBindingEnabled) {
|
|
363
|
+
const derivedIdentityHeaders = {};
|
|
364
|
+
for (const header of protectedIdentityHeaders){
|
|
365
|
+
const incomingHeaderValue = readHeader(webRequestHeaders, header);
|
|
366
|
+
if (void 0 !== incomingHeaderValue) writeHeader(derivedIdentityHeaders, header, incomingHeaderValue);
|
|
367
|
+
}
|
|
368
|
+
const customDerivedHeaders = identityBinding?.deriveHeaders?.({
|
|
369
|
+
requestId,
|
|
370
|
+
target: 'server',
|
|
371
|
+
incomingHeaders: {
|
|
372
|
+
...webRequestHeaders
|
|
373
|
+
},
|
|
374
|
+
protectedHeaders: [
|
|
375
|
+
...protectedIdentityHeaders
|
|
376
|
+
]
|
|
377
|
+
});
|
|
378
|
+
if (customDerivedHeaders && 'object' == typeof customDerivedHeaders) for (const header of protectedIdentityHeaders){
|
|
379
|
+
const customValue = readHeader(customDerivedHeaders, header);
|
|
380
|
+
if (void 0 !== customValue) writeHeader(derivedIdentityHeaders, header, customValue);
|
|
381
|
+
}
|
|
382
|
+
for (const header of protectedIdentityHeaders){
|
|
383
|
+
const attemptedValue = readHeader(headers, header);
|
|
384
|
+
if (void 0 === attemptedValue) continue;
|
|
385
|
+
const violation = {
|
|
386
|
+
requestId,
|
|
387
|
+
target: 'server',
|
|
388
|
+
header,
|
|
389
|
+
attemptedValue,
|
|
390
|
+
derivedValue: readHeader(derivedIdentityHeaders, header),
|
|
391
|
+
reason: identityBindingStrict ? 'client_override_rejected' : 'client_override_blocked'
|
|
392
|
+
};
|
|
393
|
+
identityBinding?.onViolation?.(violation);
|
|
394
|
+
if (identityBindingStrict) throw new IdentityBindingViolationError(violation);
|
|
395
|
+
deleteHeader(headers, header);
|
|
396
|
+
}
|
|
397
|
+
Object.keys(derivedIdentityHeaders).forEach((header)=>{
|
|
398
|
+
writeHeader(forwardedHeaders, header, derivedIdentityHeaders[header]);
|
|
399
|
+
});
|
|
400
|
+
}
|
|
401
|
+
const resolveHeaders = realResolveHeaders.get(requestId);
|
|
402
|
+
if (resolveHeaders) {
|
|
403
|
+
const resolvedHeaders = resolveHeaders({
|
|
404
|
+
requestId,
|
|
405
|
+
allowedHeaders: targetAllowedHeaders,
|
|
406
|
+
incomingHeaders: {
|
|
407
|
+
...forwardedHeaders
|
|
408
|
+
}
|
|
409
|
+
});
|
|
410
|
+
if (resolvedHeaders && 'object' == typeof resolvedHeaders) {
|
|
411
|
+
for (const key of targetAllowedHeaders)if (void 0 !== resolvedHeaders[key]) forwardedHeaders[key] = resolvedHeaders[key];
|
|
412
|
+
}
|
|
413
|
+
}
|
|
414
|
+
headers = {
|
|
415
|
+
...headers,
|
|
416
|
+
...forwardedHeaders
|
|
417
|
+
};
|
|
418
|
+
if (payload.data) {
|
|
419
|
+
headers['Content-Type'] = 'application/json';
|
|
420
|
+
body = 'object' == typeof payload.data ? JSON.stringify(payload.data) : payload.body;
|
|
421
|
+
} else if (payload.body) {
|
|
422
|
+
headers['Content-Type'] = 'text/plain';
|
|
423
|
+
body = payload.body;
|
|
424
|
+
} else if (payload.formData) body = payload.formData;
|
|
425
|
+
else if (payload.formUrlencoded) {
|
|
426
|
+
headers['Content-Type'] = 'application/x-www-form-urlencoded';
|
|
427
|
+
body = 'object' == typeof payload.formUrlencoded ? (0, qs__rspack_import_2.stringify)(payload.formUrlencoded) : payload.formUrlencoded;
|
|
428
|
+
}
|
|
429
|
+
const configDomain = domainMap.get(requestId);
|
|
430
|
+
if ('default' !== requestId && isEmptyDomain(configDomain)) throw new ProducerDomainNotConfiguredError(requestId);
|
|
431
|
+
url = `${configDomain || `http://127.0.0.1:${port}`}${finalPath}`;
|
|
432
|
+
}
|
|
433
|
+
if (void 0 === readHeader(headers, TRACEPARENT_HEADER)) {
|
|
434
|
+
const incomingTraceparent = firstHeaderValue(readHeader(webRequestHeaders, TRACEPARENT_HEADER));
|
|
435
|
+
if ('string' == typeof incomingTraceparent) writeHeader(headers, TRACEPARENT_HEADER, incomingTraceparent);
|
|
436
|
+
}
|
|
437
|
+
if (void 0 === readHeader(headers, TRACEPARENT_HEADER) && operationContext?.traceparent) writeHeader(headers, TRACEPARENT_HEADER, operationContext.traceparent);
|
|
438
|
+
const shouldRequireEnvelope = realRequireEnvelope.get(requestId) ?? isSecuredRequestId(requestId);
|
|
439
|
+
if (shouldRequireEnvelope) {
|
|
440
|
+
const sourceOrigin = resolveSourceOrigin(webRequestHeaders);
|
|
441
|
+
const targetOrigin = toOrigin(url);
|
|
442
|
+
const traceContext = parseTraceparent(readHeader(headers, TRACEPARENT_HEADER));
|
|
443
|
+
const isCrossOrigin = Boolean(sourceOrigin) && Boolean(targetOrigin) && sourceOrigin !== targetOrigin;
|
|
444
|
+
if (isCrossOrigin) {
|
|
445
|
+
const policy = realAllowCrossOriginEnvelope.get(requestId);
|
|
446
|
+
const isAllowed = 'function' == typeof policy ? policy({
|
|
447
|
+
requestId,
|
|
448
|
+
sourceOrigin,
|
|
449
|
+
targetOrigin,
|
|
450
|
+
target: 'server'
|
|
451
|
+
}) : true === policy;
|
|
452
|
+
if (!isAllowed) throw new CrossOriginEnvelopePolicyError(requestId, sourceOrigin, targetOrigin);
|
|
453
|
+
}
|
|
454
|
+
headers[_types__rspack_import_5.BFF_ENVELOPE_HEADER] = JSON.stringify({
|
|
455
|
+
requestId,
|
|
456
|
+
target: 'server',
|
|
457
|
+
timestamp: Date.now(),
|
|
458
|
+
sourceOrigin,
|
|
459
|
+
targetOrigin,
|
|
460
|
+
...traceContext ? {
|
|
461
|
+
traceId: traceContext.traceId,
|
|
462
|
+
spanId: traceContext.spanId
|
|
463
|
+
} : {}
|
|
464
|
+
});
|
|
465
|
+
}
|
|
466
|
+
if (isSecuredRequestId(requestId)) {
|
|
467
|
+
const contextPayload = buildOperationContext({
|
|
468
|
+
requestId,
|
|
469
|
+
method,
|
|
470
|
+
path,
|
|
471
|
+
operationContext,
|
|
472
|
+
traceparent: readHeader(headers, TRACEPARENT_HEADER)
|
|
473
|
+
});
|
|
474
|
+
validateOperationContract(requestId, contextPayload);
|
|
475
|
+
if (void 0 === readHeader(headers, _types__rspack_import_5.BFF_OPERATION_CONTEXT_HEADER)) writeHeader(headers, _types__rspack_import_5.BFF_OPERATION_CONTEXT_HEADER, contextPayload.operationId);
|
|
476
|
+
writeHeader(headers, OPERATION_CONTEXT_DETAIL_HEADER, JSON.stringify(contextPayload));
|
|
477
|
+
}
|
|
478
|
+
if ('get' === method.toLowerCase()) body = void 0;
|
|
479
|
+
headers.accept = "application/json,*/*;q=0.8";
|
|
480
|
+
return (0, _transport__rspack_import_4.executeWithResilience)({
|
|
481
|
+
requestId,
|
|
482
|
+
target: 'server',
|
|
483
|
+
method,
|
|
484
|
+
url,
|
|
485
|
+
init: {
|
|
486
|
+
method,
|
|
487
|
+
body,
|
|
488
|
+
headers
|
|
489
|
+
},
|
|
490
|
+
fetcher,
|
|
491
|
+
transport: realTransportResilience.get(requestId)
|
|
492
|
+
});
|
|
493
|
+
};
|
|
494
|
+
return sender;
|
|
495
|
+
};
|
|
496
|
+
const createUploader = ({ path, requestId = 'default' })=>{
|
|
497
|
+
const sender = (...args)=>{
|
|
498
|
+
const fetcher = getConfiguredRequest(requestId, originFetch);
|
|
499
|
+
const { body, headers } = (0, _utiles__rspack_import_6.getUploadPayload)(args);
|
|
500
|
+
const configDomain = domainMap.get(requestId);
|
|
501
|
+
const finalURL = `${configDomain || ''}${path}`;
|
|
502
|
+
return fetcher(finalURL, {
|
|
503
|
+
method: 'POST',
|
|
504
|
+
body,
|
|
505
|
+
headers
|
|
506
|
+
});
|
|
507
|
+
};
|
|
508
|
+
return sender;
|
|
509
|
+
};
|
|
510
|
+
})();
|
|
511
|
+
exports.CrossOriginEnvelopePolicyError = __webpack_exports__.CrossOriginEnvelopePolicyError;
|
|
512
|
+
exports.IdentityBindingViolationError = __webpack_exports__.IdentityBindingViolationError;
|
|
513
|
+
exports.OperationContractViolationError = __webpack_exports__.OperationContractViolationError;
|
|
514
|
+
exports.ProducerClientNotInitializedError = __webpack_exports__.ProducerClientNotInitializedError;
|
|
515
|
+
exports.ProducerDomainNotConfiguredError = __webpack_exports__.ProducerDomainNotConfiguredError;
|
|
516
|
+
exports.configure = __webpack_exports__.configure;
|
|
517
|
+
exports.createRequest = __webpack_exports__.createRequest;
|
|
518
|
+
exports.createUploader = __webpack_exports__.createUploader;
|
|
519
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
520
|
+
"CrossOriginEnvelopePolicyError",
|
|
521
|
+
"IdentityBindingViolationError",
|
|
522
|
+
"OperationContractViolationError",
|
|
523
|
+
"ProducerClientNotInitializedError",
|
|
524
|
+
"ProducerDomainNotConfiguredError",
|
|
525
|
+
"configure",
|
|
526
|
+
"createRequest",
|
|
527
|
+
"createUploader"
|
|
528
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
529
|
+
Object.defineProperty(exports, '__esModule', {
|
|
530
|
+
value: true
|
|
531
|
+
});
|
package/dist/cjs/qs.js
ADDED
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
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
|
+
parse: ()=>external_qs_namespaceObject.parse,
|
|
28
|
+
stringify: ()=>external_qs_namespaceObject.stringify
|
|
29
|
+
});
|
|
30
|
+
const external_qs_namespaceObject = require("qs");
|
|
31
|
+
exports.parse = __webpack_exports__.parse;
|
|
32
|
+
exports.stringify = __webpack_exports__.stringify;
|
|
33
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
34
|
+
"parse",
|
|
35
|
+
"stringify"
|
|
36
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
37
|
+
Object.defineProperty(exports, '__esModule', {
|
|
38
|
+
value: true
|
|
39
|
+
});
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
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
|
+
BFF_LOCALE_HEADER: ()=>BFF_LOCALE_HEADER,
|
|
28
|
+
BFF_TRACEPARENT_HEADER: ()=>BFF_TRACEPARENT_HEADER,
|
|
29
|
+
createRequestContextHeaders: ()=>createRequestContextHeaders,
|
|
30
|
+
createRequestContextSnapshot: ()=>createRequestContextSnapshot
|
|
31
|
+
});
|
|
32
|
+
const BFF_LOCALE_HEADER = 'accept-language';
|
|
33
|
+
const BFF_TRACEPARENT_HEADER = 'traceparent';
|
|
34
|
+
const TRACEPARENT_REGEX = /^00-([0-9a-f]{32})-([0-9a-f]{16})-[0-9a-f]{2}$/i;
|
|
35
|
+
const readHeader = (headers, header)=>{
|
|
36
|
+
if (!headers) return;
|
|
37
|
+
const normalized = header.toLowerCase();
|
|
38
|
+
const key = Object.keys(headers).find((current)=>current.toLowerCase() === normalized);
|
|
39
|
+
if (!key) return;
|
|
40
|
+
const value = headers[key];
|
|
41
|
+
return Array.isArray(value) ? value[0] : value;
|
|
42
|
+
};
|
|
43
|
+
const readString = (value)=>'string' == typeof value && value.length > 0 ? value : void 0;
|
|
44
|
+
function parseTraceparent(traceparent) {
|
|
45
|
+
if (!traceparent) return;
|
|
46
|
+
const match = traceparent.trim().match(TRACEPARENT_REGEX);
|
|
47
|
+
if (!match) return;
|
|
48
|
+
const [, traceId, spanId] = match;
|
|
49
|
+
if (!traceId || !spanId) return;
|
|
50
|
+
return {
|
|
51
|
+
traceId: traceId.toLowerCase(),
|
|
52
|
+
spanId: spanId.toLowerCase()
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
function createRequestContextSnapshot(input = {}) {
|
|
56
|
+
const locale = readString(input.locale) || readString(readHeader(input.headers, BFF_LOCALE_HEADER));
|
|
57
|
+
const traceparent = readString(input.traceparent) || readString(input.operationContext?.traceparent) || readString(readHeader(input.headers, BFF_TRACEPARENT_HEADER));
|
|
58
|
+
const parsedTraceparent = input.operationContext?.traceId && input.operationContext?.spanId ? {
|
|
59
|
+
traceId: input.operationContext.traceId,
|
|
60
|
+
spanId: input.operationContext.spanId
|
|
61
|
+
} : parseTraceparent(traceparent);
|
|
62
|
+
const headers = {};
|
|
63
|
+
if (locale) headers[BFF_LOCALE_HEADER] = locale;
|
|
64
|
+
if (traceparent) headers[BFF_TRACEPARENT_HEADER] = traceparent;
|
|
65
|
+
return {
|
|
66
|
+
headers,
|
|
67
|
+
...locale ? {
|
|
68
|
+
locale
|
|
69
|
+
} : {},
|
|
70
|
+
...traceparent ? {
|
|
71
|
+
traceparent
|
|
72
|
+
} : {},
|
|
73
|
+
...parsedTraceparent ? {
|
|
74
|
+
traceId: parsedTraceparent.traceId,
|
|
75
|
+
spanId: parsedTraceparent.spanId
|
|
76
|
+
} : {}
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
function createRequestContextHeaders(input = {}) {
|
|
80
|
+
return createRequestContextSnapshot(input).headers;
|
|
81
|
+
}
|
|
82
|
+
exports.BFF_LOCALE_HEADER = __webpack_exports__.BFF_LOCALE_HEADER;
|
|
83
|
+
exports.BFF_TRACEPARENT_HEADER = __webpack_exports__.BFF_TRACEPARENT_HEADER;
|
|
84
|
+
exports.createRequestContextHeaders = __webpack_exports__.createRequestContextHeaders;
|
|
85
|
+
exports.createRequestContextSnapshot = __webpack_exports__.createRequestContextSnapshot;
|
|
86
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
87
|
+
"BFF_LOCALE_HEADER",
|
|
88
|
+
"BFF_TRACEPARENT_HEADER",
|
|
89
|
+
"createRequestContextHeaders",
|
|
90
|
+
"createRequestContextSnapshot"
|
|
91
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
92
|
+
Object.defineProperty(exports, '__esModule', {
|
|
93
|
+
value: true
|
|
94
|
+
});
|