32 releases
0.7.0 | Dec 18, 2024 |
---|---|
0.6.6 | Sep 2, 2024 |
0.6.5 | Aug 6, 2024 |
0.6.0 | Jul 30, 2024 |
0.2.15 | Jul 6, 2021 |
#942 in Command line utilities
247 downloads per month
55KB
1K
SLoC
hadolint-sarif
This crate provides a command line tool to convert hadolint
diagnostic output
into SARIF.
The latest documentation can be found here.
hadolint is a popular linter / static analysis tool for Dockerfiles. More information can be found on the official repository: https://github.com/hadolint/hadolint
SARIF or the Static Analysis Results Interchange Format is an industry standard format for the output of static analysis tools. More information can be found on the official website: https://sarifweb.azurewebsites.net/.
Installation
hadolint-sarif
may be installed via cargo
cargo install hadolint-sarif
via cargo-binstall
cargo binstall hadolint-sarif
or downloaded directly from Github Releases
# make sure to adjust the target and version (you may also want to pin to a specific version)
curl -sSL https://github.com/psastras/sarif-rs/releases/download/shellcheck-sarif-v0.7.0/hadolint-sarif-x86_64-unknown-linux-gnu -o hadolint-sarif
Fedora Linux
sudo dnf install <cli_name> # ex. cargo binstall hadolint-sarif
Nix
Through the nix
cli,
nix --accept-flake-config profile install github:psastras/sarif-rs#hadolint-sarif
Usage
For most cases, simply run hadolint
with json
output and pipe the results
into hadolint-sarif
.
Example
hadolint -f json Dockerfile | hadolint-sarif
If you are using Github Actions, SARIF is useful for integrating with Github Advanced Security (GHAS), which can show code alerts in the "Security" tab of your repository.
After uploading hadolint-sarif
output to Github, hadolint
diagnostics are
available in GHAS.
Example
on:
workflow_run:
workflows: ["main"]
branches: [main]
types: [completed]
name: sarif
jobs:
upload-sarif:
runs-on: ubuntu-latest
if: ${{ github.ref == 'refs/heads/main' }}
steps:
- uses: actions/checkout@v2
- uses: actions-rs/toolchain@v1
with:
profile: minimal
toolchain: stable
override: true
- uses: Swatinem/rust-cache@v1
- run: cargo install hadolint-sarif sarif-fmt
- run: hadolint -f json Dockerfile | hadolint-sarif | tee results.sarif |
sarif-fmt
- name: Upload SARIF file
uses: github/codeql-action/upload-sarif@v1
with:
sarif_file: results.sarif
License: MIT
Dependencies
~1.7–2.9MB
~53K SLoC