IBM Cloud Docs
Configuring IBM Cloud Code Risk Analyzer scans

Configuring IBM Cloud Code Risk Analyzer scans

You can use IBM Cloud Code Risk Analyzer to analyze your code for vulnerabilities and validate compliance against specified rules.

When Code Risk Analyzer evaluates your app:

  • A software bill of materials (SBOM) is generated that lists the dependencies and available license information of all third-party packages. This can be generated in cycloneDX-specific format if needed.

  • The packages listed in the SBOM file are scanned for vulnerabilities. This file can be generated in cycloneDX-specific format. Alternatively, you can enable auto-remediation of vulnerabilties that are found for applications written in Node.js, Maven, or Gradle.

  • All of your Kubernetes files are analyzed for compliance.

  • All of your Terraform plans are analyzed for compliance.

Code Risk Analyzer is available in all IBM Cloud regions where toolchains are supported. For more information, see the plug-in documentation.

Configuring scans

To generate the SBOM file, a Code Risk Analyzer scan accesses artifacts in the specified directory path and performs deep discovery to identify all of the dependencies; including trasitive dependencies. There are no specific pipeline environment variables that are needed to generate the SBOM file and discover vulnerabilities, but if the path contains a Dockerfile, the base image is pulled and images are built for each build stage specified in the file.

If your Dockerfile requires ARGS, set an individual ARG as an environment variable in a custom script and provide the location of the custom script as the pipeline vairable.

Docker script environment variables
Environment variables Description Required or optional Purpose
cra-custom-script-path Path to the script in your repo. Optional Sets environment variables that are needed by the Docker script.

For more information, see custom scripts

By default, Terraform files are not analyzed. To scan your Terraform file, you must set the following pipeline environment variables.

Terraform analysis environment variables
Environment variables Description Required or optional Purpose
opt-in-tfsec True or false. Set to false by default. Optional Scans Terraform files for security.
opt-in-cra-tf-validate True or false. Set to false by default. Optional Validates Terraform files.

The Code Risk Analyzer scan utilizes the API key provided to log in to the IBMCloud CLI and triggers a Docker build. The existing IBM Cloud CLI session is continued to be used for the remainder of this CRA step. However, the IBM Cloud CLI session expires after 20 minutes for a standard API key login. If the build process takes longer than 20 minutes, the CRA step will fail with a 401 error message since the session has expired. An environment variable ibmcloud-enable-session-keep-alive has been introduced to keep the IBMCloud CLI session alive for such long operations.

IBMCloud Live Session for long running job
Environment variables Description Type Required or optional Purpose
ibmcloud-enable-session-keep-alive 0 or 1. Set to 0 by default. select Optional Keep the IBMCloud CLI session alive for long running jobs in Code Risk Analyzer scan.

By default, The Code Risk Analyzer deployment-analyze command runs configuration checks on Kubernetes deployment manifests. The Code Risk Analyzer deployment-analyze command runs with the --strict option set. To ignore files during Code Risk Analyzer deployment-analyze scan, the following environment variable has to be used.

IBMCloud CRA CIS scan environment variables
Environment variables Description Required or optional Purpose
cra-cis-fileignore-path The path of the .fileignore file in your repo. Optional Specify the path of the .fileignore file which contains the information of files to ignore during Code Risk Analyzer deployment-analyze scan.

Omitting vulnerabilities to deploy your app

The Code Risk Analyzer is designed to find vulnerable packages before an adivsory board does. In exceptional circumstances, you might need to deploy your application even if vulnerable packages have been detected and have not yet been fixed. Whenever possible, you should update the packages or remove them before redeploying your code.

To ignore specific files and complete your push to production, you can create a file called .cra/.cveignore in the scanned repository's root with the following schema:

[
  {
    "cve": "string",
    "alwaysOmit": "bool",
    "untilRemediationAvailable": "bool",
    "expiration": "string"
  },
]

The following code snippet shows a sample .cveignore file:

[
  {
    "cve": "CVE-2021-27290",
    "alwaysOmit": true
  },
  {
    "cve": "CVE-2020-8244",
    "untilRemediationAvailable": true,
  },
  {
    "cve": "CLAIR-JAVA-ORGAPACHEHTTPCOMPONENTS-31517",
    "expiration": "2022-02-10T22:08:41+04:00",
    "comment": "Additional security measures are in place"
  }
]

This file used to be known as .craveomit. The original file format has been deprecated and replaced by .cra/.cveignore. Please update your code to use the most recent file.

You can learn more about the Code Risk Analyzer plug-in's docs, or you can also check the deprecated CRA docs.

Automatically remediating vulnerabilities

You can use the Code Risk Analyzer as part of the Continuous Compliance (CC) pipeline to not only find but automatically remediate vulnerabiltiies. The Code Risk Analyzer works as part of the compliance-check step of the pipeline. By default, auto-remediation is turned off.

Auto-remediation is available for the CC pipeline only.

When auto-remediation is turned on, the Code Risk Analyzer attempts to update a vulnerable package to a non-vunlnerable version by creating a pull request with the identified fixes against the default branch of your repo. By default, the Code Risk Analyzer will update minor and patch versions for the main vulnerable package as well as dependent packages, but does not update the major version of a package. If the pull request is acceptable, you can manually approve and merge it. Each time the pipeline is run, a new pull request is generated, so be sure to review and merge as they are opened to avoid duplications.

Auto-remediation is available for the both Enterprise GitHub and GitLab repositories and can modify the files specified in the following table.

Supported ecosystems
Ecosystem Modifiable files
Nodejs package.json and package-lock.json
Gradle build.gradle, gradle.lockfile, and buildscript-gradle.lockfile
Maven pom.xml

To start automatically remediating vulnerabilities, set the following optional environment variables for your pipeline.

Supported ecosystems
Variable Description Default settings
opt-in-cra-auto-remediation Enables auto-remediation for your pipeline. false
To start remediating, set this variable to true.
opt-in-cra-auto-remediation-force Forces a major package update as part of the pull request that is opened. false
To force a major package update, set this variable to true.
opt-in-cra-auto-remediation-enabled-repos Specifies specific repos where you want to enable auto-remediation. Enabled for all repositories that are returned when list_repos is called. To specify specific repos, provide a comma-separated list of repo names.