- Checkmarx Documentation
- Checkmarx One
- Checkmarx One Integrations
- CI/CD Integrations
- Checkmarx One Azure DevOps Plugin
- Quick Start Guide - Checkmarx One Azure DevOps Plugin
Quick Start Guide - Checkmarx One Azure DevOps Plugin
Overview
The Checkmarx One Azure DevOps plugin enables you to trigger SAST, SCA, IaC Security and API Security scans directly from an Azure DevOps pipeline. It provides a wrapper around the Checkmarx One CLI Tool which creates a zip archive from your source code repository and uploads it to Checkmarx One for scanning. This plugin provides easy integration with Azure while enabling scan customization using the full functionality and flexibility of the CLI tool.
Prerequisites
The source code for your project is hosted on a Git repo (public or private)
You have a Checkmarx One account and have credentials to log in to your account
Getting Started Using the Azure DevOps Plugin
This tutorial will guide you through the initial setup and basic workflow for using the Checkmarx One Azure DevOps plugin. We will use an API Key to authenticate with Checkmarx One and we will create a pipeline to scan a project that is hosted on your Azure Git repo.
Step 1 – Generating an API Key in Checkmarx One
First, you need to generate an API Key in Checkmarx One to be used for authentication in Azure DevOps. To create an API Key, see Generating an API Key.
Step 2 – Installing and Setting up the Checkmarx One Plugin
The Checkmarx One plugin for Azure DevOps is available free on Azure DevOps Marketplace. Install the plugin and then create a Service connection to access your Checkmarx One environment.
Open your project in the Azure DevOps console.
Click on the Marketplace icon :marketplace: in the header bar and then select Browse marketplace from the dropdown menu.
Search for the Checkmarx AST plugin and click on it, then click Get it free.
Follow the prompts to run the installation.
In the Azure console, click on Project settings > Service Connections.
Click New service connection at the top right of the screen.
In the New service connection pane, select the radio button next to Checkmarx One Service Connection and then click Next.
The service connection setup form is displayed.
For API Key authentication, select the API KEY Authentication radio button, and fill in the following info:
Fill in the Server URL with the appropriate URL for your environment.
US Environment - https://ast.checkmarx.net
US2 Environment - https://us.ast.checkmarx.net
EU Environment - https://eu.ast.checkmarx.net
EU2 Environment - https://eu-2.ast.checkmarx.net
DEU Environment - https://deu.ast.checkmarx.net
Australia & New Zealand – https://anz.ast.checkmarx.net
India - https://ind.ast.checkmarx.net
Singapore - https://sng.ast.checkmarx.net
UAE - https://mea.ast.checkmarx.net
Enter your API Key. To generate an API Key, see Generating an API Key.
In the Details section, it is recommended to give the connection a descriptive name (e.g., Checkmarx One Connection) and add a brief description. (optional)
Click Save.
Step 3 - Create an Azure Pipeline
For this tutorial we will create a simple pipeline that gets the source code from your Azure repo and runs a Checkmarx One scan on the source code.
In your Azure DevOps console, in the main navigation, select Pipelines .
On the Pipelines screen, click New pipeline.
A new pipeline form opens.
Specify the repo where the source code is located. We will specify an Azure repo using the following procedure:
Click on Other Git and then select Azure Repos Git.
Notice
If you don't see this option, go to Project Settings > Settings and turn off the toggles for Disable creation of classic build pipelines and Disable creation of classic release pipelines. Alternatively, you can create the pipeline using the procedure described in Creating a Checkmarx One Pipeline Using a YAML.
Select the desired Team project, Repository and Default branch from the dropdown lists and then click Continue.
In the Select Template section, click on Empty job.
Click on the “+” button for “Agent job 1” and search for the Checkmarx One plugin.
Hover over the Checkmarx One plugin and click Add.
The Checkmarx One task configuration form is shown in the right-side panel.
Under Checkmarx One Service Connection, select from the dropdown list the connection that you configured for Checkmarx One in Step 2 above.
By default, the Project Name is designated as $(Build.Repository.Name). You can enter an alternative name if you prefer.
By default, the Branch Name is designated as $(Build.SourceBranchName). You can enter an alternative name if you prefer.
Under Tenant Name, enter the name of your Checkmarx One tenant account.
Under Additional Parameters, you can specify any CLI arguments that you would like to apply to scans of this project. See documentation here.
Notice
By default all scanners that you are authorized to run (licensed or open source) will run. To limit scans to one or more specific scanners, add the argument
--scan-types {scanner}
,where{scanner}
is one or more of the following scannerssast
orsca
,iac-security
, orapi-security
.When you are finished configuring the task, to save the pipeline and run an initial scan, click Save & queue and then in the dialog that opens click Save and Run.