HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux ip-172-31-4-197 6.8.0-1036-aws #38~22.04.1-Ubuntu SMP Fri Aug 22 15:44:33 UTC 2025 x86_64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/web.enelar.com.co/node_modules/nx/src/project-graph/project-graph-builder.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.validateDependency = exports.ProjectGraphBuilder = void 0;
/**
 * Builder for adding nodes and dependencies to a {@link ProjectGraph}
 */
const project_graph_1 = require("../config/project-graph");
const build_project_graph_1 = require("./build-project-graph");
/**
 * A class which builds up a project graph
 * @deprecated The {@link ProjectGraphProcessor} has been deprecated. Use a {@link CreateNodes} and/or a {@link CreateDependencies} instead. This will be removed in Nx 18.
 */
class ProjectGraphBuilder {
    constructor(graph, projectFileMap, nonProjectFiles) {
        this.removedEdges = {};
        if (!projectFileMap || !nonProjectFiles) {
            const fileMap = (0, build_project_graph_1.getFileMap)().fileMap;
            projectFileMap ??= fileMap.projectFileMap;
            nonProjectFiles ??= fileMap.nonProjectFiles;
        }
        if (graph) {
            this.graph = graph;
            this.projectFileMap = projectFileMap;
            this.nonProjectFiles = nonProjectFiles;
        }
        else {
            this.graph = {
                nodes: {},
                externalNodes: {},
                dependencies: {},
            };
            this.projectFileMap = projectFileMap || {};
            this.nonProjectFiles = nonProjectFiles || [];
        }
    }
    /**
     * Merges the nodes and dependencies of p into the built project graph.
     */
    mergeProjectGraph(p) {
        this.graph.nodes = { ...this.graph.nodes, ...p.nodes };
        this.graph.externalNodes = {
            ...this.graph.externalNodes,
            ...p.externalNodes,
        };
        this.graph.dependencies = { ...this.graph.dependencies, ...p.dependencies };
    }
    /**
     * Adds a project node to the project graph
     */
    addNode(node) {
        // Check if project with the same name already exists
        if (this.graph.nodes[node.name]) {
            // Throw if existing project is of a different type
            if (this.graph.nodes[node.name].type !== node.type) {
                throw new Error(`Multiple projects are named "${node.name}". One is of type "${node.type}" and the other is of type "${this.graph.nodes[node.name].type}". Please resolve the conflicting project names.`);
            }
        }
        this.graph.nodes[node.name] = node;
    }
    /**
     * Removes a node and all of its dependency edges from the graph
     */
    removeNode(name) {
        if (!this.graph.nodes[name] && !this.graph.externalNodes[name]) {
            throw new Error(`There is no node named: "${name}"`);
        }
        this.removeDependenciesWithNode(name);
        if (this.graph.nodes[name]) {
            delete this.graph.nodes[name];
        }
        else {
            delete this.graph.externalNodes[name];
        }
    }
    /**
     * Adds a external node to the project graph
     */
    addExternalNode(node) {
        // Check if project with the same name already exists
        if (this.graph.externalNodes[node.name]) {
            throw new Error(`Multiple projects are named "${node.name}". One has version "${node.data.version}" and the other has version "${this.graph.externalNodes[node.name].data.version}". Please resolve the conflicting package names.`);
        }
        this.graph.externalNodes[node.name] = node;
    }
    /**
     * Adds static dependency from source project to target project
     */
    addStaticDependency(sourceProjectName, targetProjectName, sourceProjectFile) {
        this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.static, sourceProjectFile);
    }
    /**
     * Adds dynamic dependency from source project to target project
     */
    addDynamicDependency(sourceProjectName, targetProjectName, sourceProjectFile) {
        this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.dynamic, sourceProjectFile);
    }
    /**
     * Adds implicit dependency from source project to target project
     */
    addImplicitDependency(sourceProjectName, targetProjectName) {
        this.addDependency(sourceProjectName, targetProjectName, project_graph_1.DependencyType.implicit);
    }
    /**
     * Removes a dependency from source project to target project
     */
    removeDependency(sourceProjectName, targetProjectName) {
        if (sourceProjectName === targetProjectName) {
            return;
        }
        if (!this.graph.nodes[sourceProjectName]) {
            throw new Error(`Source project does not exist: ${sourceProjectName}`);
        }
        if (!this.graph.nodes[targetProjectName] &&
            !this.graph.externalNodes[targetProjectName]) {
            throw new Error(`Target project does not exist: ${targetProjectName}`);
        }
        // this.graph.dependencies[sourceProjectName] = this.graph.dependencies[
        //   sourceProjectName
        // ].filter((d) => d.target !== targetProjectName);
        if (!this.removedEdges[sourceProjectName]) {
            this.removedEdges[sourceProjectName] = new Set();
        }
        this.removedEdges[sourceProjectName].add(targetProjectName);
    }
    /**
     * Add an explicit dependency from a file in source project to target project
     * @deprecated this method will be removed in v17. Use {@link addStaticDependency} or {@link addDynamicDependency} instead
     */
    addExplicitDependency(sourceProjectName, sourceProjectFile, targetProjectName) {
        this.addStaticDependency(sourceProjectName, targetProjectName, sourceProjectFile);
    }
    /**
     * Set version of the project graph
     */
    setVersion(version) {
        this.graph.version = version;
    }
    getUpdatedProjectGraph() {
        for (const sourceProject of Object.keys(this.graph.nodes)) {
            const alreadySetTargetProjects = this.calculateAlreadySetTargetDeps(sourceProject);
            this.graph.dependencies[sourceProject] = [
                ...alreadySetTargetProjects.values(),
            ].flatMap((depsMap) => [...depsMap.values()]);
            const fileDeps = this.calculateTargetDepsFromFiles(sourceProject);
            for (const [targetProject, types] of fileDeps.entries()) {
                // only add known nodes
                if (!this.graph.nodes[targetProject] &&
                    !this.graph.externalNodes[targetProject]) {
                    continue;
                }
                for (const type of types.values()) {
                    if (!alreadySetTargetProjects.has(targetProject) ||
                        !alreadySetTargetProjects.get(targetProject).has(type)) {
                        if (!this.removedEdges[sourceProject] ||
                            !this.removedEdges[sourceProject].has(targetProject)) {
                            this.graph.dependencies[sourceProject].push({
                                source: sourceProject,
                                target: targetProject,
                                type,
                            });
                        }
                    }
                }
            }
        }
        for (const file of this.nonProjectFiles) {
            if (file.deps) {
                for (const dep of file.deps) {
                    if (!Array.isArray(dep)) {
                        throw new Error('Cached data on non project files should be a tuple');
                    }
                    const [source, target, type] = dep;
                    if (!source || !target || !type) {
                        throw new Error('Cached dependencies for non project files should be a tuple of length 3.');
                    }
                    this.graph.dependencies[source].push({
                        source,
                        target,
                        type,
                    });
                }
            }
        }
        return this.graph;
    }
    addDependency(source, target, type, sourceFile) {
        if (source === target) {
            return;
        }
        validateDependency({
            source,
            target,
            type,
            sourceFile,
        }, {
            externalNodes: this.graph.externalNodes,
            fileMap: {
                projectFileMap: this.projectFileMap,
                nonProjectFiles: this.nonProjectFiles,
            },
            // the validators only really care about the keys on this.
            projects: this.graph.nodes,
            filesToProcess: null,
            nxJsonConfiguration: null,
            workspaceRoot: null,
        });
        if (!this.graph.dependencies[source]) {
            this.graph.dependencies[source] = [];
        }
        const isDuplicate = !!this.graph.dependencies[source].find((d) => d.target === target && d.type === type);
        if (sourceFile) {
            let fileData = getProjectFileData(source, sourceFile, this.projectFileMap);
            const isProjectFileData = !!fileData;
            fileData ??= getNonProjectFileData(sourceFile, this.nonProjectFiles);
            if (!fileData.deps) {
                fileData.deps = [];
            }
            if (!fileData.deps.find((t) => (0, project_graph_1.fileDataDepTarget)(t) === target && (0, project_graph_1.fileDataDepType)(t) === type)) {
                const dep = isProjectFileData
                    ? type === 'static'
                        ? target
                        : [target, type]
                    : [source, target, type];
                fileData.deps.push(dep);
            }
        }
        else if (!isDuplicate) {
            // only add to dependencies section if the source file is not specified
            // and not already added
            this.graph.dependencies[source].push({
                source: source,
                target: target,
                type,
            });
        }
    }
    removeDependenciesWithNode(name) {
        // remove all source dependencies
        delete this.graph.dependencies[name];
        // remove all target dependencies
        for (const dependencies of Object.values(this.graph.dependencies)) {
            for (const [index, { source, target }] of dependencies.entries()) {
                if (target === name) {
                    const deps = this.graph.dependencies[source];
                    this.graph.dependencies[source] = [
                        ...deps.slice(0, index),
                        ...deps.slice(index + 1),
                    ];
                    if (this.graph.dependencies[source].length === 0) {
                        delete this.graph.dependencies[source];
                    }
                }
            }
        }
    }
    calculateTargetDepsFromFiles(sourceProject) {
        const fileDeps = new Map();
        const files = this.projectFileMap[sourceProject] || [];
        if (!files) {
            return fileDeps;
        }
        for (let f of files) {
            if (f.deps) {
                for (let d of f.deps) {
                    const target = (0, project_graph_1.fileDataDepTarget)(d);
                    if (!fileDeps.has(target)) {
                        fileDeps.set(target, new Set([(0, project_graph_1.fileDataDepType)(d)]));
                    }
                    else {
                        fileDeps.get(target).add((0, project_graph_1.fileDataDepType)(d));
                    }
                }
            }
        }
        return fileDeps;
    }
    calculateAlreadySetTargetDeps(sourceProject) {
        const alreadySetTargetProjects = new Map();
        if (this.graph.dependencies[sourceProject]) {
            const removed = this.removedEdges[sourceProject];
            for (const d of this.graph.dependencies[sourceProject]) {
                // static and dynamic dependencies of internal projects
                // will be rebuilt based on the file dependencies
                // we only need to keep the implicit dependencies
                if (d.type === project_graph_1.DependencyType.implicit && !removed?.has(d.target)) {
                    if (!alreadySetTargetProjects.has(d.target)) {
                        alreadySetTargetProjects.set(d.target, new Map([[d.type, d]]));
                    }
                    else {
                        alreadySetTargetProjects.get(d.target).set(d.type, d);
                    }
                }
            }
        }
        return alreadySetTargetProjects;
    }
}
exports.ProjectGraphBuilder = ProjectGraphBuilder;
/**
 * A function to validate dependencies in a {@link CreateDependencies} function
 * @throws If the dependency is invalid.
 */
