mirror of
https://github.com/github/codeql-action.git
synced 2025-12-06 07:48:17 +08:00
162 lines
7.9 KiB
JavaScript
Generated
162 lines
7.9 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.determineAutobuildLanguages = determineAutobuildLanguages;
|
|
exports.setupCppAutobuild = setupCppAutobuild;
|
|
exports.runAutobuild = runAutobuild;
|
|
const core = __importStar(require("@actions/core"));
|
|
const actions_util_1 = require("./actions-util");
|
|
const api_client_1 = require("./api-client");
|
|
const codeql_1 = require("./codeql");
|
|
const doc_url_1 = require("./doc-url");
|
|
const environment_1 = require("./environment");
|
|
const feature_flags_1 = require("./feature-flags");
|
|
const languages_1 = require("./languages");
|
|
const repository_1 = require("./repository");
|
|
const util_1 = require("./util");
|
|
async function determineAutobuildLanguages(codeql, config, logger) {
|
|
if (config.buildMode === util_1.BuildMode.None ||
|
|
config.buildMode === util_1.BuildMode.Manual) {
|
|
logger.info(`Using build mode "${config.buildMode}", nothing to autobuild. ` +
|
|
`See ${doc_url_1.DocUrl.CODEQL_BUILD_MODES} for more information.`);
|
|
return undefined;
|
|
}
|
|
// Attempt to find a language to autobuild
|
|
// We want pick the dominant language in the repo from the ones we're able to build
|
|
// The languages are sorted in order specified by user or by lines of code if we got
|
|
// them from the GitHub API, so try to build the first language on the list.
|
|
const autobuildLanguages = await (0, util_1.asyncFilter)(config.languages, async (language) => await codeql.isTracedLanguage(language));
|
|
if (!autobuildLanguages) {
|
|
logger.info("None of the languages in this project require extra build steps");
|
|
return undefined;
|
|
}
|
|
/**
|
|
* Additionally autobuild Go in the autobuild Action to ensure backwards
|
|
* compatibility for users performing a multi-language build within a single
|
|
* job.
|
|
*
|
|
* For example, consider a user with the following workflow file:
|
|
*
|
|
* ```yml
|
|
* - uses: github/codeql-action/init@v3
|
|
* with:
|
|
* languages: go, java
|
|
* - uses: github/codeql-action/autobuild@v3
|
|
* - uses: github/codeql-action/analyze@v3
|
|
* ```
|
|
*
|
|
* - With Go extraction disabled, we will run the Java autobuilder in the
|
|
* autobuild Action, ensuring we extract both Java and Go code.
|
|
* - With Go extraction enabled, taking the previous behavior we'd run the Go
|
|
* autobuilder, since Go is first on the list of languages. We wouldn't run
|
|
* the Java autobuilder at all and so we'd only extract Go code.
|
|
*
|
|
* We therefore introduce a special case here such that we'll autobuild Go
|
|
* in addition to the primary non-Go traced language in the autobuild Action.
|
|
*
|
|
* This special case behavior should be removed as part of the next major
|
|
* version of the CodeQL Action.
|
|
*/
|
|
const autobuildLanguagesWithoutGo = autobuildLanguages.filter((l) => l !== String(languages_1.KnownLanguage.go));
|
|
const languages = [];
|
|
// First run the autobuilder for the first non-Go traced language, if one
|
|
// exists.
|
|
if (autobuildLanguagesWithoutGo[0] !== undefined) {
|
|
languages.push(autobuildLanguagesWithoutGo[0]);
|
|
}
|
|
// If Go is requested, run the Go autobuilder last to ensure it doesn't
|
|
// interfere with the other autobuilder.
|
|
if (autobuildLanguages.length !== autobuildLanguagesWithoutGo.length) {
|
|
languages.push(languages_1.KnownLanguage.go);
|
|
}
|
|
logger.debug(`Will autobuild ${languages.join(" and ")}.`);
|
|
// In general the autobuilders for other traced languages may conflict with
|
|
// each other. Therefore if a user has requested more than one non-Go traced
|
|
// language, we ask for manual build steps.
|
|
// Matrixing the build would also work, but that would change the SARIF
|
|
// categories, potentially leading to a "stale tips" situation where alerts
|
|
// that should be fixed remain on a repo since they are linked to SARIF
|
|
// categories that are no longer updated.
|
|
if (autobuildLanguagesWithoutGo.length > 1) {
|
|
logger.warning(`We will only automatically build ${languages.join(" and ")} code. If you wish to scan ${autobuildLanguagesWithoutGo
|
|
.slice(1)
|
|
.join(" and ")}, you must replace the autobuild step of your workflow with custom build steps. ` +
|
|
`See ${doc_url_1.DocUrl.SPECIFY_BUILD_STEPS_MANUALLY} for more information.`);
|
|
}
|
|
return languages;
|
|
}
|
|
async function setupCppAutobuild(codeql, logger) {
|
|
const envVar = feature_flags_1.featureConfig[feature_flags_1.Feature.CppDependencyInstallation].envVar;
|
|
const featureName = "C++ automatic installation of dependencies";
|
|
const gitHubVersion = await (0, api_client_1.getGitHubVersion)();
|
|
const repositoryNwo = (0, repository_1.getRepositoryNwo)();
|
|
const features = new feature_flags_1.Features(gitHubVersion, repositoryNwo, (0, actions_util_1.getTemporaryDirectory)(), logger);
|
|
if (await features.getValue(feature_flags_1.Feature.CppDependencyInstallation, codeql)) {
|
|
// disable autoinstall on self-hosted runners unless explicitly requested
|
|
if (process.env["RUNNER_ENVIRONMENT"] === "self-hosted" &&
|
|
process.env[envVar] !== "true") {
|
|
logger.info(`Disabling ${featureName} as we are on a self-hosted runner.${(0, actions_util_1.getWorkflowEventName)() !== "dynamic"
|
|
? ` To override this, set the ${envVar} environment variable to 'true' in your workflow. See ${doc_url_1.DocUrl.DEFINE_ENV_VARIABLES} for more information.`
|
|
: ""}`);
|
|
core.exportVariable(envVar, "false");
|
|
}
|
|
else {
|
|
logger.info(`Enabling ${featureName}. This can be disabled by setting the ${envVar} environment variable to 'false'. See ${doc_url_1.DocUrl.DEFINE_ENV_VARIABLES} for more information.`);
|
|
core.exportVariable(envVar, "true");
|
|
}
|
|
}
|
|
else {
|
|
logger.info(`Disabling ${featureName}.`);
|
|
core.exportVariable(envVar, "false");
|
|
}
|
|
}
|
|
async function runAutobuild(config, language, logger) {
|
|
logger.startGroup(`Attempting to automatically build ${language} code`);
|
|
const codeQL = await (0, codeql_1.getCodeQL)(config.codeQLCmd);
|
|
if (language === String(languages_1.KnownLanguage.cpp)) {
|
|
await setupCppAutobuild(codeQL, logger);
|
|
}
|
|
if (config.buildMode) {
|
|
await codeQL.extractUsingBuildMode(config, language);
|
|
}
|
|
else {
|
|
await codeQL.runAutobuild(config, language);
|
|
}
|
|
if (language === String(languages_1.KnownLanguage.go)) {
|
|
core.exportVariable(environment_1.EnvVar.DID_AUTOBUILD_GOLANG, "true");
|
|
}
|
|
logger.endGroup();
|
|
}
|
|
//# sourceMappingURL=autobuild.js.map
|