-
Notifications
You must be signed in to change notification settings - Fork 92
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Run vulnerability scan on latest release version (#762)
Previously the scan ran on the current state of the codebase. This fails to identify vulnerabilities in dependencies for the latest release version if those dependencies have already been updated in the development codebase. The gating factor for whether a new release is required should be whether the previous release contains vulnerabilities. This change runs the scheduled vulnerability scan on the latest release tag. It also adds vulnerability scanning to pull request builds. This is purely informational. A scan failure does not fail the pull request build. Signed-off-by: Mark S. Lewis <[email protected]>
- Loading branch information
1 parent
315fe5c
commit c9ad8a6
Showing
3 changed files
with
125 additions
and
84 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,110 @@ | ||
name: "Security vulnerability scan" | ||
|
||
on: | ||
workflow_call: | ||
inputs: | ||
ref: | ||
description: Branch, tag or SHA to scan. | ||
type: string | ||
required: false | ||
default: "" | ||
|
||
permissions: | ||
contents: read | ||
|
||
jobs: | ||
go: | ||
runs-on: ubuntu-latest | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
target: | ||
- govulncheck | ||
- nancy | ||
- osv-scanner | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
ref: ${{ inputs.ref }} | ||
- name: Set up Go | ||
uses: actions/setup-go@v5 | ||
with: | ||
go-version: stable | ||
check-latest: true | ||
- name: Scan | ||
run: make scan-go-${{ matrix.target }} | ||
|
||
node: | ||
runs-on: ubuntu-latest | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
target: | ||
- npm-audit | ||
- osv-scanner | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
ref: ${{ inputs.ref }} | ||
- name: Set up Node | ||
uses: actions/setup-node@v4 | ||
with: | ||
node-version: "lts/*" | ||
- name: Set up Go | ||
if: ${{ matrix.target == 'osv-scanner' }} | ||
uses: actions/setup-go@v5 | ||
with: | ||
go-version: stable | ||
- name: Scan | ||
run: make scan-node-${{ matrix.target }} | ||
|
||
java_osv_scanner: | ||
name: "java (osv-scanner)" | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
ref: ${{ inputs.ref }} | ||
- name: Set up Go | ||
uses: actions/setup-go@v5 | ||
with: | ||
go-version: stable | ||
- name: Scan | ||
run: make scan-java-osv-scanner | ||
|
||
java_dependency_check: | ||
name: "java (dependency-check)" | ||
runs-on: ubuntu-latest | ||
defaults: | ||
run: | ||
working-directory: java | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
ref: ${{ inputs.ref }} | ||
- name: Set up Java | ||
uses: actions/setup-java@v4 | ||
with: | ||
java-version: 21 | ||
distribution: temurin | ||
cache: maven | ||
- name: Download dependencies | ||
run: mvn dependency:copy-dependencies -DincludeScope=runtime | ||
- name: Scan | ||
env: | ||
JAVA_HOME: /opt/jdk | ||
uses: dependency-check/Dependency-Check_Action@main | ||
with: | ||
project: fabric-gateway | ||
path: java/target/dependency | ||
format: HTML | ||
out: reports | ||
args: > | ||
--suppression java/dependency-suppression.xml | ||
--failOnCVSS 4 | ||
- name: Archive dependency-check report | ||
if: ${{ !cancelled() }} | ||
uses: actions/upload-artifact@v4 | ||
with: | ||
name: dependency-check-report | ||
path: reports |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters