mirror of
https://github.com/actions/setup-node.git
synced 2025-09-06 16:12:55 +08:00
* setup node in local * Enhance caching in setup-node with package manager filed detection * updated with array * update the field
152 lines
4.7 KiB
TypeScript
152 lines
4.7 KiB
TypeScript
import * as core from '@actions/core';
|
|
|
|
import os from 'os';
|
|
import fs from 'fs';
|
|
|
|
import * as auth from './authutil';
|
|
import * as path from 'path';
|
|
import {restoreCache} from './cache-restore';
|
|
import {isCacheFeatureAvailable} from './cache-utils';
|
|
import {getNodejsDistribution} from './distributions/installer-factory';
|
|
import {getNodeVersionFromFile, printEnvDetailsAndSetOutput} from './util';
|
|
import {State} from './constants';
|
|
|
|
export async function run() {
|
|
try {
|
|
//
|
|
// Version is optional. If supplied, install / use from the tool cache
|
|
// If not supplied then task is still used to setup proxy, auth, etc...
|
|
//
|
|
const version = resolveVersionInput();
|
|
|
|
let arch = core.getInput('architecture');
|
|
const cache = core.getInput('cache');
|
|
const packagemanagercache =
|
|
(core.getInput('package-manager-cache') || 'true').toUpperCase() ===
|
|
'TRUE';
|
|
|
|
// if architecture supplied but node-version is not
|
|
// if we don't throw a warning, the already installed x64 node will be used which is not probably what user meant.
|
|
if (arch && !version) {
|
|
core.warning(
|
|
'`architecture` is provided but `node-version` is missing. In this configuration, the version/architecture of Node will not be changed. To fix this, provide `architecture` in combination with `node-version`'
|
|
);
|
|
}
|
|
|
|
if (!arch) {
|
|
arch = os.arch();
|
|
}
|
|
|
|
if (version) {
|
|
const token = core.getInput('token');
|
|
const auth = !token ? undefined : `token ${token}`;
|
|
const mirror = core.getInput('mirror');
|
|
const mirrorToken = core.getInput('mirror-token');
|
|
const stable =
|
|
(core.getInput('stable') || 'true').toUpperCase() === 'TRUE';
|
|
const checkLatest =
|
|
(core.getInput('check-latest') || 'false').toUpperCase() === 'TRUE';
|
|
const nodejsInfo = {
|
|
versionSpec: version,
|
|
checkLatest,
|
|
auth,
|
|
stable,
|
|
arch,
|
|
mirror,
|
|
mirrorToken
|
|
};
|
|
const nodeDistribution = getNodejsDistribution(nodejsInfo);
|
|
await nodeDistribution.setupNodeJs();
|
|
}
|
|
|
|
await printEnvDetailsAndSetOutput();
|
|
|
|
const registryUrl: string = core.getInput('registry-url');
|
|
const alwaysAuth: string = core.getInput('always-auth');
|
|
if (registryUrl) {
|
|
auth.configAuthentication(registryUrl, alwaysAuth);
|
|
}
|
|
|
|
const resolvedPackageManager = getNameFromPackageManagerField();
|
|
const cacheDependencyPath = core.getInput('cache-dependency-path');
|
|
if (cache && isCacheFeatureAvailable()) {
|
|
core.saveState(State.CachePackageManager, cache);
|
|
await restoreCache(cache, cacheDependencyPath);
|
|
} else if (resolvedPackageManager && packagemanagercache) {
|
|
core.saveState(State.CachePackageManager, resolvedPackageManager);
|
|
await restoreCache(resolvedPackageManager, cacheDependencyPath);
|
|
}
|
|
|
|
const matchersPath = path.join(__dirname, '../..', '.github');
|
|
core.info(`##[add-matcher]${path.join(matchersPath, 'tsc.json')}`);
|
|
core.info(
|
|
`##[add-matcher]${path.join(matchersPath, 'eslint-stylish.json')}`
|
|
);
|
|
core.info(
|
|
`##[add-matcher]${path.join(matchersPath, 'eslint-compact.json')}`
|
|
);
|
|
} catch (err) {
|
|
core.setFailed((err as Error).message);
|
|
}
|
|
}
|
|
|
|
function resolveVersionInput(): string {
|
|
let version = core.getInput('node-version');
|
|
const versionFileInput = core.getInput('node-version-file');
|
|
|
|
if (version && versionFileInput) {
|
|
core.warning(
|
|
'Both node-version and node-version-file inputs are specified, only node-version will be used'
|
|
);
|
|
}
|
|
|
|
if (version) {
|
|
return version;
|
|
}
|
|
|
|
if (versionFileInput) {
|
|
const versionFilePath = path.join(
|
|
process.env.GITHUB_WORKSPACE!,
|
|
versionFileInput
|
|
);
|
|
|
|
const parsedVersion = getNodeVersionFromFile(versionFilePath);
|
|
|
|
if (parsedVersion) {
|
|
version = parsedVersion;
|
|
} else {
|
|
core.warning(
|
|
`Could not determine node version from ${versionFilePath}. Falling back`
|
|
);
|
|
}
|
|
|
|
core.info(`Resolved ${versionFileInput} as ${version}`);
|
|
}
|
|
|
|
return version;
|
|
}
|
|
|
|
export function getNameFromPackageManagerField(): string | undefined {
|
|
// Check packageManager field in package.json
|
|
const SUPPORTED_PACKAGE_MANAGERS = ['npm', 'yarn', 'pnpm'];
|
|
try {
|
|
const packageJson = JSON.parse(
|
|
fs.readFileSync(
|
|
path.join(process.env.GITHUB_WORKSPACE!, 'package.json'),
|
|
'utf-8'
|
|
)
|
|
);
|
|
const pm = packageJson.packageManager;
|
|
if (typeof pm === 'string') {
|
|
const regex = new RegExp(
|
|
`^(?:\\^)?(${SUPPORTED_PACKAGE_MANAGERS.join('|')})@`
|
|
);
|
|
const match = pm.match(regex);
|
|
return match ? match[1] : undefined;
|
|
}
|
|
return undefined;
|
|
} catch (err) {
|
|
return undefined;
|
|
}
|
|
}
|