UNPKG

@nx/module-federation

Version:

The Nx Plugin for Module Federation contains executors and utilities that support building applications using Module Federation.

93 lines (92 loc) 4.1 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.mapRemotes = mapRemotes; exports.mapRemotesForSSR = mapRemotesForSSR; const path_1 = require("path"); /** * Map remote names to a format that can be understood and used by Module * Federation. * * @param remotes - The remotes to map * @param remoteEntryExt - The file extension of the remoteEntry file * @param determineRemoteUrl - The function used to lookup the URL of the served remote */ function mapRemotes(remotes, remoteEntryExt, determineRemoteUrl, isRemoteGlobal = false) { const mappedRemotes = {}; for (const nxRemoteProjectName of remotes) { if (Array.isArray(nxRemoteProjectName)) { const mfRemoteName = normalizeRemoteName(nxRemoteProjectName[0]); mappedRemotes[mfRemoteName] = handleArrayRemote(nxRemoteProjectName, remoteEntryExt, isRemoteGlobal); } else if (typeof nxRemoteProjectName === 'string') { const mfRemoteName = normalizeRemoteName(nxRemoteProjectName); mappedRemotes[mfRemoteName] = handleStringRemote(nxRemoteProjectName, determineRemoteUrl, isRemoteGlobal); } } return mappedRemotes; } // Helper function to deal with remotes that are arrays function handleArrayRemote(remote, remoteEntryExt, isRemoteGlobal) { let [nxRemoteProjectName, remoteLocation] = remote; const mfRemoteName = normalizeRemoteName(nxRemoteProjectName); const remoteLocationExt = (0, path_1.extname)(remoteLocation); // If remote location already has .js or .mjs extension if (['.js', '.mjs', '.json'].includes(remoteLocationExt)) { if (isRemoteGlobal && !remoteLocation.startsWith(`${mfRemoteName}@`)) { return `${mfRemoteName}@${remoteLocation}`; } return remoteLocation; } const baseRemote = remoteLocation.endsWith('/') ? remoteLocation.slice(0, -1) : remoteLocation; const globalPrefix = isRemoteGlobal ? `${normalizeRemoteName(nxRemoteProjectName)}@` : ''; // if the remote is defined with anything other than http then we assume it's a promise based remote // In that case we should use what the user provides as the remote location if (!remoteLocation.startsWith('promise new Promise')) { return `${globalPrefix}${baseRemote}/remoteEntry.${remoteEntryExt}`; } else { return remoteLocation; } } // Helper function to deal with remotes that are strings function handleStringRemote(nxRemoteProjectName, determineRemoteUrl, isRemoteGlobal) { const globalPrefix = isRemoteGlobal ? `${normalizeRemoteName(nxRemoteProjectName)}@` : ''; return `${globalPrefix}${determineRemoteUrl(nxRemoteProjectName)}`; } /** * Map remote names to a format that can be understood and used by Module * Federation. * * @param remotes - The remotes to map * @param remoteEntryExt - The file extension of the remoteEntry file * @param determineRemoteUrl - The function used to lookup the URL of the served remote */ function mapRemotesForSSR(remotes, remoteEntryExt, determineRemoteUrl) { const mappedRemotes = {}; for (const remote of remotes) { if (Array.isArray(remote)) { let [nxRemoteProjectName, remoteLocation] = remote; const mfRemoteName = normalizeRemoteName(nxRemoteProjectName); const remoteLocationExt = (0, path_1.extname)(remoteLocation); mappedRemotes[mfRemoteName] = `${mfRemoteName}@${['.js', '.mjs', '.json'].includes(remoteLocationExt) ? remoteLocation : `${remoteLocation.endsWith('/') ? remoteLocation.slice(0, -1) : remoteLocation}/remoteEntry.${remoteEntryExt}`}`; } else if (typeof remote === 'string') { const mfRemoteName = normalizeRemoteName(remote); mappedRemotes[mfRemoteName] = `${mfRemoteName}@${determineRemoteUrl(remote)}`; } } return mappedRemotes; } function normalizeRemoteName(remote) { return remote.replace(/-/g, '_'); }