@bleedingdev/modern-js-plugin-bff 3.2.0-ultramodern.12 → 3.2.0-ultramodern.121

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 (80) hide show
  1. package/dist/cjs/cli.js +9 -5
  2. package/dist/cjs/constants.js +13 -9
  3. package/dist/cjs/index.js +9 -5
  4. package/dist/cjs/loader.js +32 -5
  5. package/dist/cjs/runtime/create-request/index.js +9 -5
  6. package/dist/cjs/runtime/data-platform/index.js +50 -26
  7. package/dist/cjs/runtime/effect/adapter.js +99 -93
  8. package/dist/cjs/runtime/effect/context.js +19 -7
  9. package/dist/cjs/runtime/effect/edge.js +169 -0
  10. package/dist/cjs/runtime/effect/endpoint-contracts.js +130 -0
  11. package/dist/cjs/runtime/effect/handler.js +642 -0
  12. package/dist/cjs/runtime/effect/index.js +30 -547
  13. package/dist/cjs/runtime/effect/module.js +151 -0
  14. package/dist/cjs/runtime/effect/operation-context.js +103 -0
  15. package/dist/cjs/runtime/effect-client/index.js +22 -6
  16. package/dist/cjs/runtime/effect-client/runtime.js +266 -0
  17. package/dist/cjs/runtime/hono/adapter.js +30 -14
  18. package/dist/cjs/runtime/hono/index.js +9 -5
  19. package/dist/cjs/runtime/hono/operators.js +9 -5
  20. package/dist/cjs/runtime/safe-failure.js +83 -0
  21. package/dist/cjs/server.js +9 -5
  22. package/dist/cjs/utils/clientGenerator.js +13 -9
  23. package/dist/cjs/utils/createHonoRoutes.js +9 -5
  24. package/dist/cjs/utils/crossProjectApiPlugin.js +9 -5
  25. package/dist/cjs/utils/crossProjectServerPolicy.js +104 -0
  26. package/dist/cjs/utils/effectClientGenerator.js +116 -488
  27. package/dist/cjs/utils/pluginGenerator.js +9 -5
  28. package/dist/cjs/utils/runtimeGenerator.js +9 -5
  29. package/dist/esm/loader.mjs +23 -0
  30. package/dist/esm/runtime/data-platform/index.mjs +33 -22
  31. package/dist/esm/runtime/effect/adapter.mjs +91 -89
  32. package/dist/esm/runtime/effect/context.mjs +3 -1
  33. package/dist/esm/runtime/effect/edge.mjs +83 -0
  34. package/dist/esm/runtime/effect/endpoint-contracts.mjs +68 -0
  35. package/dist/esm/runtime/effect/handler.mjs +470 -0
  36. package/dist/esm/runtime/effect/index.mjs +3 -437
  37. package/dist/esm/runtime/effect/module.mjs +113 -0
  38. package/dist/esm/runtime/effect/operation-context.mjs +65 -0
  39. package/dist/esm/runtime/effect-client/index.mjs +14 -2
  40. package/dist/esm/runtime/effect-client/runtime.mjs +228 -0
  41. package/dist/esm/runtime/hono/adapter.mjs +21 -9
  42. package/dist/esm/runtime/safe-failure.mjs +45 -0
  43. package/dist/esm/utils/clientGenerator.mjs +5 -5
  44. package/dist/esm/utils/crossProjectServerPolicy.mjs +50 -0
  45. package/dist/esm/utils/effectClientGenerator.mjs +105 -484
  46. package/dist/esm-node/loader.mjs +23 -0
  47. package/dist/esm-node/runtime/data-platform/index.mjs +33 -22
  48. package/dist/esm-node/runtime/effect/adapter.mjs +91 -89
  49. package/dist/esm-node/runtime/effect/context.mjs +3 -1
  50. package/dist/esm-node/runtime/effect/edge.mjs +84 -0
  51. package/dist/esm-node/runtime/effect/endpoint-contracts.mjs +69 -0
  52. package/dist/esm-node/runtime/effect/handler.mjs +471 -0
  53. package/dist/esm-node/runtime/effect/index.mjs +3 -437
  54. package/dist/esm-node/runtime/effect/module.mjs +114 -0
  55. package/dist/esm-node/runtime/effect/operation-context.mjs +66 -0
  56. package/dist/esm-node/runtime/effect-client/index.mjs +14 -2
  57. package/dist/esm-node/runtime/effect-client/runtime.mjs +229 -0
  58. package/dist/esm-node/runtime/hono/adapter.mjs +21 -9
  59. package/dist/esm-node/runtime/safe-failure.mjs +46 -0
  60. package/dist/esm-node/utils/clientGenerator.mjs +5 -5
  61. package/dist/esm-node/utils/crossProjectServerPolicy.mjs +52 -0
  62. package/dist/esm-node/utils/effectClientGenerator.mjs +105 -484
  63. package/dist/types/runtime/create-request/index.d.ts +1 -0
  64. package/dist/types/runtime/data-platform/index.d.ts +4 -0
  65. package/dist/types/runtime/effect/adapter.d.ts +25 -0
  66. package/dist/types/runtime/effect/context.d.ts +3 -6
  67. package/dist/types/runtime/effect/edge.d.ts +25 -0
  68. package/dist/types/runtime/effect/endpoint-contracts.d.ts +62 -0
  69. package/dist/types/runtime/effect/handler.d.ts +203 -0
  70. package/dist/types/runtime/effect/index.d.ts +2 -170
  71. package/dist/types/runtime/effect/module.d.ts +48 -0
  72. package/dist/types/runtime/effect/operation-context.d.ts +10 -0
  73. package/dist/types/runtime/effect-client/index.d.ts +6 -1
  74. package/dist/types/runtime/effect-client/runtime.d.ts +71 -0
  75. package/dist/types/runtime/hono/adapter.d.ts +3 -0
  76. package/dist/types/runtime/safe-failure.d.ts +1 -0
  77. package/dist/types/utils/createHonoRoutes.d.ts +3 -3
  78. package/dist/types/utils/crossProjectServerPolicy.d.ts +35 -0
  79. package/dist/types/utils/effectClientGenerator.d.ts +16 -2
  80. package/package.json +41 -20
