This GitHub action reports results from a Trivy vulnerability scan as GitHub issues. It will parse the JSON file and look for any vulnerabilties, and report them as issues (unless they are already reported). Issues may also be assigned to specific users, and can be attached to a GitHub project.
If a package has multiple vulnerabilities it will be grouped on the package and only one issue is created.
This action requires a file containing the scan result from Trivy. First run the
Trivy scan action and tell it to output
in JSON
format and into a file, then use that file as input to this action.
First make sure the repository has the required issue label, this is vulnerability
by default,
if not create the label. If this is not present the label will fail.
Add the following steps to your GitHub workflow, for instance a scheduled workflow.
The important part for trivy-action
is format
and output
, this is required to export
the results as a file which can then be sent to this action, the other parameters can be
tweaked for the project.
- name: Run Trivy vulnerability scanner in repo mode
uses: aquasecurity/trivy-action@master
with:
scan-type: 'fs'
severity: 'HIGH,CRITICAL'
ignore-unfixed: true
format: 'json'
output: 'result.json'
- uses: CemitDigital/[email protected]
with:
# Token passed by GitHub actions, required for access to GitHub issues
token: ${{ secrets.GITHUB_TOKEN }}
# File with scan results
input-filename: "result.json"
# Label name
# Default: vulnerability (this label must be created in advance)
label: ''
# Assignees, comma separated
# Default: ''
# Example: 'monalisa,hubot'
assignee: ''
# If set the new issues will be assigned to the specified project
# Default: ''
project-id: ''
The following inputs can be used as with
keys:
Parameter | Type | Required | Default | Description |
---|---|---|---|---|
token |
String | True | N/A | Token for accessing the GitHub repository |
input-filename |
String | True | N/A | Filename containing Trivy scan results, in JSON format. A Trivy scan must have been performed in a previous step. |
label |
String | False | vulnerability |
Issue label (separated by commma) |
assignee |
String | False | N/A | Issue assignee (separated by commma) |
The accompanying Dockerfile.dev
can be used to create a test or development environment.
To run all the tests use:
docker build -t trivy-issue-action:test -f Dockerfile.dev --target test ./
docker run -it --rm trivy-issue-action:test
This will build the test
target which runs pytest
when the container starts.
If python
and pytest
is installed locally the test suite can also be run using:
PYTHONPATH=. pytest
Development on the action can either be done using a local Python executable. The
Python code is located in the trivy_report
folder. The easiest way to test it
without running gh
commands is to generate a JSON report using trivy
and then
passing the file to the print_issues.py
command.
python -m trivy_report.print_issues <path-to-report>
This will then find any vulnerabilities and print the Markdown results, and inserting a null character between each report.
To get an environment that is closer to how it is run as a GitHub action the Dockerfile
can be used, just switch to the dev target. This image will run the print_issues
command with any arguments passed. The image also includes the gh
cli command.
For instance to scan one of the test reports:
docker build -t trivy-issue-action:dev -f Dockerfile.dev --target dev ./
docker run -it --rm -v `pwd`/tests:/tests trivy-issue-action:dev /tests/scans/scan2.json
Alternatively the docker-compose
file can be used to simplify this, and can even
be used for remote container development.
docker-compose run --rm trivy-reporter /tests/scans/scan2.json
Additionally the tests can be run with the docker-compose.test.yml
.
docker-compose -f docker-compose.test.yml run --rm trivy-reporter-test