@aws/pdk
Version:
All documentation is located at: https://aws.github.io/aws-pdk
65 lines • 14.2 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.sonarqubeScanner = exports.createSonarqubeProject = exports.generateSonarqubeReports = void 0;
const cube = (path, action = "GET", args) => `curl -X ${action} -u $SONARQUBE_TOKEN: "$SONARQUBE_ENDPOINT${path}" ${args || ""}`;
const setupSonarqubeQualityGates = (defaultProfileOrGateName, specificProfileOrGateName) => [
`export DEFAULT_GATE=\`${cube(`/api/qualitygates/search?gateName=${defaultProfileOrGateName}`)}\``,
`export SPECIFIC_GATE=\`${cube(`/api/qualitygates/search?gateName=${specificProfileOrGateName}`)}\``,
`if [[ "$(echo $SPECIFIC_GATE | jq .errors)" == "null" && "$(echo $SPECIFIC_GATE | jq '.results | length')" -gt 0 ]]; then export GATE_NAME=${specificProfileOrGateName}; else export GATE_NAME=${defaultProfileOrGateName}; fi`,
`${cube("/api/qualitygates/select?projectKey=$PROJECT_NAME&gateName=$GATE_NAME", "POST")}`,
];
const setupSonarqubeQualityProfiles = (defaultProfileOrGateName, specificProfileOrGateName) => [
`export DEFAULT_PROFILE=\`${cube(`/api/qualityprofiles/search?qualityProfile=${defaultProfileOrGateName}`)} | jq .profiles\``,
`export SPECIFIC_PROFILE=\`${cube(`/api/qualityprofiles/search?qualityProfile=${specificProfileOrGateName}`)} | jq .profiles\``,
`export MERGED_PROFILES=\`jq --argjson arr1 "$DEFAULT_PROFILE" --argjson arr2 "$SPECIFIC_PROFILE" -n '$arr1 + $arr2 | group_by(.language) | map(.[-1])'\``,
`echo $MERGED_PROFILES | jq -c '.[]' | while read i; do ${cube("/api/qualityprofiles/add_project?project=$PROJECT_NAME&language=`echo $i | jq -r .language`&qualityProfile=`echo $i | jq -r .name`", "POST")}; done`,
];
const setupSonarqubePermissions = (authorizedGroup) => !authorizedGroup
? []
: [
"admin",
"codeviewer",
"issueadmin",
"securityhotspotadmin",
"scan",
"user",
].map((p) => `${cube(`/api/permissions/add_group?projectKey=$PROJECT_NAME&groupName=${authorizedGroup}&permission=${p}`, "POST")}`);
const setupSonarqubeProject = ({ sonarqubeTags, sonarqubeAuthorizedGroup, sonarqubeDefaultProfileOrGateName, sonarqubeSpecificProfileOrGateName, }) => {
return [
...setupSonarqubePermissions(sonarqubeAuthorizedGroup),
`${cube("/api/project_branches/rename?project=$PROJECT_NAME&name=mainline", "POST")}`,
`${cube(`/api/project_tags/set?project=$PROJECT_NAME&tags=${[
sonarqubeAuthorizedGroup,
...(sonarqubeTags || []),
].join(",")}`, "POST")}`,
...setupSonarqubeQualityProfiles(sonarqubeDefaultProfileOrGateName, sonarqubeSpecificProfileOrGateName),
...setupSonarqubeQualityGates(sonarqubeDefaultProfileOrGateName, sonarqubeSpecificProfileOrGateName),
].join(";");
};
const generateSonarqubeReports = () => [
cube("/api/bitegarden/report/pdf_issues_breakdown?resource=$PROJECT_NAME&branch=mainline", "GET", "--output reports/prototype-issues-report.pdf"),
cube("/api/bitegarden/report/pdf?resource=$PROJECT_NAME&branch=mainline", "GET", "--output reports/prototype-executive-report.pdf"),
cube("/api/security_reports/download?project=$PROJECT_NAME", "GET", "--output reports/prototype-security-report.pdf"),
];
exports.generateSonarqubeReports = generateSonarqubeReports;
const createSonarqubeProject = (props) => [
`CREATE_PROJECT_OUTPUT=\`${cube("/api/projects/create?name=$PROJECT_NAME&project=$PROJECT_NAME&visibility=private", "POST")}\``,
`if [[ "$(echo $CREATE_PROJECT_OUTPUT | jq .errors)" == "null" ]]; then ${setupSonarqubeProject(props)}; fi;`,
];
exports.createSonarqubeProject = createSonarqubeProject;
const sonarqubeScanner = (excludeGlobsForScan) => [
"npx sonarqube-scanner -Dsonar.login=$SONARQUBE_TOKEN",
"-Dsonar.projectKey=$PROJECT_NAME",
"-Dsonar.projectName=$PROJECT_NAME",
"-Dsonar.projectVersion=`echo $RESOLVED_SOURCE_VERSION | cut -c1-7`",
"-Dsonar.branch.name=mainline",
"-Dsonar.host.url=$SONARQUBE_ENDPOINT",
"-Dsonar.cfn.nag.reportFiles=reports/cfn-nag-report.json",
"-Dsonar.dependencyCheck.htmlReportPath=reports/dependency-check-report.html",
"-Dsonar.javascript.lcov.reportPaths=**/coverage/lcov.info",
"-Dsonar.clover.reportPath=**/coverage/clover.xml",
`-Dsonar.exclusions="**/reports/**,**/coverage/**${excludeGlobsForScan ? `,${excludeGlobsForScan.join(",")}` : ""}"`,
"-Dsonar.sources=.",
].join(" ");
exports.sonarqubeScanner = sonarqubeScanner;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sonarqube-commands.js","sourceRoot":"","sources":["sonarqube-commands.ts"],"names":[],"mappings":"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","sourcesContent":["/*! Copyright [Amazon.com](http://amazon.com/), Inc. or its affiliates. All Rights Reserved.\nSPDX-License-Identifier: Apache-2.0 */\nimport { SonarCodeScannerProps } from \"./sonar-code-scanner\";\n\nconst cube = (path: string, action: string = \"GET\", args?: string) =>\n  `curl -X ${action} -u $SONARQUBE_TOKEN: \"$SONARQUBE_ENDPOINT${path}\" ${\n    args || \"\"\n  }`;\n\nconst setupSonarqubeQualityGates = (\n  defaultProfileOrGateName: string,\n  specificProfileOrGateName?: string\n) => [\n  `export DEFAULT_GATE=\\`${cube(\n    `/api/qualitygates/search?gateName=${defaultProfileOrGateName}`\n  )}\\``,\n  `export SPECIFIC_GATE=\\`${cube(\n    `/api/qualitygates/search?gateName=${specificProfileOrGateName}`\n  )}\\``,\n  `if [[ \"$(echo $SPECIFIC_GATE | jq .errors)\" == \"null\" && \"$(echo $SPECIFIC_GATE | jq '.results | length')\" -gt 0 ]]; then export GATE_NAME=${specificProfileOrGateName}; else export GATE_NAME=${defaultProfileOrGateName}; fi`,\n  `${cube(\n    \"/api/qualitygates/select?projectKey=$PROJECT_NAME&gateName=$GATE_NAME\",\n    \"POST\"\n  )}`,\n];\n\nconst setupSonarqubeQualityProfiles = (\n  defaultProfileOrGateName: string,\n  specificProfileOrGateName?: string\n) => [\n  `export DEFAULT_PROFILE=\\`${cube(\n    `/api/qualityprofiles/search?qualityProfile=${defaultProfileOrGateName}`\n  )} | jq .profiles\\``,\n  `export SPECIFIC_PROFILE=\\`${cube(\n    `/api/qualityprofiles/search?qualityProfile=${specificProfileOrGateName}`\n  )} | jq .profiles\\``,\n  `export MERGED_PROFILES=\\`jq --argjson arr1 \"$DEFAULT_PROFILE\" --argjson arr2 \"$SPECIFIC_PROFILE\" -n '$arr1 + $arr2 | group_by(.language) | map(.[-1])'\\``,\n  `echo $MERGED_PROFILES | jq -c '.[]' | while read i; do ${cube(\n    \"/api/qualityprofiles/add_project?project=$PROJECT_NAME&language=`echo $i | jq -r .language`&qualityProfile=`echo $i | jq -r .name`\",\n    \"POST\"\n  )}; done`,\n];\n\nconst setupSonarqubePermissions = (authorizedGroup?: string) =>\n  !authorizedGroup\n    ? []\n    : [\n        \"admin\",\n        \"codeviewer\",\n        \"issueadmin\",\n        \"securityhotspotadmin\",\n        \"scan\",\n        \"user\",\n      ].map(\n        (p) =>\n          `${cube(\n            `/api/permissions/add_group?projectKey=$PROJECT_NAME&groupName=${authorizedGroup}&permission=${p}`,\n            \"POST\"\n          )}`\n      );\n\nconst setupSonarqubeProject = ({\n  sonarqubeTags,\n  sonarqubeAuthorizedGroup,\n  sonarqubeDefaultProfileOrGateName,\n  sonarqubeSpecificProfileOrGateName,\n}: SonarCodeScannerProps) => {\n  return [\n    ...setupSonarqubePermissions(sonarqubeAuthorizedGroup),\n    `${cube(\n      \"/api/project_branches/rename?project=$PROJECT_NAME&name=mainline\",\n      \"POST\"\n    )}`,\n    `${cube(\n      `/api/project_tags/set?project=$PROJECT_NAME&tags=${[\n        sonarqubeAuthorizedGroup,\n        ...(sonarqubeTags || []),\n      ].join(\",\")}`,\n      \"POST\"\n    )}`,\n    ...setupSonarqubeQualityProfiles(\n      sonarqubeDefaultProfileOrGateName,\n      sonarqubeSpecificProfileOrGateName\n    ),\n    ...setupSonarqubeQualityGates(\n      sonarqubeDefaultProfileOrGateName,\n      sonarqubeSpecificProfileOrGateName\n    ),\n  ].join(\";\");\n};\n\nexport const generateSonarqubeReports = () => [\n  cube(\n    \"/api/bitegarden/report/pdf_issues_breakdown?resource=$PROJECT_NAME&branch=mainline\",\n    \"GET\",\n    \"--output reports/prototype-issues-report.pdf\"\n  ),\n  cube(\n    \"/api/bitegarden/report/pdf?resource=$PROJECT_NAME&branch=mainline\",\n    \"GET\",\n    \"--output reports/prototype-executive-report.pdf\"\n  ),\n  cube(\n    \"/api/security_reports/download?project=$PROJECT_NAME\",\n    \"GET\",\n    \"--output reports/prototype-security-report.pdf\"\n  ),\n];\n\nexport const createSonarqubeProject = (props: SonarCodeScannerProps) => [\n  `CREATE_PROJECT_OUTPUT=\\`${cube(\n    \"/api/projects/create?name=$PROJECT_NAME&project=$PROJECT_NAME&visibility=private\",\n    \"POST\"\n  )}\\``,\n  `if [[ \"$(echo $CREATE_PROJECT_OUTPUT | jq .errors)\" == \"null\" ]]; then ${setupSonarqubeProject(\n    props\n  )}; fi;`,\n];\n\nexport const sonarqubeScanner = (excludeGlobsForScan?: string[]) =>\n  [\n    \"npx sonarqube-scanner -Dsonar.login=$SONARQUBE_TOKEN\",\n    \"-Dsonar.projectKey=$PROJECT_NAME\",\n    \"-Dsonar.projectName=$PROJECT_NAME\",\n    \"-Dsonar.projectVersion=`echo $RESOLVED_SOURCE_VERSION | cut -c1-7`\",\n    \"-Dsonar.branch.name=mainline\",\n    \"-Dsonar.host.url=$SONARQUBE_ENDPOINT\",\n    \"-Dsonar.cfn.nag.reportFiles=reports/cfn-nag-report.json\",\n    \"-Dsonar.dependencyCheck.htmlReportPath=reports/dependency-check-report.html\",\n    \"-Dsonar.javascript.lcov.reportPaths=**/coverage/lcov.info\",\n    \"-Dsonar.clover.reportPath=**/coverage/clover.xml\",\n    `-Dsonar.exclusions=\"**/reports/**,**/coverage/**${\n      excludeGlobsForScan ? `,${excludeGlobsForScan.join(\",\")}` : \"\"\n    }\"`,\n    \"-Dsonar.sources=.\",\n  ].join(\" \");\n"]}