@@ -0,0 +1,151 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, getters, values)=>{
5
+ var define = (defs, kind)=>{
6
+ for(var key in defs)if (__webpack_require__.o(defs, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
7
+ enumerable: true,
8
+ [kind]: defs[key]
9
+ });
10
+ };
11
+ define(getters, "get");
12
+ define(values, "value");
13
+ };
14
+ })();
15
+ (()=>{
16
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
17
+ })();
18
+ (()=>{
19
+ __webpack_require__.r = (exports1)=>{
20
+ if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
21
+ value: 'Module'
22
+ });
23
+ Object.defineProperty(exports1, '__esModule', {
24
+ value: true
25
+ });
26
+ };
27
+ })();
28
+ var __webpack_exports__ = {};
29
+ __webpack_require__.r(__webpack_exports__);
30
+ __webpack_require__.d(__webpack_exports__, {
31
+ resolveEffectBffModuleHandler: ()=>resolveEffectBffModuleHandler
32
+ });
33
+ const Context_namespaceObject = require("effect/Context");
34
+ const httpapi_namespaceObject = require("effect/unstable/httpapi");
35
+ const external_handler_js_namespaceObject = require("./handler.js");
36
+ function isRecord(value) {
37
+ return 'object' == typeof value && null !== value;
38
+ }
39
+ function includesRuntimeExports(value) {
40
+ return 'api' in value || 'layer' in value || 'createHandler' in value || 'handler' in value;
41
+ }
42
+ function isRequestHandler(value) {
43
+ return 'function' == typeof value;
44
+ }
45
+ function isEffectApiDefinition(module) {
46
+ return httpapi_namespaceObject.HttpApi.isHttpApi(module.api) && void 0 !== module.layer;
47
+ }
48
+ function isEffectServiceContext(context) {
49
+ return 'object' == typeof context && null !== context && 'mapUnsafe' in context;
50
+ }
51
+ const emptyEffectServiceContext = Context_namespaceObject.empty();
52
+ function callEffectBffRequestHandler(handler, request, context) {
53
+ return void 0 === context ? handler(request) : handler(request, context);
54
+ }
55
+ function createLoadedHandler(webHandler, appliesRequestValidator) {
56
+ return {
57
+ handler: (request, context)=>callEffectBffRequestHandler(webHandler.handler, request, context),
58
+ dispose: webHandler.dispose,
59
+ ...appliesRequestValidator ? {
60
+ appliesRequestValidator: true
61
+ } : {}
62
+ };
63
+ }
64
+ function createLoadedHttpApiHandler(webHandler) {
65
+ return {
66
+ handler: (request, context)=>{
67
+ const effectContext = isEffectServiceContext(context) ? context : emptyEffectServiceContext;
68
+ return webHandler.handler(request, effectContext);
69
+ },
70
+ dispose: webHandler.dispose,
71
+ appliesRequestValidator: true
72
+ };
73
+ }
74
+ function resolveNormalizedEffectBffModuleHandler(normalizedModule, options = {}) {
75
+ if (isRequestHandler(normalizedModule.handler)) return {
76
+ handler: normalizedModule.handler
77
+ };
78
+ const entry = normalizedModule.default;
79
+ if (isRequestHandler(entry)) return {
80
+ handler: entry
81
+ };
82
+ if (isRecord(entry)) normalizedModule = {
83
+ ...normalizedModule,
84
+ ...entry
85
+ };
86
+ if (isRecord(entry) && 'handler' in entry) {
87
+ const maybeHandler = entry.handler;
88
+ if (isRequestHandler(maybeHandler)) normalizedModule = {
89
+ ...normalizedModule,
90
+ handler: maybeHandler
91
+ };
92
+ }
93
+ if (isRequestHandler(normalizedModule.handler)) return {
94
+ handler: normalizedModule.handler
95
+ };
96
+ if ('function' == typeof normalizedModule.createHandler) {
97
+ const factory = normalizedModule.createHandler;
98
+ const validatorAware = (0, external_handler_js_namespaceObject.isValidatorAwareHandlerFactory)(factory);
99
+ if (!validatorAware && void 0 !== options.validateRequest) options.onWarning?.('[BFF][Effect] Custom createHandler export detected: it cannot be verified to apply validateRequest (cross-project policy), so the policy is enforced by the adapter middleware on the outer request. Batched calls will be denied at the batch POST (it carries no per-operation contract); export defineEffectBff(...) to get per-batch-item enforcement.');
100
+ const webHandler = factory({
101
+ openapi: options.openapi,
102
+ dataPlatform: options.dataPlatform,
103
+ validateRequest: options.validateRequest
104
+ });
105
+ return createLoadedHandler(webHandler, validatorAware);
106
+ }
107
+ if (isEffectApiDefinition(normalizedModule)) {
108
+ options.onWarning?.('[BFF][Effect] Detected { api, layer } export without createHandler. Prefer `defineEffectBff(...)` from @modern-js/plugin-bff/server to avoid module instance mismatch.');
109
+ const webHandler = (0, external_handler_js_namespaceObject.createHttpApiHandler)({
110
+ api: normalizedModule.api,
111
+ layer: normalizedModule.layer,
112
+ openapi: options.openapi,
113
+ dataPlatform: options.dataPlatform,
114
+ validateRequest: options.validateRequest
115
+ });
116
+ return createLoadedHttpApiHandler(webHandler);
117
+ }
118
+ return null;
119
+ }
120
+ function resolveEffectBffModuleHandler(mod, options = {}) {
121
+ let normalizedModule = mod;
122
+ const mergeRuntimeExports = (value)=>{
123
+ if (!isRecord(value) || !includesRuntimeExports(value)) return;
124
+ normalizedModule = {
125
+ ...normalizedModule,
126
+ ...value
127
+ };
128
+ };
129
+ if (isRequestHandler(normalizedModule.handler)) return Promise.resolve({
130
+ handler: normalizedModule.handler
131
+ });
132
+ const entry = normalizedModule.default;
133
+ if (isRequestHandler(entry)) return Promise.resolve({
134
+ handler: entry
135
+ });
136
+ if ('function' == typeof entry && 0 === entry.length) return Promise.resolve(entry()).then((out)=>{
137
+ if (isRequestHandler(out)) return {
138
+ handler: out
139
+ };
140
+ mergeRuntimeExports(out);
141
+ return resolveNormalizedEffectBffModuleHandler(normalizedModule, options);
142
+ });
143
+ return Promise.resolve(resolveNormalizedEffectBffModuleHandler(normalizedModule, options));
144
+ }
145
+ exports.resolveEffectBffModuleHandler = __webpack_exports__.resolveEffectBffModuleHandler;
146
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
147
+ "resolveEffectBffModuleHandler"
148
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
149
+ Object.defineProperty(exports, '__esModule', {
150
+ value: true
151
+ });
@@ -0,0 +1,103 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, getters, values)=>{
5
+ var define = (defs, kind)=>{
6
+ for(var key in defs)if (__webpack_require__.o(defs, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
7
+ enumerable: true,
8
+ [kind]: defs[key]
9
+ });
10
+ };
11
+ define(getters, "get");
12
+ define(values, "value");
13
+ };
14
+ })();
15
+ (()=>{
16
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
17
+ })();
18
+ (()=>{
19
+ __webpack_require__.r = (exports1)=>{
20
+ if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
21
+ value: 'Module'
22
+ });
23
+ Object.defineProperty(exports1, '__esModule', {
24
+ value: true
25
+ });
26
+ };
27
+ })();
28
+ var __webpack_exports__ = {};
29
+ __webpack_require__.r(__webpack_exports__);
30
+ __webpack_require__.d(__webpack_exports__, {
31
+ createEffectOperationContext: ()=>createEffectOperationContext
32
+ });
33
+ const create_request_namespaceObject = require("@modern-js/create-request");
34
+ const readHeader = (headers, header)=>{
35
+ const value = headers.get(header);
36
+ return value && value.length > 0 ? value : void 0;
37
+ };
38
+ const copyStringField = (target, details, key)=>{
39
+ const value = details[key];
40
+ if ('string' == typeof value && value.length > 0) target[key] = value;
41
+ };
42
+ const readOperationContextDetails = (request)=>{
43
+ const rawDetails = readHeader(request.headers, create_request_namespaceObject.BFF_OPERATION_CONTEXT_DETAIL_HEADER);
44
+ if (!rawDetails) return {};
45
+ try {
46
+ const parsed = JSON.parse(rawDetails);
47
+ if (!parsed || 'object' != typeof parsed || Array.isArray(parsed)) return {};
48
+ const details = parsed;
49
+ const safeDetails = {};
50
+ copyStringField(safeDetails, details, 'requestId');
51
+ copyStringField(safeDetails, details, 'operationId');
52
+ copyStringField(safeDetails, details, 'schemaHash');
53
+ copyStringField(safeDetails, details, 'traceparent');
54
+ copyStringField(safeDetails, details, 'traceId');
55
+ copyStringField(safeDetails, details, 'spanId');
56
+ if ('number' == typeof details.operationVersion) safeDetails.operationVersion = details.operationVersion;
57
+ return safeDetails;
58
+ } catch {
59
+ return {};
60
+ }
61
+ };
62
+ const createEffectOperationContext = ({ request, path, method })=>{
63
+ const details = readOperationContextDetails(request);
64
+ const servicePath = new URL(request.url).pathname;
65
+ const traceparent = readHeader(request.headers, create_request_namespaceObject.BFF_TRACEPARENT_HEADER) || details.traceparent;
66
+ const parsedTraceparent = details.traceId && details.spanId ? {
67
+ traceId: details.traceId,
68
+ spanId: details.spanId
69
+ } : (0, create_request_namespaceObject.parseTraceparent)(traceparent);
70
+ const locale = readHeader(request.headers, create_request_namespaceObject.BFF_LOCALE_HEADER);
71
+ const headerOperationId = readHeader(request.headers, create_request_namespaceObject.BFF_OPERATION_CONTEXT_HEADER);
72
+ return {
73
+ ...details,
74
+ ...headerOperationId || details.operationId ? {
75
+ operationId: headerOperationId || details.operationId
76
+ } : {},
77
+ routePath: servicePath,
78
+ method: (method || request.method || 'GET').toUpperCase(),
79
+ source: 'effect-adapter',
80
+ ...path && path !== servicePath ? {
81
+ attributes: {
82
+ mountedPath: path
83
+ }
84
+ } : {},
85
+ ...locale ? {
86
+ locale
87
+ } : {},
88
+ ...traceparent ? {
89
+ traceparent
90
+ } : {},
91
+ ...parsedTraceparent ? {
92
+ traceId: parsedTraceparent.traceId,
93
+ spanId: parsedTraceparent.spanId
94
+ } : {}
95
+ };
96
+ };
97
+ exports.createEffectOperationContext = __webpack_exports__.createEffectOperationContext;
98
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
99
+ "createEffectOperationContext"
100
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
101
+ Object.defineProperty(exports, '__esModule', {
102
+ value: true
103
+ });
@@ -1,11 +1,15 @@
1
1
  "use strict";
