mirror of
https://github.com/github/codeql-action.git
synced 2025-12-27 01:30:10 +08:00
This is not the case when downloading the bundle from a GitHub Release synced to GHES with the CodeQL Action sync tool.
153 lines
7.3 KiB
JavaScript
Generated
153 lines
7.3 KiB
JavaScript
Generated
"use strict";
|
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
if (k2 === undefined) k2 = k;
|
|
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
}
|
|
Object.defineProperty(o, k2, desc);
|
|
}) : (function(o, m, k, k2) {
|
|
if (k2 === undefined) k2 = k;
|
|
o[k2] = m[k];
|
|
}));
|
|
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
}) : function(o, v) {
|
|
o["default"] = v;
|
|
});
|
|
var __importStar = (this && this.__importStar) || (function () {
|
|
var ownKeys = function(o) {
|
|
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
var ar = [];
|
|
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
return ar;
|
|
};
|
|
return ownKeys(o);
|
|
};
|
|
return function (mod) {
|
|
if (mod && mod.__esModule) return mod;
|
|
var result = {};
|
|
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
__setModuleDefault(result, mod);
|
|
return result;
|
|
};
|
|
})();
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.STREAMING_HIGH_WATERMARK_BYTES = void 0;
|
|
exports.downloadAndExtract = downloadAndExtract;
|
|
exports.getToolcacheDirectory = getToolcacheDirectory;
|
|
exports.writeToolcacheMarkerFile = writeToolcacheMarkerFile;
|
|
const fs = __importStar(require("fs"));
|
|
const os = __importStar(require("os"));
|
|
const path = __importStar(require("path"));
|
|
const perf_hooks_1 = require("perf_hooks");
|
|
const core = __importStar(require("@actions/core"));
|
|
const http_client_1 = require("@actions/http-client");
|
|
const toolcache = __importStar(require("@actions/tool-cache"));
|
|
const follow_redirects_1 = require("follow-redirects");
|
|
const semver = __importStar(require("semver"));
|
|
const logging_1 = require("./logging");
|
|
const tar = __importStar(require("./tar"));
|
|
const util_1 = require("./util");
|
|
/**
|
|
* High watermark to use when streaming the download and extraction of the CodeQL tools.
|
|
*/
|
|
exports.STREAMING_HIGH_WATERMARK_BYTES = 4 * 1024 * 1024; // 4 MiB
|
|
/**
|
|
* The name of the tool cache directory for the CodeQL tools.
|
|
*/
|
|
const TOOLCACHE_TOOL_NAME = "CodeQL";
|
|
function makeDownloadFirstToolsDownloadDurations(downloadDurationMs, extractionDurationMs) {
|
|
return {
|
|
combinedDurationMs: downloadDurationMs + extractionDurationMs,
|
|
downloadDurationMs,
|
|
extractionDurationMs,
|
|
streamExtraction: false,
|
|
};
|
|
}
|
|
function makeStreamedToolsDownloadDurations(combinedDurationMs) {
|
|
return {
|
|
combinedDurationMs,
|
|
downloadDurationMs: undefined,
|
|
extractionDurationMs: undefined,
|
|
streamExtraction: true,
|
|
};
|
|
}
|
|
async function downloadAndExtract(codeqlURL, compressionMethod, dest, authorization, headers, tarVersion, logger) {
|
|
logger.info(`Downloading CodeQL tools from ${codeqlURL} . This may take a while.`);
|
|
try {
|
|
if (compressionMethod === "zstd" && process.platform === "linux") {
|
|
logger.info(`Streaming the extraction of the CodeQL bundle.`);
|
|
const toolsInstallStart = perf_hooks_1.performance.now();
|
|
await downloadAndExtractZstdWithStreaming(codeqlURL, dest, authorization, headers, tarVersion, logger);
|
|
const combinedDurationMs = Math.round(perf_hooks_1.performance.now() - toolsInstallStart);
|
|
logger.info(`Finished downloading and extracting CodeQL bundle to ${dest} (${(0, logging_1.formatDuration)(combinedDurationMs)}).`);
|
|
return {
|
|
compressionMethod,
|
|
toolsUrl: sanitizeUrlForStatusReport(codeqlURL),
|
|
...makeStreamedToolsDownloadDurations(combinedDurationMs),
|
|
};
|
|
}
|
|
}
|
|
catch (e) {
|
|
core.warning(`Failed to download and extract CodeQL bundle using streaming with error: ${(0, util_1.getErrorMessage)(e)}`);
|
|
core.warning(`Falling back to downloading the bundle before extracting.`);
|
|
// If we failed during processing, we want to clean up the destination directory
|
|
// before we try again.
|
|
await (0, util_1.cleanUpGlob)(dest, "CodeQL bundle", logger);
|
|
}
|
|
const toolsDownloadStart = perf_hooks_1.performance.now();
|
|
const archivedBundlePath = await toolcache.downloadTool(codeqlURL, undefined, authorization, headers);
|
|
const downloadDurationMs = Math.round(perf_hooks_1.performance.now() - toolsDownloadStart);
|
|
logger.info(`Finished downloading CodeQL bundle to ${archivedBundlePath} (${(0, logging_1.formatDuration)(downloadDurationMs)}).`);
|
|
let extractionDurationMs;
|
|
try {
|
|
logger.info("Extracting CodeQL bundle.");
|
|
const extractionStart = perf_hooks_1.performance.now();
|
|
await tar.extract(archivedBundlePath, dest, compressionMethod, tarVersion, logger);
|
|
extractionDurationMs = Math.round(perf_hooks_1.performance.now() - extractionStart);
|
|
logger.info(`Finished extracting CodeQL bundle to ${dest} (${(0, logging_1.formatDuration)(extractionDurationMs)}).`);
|
|
}
|
|
finally {
|
|
await (0, util_1.cleanUpGlob)(archivedBundlePath, "CodeQL bundle archive", logger);
|
|
}
|
|
return {
|
|
compressionMethod,
|
|
toolsUrl: sanitizeUrlForStatusReport(codeqlURL),
|
|
...makeDownloadFirstToolsDownloadDurations(downloadDurationMs, extractionDurationMs),
|
|
};
|
|
}
|
|
async function downloadAndExtractZstdWithStreaming(codeqlURL, dest, authorization, headers, tarVersion, logger) {
|
|
// Ensure destination exists
|
|
fs.mkdirSync(dest, { recursive: true });
|
|
// Get HTTP Agent to use (respects proxy settings).
|
|
const agent = new http_client_1.HttpClient().getAgent(codeqlURL);
|
|
// Add User-Agent header and Authorization header if provided.
|
|
headers = Object.assign({ "User-Agent": "CodeQL Action" }, authorization ? { authorization } : {}, headers);
|
|
const response = await new Promise((resolve) => follow_redirects_1.https.get(codeqlURL, {
|
|
headers,
|
|
// Increase the high water mark to improve performance.
|
|
highWaterMark: exports.STREAMING_HIGH_WATERMARK_BYTES,
|
|
// Use the agent to respect proxy settings.
|
|
agent,
|
|
}, (r) => resolve(r)));
|
|
if (response.statusCode !== 200) {
|
|
throw new Error(`Failed to download CodeQL bundle from ${codeqlURL}. HTTP status code: ${response.statusCode}.`);
|
|
}
|
|
await tar.extractTarZst(response, dest, tarVersion, logger);
|
|
}
|
|
/** Gets the path to the toolcache directory for the specified version of the CodeQL tools. */
|
|
function getToolcacheDirectory(version) {
|
|
return path.join((0, util_1.getRequiredEnvParam)("RUNNER_TOOL_CACHE"), TOOLCACHE_TOOL_NAME, semver.clean(version) || version, os.arch() || "");
|
|
}
|
|
function writeToolcacheMarkerFile(extractedPath, logger) {
|
|
const markerFilePath = `${extractedPath}.complete`;
|
|
fs.writeFileSync(markerFilePath, "");
|
|
logger.info(`Created toolcache marker file ${markerFilePath}`);
|
|
}
|
|
function sanitizeUrlForStatusReport(url) {
|
|
return ["github/codeql-action", "dsp-testing/codeql-cli-nightlies"].some((repo) => url.startsWith(`https://github.com/${repo}/releases/download/`))
|
|
? url
|
|
: "sanitized-value";
|
|
}
|
|
//# sourceMappingURL=tools-download.js.map
|