Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/contrast-security-oss/contrastscan-action
Contrast Scan GitHub action
https://github.com/contrast-security-oss/contrastscan-action
contrast-security dockerfile kotlin sast sca security static-analysis
Last synced: about 20 hours ago
JSON representation
Contrast Scan GitHub action
- Host: GitHub
- URL: https://github.com/contrast-security-oss/contrastscan-action
- Owner: Contrast-Security-OSS
- License: apache-2.0
- Created: 2021-11-08T20:26:03.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-08-12T13:32:55.000Z (6 months ago)
- Last Synced: 2025-01-19T21:37:54.090Z (7 days ago)
- Topics: contrast-security, dockerfile, kotlin, sast, sca, security, static-analysis
- Homepage:
- Size: 125 KB
- Stars: 19
- Watchers: 15
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Use Contrast Scan to analyze your code
This GitHub action lets you use Contrast Security's industry leading Code Scanner (Contrast Scan) to find vulnerabilities in your code.
The Action compares the code scanning analysis of the PR to the last code scan analysis of the destination branch. GitHub fails the check if new vulnerabilities have been introduced.- **Supported languages:** Java, Javascript and .NET
## **Initial steps for using the action**
If you are not familiar with GitHub actions read the
[GitHub Actions](https://docs.github.com/en/actions) documentation to learn what GitHub Actions are and how to set them
up. After which, complete the following steps:1. Configure the following GitHub secrets CONTRAST_API_KEY, CONTRAST_ORGANIZATION_ID, CONTRAST_AUTH_HEADER and CONTRAST_API_URL
![image](https://user-images.githubusercontent.com/24421341/195881793-1ae0c552-8701-4501-a5b9-25863b0c84a5.png)
- **CodeSec by Contrast Security users:** Retrieve authentication details for the secrets using the CLI.
- Installation instructions here : [https://www.contrastsecurity.com/developer/codesec](https://www.contrastsecurity.com/developer/codesec)
- If you are a new user, create an account with the 'contrast auth' command
- Run the 'contrast config' command in the CLI to collect the required credentials
![image](https://user-images.githubusercontent.com/24421341/195882697-cd56ea93-01d3-43d4-99e6-9005e7683111.png)- **Licensed Contrast Security users:** Get your authentication details for the secrets from the 'User Settings' menu in the Contrast web interface: You will need the following
- Organization ID
- Your API key
- Authorization header
- You will also need the URL of your Contrast UI host. This input includes the protocol section of the URL (https://).
![image](https://user-images.githubusercontent.com/24421341/195883255-b436a666-a040-478a-a9d5-15314097695b.png)2. Copy sample workflow below and create a branch of your code to add Contrast security Scan. This branch is typically located at `.github/workflows/build.yml`
3. Update the workflow file to specify when the action should run (for example on pull_request, on push)
```yaml
on:
# Trigger analysis when pushing to main or an existing pull requests. Also trigger on
# new pull requests
push:
branches:
- main
pull_request:
types: [opened, synchronize, reopened]
```4. Update the filepath in the workflow file to specfy the location of the built artifact or file to scan
```yaml
with:
artifact: mypath/target/myartifact.jar
```5. To fail based on severity of vulnerability found set severity (critical/high/medium or low) and fail to true
```yaml
severity: high
fail: true
```6. In order for GitHub to list vulnerabilities in the **Security** Tab of the repo, the contrast action must be accompanied by this GitHub action
```yaml
- name: Upload SARIF file
uses: github/codeql-action/upload-sarif@v2
with:
sarif_file: results.sarif
```
The value of `sarif_file` *must* be `results.sarif` which is the name that Contrast Scan Action will write the sarif to.
7. After committing, create a Pull Request (PR) to merge the update back to your main branch. Creating the PR triggers the scan to run. The extra "Code Scanning" check appears in the PRSince it’s likely there will be new findings when you add Contrast Scan, we don't want to fail and block merging the PR that adds Contrast Scan, forcing the owner of the PR to now fix all the newly exposed vulnerabilities that already existed in the code base.
After Contrast Scan runs on the main branch, all new PRs that you create where the Contrast Scan is run fail the code scanning check if they introduce new vulnerabilities beyond the baseline you just established.
## Usage
All Contrast-related account secrets should be configured as GitHub secrets and will be passed to the scanner via
environment variables in the GitHub runner.
A simple workflow to get going is:
```yaml
on:
# Trigger analysis when pushing to main or an existing pull requests. Also trigger on
# new pull requests
push:
branches:
- main
pull_request:
types: [opened, synchronize, reopened]
name: Contrast Security Scan
jobs:
build_and_scan:
permissions:
contents: read # for actions/checkout
security-events: write # for github/codeql-action/upload-sarif
actions: read # only required for a private repository by github/codeql-action/upload-sarif to get the Action run status
runs-on: ubuntu-latest
# check out project
steps:
- uses: actions/checkout@v2
# steps to build the artifact you want to scan
# -name: Build Project
# ...
# Scan Artifact
- name: Contrast Scan Action
uses: Contrast-Security-OSS/[email protected]
with:
artifact: mypath/target/myartifact.jar
apiKey: ${{ secrets.CONTRAST_API_KEY }}
orgId: ${{ secrets.CONTRAST_ORGANIZATION_ID }}
authHeader: ${{ secrets.CONTRAST_AUTH_HEADER }}
severity: high
fail: true
# To list vulnerabilities in the GitHub Security Tab of the repo include GitHub upload-sarif action
# The value of `sarif_file` must be `results.sarif`
- name: Upload SARIF file
uses: github/codeql-action/upload-sarif@v2
with:
sarif_file: results.sarif
```## Required inputs
- apiKey - An API key from the Contrast platform.
- authHeader - User authorization credentials from Contrast.
- orgId - The ID of your organization in Contrast.
- artifact - The artifact to scan on the Contrast platform.
## Optional inputs
- apiUrl - The URL of the host. This input includes the protocol section of the URL (https://). The default value is [https://ce.contrastsecurity.com](https://ce.contrastsecurity.com/) (Contrast Community Edition).
- severity - Specify severity of vulnerability. Values for severity are critical, high, medium or low. Fail must also be set to true to fail the check
- fail - When set to true, fails the check if vulnerabilities have been detected that match at least the severity option specified.
- projectName - The name of the scan project in Contrast.
If you don’t specify a project name, Contrast Scan uses the artifact file name for the project name.
- projectId - The ID of your project in Contrast.
- If a project ID already exists, Contrast Scan uses that ID instead of one you specify.
- If you don’t specify a project ID, Contrast Scan creates a project ID for the specified project name.
- timeout - Sets a specific time span (in seconds) before the function times out. The default timeout is five minutes.## **If you are using the Contrast Maven plugin**
This GitHub action and the **[Contrast Maven plugin](https://github.com/Contrast-Security-OSS/contrast-maven-plugin)** accomplish the same thing. You cannot use both at the same time.
For example, if you are using maven to build your code and you run org.contrastsecurity.maven:scan during the build, do not use the Contrast Scan GitHub action.