JFrog Evidence Collection integration

SonarQube Server integrates with JFrog Evidence Collection to provide trusted auditing for software packages.

This integration is available from SonarQube Server Enterprise Edition.

The JFrog Evidence Collectionarrow-up-right expands JFrog’s Release Lifecycle Management capabilities to enrich artifacts, builds, and release bundles with signed attestation metadata that can be easily tracked and verified for governance and compliance.

SonarQube Server integrates with JFrog Evidence Collection to provide trusted auditing for software packages.

Integration overview

The JFrog CLIarrow-up-right is used within the CI pipeline to create the Sonar evidence that will be displayed on the JFrog platform. This evidence contains the quality gate status computed by SonarQube Server and made accessible via its API.

The figure below shows the process:

  1. The CI pipeline starts the SonarQube analysis.

  2. The SonarScanner performs the analysis and sends the results to SonarQube Server .

  3. SonarQube Server processes the analysis results and computes the quality gate status.

  4. The CI pipeline asks JFrog CLI to create the Sonar evidence for the analysis.

  5. The JFrog CLI, which waits for the analysis completion, retrieves SonarQube analysis evidence payload from SonarQube Server's endpoint: <serverBaseUrl>/api/v2/dop-translation/jfrog-evidence/<backgroundTaskId> (see the Example of a Sonar endpoint response expandable below).

The JFrog CLI waits for the SonarQube Server analysis completion, retrieves SonarQube analysis evidence payload from SonarQube Server's endpoint, creates the Sonar evidence, and sends it to JFrog Evidence Collection.
chevron-rightExample of a Sonar endpoint responsehashtag

The endpoint response contains the evidence payload in JSON format with a markdown section.

{
   "predicateType":"https://jfrog.com/evidence/sonarqube/v1",
   "predicate":{
      "projectStatus":{
         "status":"ERROR",
         "ignoredConditions":false,
         "caycStatus":"non-compliant",
         "conditions":[
            {
               "status":"ERROR",
               "metricKey":"new_coverage",
               "comparator":"LT",
               "errorThreshold":"85",
               "actualValue":"82.50562381034781"
            },
            {
               "status":"OK",
               "metricKey":"skipped_tests",
               "comparator":"GT",
               "actualValue":"0"
            }
         ],
         "period":{
            "mode":"last_version",
            "date":"2000-04-27T00:45:23+0200",
            "parameter":"2015-12-07"
         }
      }
   },
    "createdAt": "2222-01-01T00:00:00.000Z",
    "createdBy": "SonarQube",
    "markdown": "# SVG in Markdown example\n\n## Details\n\n- **Type**: svg examples\n\nThis demonstrates the syntax for embedding an SVG without a separate file.\n\n!"
}

Prerequisites

  • SonarQube Server Enterprise Edition

  • JFrog Artifactory Enterprise+ license

  • Minimum JFrog CLI version: 2.78.9

Setting up the integration

You must set up your pipeline to use the JFrog CLI to create the Sonar evidence. See the JFrog pipelines documentationarrow-up-right.

Last updated

Was this helpful?