@storm-software/workspace-tools
Version:
Tools for managing a Storm workspace, including various Nx generators and executors for common development tasks.
164 lines (161 loc) • 5.11 kB
JavaScript
import {
joinPaths
} from "./chunk-U7JFVMCK.mjs";
// src/utils/pnpm-deps-update.ts
import {
createProjectGraphAsync,
readCachedProjectGraph
} from "@nx/devkit";
import { existsSync } from "node:fs";
import { readFile, writeFile } from "node:fs/promises";
import { format } from "prettier";
import readYamlFile from "read-yaml-file";
var pnpmCatalog;
async function pnpmCatalogUpdate(packageJson, workspaceRoot = process.cwd()) {
if (!pnpmCatalog) {
const pnpmWorkspacePath = joinPaths(workspaceRoot, "pnpm-workspace.yaml");
if (!existsSync(pnpmWorkspacePath)) {
console.warn(
`No \`pnpm-workspace.yaml\` file found in workspace root (searching in: ${pnpmWorkspacePath}). Skipping pnpm catalog read for now.`
);
return packageJson;
}
const pnpmWorkspaceYaml = await readYamlFile(pnpmWorkspacePath);
if (pnpmWorkspaceYaml?.catalog) {
pnpmCatalog = pnpmWorkspaceYaml.catalog;
} else {
console.warn(
`Found a \`pnpm-workspace.yaml\` file in the workspace root directory, but no pnpm catalog existed:
File name: ${pnpmWorkspacePath}
File contents: ${pnpmWorkspaceYaml ? JSON.stringify(pnpmWorkspaceYaml) : "EMPTY FILE"}`
);
}
}
if (!pnpmCatalog) {
console.warn(
`No pnpm catalog found. Attempting to read from workspace root's \`pnpm-workspace.yaml\` file.`
);
}
for (const dependencyType of [
"dependencies",
"devDependencies",
"peerDependencies"
]) {
const dependencies = packageJson[dependencyType];
if (!dependencies) {
continue;
}
for (const dependencyName of Object.keys(dependencies)) {
if (dependencies[dependencyName] === "catalog:") {
if (!pnpmCatalog) {
throw new Error(
`Dependency ${dependencyName} is marked as \`catalog:\`, but no catalog exists in the workspace root's \`pnpm-workspace.yaml\` file.`
);
}
const catalogVersion = pnpmCatalog[dependencyName];
if (!catalogVersion) {
throw new Error("Missing pnpm catalog version for " + dependencyName);
}
dependencies[dependencyName] = catalogVersion;
} else if (dependencies[dependencyName].startsWith("catalog:")) {
throw new Error("multiple named catalogs not supported");
}
}
}
return packageJson;
}
async function pnpmWorkspaceUpdate(packageJson, workspaceRoot = process.cwd()) {
let projectGraph;
try {
projectGraph = readCachedProjectGraph();
} catch {
await createProjectGraphAsync();
projectGraph = readCachedProjectGraph();
}
const workspacePackages = {};
if (projectGraph) {
await Promise.all(
Object.keys(projectGraph.nodes).map(async (node) => {
const projectNode = projectGraph.nodes[node];
if (projectNode?.data.root) {
const projectPackageJsonPath = joinPaths(
workspaceRoot,
projectNode.data.root,
"package.json"
);
if (existsSync(projectPackageJsonPath)) {
const projectPackageJsonContent = await readFile(
projectPackageJsonPath,
"utf8"
);
const projectPackageJson = JSON.parse(projectPackageJsonContent);
if (projectPackageJson.private !== true) {
workspacePackages[projectPackageJson.name] = projectPackageJson.version;
}
}
}
})
);
}
for (const dependencyType of [
"dependencies",
"devDependencies",
"peerDependencies"
]) {
const dependencies = packageJson[dependencyType];
if (!dependencies) {
continue;
}
for (const dependencyName of Object.keys(dependencies)) {
if (dependencies[dependencyName].startsWith("workspace:")) {
if (workspacePackages[dependencyName]) {
dependencies[dependencyName] = `^${workspacePackages[dependencyName]}`;
} else {
throw new Error(
`Workspace dependency ${dependencyName} not found in workspace packages.`
);
}
}
}
}
return packageJson;
}
async function pnpmUpdate(packageRoot, workspaceRoot = process.cwd()) {
const packageJsonPath = joinPaths(packageRoot, "package.json");
const packageJsonFile = await readFile(packageJsonPath, "utf8");
if (!packageJsonFile) {
throw new Error(
"No package.json file found in package root: " + packageRoot
);
}
return writeFile(
packageJsonPath,
await format(
JSON.stringify(
await pnpmWorkspaceUpdate(
await pnpmCatalogUpdate(JSON.parse(packageJsonFile), workspaceRoot),
workspaceRoot
)
),
{
parser: "json",
proseWrap: "always",
trailingComma: "none",
tabWidth: 2,
semi: true,
singleQuote: false,
quoteProps: "as-needed",
insertPragma: false,
bracketSameLine: true,
printWidth: 80,
bracketSpacing: true,
arrowParens: "avoid",
endOfLine: "lf",
plugins: ["prettier-plugin-pkg"]
}
)
);
}
export {
pnpmUpdate
};