UNPKG

azure-pipelines-tool-lib

Version:
202 lines (201 loc) 8.08 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); const toolLib = require("./tool"); const taskLib = require("azure-pipelines-task-lib/task"); const restm = require("typed-rest-client/RestClient"); const os = require("os"); const path = require("path"); function run() { return __awaiter(this, void 0, void 0, function* () { try { // // Get an explicit version // yield getNode('v5.10.1', false); // // Query latest with a wildcard // yield getNode('6.x', true); // // Complex versionSpecs are supported. // // For example: // await getNode('9.x || >=4.7.0', true); // } catch (error) { taskLib.setResult(taskLib.TaskResult.Failed, error.message); } }); } let osPlat = os.platform(); let osArch = os.arch(); // // Basic pattern: // if !checkLatest // toolPath = check cache // if !toolPath // if version is a range // match = query nodejs.org // if !match // fail // toolPath = check cache // if !toolPath // download, extract, and cache // toolPath = cacheDir // PATH = cacheDir + PATH // function getNode(versionSpec, checkLatest) { return __awaiter(this, void 0, void 0, function* () { console.log(''); console.log('--------------------------'); console.log('SAMPLE: ' + versionSpec); console.log('--------------------------'); if (toolLib.isExplicitVersion(versionSpec)) { checkLatest = false; // check latest doesn't make sense when explicit version } let toolPath; if (!checkLatest) { // // Let's try and resolve the version spec locally first // toolPath = toolLib.findLocalTool('node', versionSpec); } if (!toolPath) { let version; if (toolLib.isExplicitVersion(versionSpec)) { // // Explicit version was specified. No need to query for list of versions. // version = versionSpec; } else { // // Let's query and resolve the latest version for the versionSpec. // If the version is an explicit version (1.1.1 or v1.1.1) then no need to query. // If your tool doesn't offer a mechanism to query, // then it can only support exact version inputs. // version = yield queryLatestMatch(versionSpec); if (!version) { throw new Error(`Unable to find Node version '${versionSpec}' for platform ${osPlat} and architecture ${osArch}.`); } // // Check the cache for the resolved version. // toolPath = toolLib.findLocalTool('node', version); } if (!toolPath) { // // Download, extract, cache // toolPath = yield acquireNode(version); } } // // A tool installer initimately knows details about the layout of that tool // for example, node binary is in the bin folder after the extract on Mac/Linux. // layouts could change by version, by platform etc... but that's the tool installers job // if (osPlat != 'win32') { toolPath = path.join(toolPath, 'bin'); } // // Prepend the tools path. This prepends the PATH for the current process and // instructs the agent to prepend for each task that follows. // toolLib.prependPath(toolPath); }); } function queryLatestMatch(versionSpec) { return __awaiter(this, void 0, void 0, function* () { // // Hopefully your tool supports an easy way to get a version list. // Node offers a json list of versions. // let dataFileName; switch (osPlat) { case "linux": dataFileName = "linux-" + osArch; break; case "darwin": dataFileName = "osx-" + osArch + '-tar'; break; case "win32": dataFileName = "win-" + osArch + '-exe'; break; default: throw new Error(`Unexpected OS '${osPlat}'`); } let versions = []; let dataUrl = "https://nodejs.org/dist/index.json"; let rest = new restm.RestClient('vsts-node-tool'); let nodeVersions = (yield rest.get(dataUrl)).result; nodeVersions.forEach((nodeVersion) => { // // Ensure this version supports your os and platform. // if (nodeVersion.files.indexOf(dataFileName) >= 0) { versions.push(nodeVersion.version); } }); // // If there is no data driven way to get versions supported, // a last option is to tool.scrape() with a regex. // // For example: // let scrapeUrl = 'https://nodejs.org/dist/'; // let re: RegExp = /v(\d+\.)(\d+\.)(\d+)/g; // versions = await toolLib.scrape(scrapeUrl, re); // // // Get the latest version that matches the version spec. // let version = toolLib.evaluateVersions(versions, versionSpec); return version; }); } function acquireNode(version) { return __awaiter(this, void 0, void 0, function* () { // // Download - a tool installer intimately knows how to get the tool (and construct urls) // version = toolLib.cleanVersion(version); let fileName = osPlat == 'win32' ? 'node-v' + version + '-win-' + os.arch() : 'node-v' + version + '-' + osPlat + '-' + os.arch(); let urlFileName = osPlat == 'win32' ? fileName + '.7z' : fileName + '.tar.gz'; let downloadUrl = 'https://nodejs.org/dist/v' + version + '/' + urlFileName; let downloadPath = yield toolLib.downloadTool(downloadUrl); // // Extract // let extPath; if (osPlat == 'win32') { taskLib.assertAgent('2.115.0'); extPath = taskLib.getVariable('Agent.TempDirectory'); if (!extPath) { throw new Error('Expected Agent.TempDirectory to be set'); } extPath = path.join(extPath, 'n'); // use as short a path as possible due to nested node_modules folders extPath = yield toolLib.extract7z(downloadPath, extPath); } else { extPath = yield toolLib.extractTar(downloadPath); } // // Install into the local tool cache - node extracts with a root folder that matches the fileName downloaded // let toolRoot = path.join(extPath, fileName); return yield toolLib.cacheDir(toolRoot, 'node', version); }); } run();