@module-federation/modern-js 0.22.1 → 0.23.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.
@@ -1,5 +1,19 @@
1
1
  "use strict";
2
- var __webpack_require__ = {};
2
+ var __webpack_modules__ = {
3
+ jiti (module) {
4
+ module.exports = require("jiti");
5
+ }
6
+ };
7
+ var __webpack_module_cache__ = {};
8
+ function __webpack_require__(moduleId) {
9
+ var cachedModule = __webpack_module_cache__[moduleId];
10
+ if (void 0 !== cachedModule) return cachedModule.exports;
11
+ var module = __webpack_module_cache__[moduleId] = {
12
+ exports: {}
13
+ };
14
+ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
15
+ return module.exports;
16
+ }
3
17
  (()=>{
4
18
  __webpack_require__.n = (module)=>{
5
19
  var getter = module && module.__esModule ? ()=>module['default'] : ()=>module;
@@ -31,282 +45,288 @@ var __webpack_require__ = {};
31
45
  };
32
46
  })();
33
47
  var __webpack_exports__ = {};
34
- __webpack_require__.r(__webpack_exports__);
35
- __webpack_require__.d(__webpack_exports__, {
36
- patchMFConfig: ()=>patchMFConfig,
37
- default: ()=>configPlugin,
38
- getMFConfig: ()=>getMFConfig,
39
- isWebTarget: ()=>external_utils_js_namespaceObject.isWebTarget,
40
- moduleFederationConfigPlugin: ()=>moduleFederationConfigPlugin,
41
- addMyTypes2Ignored: ()=>addMyTypes2Ignored,
42
- skipByTarget: ()=>external_utils_js_namespaceObject.skipByTarget,
43
- setEnv: ()=>setEnv,
44
- patchBundlerConfig: ()=>patchBundlerConfig
45
- });
46
- const external_path_namespaceObject = require("path");
47
- var external_path_default = /*#__PURE__*/ __webpack_require__.n(external_path_namespaceObject);
48
- const external_utils_js_namespaceObject = require("./utils.js");
49
- const sdk_namespaceObject = require("@module-federation/sdk");
50
- const node_bundle_require_namespaceObject = require("@modern-js/node-bundle-require");
51
- const external_constant_js_namespaceObject = require("../constant.js");
52
- const utils_namespaceObject = require("@module-federation/rsbuild-plugin/utils");
53
- const external_logger_js_namespaceObject = require("../logger.js");
54
- var external_logger_js_default = /*#__PURE__*/ __webpack_require__.n(external_logger_js_namespaceObject);
55
- const defaultPath = external_path_default().resolve(process.cwd(), 'module-federation.config.ts');
56
- function setEnv(enableSSR) {
57
- if (enableSSR) process.env['MF_SSR_PRJ'] = 'true';
58
- }
59
- const getMFConfig = async (userConfig)=>{
60
- const { config, configPath } = userConfig;
61
- if (config) return config;
62
- const mfConfigPath = configPath ? configPath : defaultPath;
63
- const preBundlePath = await (0, node_bundle_require_namespaceObject.bundle)(mfConfigPath);
64
- const mfConfig = (await import(preBundlePath)).default;
65
- return mfConfig;
66
- };
67
- const injectRuntimePlugins = (runtimePlugin, runtimePlugins)=>{
68
- const pluginName = 'string' == typeof runtimePlugin ? runtimePlugin : runtimePlugin[0];
69
- const hasPlugin = runtimePlugins.some((existingPlugin)=>{
70
- if ('string' == typeof existingPlugin) return existingPlugin === pluginName;
71
- return existingPlugin[0] === pluginName;
48
+ (()=>{
49
+ __webpack_require__.r(__webpack_exports__);
50
+ __webpack_require__.d(__webpack_exports__, {
51
+ patchMFConfig: ()=>patchMFConfig,
52
+ default: ()=>configPlugin,
53
+ getMFConfig: ()=>getMFConfig,
54
+ isWebTarget: ()=>external_utils_js_namespaceObject.isWebTarget,
55
+ moduleFederationConfigPlugin: ()=>moduleFederationConfigPlugin,
56
+ addMyTypes2Ignored: ()=>addMyTypes2Ignored,
57
+ skipByTarget: ()=>external_utils_js_namespaceObject.skipByTarget,
58
+ setEnv: ()=>setEnv,
59
+ patchBundlerConfig: ()=>patchBundlerConfig
72
60
  });
73
- if (!hasPlugin) runtimePlugins.push(runtimePlugin);
74
- };
75
- const replaceRemoteUrl = (mfConfig, remoteIpStrategy)=>{
76
- if (remoteIpStrategy && 'inherit' === remoteIpStrategy) return;
77
- if (!mfConfig.remotes) return;
78
- const ipv4 = (0, external_utils_js_namespaceObject.getIPV4)();
79
- const handleRemoteObject = (remoteObject)=>{
80
- Object.keys(remoteObject).forEach((remoteKey)=>{
81
- const remote = remoteObject[remoteKey];
82
- if (Array.isArray(remote)) return;
83
- if ('string' == typeof remote && remote.includes(external_constant_js_namespaceObject.LOCALHOST)) remoteObject[remoteKey] = remote.replace(external_constant_js_namespaceObject.LOCALHOST, ipv4);
84
- if ('object' == typeof remote && !Array.isArray(remote.external) && remote.external.includes(external_constant_js_namespaceObject.LOCALHOST)) remote.external = remote.external.replace(external_constant_js_namespaceObject.LOCALHOST, ipv4);
61
+ const external_path_namespaceObject = require("path");
62
+ var external_path_default = /*#__PURE__*/ __webpack_require__.n(external_path_namespaceObject);
63
+ const external_utils_js_namespaceObject = require("./utils.js");
64
+ const sdk_namespaceObject = require("@module-federation/sdk");
65
+ const external_constant_js_namespaceObject = require("../constant.js");
66
+ const utils_namespaceObject = require("@module-federation/rsbuild-plugin/utils");
67
+ const external_logger_js_namespaceObject = require("../logger.js");
68
+ var external_logger_js_default = /*#__PURE__*/ __webpack_require__.n(external_logger_js_namespaceObject);
69
+ const defaultPath = external_path_default().resolve(process.cwd(), 'module-federation.config.ts');
70
+ function setEnv(enableSSR) {
71
+ if (enableSSR) process.env['MF_SSR_PRJ'] = 'true';
72
+ }
73
+ const getMFConfig = async (userConfig)=>{
74
+ const { config, configPath } = userConfig;
75
+ if (config) return config;
76
+ const mfConfigPath = configPath ? configPath : defaultPath;
77
+ const { createJiti } = __webpack_require__("jiti");
78
+ const jit = createJiti(__filename, {
79
+ interopDefault: true,
80
+ esmResolve: true
85
81
  });
82
+ const configModule = await jit(mfConfigPath);
83
+ const resolvedConfig = configModule && 'object' == typeof configModule && 'default' in configModule ? configModule.default : configModule;
84
+ return resolvedConfig;
86
85
  };
87
- if (Array.isArray(mfConfig.remotes)) mfConfig.remotes.forEach((remoteObject)=>{
88
- if ('string' == typeof remoteObject) return;
89
- handleRemoteObject(remoteObject);
90
- });
91
- else if ('string' != typeof mfConfig.remotes) handleRemoteObject(mfConfig.remotes);
92
- };
93
- const patchDTSConfig = (mfConfig, isServer)=>{
94
- if (isServer) return;
95
- const ModernJSRuntime = '@module-federation/modern-js/runtime';
96
- if (false !== mfConfig.dts) {
97
- var _mfConfig_dts, _mfConfig_dts1;
98
- if ('boolean' == typeof mfConfig.dts || void 0 === mfConfig.dts) mfConfig.dts = {
99
- consumeTypes: {
100
- runtimePkgs: [
101
- ModernJSRuntime
102
- ]
103
- }
86
+ const injectRuntimePlugins = (runtimePlugin, runtimePlugins)=>{
87
+ const pluginName = 'string' == typeof runtimePlugin ? runtimePlugin : runtimePlugin[0];
88
+ const hasPlugin = runtimePlugins.some((existingPlugin)=>{
89
+ if ('string' == typeof existingPlugin) return existingPlugin === pluginName;
90
+ return existingPlugin[0] === pluginName;
91
+ });
92
+ if (!hasPlugin) runtimePlugins.push(runtimePlugin);
93
+ };
94
+ const replaceRemoteUrl = (mfConfig, remoteIpStrategy)=>{
95
+ if (remoteIpStrategy && 'inherit' === remoteIpStrategy) return;
96
+ if (!mfConfig.remotes) return;
97
+ const ipv4 = (0, external_utils_js_namespaceObject.getIPV4)();
98
+ const handleRemoteObject = (remoteObject)=>{
99
+ Object.keys(remoteObject).forEach((remoteKey)=>{
100
+ const remote = remoteObject[remoteKey];
101
+ if (Array.isArray(remote)) return;
102
+ if ('string' == typeof remote && remote.includes(external_constant_js_namespaceObject.LOCALHOST)) remoteObject[remoteKey] = remote.replace(external_constant_js_namespaceObject.LOCALHOST, ipv4);
103
+ if ('object' == typeof remote && !Array.isArray(remote.external) && remote.external.includes(external_constant_js_namespaceObject.LOCALHOST)) remote.external = remote.external.replace(external_constant_js_namespaceObject.LOCALHOST, ipv4);
104
+ });
104
105
  };
105
- else if ((null == (_mfConfig_dts = mfConfig.dts) ? void 0 : _mfConfig_dts.consumeTypes) || (null == (_mfConfig_dts1 = mfConfig.dts) ? void 0 : _mfConfig_dts1.consumeTypes) === void 0) {
106
- var _mfConfig_dts2;
107
- if ('boolean' == typeof mfConfig.dts.consumeTypes || (null == (_mfConfig_dts2 = mfConfig.dts) ? void 0 : _mfConfig_dts2.consumeTypes) === void 0) mfConfig.dts.consumeTypes = {
108
- runtimePkgs: [
109
- ModernJSRuntime
110
- ]
106
+ if (Array.isArray(mfConfig.remotes)) mfConfig.remotes.forEach((remoteObject)=>{
107
+ if ('string' == typeof remoteObject) return;
108
+ handleRemoteObject(remoteObject);
109
+ });
110
+ else if ('string' != typeof mfConfig.remotes) handleRemoteObject(mfConfig.remotes);
111
+ };
112
+ const patchDTSConfig = (mfConfig, isServer)=>{
113
+ if (isServer) return;
114
+ const ModernJSRuntime = '@module-federation/modern-js/runtime';
115
+ if (false !== mfConfig.dts) {
116
+ var _mfConfig_dts, _mfConfig_dts1;
117
+ if ('boolean' == typeof mfConfig.dts || void 0 === mfConfig.dts) mfConfig.dts = {
118
+ consumeTypes: {
119
+ runtimePkgs: [
120
+ ModernJSRuntime
121
+ ]
122
+ }
111
123
  };
112
- else {
113
- mfConfig.dts.consumeTypes.runtimePkgs = mfConfig.dts.consumeTypes.runtimePkgs || [];
114
- if (!mfConfig.dts.consumeTypes.runtimePkgs.includes(ModernJSRuntime)) mfConfig.dts.consumeTypes.runtimePkgs.push(ModernJSRuntime);
124
+ else if ((null == (_mfConfig_dts = mfConfig.dts) ? void 0 : _mfConfig_dts.consumeTypes) || (null == (_mfConfig_dts1 = mfConfig.dts) ? void 0 : _mfConfig_dts1.consumeTypes) === void 0) {
125
+ var _mfConfig_dts2;
126
+ if ('boolean' == typeof mfConfig.dts.consumeTypes || (null == (_mfConfig_dts2 = mfConfig.dts) ? void 0 : _mfConfig_dts2.consumeTypes) === void 0) mfConfig.dts.consumeTypes = {
127
+ runtimePkgs: [
128
+ ModernJSRuntime
129
+ ]
130
+ };
131
+ else {
132
+ mfConfig.dts.consumeTypes.runtimePkgs = mfConfig.dts.consumeTypes.runtimePkgs || [];
133
+ if (!mfConfig.dts.consumeTypes.runtimePkgs.includes(ModernJSRuntime)) mfConfig.dts.consumeTypes.runtimePkgs.push(ModernJSRuntime);
134
+ }
115
135
  }
116
136
  }
117
- }
118
- };
119
- const patchMFConfig = (mfConfig, isServer, remoteIpStrategy, enableSSR)=>{
120
- replaceRemoteUrl(mfConfig, remoteIpStrategy);
121
- (0, utils_namespaceObject.addDataFetchExposes)(mfConfig.exposes, isServer);
122
- if (void 0 === mfConfig.remoteType) mfConfig.remoteType = "script";
123
- if (!mfConfig.name) throw new Error(`${external_constant_js_namespaceObject.PLUGIN_IDENTIFIER} mfConfig.name can not be empty!`);
124
- const runtimePlugins = [
125
- ...mfConfig.runtimePlugins || []
126
- ];
127
- patchDTSConfig(mfConfig, isServer);
128
- injectRuntimePlugins(require.resolve('@module-federation/modern-js/shared-strategy'), runtimePlugins);
129
- if (enableSSR && (0, external_utils_js_namespaceObject.isDev)()) injectRuntimePlugins(require.resolve('@module-federation/modern-js/resolve-entry-ipv4'), runtimePlugins);
130
- if (isServer) {
131
- injectRuntimePlugins(require.resolve('@module-federation/node/runtimePlugin'), runtimePlugins);
132
- if ((0, external_utils_js_namespaceObject.isDev)()) injectRuntimePlugins(require.resolve('@module-federation/node/record-dynamic-remote-entry-hash-plugin'), runtimePlugins);
133
- injectRuntimePlugins(require.resolve('@module-federation/modern-js/inject-node-fetch'), runtimePlugins);
134
- if (mfConfig.library) {
135
- if (!mfConfig.library.type) mfConfig.library.type = 'commonjs-module';
136
- if (!mfConfig.library.name) mfConfig.library.name = mfConfig.name;
137
- } else mfConfig.library = {
138
- type: 'commonjs-module',
139
- name: mfConfig.name
140
- };
141
- }
142
- mfConfig.runtimePlugins = runtimePlugins;
143
- if (!isServer) {
144
- var _mfConfig_library;
145
- if ((null == (_mfConfig_library = mfConfig.library) ? void 0 : _mfConfig_library.type) === 'commonjs-module') mfConfig.library.type = 'global';
137
+ };
138
+ const patchMFConfig = (mfConfig, isServer, remoteIpStrategy, enableSSR)=>{
139
+ replaceRemoteUrl(mfConfig, remoteIpStrategy);
140
+ (0, utils_namespaceObject.addDataFetchExposes)(mfConfig.exposes, isServer);
141
+ if (void 0 === mfConfig.remoteType) mfConfig.remoteType = "script";
142
+ if (!mfConfig.name) throw new Error(`${external_constant_js_namespaceObject.PLUGIN_IDENTIFIER} mfConfig.name can not be empty!`);
143
+ const runtimePlugins = [
144
+ ...mfConfig.runtimePlugins || []
145
+ ];
146
+ patchDTSConfig(mfConfig, isServer);
147
+ injectRuntimePlugins(require.resolve('@module-federation/modern-js/shared-strategy'), runtimePlugins);
148
+ if (enableSSR && (0, external_utils_js_namespaceObject.isDev)()) injectRuntimePlugins(require.resolve('@module-federation/modern-js/resolve-entry-ipv4'), runtimePlugins);
149
+ if (isServer) {
150
+ injectRuntimePlugins(require.resolve('@module-federation/node/runtimePlugin'), runtimePlugins);
151
+ if ((0, external_utils_js_namespaceObject.isDev)()) injectRuntimePlugins(require.resolve('@module-federation/node/record-dynamic-remote-entry-hash-plugin'), runtimePlugins);
152
+ injectRuntimePlugins(require.resolve('@module-federation/modern-js/inject-node-fetch'), runtimePlugins);
153
+ if (mfConfig.library) {
154
+ if (!mfConfig.library.type) mfConfig.library.type = 'commonjs-module';
155
+ if (!mfConfig.library.name) mfConfig.library.name = mfConfig.name;
156
+ } else mfConfig.library = {
157
+ type: 'commonjs-module',
158
+ name: mfConfig.name
159
+ };
160
+ }
161
+ mfConfig.runtimePlugins = runtimePlugins;
162
+ if (!isServer) {
163
+ var _mfConfig_library;
164
+ if ((null == (_mfConfig_library = mfConfig.library) ? void 0 : _mfConfig_library.type) === 'commonjs-module') mfConfig.library.type = 'global';
165
+ return mfConfig;
166
+ }
167
+ mfConfig.dts = false;
168
+ mfConfig.dev = false;
146
169
  return mfConfig;
170
+ };
171
+ function patchIgnoreWarning(chain) {
172
+ const ignoreWarnings = chain.get('ignoreWarnings') || [];
173
+ const ignoredMsgs = [
174
+ "external script",
175
+ 'process.env.WS_NO_BUFFER_UTIL',
176
+ "Can't resolve 'utf-8-validate"
177
+ ];
178
+ ignoreWarnings.push((warning)=>{
179
+ if (ignoredMsgs.some((msg)=>warning.message.includes(msg))) return true;
180
+ return false;
181
+ });
182
+ chain.ignoreWarnings(ignoreWarnings);
147
183
  }
148
- mfConfig.dts = false;
149
- mfConfig.dev = false;
150
- return mfConfig;
151
- };
152
- function patchIgnoreWarning(chain) {
153
- const ignoreWarnings = chain.get('ignoreWarnings') || [];
154
- const ignoredMsgs = [
155
- "external script",
156
- 'process.env.WS_NO_BUFFER_UTIL',
157
- "Can't resolve 'utf-8-validate"
158
- ];
159
- ignoreWarnings.push((warning)=>{
160
- if (ignoredMsgs.some((msg)=>warning.message.includes(msg))) return true;
161
- return false;
162
- });
163
- chain.ignoreWarnings(ignoreWarnings);
164
- }
165
- function addMyTypes2Ignored(chain, mfConfig) {
166
- const watchOptions = chain.get('watchOptions');
167
- if (!watchOptions || !watchOptions.ignored) return void chain.watchOptions({
168
- ignored: /[\\/](?:\.git|node_modules|@mf-types)[\\/]/
169
- });
170
- const ignored = watchOptions.ignored;
171
- const DEFAULT_IGNORED_GLOB = '**/@mf-types/**';
172
- if (Array.isArray(ignored)) {
173
- if (false !== mfConfig.dts && 'object' == typeof mfConfig.dts && 'object' == typeof mfConfig.dts.consumeTypes && mfConfig.dts.consumeTypes.remoteTypesFolder) chain.watchOptions({
184
+ function addMyTypes2Ignored(chain, mfConfig) {
185
+ const watchOptions = chain.get('watchOptions');
186
+ if (!watchOptions || !watchOptions.ignored) return void chain.watchOptions({
187
+ ignored: /[\\/](?:\.git|node_modules|@mf-types)[\\/]/
188
+ });
189
+ const ignored = watchOptions.ignored;
190
+ const DEFAULT_IGNORED_GLOB = '**/@mf-types/**';
191
+ if (Array.isArray(ignored)) {
192
+ if (false !== mfConfig.dts && 'object' == typeof mfConfig.dts && 'object' == typeof mfConfig.dts.consumeTypes && mfConfig.dts.consumeTypes.remoteTypesFolder) chain.watchOptions({
193
+ ...watchOptions,
194
+ ignored: ignored.concat(`**/${mfConfig.dts.consumeTypes.remoteTypesFolder}/**`)
195
+ });
196
+ else chain.watchOptions({
197
+ ...watchOptions,
198
+ ignored: ignored.concat(DEFAULT_IGNORED_GLOB)
199
+ });
200
+ return;
201
+ }
202
+ if ('string' != typeof ignored) return void chain.watchOptions({
174
203
  ...watchOptions,
175
- ignored: ignored.concat(`**/${mfConfig.dts.consumeTypes.remoteTypesFolder}/**`)
204
+ ignored: /[\\/](?:\.git|node_modules|@mf-types)[\\/]/
176
205
  });
177
- else chain.watchOptions({
206
+ chain.watchOptions({
178
207
  ...watchOptions,
179
208
  ignored: ignored.concat(DEFAULT_IGNORED_GLOB)
180
209
  });
181
- return;
182
- }
183
- if ('string' != typeof ignored) return void chain.watchOptions({
184
- ...watchOptions,
185
- ignored: /[\\/](?:\.git|node_modules|@mf-types)[\\/]/
186
- });
187
- chain.watchOptions({
188
- ...watchOptions,
189
- ignored: ignored.concat(DEFAULT_IGNORED_GLOB)
190
- });
191
- }
192
- function patchBundlerConfig(options) {
193
- var _modernjsConfig_deploy;
194
- const { chain, modernjsConfig, isServer, mfConfig, enableSSR } = options;
195
- chain.optimization.delete('runtimeChunk');
196
- patchIgnoreWarning(chain);
197
- if (!chain.output.get('chunkLoadingGlobal')) chain.output.chunkLoadingGlobal(`chunk_${mfConfig.name}`);
198
- if (!chain.output.get('uniqueName')) chain.output.uniqueName(mfConfig.name);
199
- const splitChunkConfig = chain.optimization.splitChunks.entries();
200
- if (!isServer) (0, utils_namespaceObject.autoDeleteSplitChunkCacheGroups)(mfConfig, splitChunkConfig);
201
- if (!isServer && enableSSR && splitChunkConfig && 'object' == typeof splitChunkConfig && splitChunkConfig.cacheGroups) {
202
- splitChunkConfig.chunks = 'async';
203
- external_logger_js_default().warn('splitChunks.chunks = async is not allowed with stream SSR mode, it will auto changed to "async"');
204
- }
205
- if ((0, external_utils_js_namespaceObject.isDev)() && 'auto' === chain.output.get('publicPath')) {
206
- var _modernjsConfig_dev, _modernjsConfig_server;
207
- const port = (null == (_modernjsConfig_dev = modernjsConfig.dev) ? void 0 : _modernjsConfig_dev.port) || (null == (_modernjsConfig_server = modernjsConfig.server) ? void 0 : _modernjsConfig_server.port) || 8080;
208
- const publicPath = `http://localhost:${port}/`;
209
- chain.output.publicPath(publicPath);
210
210
  }
211
- if (isServer && enableSSR) {
212
- const uniqueName = mfConfig.name || chain.output.get('uniqueName');
213
- const chunkFileName = chain.output.get('chunkFilename');
214
- if ('string' == typeof chunkFileName && uniqueName && !chunkFileName.includes(uniqueName)) {
215
- const suffix = `${(0, sdk_namespaceObject.encodeName)(uniqueName)}-[contenthash].js`;
216
- chain.output.chunkFilename(chunkFileName.replace('.js', suffix));
211
+ function patchBundlerConfig(options) {
212
+ var _modernjsConfig_deploy;
213
+ const { chain, modernjsConfig, isServer, mfConfig, enableSSR } = options;
214
+ chain.optimization.delete('runtimeChunk');
215
+ patchIgnoreWarning(chain);
216
+ if (!chain.output.get('chunkLoadingGlobal')) chain.output.chunkLoadingGlobal(`chunk_${mfConfig.name}`);
217
+ if (!chain.output.get('uniqueName')) chain.output.uniqueName(mfConfig.name);
218
+ const splitChunkConfig = chain.optimization.splitChunks.entries();
219
+ if (!isServer) (0, utils_namespaceObject.autoDeleteSplitChunkCacheGroups)(mfConfig, splitChunkConfig);
220
+ if (!isServer && enableSSR && splitChunkConfig && 'object' == typeof splitChunkConfig && splitChunkConfig.cacheGroups) {
221
+ splitChunkConfig.chunks = 'async';
222
+ external_logger_js_default().warn('splitChunks.chunks = async is not allowed with stream SSR mode, it will auto changed to "async"');
217
223
  }
224
+ if ((0, external_utils_js_namespaceObject.isDev)() && 'auto' === chain.output.get('publicPath')) {
225
+ var _modernjsConfig_dev, _modernjsConfig_server;
226
+ const port = (null == (_modernjsConfig_dev = modernjsConfig.dev) ? void 0 : _modernjsConfig_dev.port) || (null == (_modernjsConfig_server = modernjsConfig.server) ? void 0 : _modernjsConfig_server.port) || 8080;
227
+ const publicPath = `http://localhost:${port}/`;
228
+ chain.output.publicPath(publicPath);
229
+ }
230
+ if (isServer && enableSSR) {
231
+ const uniqueName = mfConfig.name || chain.output.get('uniqueName');
232
+ const chunkFileName = chain.output.get('chunkFilename');
233
+ if ('string' == typeof chunkFileName && uniqueName && !chunkFileName.includes(uniqueName)) {
234
+ const suffix = `${(0, sdk_namespaceObject.encodeName)(uniqueName)}-[contenthash].js`;
235
+ chain.output.chunkFilename(chunkFileName.replace('.js', suffix));
236
+ }
237
+ }
238
+ if ((0, external_utils_js_namespaceObject.isDev)() && enableSSR && !isServer) chain.resolve.fallback.set('crypto', false).set('stream', false).set('vm', false);
239
+ if ((null == (_modernjsConfig_deploy = modernjsConfig.deploy) ? void 0 : _modernjsConfig_deploy.microFrontend) && Object.keys(mfConfig.exposes || {}).length) chain.optimization.usedExports(false);
218
240
  }
219
- if ((0, external_utils_js_namespaceObject.isDev)() && enableSSR && !isServer) chain.resolve.fallback.set('crypto', false).set('stream', false).set('vm', false);
220
- if ((null == (_modernjsConfig_deploy = modernjsConfig.deploy) ? void 0 : _modernjsConfig_deploy.microFrontend) && Object.keys(mfConfig.exposes || {}).length) chain.optimization.usedExports(false);
221
- }
222
- const moduleFederationConfigPlugin = (userConfig)=>({
223
- name: '@modern-js/plugin-module-federation-config',
224
- pre: [
225
- '@modern-js/plugin-initialize'
226
- ],
227
- post: [
228
- '@modern-js/plugin-module-federation'
229
- ],
230
- setup: async (api)=>{
231
- var _userConfig_userConfig, _modernjsConfig_server;
232
- const modernjsConfig = api.getConfig();
233
- const mfConfig = await getMFConfig(userConfig.originPluginOptions);
234
- const csrConfig = userConfig.csrConfig || JSON.parse(JSON.stringify(mfConfig));
235
- const ssrConfig = userConfig.ssrConfig || JSON.parse(JSON.stringify(mfConfig));
236
- userConfig.ssrConfig = ssrConfig;
237
- userConfig.csrConfig = csrConfig;
238
- var _ref;
239
- const enableSSR = Boolean(null != (_ref = null == (_userConfig_userConfig = userConfig.userConfig) ? void 0 : _userConfig_userConfig.ssr) ? _ref : Boolean(null == modernjsConfig ? void 0 : null == (_modernjsConfig_server = modernjsConfig.server) ? void 0 : _modernjsConfig_server.ssr));
240
- api.modifyBundlerChain((chain)=>{
241
- const target = chain.get('target');
242
- if ((0, external_utils_js_namespaceObject.skipByTarget)(target)) return;
243
- const isWeb = (0, external_utils_js_namespaceObject.isWebTarget)(target);
244
- addMyTypes2Ignored(chain, isWeb ? csrConfig : ssrConfig);
245
- const targetMFConfig = isWeb ? csrConfig : ssrConfig;
246
- patchMFConfig(targetMFConfig, !isWeb, userConfig.remoteIpStrategy || 'ipv4', enableSSR);
247
- patchBundlerConfig({
248
- chain,
249
- isServer: !isWeb,
250
- modernjsConfig,
251
- mfConfig,
252
- enableSSR
253
- });
254
- if (isWeb) userConfig.distOutputDir = chain.output.get('path') || external_path_default().resolve(process.cwd(), 'dist');
255
- else if (enableSSR) {
256
- var _userConfig, _userConfig_userConfig;
257
- (_userConfig = userConfig).userConfig || (_userConfig.userConfig = {});
258
- (_userConfig_userConfig = userConfig.userConfig).ssr || (_userConfig_userConfig.ssr = {});
259
- if (true === userConfig.userConfig.ssr) userConfig.userConfig.ssr = {};
260
- userConfig.userConfig.ssr.distOutputDir = chain.output.get('path') || external_path_default().resolve(process.cwd(), 'dist/bundles');
261
- }
262
- });
263
- api.config(()=>{
264
- var _modernjsConfig_tools, _userConfig_csrConfig, _modernjsConfig_source, _modernjsConfig_source1, _modernjsConfig_dev;
265
- const bundlerType = 'rspack' === api.getAppContext().bundlerType ? 'rspack' : 'webpack';
266
- const ipv4 = (0, external_utils_js_namespaceObject.getIPV4)();
267
- if (void 0 === userConfig.remoteIpStrategy) if (enableSSR) userConfig.remoteIpStrategy = 'ipv4';
268
- else userConfig.remoteIpStrategy = 'inherit';
269
- const devServerConfig = null == (_modernjsConfig_tools = modernjsConfig.tools) ? void 0 : _modernjsConfig_tools.devServer;
270
- const corsWarnMsgs = [
271
- 'View https://module-federation.io/guide/troubleshooting/other.html#cors-warn for more details.'
272
- ];
273
- if ('object' != typeof devServerConfig || !('headers' in devServerConfig)) corsWarnMsgs.unshift('Detect devServer.headers is empty, mf modern plugin will add default cors header: devServer.headers["Access-Control-Allow-Headers"] = "*". It is recommended to specify an allowlist of trusted origins instead.');
274
- const exposes = null == (_userConfig_csrConfig = userConfig.csrConfig) ? void 0 : _userConfig_csrConfig.exposes;
275
- const hasExposes = exposes && Array.isArray(exposes) ? exposes.length : Object.keys(null != exposes ? exposes : {}).length;
276
- if (corsWarnMsgs.length > 1 && hasExposes) external_logger_js_default().warn(corsWarnMsgs.join('\n'));
277
- const corsHeaders = hasExposes ? {
278
- 'Access-Control-Allow-Origin': '*',
279
- 'Access-Control-Allow-Methods': 'GET, POST, PUT, DELETE, PATCH, OPTIONS',
280
- 'Access-Control-Allow-Headers': '*'
281
- } : void 0;
282
- const defineConfig = {
283
- REMOTE_IP_STRATEGY: JSON.stringify(userConfig.remoteIpStrategy)
284
- };
285
- if (enableSSR && (0, external_utils_js_namespaceObject.isDev)()) defineConfig['FEDERATION_IPV4'] = JSON.stringify(ipv4);
241
+ const moduleFederationConfigPlugin = (userConfig)=>({
242
+ name: '@modern-js/plugin-module-federation-config',
243
+ pre: [
244
+ '@modern-js/plugin-initialize'
245
+ ],
246
+ post: [
247
+ '@modern-js/plugin-module-federation'
248
+ ],
249
+ setup: async (api)=>{
250
+ var _userConfig_userConfig, _modernjsConfig_server;
251
+ const modernjsConfig = api.getConfig();
252
+ const mfConfig = await getMFConfig(userConfig.originPluginOptions);
253
+ const csrConfig = userConfig.csrConfig || JSON.parse(JSON.stringify(mfConfig));
254
+ const ssrConfig = userConfig.ssrConfig || JSON.parse(JSON.stringify(mfConfig));
255
+ userConfig.ssrConfig = ssrConfig;
256
+ userConfig.csrConfig = csrConfig;
286
257
  var _ref;
287
- return {
288
- tools: {
289
- devServer: {
290
- headers: corsHeaders
291
- }
292
- },
293
- resolve: {
294
- alias: {
295
- '@modern-js/runtime/mf': require.resolve('@module-federation/modern-js/runtime')
296
- }
297
- },
298
- source: {
299
- define: defineConfig,
300
- enableAsyncEntry: 'rspack' === bundlerType ? null != (_ref = null == (_modernjsConfig_source = modernjsConfig.source) ? void 0 : _modernjsConfig_source.enableAsyncEntry) ? _ref : true : null == (_modernjsConfig_source1 = modernjsConfig.source) ? void 0 : _modernjsConfig_source1.enableAsyncEntry
301
- },
302
- dev: {
303
- assetPrefix: (null == modernjsConfig ? void 0 : null == (_modernjsConfig_dev = modernjsConfig.dev) ? void 0 : _modernjsConfig_dev.assetPrefix) ? modernjsConfig.dev.assetPrefix : true
258
+ const enableSSR = Boolean(null != (_ref = null == (_userConfig_userConfig = userConfig.userConfig) ? void 0 : _userConfig_userConfig.ssr) ? _ref : Boolean(null == modernjsConfig ? void 0 : null == (_modernjsConfig_server = modernjsConfig.server) ? void 0 : _modernjsConfig_server.ssr));
259
+ api.modifyBundlerChain((chain)=>{
260
+ const target = chain.get('target');
261
+ if ((0, external_utils_js_namespaceObject.skipByTarget)(target)) return;
262
+ const isWeb = (0, external_utils_js_namespaceObject.isWebTarget)(target);
263
+ addMyTypes2Ignored(chain, isWeb ? csrConfig : ssrConfig);
264
+ const targetMFConfig = isWeb ? csrConfig : ssrConfig;
265
+ patchMFConfig(targetMFConfig, !isWeb, userConfig.remoteIpStrategy || 'ipv4', enableSSR);
266
+ patchBundlerConfig({
267
+ chain,
268
+ isServer: !isWeb,
269
+ modernjsConfig,
270
+ mfConfig,
271
+ enableSSR
272
+ });
273
+ if (isWeb) userConfig.distOutputDir = chain.output.get('path') || external_path_default().resolve(process.cwd(), 'dist');
274
+ else if (enableSSR) {
275
+ var _userConfig, _userConfig_userConfig;
276
+ (_userConfig = userConfig).userConfig || (_userConfig.userConfig = {});
277
+ (_userConfig_userConfig = userConfig.userConfig).ssr || (_userConfig_userConfig.ssr = {});
278
+ if (true === userConfig.userConfig.ssr) userConfig.userConfig.ssr = {};
279
+ userConfig.userConfig.ssr.distOutputDir = chain.output.get('path') || external_path_default().resolve(process.cwd(), 'dist/bundles');
304
280
  }
305
- };
306
- });
307
- }
308
- });
309
- const configPlugin = moduleFederationConfigPlugin;
281
+ });
282
+ api.config(()=>{
283
+ var _modernjsConfig_tools, _userConfig_csrConfig, _modernjsConfig_source, _modernjsConfig_source1, _modernjsConfig_dev;
284
+ const bundlerType = 'rspack' === api.getAppContext().bundlerType ? 'rspack' : 'webpack';
285
+ const ipv4 = (0, external_utils_js_namespaceObject.getIPV4)();
286
+ if (void 0 === userConfig.remoteIpStrategy) if (enableSSR) userConfig.remoteIpStrategy = 'ipv4';
287
+ else userConfig.remoteIpStrategy = 'inherit';
288
+ const devServerConfig = null == (_modernjsConfig_tools = modernjsConfig.tools) ? void 0 : _modernjsConfig_tools.devServer;
289
+ const corsWarnMsgs = [
290
+ 'View https://module-federation.io/guide/troubleshooting/other.html#cors-warn for more details.'
291
+ ];
292
+ if ('object' != typeof devServerConfig || !('headers' in devServerConfig)) corsWarnMsgs.unshift('Detect devServer.headers is empty, mf modern plugin will add default cors header: devServer.headers["Access-Control-Allow-Headers"] = "*". It is recommended to specify an allowlist of trusted origins instead.');
293
+ const exposes = null == (_userConfig_csrConfig = userConfig.csrConfig) ? void 0 : _userConfig_csrConfig.exposes;
294
+ const hasExposes = exposes && Array.isArray(exposes) ? exposes.length : Object.keys(null != exposes ? exposes : {}).length;
295
+ if (corsWarnMsgs.length > 1 && hasExposes) external_logger_js_default().warn(corsWarnMsgs.join('\n'));
296
+ const corsHeaders = hasExposes ? {
297
+ 'Access-Control-Allow-Origin': '*',
298
+ 'Access-Control-Allow-Methods': 'GET, POST, PUT, DELETE, PATCH, OPTIONS',
299
+ 'Access-Control-Allow-Headers': '*'
300
+ } : void 0;
301
+ const defineConfig = {
302
+ REMOTE_IP_STRATEGY: JSON.stringify(userConfig.remoteIpStrategy)
303
+ };
304
+ if (enableSSR && (0, external_utils_js_namespaceObject.isDev)()) defineConfig['FEDERATION_IPV4'] = JSON.stringify(ipv4);
305
+ var _ref;
306
+ return {
307
+ tools: {
308
+ devServer: {
309
+ headers: corsHeaders
310
+ }
311
+ },
312
+ resolve: {
313
+ alias: {
314
+ '@modern-js/runtime/mf': require.resolve('@module-federation/modern-js/runtime')
315
+ }
316
+ },
317
+ source: {
318
+ define: defineConfig,
319
+ enableAsyncEntry: 'rspack' === bundlerType ? null != (_ref = null == (_modernjsConfig_source = modernjsConfig.source) ? void 0 : _modernjsConfig_source.enableAsyncEntry) ? _ref : true : null == (_modernjsConfig_source1 = modernjsConfig.source) ? void 0 : _modernjsConfig_source1.enableAsyncEntry
320
+ },
321
+ dev: {
322
+ assetPrefix: (null == modernjsConfig ? void 0 : null == (_modernjsConfig_dev = modernjsConfig.dev) ? void 0 : _modernjsConfig_dev.assetPrefix) ? modernjsConfig.dev.assetPrefix : true
323
+ }
324
+ };
325
+ });
326
+ }
327
+ });
328
+ const configPlugin = moduleFederationConfigPlugin;
329
+ })();
310
330
  exports.addMyTypes2Ignored = __webpack_exports__.addMyTypes2Ignored;
311
331
  exports["default"] = __webpack_exports__["default"];
312
332
  exports.getMFConfig = __webpack_exports__.getMFConfig;
@@ -1,3 +1,4 @@
1
+ import * as __rspack_external_jiti from "jiti";
1
2
  import { _ } from "@swc/helpers/_/_async_to_generator";
2
3
  import { _ as _object_spread__ } from "@swc/helpers/_/_object_spread";
3
4
  import { _ as _object_spread_props__ } from "@swc/helpers/_/_object_spread_props";
@@ -7,17 +8,31 @@ import { _ as _ts_generator__ } from "@swc/helpers/_/_ts_generator";
7
8
  import path from "path";
8
9
  import { getIPV4, isDev, isWebTarget, skipByTarget } from "./utils.mjs";
9
10
  import { encodeName } from "@module-federation/sdk";
10
- import { bundle } from "@modern-js/node-bundle-require";
11
11
  import { LOCALHOST, PLUGIN_IDENTIFIER } from "../constant.mjs";
12
12
  import { addDataFetchExposes, autoDeleteSplitChunkCacheGroups } from "@module-federation/rsbuild-plugin/utils";
13
13
  import logger from "../logger.mjs";
14
+ var __webpack_modules__ = {
15
+ jiti: function(module) {
16
+ module.exports = __rspack_external_jiti;
17
+ }
18
+ };
19
+ var __webpack_module_cache__ = {};
20
+ function __webpack_require__(moduleId) {
21
+ var cachedModule = __webpack_module_cache__[moduleId];
22
+ if (void 0 !== cachedModule) return cachedModule.exports;
23
+ var module = __webpack_module_cache__[moduleId] = {
24
+ exports: {}
25
+ };
26
+ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
27
+ return module.exports;
28
+ }
14
29
  var defaultPath = path.resolve(process.cwd(), 'module-federation.config.ts');
15
30
  function setEnv(enableSSR) {
16
31
  if (enableSSR) process.env['MF_SSR_PRJ'] = 'true';
17
32
  }
18
33
  var getMFConfig = function(userConfig) {
19
34
  return _(function() {
20
- var config, configPath, mfConfigPath, preBundlePath, mfConfig;
35
+ var config, configPath, mfConfigPath, createJiti, jit, configModule, resolvedConfig;
21
36
  return _ts_generator__(this, function(_state) {
22
37
  switch(_state.label){
23
38
  case 0:
@@ -27,21 +42,21 @@ var getMFConfig = function(userConfig) {
27
42
  config
28
43
  ];
29
44
  mfConfigPath = configPath ? configPath : defaultPath;
45
+ createJiti = __webpack_require__("jiti").createJiti;
46
+ jit = createJiti(__filename, {
47
+ interopDefault: true,
48
+ esmResolve: true
49
+ });
30
50
  return [
31
51
  4,
32
- bundle(mfConfigPath)
52
+ jit(mfConfigPath)
33
53
  ];
34
54
  case 1:
35
- preBundlePath = _state.sent();
36
- return [
37
- 4,
38
- import(preBundlePath)
39
- ];
40
- case 2:
41
- mfConfig = _state.sent().default;
55
+ configModule = _state.sent();
56
+ resolvedConfig = configModule && (void 0 === configModule ? "undefined" : _type_of__(configModule)) === 'object' && 'default' in configModule ? configModule.default : configModule;
42
57
  return [
43
58
  2,
44
- mfConfig
59
+ resolvedConfig
45
60
  ];
46
61
  }
47
62
  });
@@ -1,10 +1,25 @@
1
+ import * as __rspack_external_jiti from "jiti";
1
2
  import path from "path";
2
3
  import { getIPV4, isDev, isWebTarget, skipByTarget } from "./utils.mjs";
3
4
  import { encodeName } from "@module-federation/sdk";
4
- import { bundle } from "@modern-js/node-bundle-require";
5
5
  import { LOCALHOST, PLUGIN_IDENTIFIER } from "../constant.mjs";
6
6
  import { addDataFetchExposes, autoDeleteSplitChunkCacheGroups } from "@module-federation/rsbuild-plugin/utils";
7
7
  import logger from "../logger.mjs";
8
+ var __webpack_modules__ = {
9
+ jiti (module) {
10
+ module.exports = __rspack_external_jiti;
11
+ }
12
+ };
13
+ var __webpack_module_cache__ = {};
14
+ function __webpack_require__(moduleId) {
15
+ var cachedModule = __webpack_module_cache__[moduleId];
16
+ if (void 0 !== cachedModule) return cachedModule.exports;
17
+ var module = __webpack_module_cache__[moduleId] = {
18
+ exports: {}
19
+ };
20
+ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
21
+ return module.exports;
22
+ }
8
23
  const defaultPath = path.resolve(process.cwd(), 'module-federation.config.ts');
9
24
  function setEnv(enableSSR) {
10
25
  if (enableSSR) process.env['MF_SSR_PRJ'] = 'true';
@@ -13,9 +28,14 @@ const getMFConfig = async (userConfig)=>{
13
28
  const { config, configPath } = userConfig;
14
29
  if (config) return config;
15
30
  const mfConfigPath = configPath ? configPath : defaultPath;
16
- const preBundlePath = await bundle(mfConfigPath);
17
- const mfConfig = (await import(preBundlePath)).default;
18
- return mfConfig;
31
+ const { createJiti } = __webpack_require__("jiti");
32
+ const jit = createJiti(__filename, {
33
+ interopDefault: true,
34
+ esmResolve: true
35
+ });
36
+ const configModule = await jit(mfConfigPath);
37
+ const resolvedConfig = configModule && 'object' == typeof configModule && 'default' in configModule ? configModule.default : configModule;
38
+ return resolvedConfig;
19
39
  };
20
40
  const injectRuntimePlugins = (runtimePlugin, runtimePlugins)=>{
21
41
  const pluginName = 'string' == typeof runtimePlugin ? runtimePlugin : runtimePlugin[0];
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@module-federation/modern-js",
3
- "version": "0.22.1",
3
+ "version": "0.23.0",
4
4
  "files": [
5
5
  "dist/",
6
6
  "types.d.ts",
@@ -133,33 +133,33 @@
133
133
  "author": "hanric <hanric.zhang@gmail.com>",
134
134
  "license": "MIT",
135
135
  "dependencies": {
136
- "@modern-js/utils": "2.69.3",
137
- "@modern-js/node-bundle-require": "2.69.3",
136
+ "@modern-js/utils": "2.70.2",
138
137
  "fs-extra": "11.3.0",
139
138
  "lru-cache": "10.4.3",
140
139
  "@swc/helpers": "^0.5.17",
141
140
  "node-fetch": "~3.3.0",
141
+ "jiti": "2.4.2",
142
142
  "react-error-boundary": "4.1.2",
143
- "@module-federation/bridge-react": "0.22.1",
144
- "@module-federation/rsbuild-plugin": "0.22.1",
145
- "@module-federation/enhanced": "0.22.1",
146
- "@module-federation/node": "2.7.27",
147
- "@module-federation/sdk": "0.22.1",
148
- "@module-federation/cli": "0.22.1",
149
- "@module-federation/runtime": "0.22.1"
143
+ "@module-federation/rsbuild-plugin": "0.23.0",
144
+ "@module-federation/bridge-react": "0.23.0",
145
+ "@module-federation/enhanced": "0.23.0",
146
+ "@module-federation/runtime": "0.23.0",
147
+ "@module-federation/node": "2.7.28",
148
+ "@module-federation/sdk": "0.23.0",
149
+ "@module-federation/cli": "0.23.0"
150
150
  },
151
151
  "devDependencies": {
152
152
  "@rsbuild/plugin-react": "1.4.2",
153
153
  "@rslib/core": "0.18.5",
154
154
  "@rsbuild/core": "1.3.21",
155
- "@modern-js/app-tools": "2.69.3",
156
- "@modern-js/server-runtime": "2.69.3",
157
- "@modern-js/module-tools": "2.69.3",
158
- "@modern-js/runtime": "2.69.3",
159
- "@modern-js/tsconfig": "2.69.3",
155
+ "@modern-js/app-tools": "2.70.2",
156
+ "@modern-js/server-runtime": "2.70.2",
157
+ "@modern-js/module-tools": "2.70.2",
158
+ "@modern-js/runtime": "2.70.2",
159
+ "@modern-js/tsconfig": "2.70.2",
160
160
  "@types/react": "^18.3.11",
161
161
  "@types/react-dom": "^18.3.0",
162
- "@module-federation/manifest": "0.22.1"
162
+ "@module-federation/manifest": "0.23.0"
163
163
  },
164
164
  "peerDependencies": {
165
165
  "react": ">=17",