setup-node/src/setup-node.ts

44 lines
1.3 KiB
TypeScript
Raw Normal View History

2019-08-04 09:49:54 +08:00
import * as core from '@actions/core';
import * as installer from './installer';
import * as auth from './authutil';
2019-08-04 09:49:54 +08:00
import * as path from 'path';
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...
//
2020-04-24 20:58:38 +08:00
let version = core.getInput('node-version');
if (!version) {
2020-04-24 20:58:38 +08:00
version = core.getInput('version');
}
2020-04-24 20:58:38 +08:00
console.log(`version: ${version}`);
2019-08-04 09:49:54 +08:00
if (version) {
2020-04-24 20:58:38 +08:00
let token = core.getInput('token');
let stable = (core.getInput('stable') || 'true').toUpperCase() === 'TRUE';
await installer.getNode(version, stable, token);
2019-08-04 09:49:54 +08:00
}
const registryUrl: string = core.getInput('registry-url');
const alwaysAuth: string = core.getInput('always-auth');
if (registryUrl) {
auth.configAuthentication(registryUrl, alwaysAuth);
}
2019-08-04 09:49:54 +08:00
const matchersPath = path.join(__dirname, '..', '.github');
console.log(`##[add-matcher]${path.join(matchersPath, 'tsc.json')}`);
console.log(
`##[add-matcher]${path.join(matchersPath, 'eslint-stylish.json')}`
);
console.log(
`##[add-matcher]${path.join(matchersPath, 'eslint-compact.json')}`
);
} catch (error) {
core.setFailed(error.message);
}
}
run();