function validateDependency(dependency, ctx) {
    if (dependency.type === project_graph_1.DependencyType.implicit) {
        validateImplicitDependency(dependency, ctx);
    }
    else if (dependency.type === project_graph_1.DependencyType.dynamic) {
        validateDynamicDependency(dependency, ctx);
    }
    else if (dependency.type === project_graph_1.DependencyType.static) {
        validateStaticDependency(dependency, ctx);
    }
    validateCommonDependencyRules(dependency, ctx);
}
exports.validateDependency = validateDependency;
function validateCommonDependencyRules(d, { externalNodes, projects, fileMap }) {
    if (!projects[d.source] && !externalNodes[d.source]) {
        throw new Error(`Source project does not exist: ${d.source}`);
    }
    if (!projects[d.target] &&
        !externalNodes[d.target] &&
        !('sourceFile' in d && d.sourceFile)) {
        throw new Error(`Target project does not exist: ${d.target}`);
    }
    if (externalNodes[d.source] && projects[d.target]) {
        throw new Error(`External projects can't depend on internal projects`);
    }
    if ('sourceFile' in d && d.sourceFile) {
        if (projects[d.source]) {
            // Throws if source file is not a valid file within the source project.
            // We can pass empty array for all workspace files here, since its not checked by the impl.
            // We need all workspace files in here for the TODO comment though, so lets figure that out.
            getFileData(d.source, d.sourceFile, projects, externalNodes, fileMap.projectFileMap, fileMap.nonProjectFiles);
        }
    }
}
function validateImplicitDependency(d, { externalNodes }) {
    if (externalNodes[d.source]) {
        throw new Error(`External projects can't have "implicit" dependencies`);
    }
}
function validateDynamicDependency(d, { externalNodes }) {
    if (externalNodes[d.source]) {
        throw new Error(`External projects can't have "dynamic" dependencies`);
    }
    // dynamic dependency is always bound to a file
    if (!d.sourceFile) {
        throw new Error(`Source project file is required for "dynamic" dependencies`);
    }
}
function validateStaticDependency(d, { projects }) {
    // internal nodes must provide sourceProjectFile when creating static dependency
    // externalNodes do not have sourceProjectFile
    if (projects[d.source] && !d.sourceFile) {
        throw new Error(`Source project file is required`);
    }
}
function getProjectFileData(source, sourceFile, fileMap) {
    let fileData = (fileMap[source] || []).find((f) => f.file === sourceFile);
    if (fileData) {
        return fileData;
    }
}
function getNonProjectFileData(sourceFile, files) {
    const fileData = files.find((f) => f.file === sourceFile);
    if (!fileData) {
        throw new Error(`Source file "${sourceFile}" does not exist in the workspace.`);
    }
    return fileData;
}
function getFileData(source, sourceFile, projects, externalNodes, fileMap, nonProjectFiles) {
    const sourceProject = projects[source];
    const matchingExternalNode = externalNodes[source];
    if (!sourceProject && !matchingExternalNode) {
        throw new Error(`Source project is not a project node: ${sourceProject}`);
    }
    return (getProjectFileData(source, sourceFile, fileMap) ??
        getNonProjectFileData(sourceFile, nonProjectFiles));
}