2
2
  var __webpack_require__ = {};
3
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
- });
4
+ __webpack_require__.d = (exports1, getters, values)=>{
5
+ var define = (defs, kind)=>{
6
+ for(var key in defs)if (__webpack_require__.o(defs, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
7
+ enumerable: true,
8
+ [kind]: defs[key]
9
+ });
10
+ };
11
+ define(getters, "get");
12
+ define(values, "value");
9
13
  };
10
14
  })();
11
15
  (()=>{
@@ -45,6 +49,7 @@ __webpack_require__.d(__webpack_exports__, {
45
49
  runEffectView: ()=>runEffectView,
46
50
  view: ()=>view
47
51
  });
52
+ const create_request_namespaceObject = require("@modern-js/create-request");
48
53
  const Data_namespaceObject = require("effect/Data");
49
54
  const Effect_namespaceObject = require("effect/Effect");
50
55
  const Exit_namespaceObject = require("effect/Exit");
@@ -94,8 +99,19 @@ function getRpcSerializationLayer(serialization) {
94
99
  }
95
100
  }
96
101
  function makeEffectHttpApiClient(api, options) {
102
+ const requestContextHeaders = (0, create_request_namespaceObject.createRequestContextHeaders)(options?.requestContext);
103
+ const transformClient = (client)=>{
104
+ const contextClient = 0 === Object.keys(requestContextHeaders).length ? client : client.pipe(http_namespaceObject.HttpClient.mapRequest((request)=>{
105
+ let nextRequest = request;
106
+ for (const [header, value] of Object.entries(requestContextHeaders))if (void 0 === nextRequest.headers[header.toLowerCase()]) nextRequest = http_namespaceObject.HttpClientRequest.setHeader(nextRequest, header, value);
107
+ return nextRequest;
108
+ }));
109
+ return 'function' == typeof options?.transformClient ? options.transformClient(contextClient) : contextClient;
110
+ };
97
111
  return httpapi_namespaceObject.HttpApiClient.make(api, {
98
- baseUrl: options?.baseUrl
112
+ baseUrl: options?.baseUrl,
113
+ transformClient,
114
+ transformResponse: options?.transformResponse
99
115
  }).pipe(Effect_namespaceObject.provide(http_namespaceObject.FetchHttpClient.layer));
100
116
  }
101
117
  function makeEffectRpcClient(group, options) {
@@ -0,0 +1,266 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, getters, values)=>{
5
+ var define = (defs, kind)=>{
6
+ for(var key in defs)if (__webpack_require__.o(defs, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
7
+ enumerable: true,
8
+ [kind]: defs[key]
9
+ });
10
+ };
11
+ define(getters, "get");
12
+ define(values, "value");
13
+ };
14
+ })();
15
+ (()=>{
16
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
17
+ })();
18
+ (()=>{
19
+ __webpack_require__.r = (exports1)=>{
20
+ if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
21
+ value: 'Module'
22
+ });
23
+ Object.defineProperty(exports1, '__esModule', {
24
+ value: true
25
+ });
26
+ };
27
+ })();
28
+ var __webpack_exports__ = {};
29
+ __webpack_require__.r(__webpack_exports__);
30
+ __webpack_require__.d(__webpack_exports__, {
31
+ createGeneratedEffectClient: ()=>createGeneratedEffectClient
32
+ });
33
+ const index_js_namespaceObject = require("../data-platform/index.js");
34
+ const METHODS_WITHOUT_BODY = new Set([
35
+ 'GET',
36
+ 'DELETE',
37
+ 'HEAD',
38
+ 'OPTIONS'
39
+ ]);
40
+ const DATA_REQUEST_MODES = new Set([
41
+ 'cache-first',
42
+ 'stale-while-revalidate',
43
+ 'network-only'
44
+ ]);
45
+ const DATA_MUTATION_MODES = new Set([
46
+ 'optimistic',
47
+ 'pessimistic',
48
+ 'fire-and-forget'
49
+ ]);
50
+ const isRecord = (value)=>'object' == typeof value && null !== value;
51
+ const stringOrUndefined = (value)=>'string' == typeof value && value.length > 0 ? value : void 0;
52
+ const isDataRequestMode = (value)=>'string' == typeof value && DATA_REQUEST_MODES.has(value);
53
+ const isDataMutationMode = (value)=>'string' == typeof value && DATA_MUTATION_MODES.has(value);
54
+ const normalizeOrigin = (value)=>{
55
+ if ('string' != typeof value || 0 === value.length) return;
56
+ try {
57
+ return new URL(value).origin;
58
+ } catch {
59
+ return;
60
+ }
61
+ };
62
+ const resolveRuntimeFetch = ()=>'function' == typeof fetch ? fetch.bind(globalThis) : void 0;
63
+ const resolveOrigin = (defaultOrigin)=>{
64
+ if ("u" > typeof window && window.location && 'string' == typeof window.location.origin && window.location.origin) return window.location.origin;
65
+ const globalLocation = globalThis?.location;
66
+ if (globalLocation && 'string' == typeof globalLocation.origin && globalLocation.origin) return globalLocation.origin;
67
+ return defaultOrigin;
68
+ };
69
+ const normalizeRequest = (method, request)=>{
70
+ if (!isRecord(request)) return {};
71
+ const payload = {
72
+ ...request
73
+ };
74
+ if (isRecord(request.path) && !isRecord(payload.params)) payload.params = request.path;
75
+ if (isRecord(request.urlParams) && !isRecord(payload.query)) payload.query = request.urlParams;
76
+ if (isRecord(request.headers) && !isRecord(payload.headers)) payload.headers = request.headers;
77
+ if ('payload' in request && void 0 !== request.payload) if ("u" > typeof FormData && request.payload instanceof FormData && !('formData' in payload)) payload.formData = request.payload;
78
+ else if (METHODS_WITHOUT_BODY.has(method)) {
79
+ if (isRecord(request.payload)) payload.query = isRecord(payload.query) ? {
80
+ ...payload.query,
81
+ ...request.payload
82
+ } : request.payload;
83
+ else if (!('body' in payload)) payload.body = request.payload;
84
+ } else if (!isRecord(request.payload) || 'data' in payload) {
85
+ if (!('body' in payload)) payload.body = request.payload;
86
+ } else payload.data = request.payload;
87
+ return payload;
88
+ };
89
+ const resolveTargetOrigin = (dataPlatform, defaultOrigin)=>{
90
+ const explicitTargetOrigin = stringOrUndefined(dataPlatform.targetOrigin) || stringOrUndefined(dataPlatform.endpointOrigin);
91
+ if (explicitTargetOrigin) return explicitTargetOrigin;
92
+ return defaultOrigin;
93
+ };
94
+ const shouldAttachEnvelopeHeader = (dataPlatform, defaultOrigin)=>{
95
+ if (true === dataPlatform.allowCrossOriginEnvelope) return true;
96
+ const currentOrigin = normalizeOrigin(resolveOrigin(defaultOrigin));
97
+ const targetOrigin = normalizeOrigin(resolveTargetOrigin(dataPlatform, defaultOrigin));
98
+ if (!currentOrigin || !targetOrigin) return true;
99
+ return currentOrigin === targetOrigin;
100
+ };
101
+ const toEnvelopeInput = (normalizedRequest)=>{
102
+ const payload = {};
103
+ if (isRecord(normalizedRequest.params)) payload.path = normalizedRequest.params;
104
+ if (isRecord(normalizedRequest.query)) payload.query = normalizedRequest.query;
105
+ if ('data' in normalizedRequest && void 0 !== normalizedRequest.data) payload.data = normalizedRequest.data;
106
+ if ('body' in normalizedRequest && void 0 !== normalizedRequest.body) payload.body = normalizedRequest.body;
107
+ if ("u" > typeof FormData && normalizedRequest.formData instanceof FormData) payload.formData = Array.from(normalizedRequest.formData.entries()).map(([key, value])=>[
108
+ key,
109
+ String(value)
110
+ ]);
111
+ if ("u" > typeof URLSearchParams && normalizedRequest.formUrlencoded instanceof URLSearchParams) payload.formUrlencoded = normalizedRequest.formUrlencoded.toString();
112
+ return payload;
113
+ };
114
+ const createGeneratedEffectClient = (manifest, config, requestRuntime)=>{
115
+ const createRequest = requestRuntime.createRequest;
116
+ const configureRequest = 'function' == typeof requestRuntime.configure ? requestRuntime.configure : void 0;
117
+ const createRequestContextHeaders = 'function' == typeof requestRuntime.createRequestContextHeaders ? requestRuntime.createRequestContextHeaders : void 0;
118
+ const defaultOrigin = config.defaultOrigin;
119
+ const httpMethodDecider = config.httpMethodDecider || 'functionName';
120
+ const port = config.useEnvPort && "u" > typeof process && process.env && process.env.PORT ? process.env.PORT : config.port;
121
+ if (config.requestId && configureRequest) {
122
+ const configurePayload = {
123
+ requestId: config.requestId,
124
+ requireEnvelope: true,
125
+ identityBinding: {
126
+ enabled: true,
127
+ strict: true
128
+ },
129
+ operationContract: {
130
+ enabled: true,
131
+ strict: true,
132
+ requireSchemaHash: true,
133
+ requireOperationVersion: true
134
+ },
135
+ setDomain: ()=>resolveOrigin(defaultOrigin)
136
+ };
137
+ const runtimeFetch = resolveRuntimeFetch();
138
+ if (false !== config.batch.enabled && runtimeFetch) configurePayload.request = (0, index_js_namespaceObject.createDataBatchTransport)({
139
+ fetch: runtimeFetch,
140
+ endpoint: config.batch.endpoint,
141
+ flushIntervalMs: config.batch.flushIntervalMs,
142
+ maxBatchSize: config.batch.maxBatchSize,
143
+ maxBatchBytes: config.batch.maxBatchBytes,
144
+ requestTimeoutMs: config.batch.requestTimeoutMs,
145
+ allowedMethods: config.batch.allowedMethods
146
+ });
147
+ configureRequest(configurePayload);
148
+ }
149
+ const createEffectRequestContext = (requestContext)=>{
150
+ if (!isRecord(requestContext)) return {};
151
+ const headers = createRequestContextHeaders ? createRequestContextHeaders(requestContext) : {};
152
+ return {
153
+ ...requestContext,
154
+ headers
155
+ };
156
+ };
157
+ const applyRequestContext = (normalizedRequest, request)=>{
158
+ if (!isRecord(request) || !isRecord(request.requestContext)) return normalizedRequest;
159
+ const requestContext = createEffectRequestContext(request.requestContext);
160
+ const requestHeaders = isRecord(requestContext.headers) ? requestContext.headers : {};
161
+ if (0 === Object.keys(requestHeaders).length) return normalizedRequest;
162
+ return {
163
+ ...normalizedRequest,
164
+ headers: {
165
+ ...requestHeaders,
166
+ ...isRecord(normalizedRequest.headers) ? normalizedRequest.headers : {}
167
+ }
168
+ };
169
+ };
170
+ const prepareEffectRequest = (endpoint, operation, request)=>{
171
+ const normalizedRequest = applyRequestContext(normalizeRequest(endpoint.method, request), request);
172
+ const dataPlatform = isRecord(request) && isRecord(request.dataPlatform) ? request.dataPlatform : {};
173
+ const strictEnvelope = true === dataPlatform.requireEnvelope || true === dataPlatform.strict;
174
+ if (!strictEnvelope && !shouldAttachEnvelopeHeader(dataPlatform, defaultOrigin)) return normalizedRequest;
175
+ try {
176
+ const namespace = stringOrUndefined(dataPlatform.appNamespace) || config.appNamespace;
177
+ const origin = stringOrUndefined(dataPlatform.origin) || resolveOrigin(defaultOrigin);
178
+ const envelope = (0, index_js_namespaceObject.createRequestEnvelope)({
179
+ operation: {
180
+ ...operation,
181
+ appNamespace: namespace
182
+ },
183
+ scope: {
184
+ appNamespace: namespace,
185
+ origin,
186
+ tenantId: stringOrUndefined(dataPlatform.tenantId),
187
+ userId: stringOrUndefined(dataPlatform.userId),
188
+ sessionId: stringOrUndefined(dataPlatform.sessionId)
189
+ },
190
+ requestInput: {
191
+ method: endpoint.method,
192
+ routePath: endpoint.routePath,
193
+ payload: toEnvelopeInput(normalizedRequest)
194
+ },
195
+ requestMode: isDataRequestMode(dataPlatform.requestMode) ? dataPlatform.requestMode : void 0,
196
+ mutationMode: isDataMutationMode(dataPlatform.mutationMode) ? dataPlatform.mutationMode : void 0,
197
+ selectionPlan: isRecord(dataPlatform.selectionPlan) ? dataPlatform.selectionPlan : void 0,
198
+ traceContext: isRecord(dataPlatform.traceContext) ? dataPlatform.traceContext : void 0,
199
+ requireTraceContext: true === dataPlatform.requireTraceContext
200
+ });
201
+ const headerName = stringOrUndefined(dataPlatform.envelopeHeader) || index_js_namespaceObject.DEFAULT_DATA_ENVELOPE_HEADER;
202
+ const headers = isRecord(normalizedRequest.headers) ? {
203
+ ...normalizedRequest.headers
204
+ } : {};
205
+ if (false === dataPlatform.batch) headers[index_js_namespaceObject.DEFAULT_DATA_BATCH_HEADER] = 'off';
206
+ headers[headerName] = (0, index_js_namespaceObject.encodeRequestEnvelopeHeader)(envelope);
207
+ return {
208
+ ...normalizedRequest,
209
+ headers
210
+ };
211
+ } catch (error) {
212
+ if (strictEnvelope) throw error;
213
+ return normalizedRequest;
214
+ }
215
+ };
216
+ const client = {};
217
+ const operationManifest = {};
218
+ for (const endpoint of manifest.endpoints){
219
+ const operationId = `${endpoint.method}:${endpoint.routePath}`;
220
+ const operation = {
221
+ appNamespace: config.appNamespace,
222
+ apiId: endpoint.apiId,
223
+ group: endpoint.group,
224
+ endpoint: endpoint.endpoint,
225
+ operationId,
226
+ routePath: endpoint.routePath,
227
+ method: endpoint.method,
228
+ operationVersion: endpoint.operationVersion,
229
+ schemaHash: endpoint.schemaHash,
230
+ version: endpoint.operationVersion
231
+ };
232
+ const sender = createRequest({
233
+ path: endpoint.routePath,
234
+ method: endpoint.method,
235
+ port,
236
+ operationContext: {
237
+ operationId,
238
+ routePath: endpoint.routePath,
239
+ method: endpoint.method,
240
+ schemaHash: endpoint.schemaHash,
241
+ operationVersion: endpoint.operationVersion
242
+ },
243
+ httpMethodDecider,
244
+ ...config.requestId ? {
245
+ requestId: config.requestId
246
+ } : {}
247
+ });
248
+ const call = (request = {})=>sender(prepareEffectRequest(endpoint, operation, request));
249
+ client[endpoint.group] ??= {};
250
+ client[endpoint.group][endpoint.endpoint] = call;
251
+ operationManifest[endpoint.group] ??= {};
252
+ operationManifest[endpoint.group][endpoint.endpoint] = operation;
253
+ }
254
+ return {
255
+ client,
256
+ operationManifest,
257
+ createEffectRequestContext
258
+ };
259
+ };
260
+ exports.createGeneratedEffectClient = __webpack_exports__.createGeneratedEffectClient;
261
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
262
+ "createGeneratedEffectClient"
263
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
264
+ Object.defineProperty(exports, '__esModule', {
265
+ value: true
266
+ });
@@ -10,11 +10,15 @@ var __webpack_require__ = {};
10
10
  };
