mirror of
https://github.com/SonarSource/sonarqube-scan-action.git
synced 2026-06-05 00:57:59 +03:00
d92c61d794
Emit a warning when SONARCLOUD_URL is set, directing users to either pass nothing, use SONAR_REGION=us for the US region, or pass -Dsonar.scanner.sonarcloudUrl and -Dsonar.scanner.apiBaseUrl via args for advanced needs. Backward compatibility is preserved. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
109 lines
3.8 KiB
JavaScript
109 lines
3.8 KiB
JavaScript
// SonarQube Scan Action
|
|
// Copyright (C) SonarSource Sàrl
|
|
// mailto:contact AT sonarsource DOT com
|
|
//
|
|
// This program is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU Lesser General Public
|
|
// License as published by the Free Software Foundation; either
|
|
// version 3 of the License, or (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
// Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
// along with this program; if not, write to the Free Software Foundation,
|
|
// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
import * as core from "@actions/core";
|
|
import { installSonarScanner } from "./install-sonar-scanner.js";
|
|
import { runSonarScanner } from "./run-sonar-scanner.js";
|
|
import {
|
|
checkGradleProject,
|
|
checkMavenProject,
|
|
checkSonarToken,
|
|
validateScannerVersion,
|
|
} from "./sanity-checks.js";
|
|
|
|
/**
|
|
* Inputs are defined in action.yml
|
|
*/
|
|
function getInputs() {
|
|
const args = core.getInput("args");
|
|
const projectBaseDir = core.getInput("projectBaseDir");
|
|
const scannerBinariesUrl = core.getInput("scannerBinariesUrl");
|
|
const scannerBinariesAuthHeader = core.getInput("scannerBinariesAuthHeader") || undefined;
|
|
if (scannerBinariesAuthHeader) {
|
|
core.setSecret(scannerBinariesAuthHeader);
|
|
}
|
|
const scannerVersion = core.getInput("scannerVersion");
|
|
const skipSignatureVerification = core.getBooleanInput("skipSignatureVerification");
|
|
|
|
return { args, projectBaseDir, scannerBinariesUrl, scannerBinariesAuthHeader, scannerVersion, skipSignatureVerification };
|
|
}
|
|
|
|
/**
|
|
* These RUNNER env variables come from GitHub by default.
|
|
* See https://docs.github.com/en/actions/reference/workflows-and-actions/variables#default-environment-variables
|
|
*
|
|
* The others are optional env variables provided by the user of the action
|
|
*/
|
|
function getEnvVariables() {
|
|
return {
|
|
runnerDebug: process.env.RUNNER_DEBUG,
|
|
runnerOs: process.env.RUNNER_OS,
|
|
runnerTemp: process.env.RUNNER_TEMP,
|
|
sonarRootCert: process.env.SONAR_ROOT_CERT,
|
|
sonarcloudUrl: process.env.SONARCLOUD_URL,
|
|
sonarToken: process.env.SONAR_TOKEN,
|
|
};
|
|
}
|
|
|
|
function runSanityChecks(inputs) {
|
|
try {
|
|
const { projectBaseDir, scannerVersion, sonarToken } = inputs;
|
|
|
|
validateScannerVersion(scannerVersion);
|
|
checkSonarToken(core, sonarToken);
|
|
checkMavenProject(core, projectBaseDir);
|
|
checkGradleProject(core, projectBaseDir);
|
|
} catch (error) {
|
|
core.setFailed(`Sanity checks failed: ${error.message}`);
|
|
process.exit(1);
|
|
}
|
|
}
|
|
|
|
async function run() {
|
|
try {
|
|
const { args, projectBaseDir, scannerVersion, scannerBinariesUrl, scannerBinariesAuthHeader, skipSignatureVerification } =
|
|
getInputs();
|
|
const runnerEnv = getEnvVariables();
|
|
const { sonarToken, sonarcloudUrl } = runnerEnv;
|
|
|
|
if (sonarcloudUrl) {
|
|
core.warning(
|
|
"The SONARCLOUD_URL environment variable is deprecated and will be removed in a future version. " +
|
|
"Regular users should not set it; use SONAR_REGION=us for the US region. " +
|
|
"For advanced needs, pass -Dsonar.scanner.sonarcloudUrl and -Dsonar.scanner.apiBaseUrl via the args input."
|
|
);
|
|
}
|
|
|
|
runSanityChecks({ projectBaseDir, scannerVersion, sonarToken });
|
|
|
|
const scannerDir = await installSonarScanner({
|
|
scannerVersion,
|
|
scannerBinariesUrl,
|
|
scannerBinariesAuthHeader,
|
|
skipSignatureVerification,
|
|
});
|
|
|
|
await runSonarScanner(args, projectBaseDir, scannerDir, runnerEnv);
|
|
} catch (error) {
|
|
core.setFailed(`Action failed: ${error.message}`);
|
|
process.exit(1);
|
|
}
|
|
}
|
|
|
|
run();
|