11
11
  })();
12
12
  (()=>{
13
- __webpack_require__.d = (exports1, definition)=>{
14
- for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
15
- enumerable: true,
16
- get: definition[key]
17
- });
13
+ __webpack_require__.d = (exports1, getters, values)=>{
14
+ var define = (defs, kind)=>{
15
+ for(var key in defs)if (__webpack_require__.o(defs, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
16
+ enumerable: true,
17
+ [kind]: defs[key]
18
+ });
19
+ };
20
+ define(getters, "get");
21
+ define(values, "value");
18
22
  };
19
23
  })();
20
24
  (()=>{
@@ -39,6 +43,8 @@ const server_core_namespaceObject = require("@modern-js/server-core");
39
43
  const utils_namespaceObject = require("@modern-js/utils");
40
44
  const createHonoRoutes_js_namespaceObject = require("../../utils/createHonoRoutes.js");
41
45
  var createHonoRoutes_js_default = /*#__PURE__*/ __webpack_require__.n(createHonoRoutes_js_namespaceObject);
46
+ const crossProjectServerPolicy_js_namespaceObject = require("../../utils/crossProjectServerPolicy.js");
47
+ const external_safe_failure_js_namespaceObject = require("../safe-failure.js");
42
48
  const before = [
43
49
  'custom-server-hook',
44
50
  'custom-server-middleware',
@@ -56,6 +62,7 @@ class HonoAdapter {
56
62
  this.apiMiddleware = [];
57
63
  this.apiServer = null;
58
64
  this.isHono = true;
65
+ this.prefix = '/api';
59
66
  this.setHandlers = async ()=>{
60
67
  if (!this.isHono) return;
61
68
  const { apiHandlerInfos } = this.api.getServerContext();
@@ -68,6 +75,22 @@ class HonoAdapter {
68
75
  order: 'post',
69
76
  before
70
77
  }));
78
+ this.crossProjectPolicy = (0, crossProjectServerPolicy_js_namespaceObject.resolveAdapterCrossProjectPolicy)(this.api, apiHandlerInfos || []);
79
+ if (this.crossProjectPolicy) {
80
+ const policyMiddleware = async (c, next)=>{
81
+ const denial = (0, crossProjectServerPolicy_js_namespaceObject.checkCrossProjectPolicyResponse)(c.req.header(), this.crossProjectPolicy);
82
+ if (denial) return denial;
83
+ await next();
84
+ };
85
+ this.apiMiddleware.unshift({
86
+ name: 'bff-cross-project-policy',
87
+ path: `${this.prefix}/*`,
88
+ method: 'all',
89
+ handler: policyMiddleware,
90
+ order: 'post',
91
+ before
92
+ });
93
+ }
71
94
  };
72
95
  this.registerApiRoutes = async ()=>{
73
96
  if (!this.isHono) return;
@@ -104,15 +127,7 @@ class HonoAdapter {
104
127
  } catch (configError) {
105
128
  utils_namespaceObject.logger.error(`Error in serverConfig.onError handler: ${configError}`);
106
129
  }
107
- const status = 'object' == typeof err && null !== err && 'status' in err && 'number' == typeof err.status ? err.status : 500;
108
- return new Response(JSON.stringify({
109
- message: err instanceof Error ? err.message : '[BFF] Internal Server Error'
110
- }), {
111
- status,
112
- headers: {
113
- 'content-type': 'application/json; charset=utf-8'
114
- }
115
- });
130
+ return (0, external_safe_failure_js_namespaceObject.createSafeFailureResponse)(err);
116
131
  });
117
132
  };
118
133
  this.registerMiddleware = async (options)=>{
@@ -122,6 +137,7 @@ class HonoAdapter {
122
137
  this.isHono = false;
123
138
  return;
124
139
  }
140
+ this.prefix = prefix || this.prefix;
125
141
  const { middlewares: globalMiddlewares } = this.api.getServerContext();
126
142
  await this.setHandlers();
127
143
  if ((0, utils_namespaceObject.isProd)()) globalMiddlewares.push(...this.apiMiddleware);
@@ -27,11 +27,15 @@ function __webpack_require__(moduleId) {
27
27
  };
28
28
  })();
29
29
  (()=>{
30
- __webpack_require__.d = (exports1, definition)=>{
31
- for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
32
- enumerable: true,
33
- get: definition[key]
34
- });
30
+ __webpack_require__.d = (exports1, getters, values)=>{
31
+ var define = (defs, kind)=>{
32
+ for(var key in defs)if (__webpack_require__.o(defs, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
33
+ enumerable: true,
34
+ [kind]: defs[key]
35
+ });
36
+ };
37
+ define(getters, "get");
38
+ define(values, "value");
35
39
  };
36
40
  })();
37
41
  (()=>{