2024-01-27 23:32:42 +01:00
|
|
|
# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json
|
|
|
|
|
2022-09-14 12:55:14 +05:30
|
|
|
name: Nancy
|
|
|
|
|
2023-06-30 13:44:57 +02:00
|
|
|
permissions: {}
|
|
|
|
|
2022-09-14 12:55:14 +05:30
|
|
|
on:
|
2024-07-31 14:02:29 +05:30
|
|
|
workflow_dispatch:
|
|
|
|
schedule:
|
|
|
|
- cron: '23 2 * * *' # Every day at 02:23 UTC
|
|
|
|
|
|
|
|
|
2022-09-14 12:55:14 +05:30
|
|
|
|
2023-01-06 16:24:55 +01:00
|
|
|
|
2022-09-14 12:55:14 +05:30
|
|
|
jobs:
|
2024-07-31 14:02:29 +05:30
|
|
|
nancy-scan:
|
2022-09-14 12:55:14 +05:30
|
|
|
runs-on: ubuntu-latest
|
2024-07-31 14:02:29 +05:30
|
|
|
name: nancy-scan
|
2022-09-14 12:55:14 +05:30
|
|
|
steps:
|
|
|
|
- name: Checkout
|
2024-06-13 22:40:59 +00:00
|
|
|
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
|
2023-09-27 10:24:27 +02:00
|
|
|
- name: Setup caches
|
|
|
|
uses: ./.github/actions/setup-caches
|
|
|
|
timeout-minutes: 5
|
|
|
|
continue-on-error: true
|
2023-01-05 16:52:52 +01:00
|
|
|
- name: Setup build env
|
|
|
|
uses: ./.github/actions/setup-build-env
|
2023-08-30 22:44:51 +02:00
|
|
|
timeout-minutes: 10
|
2022-09-14 12:55:14 +05:30
|
|
|
- name: WriteGoList
|
2023-11-29 16:00:20 +01:00
|
|
|
run: go list -json -deps ./... > go.list
|
2022-09-14 12:55:14 +05:30
|
|
|
- name: Nancy SAST Scan
|
2023-02-24 10:45:19 +00:00
|
|
|
uses: sonatype-nexus-community/nancy-github-action@726e338312e68ecdd4b4195765f174d3b3ce1533 # v1.0.3
|
2024-07-31 14:02:29 +05:30
|
|
|
with:
|
|
|
|
output_format: json
|
|
|
|
output-file: nancy-results.json
|
|
|
|
- name: Parse scan results
|
|
|
|
id: parse-results
|
|
|
|
run: |
|
|
|
|
if [ -s nancy-results.json ]; then
|
|
|
|
echo "Vulnerabilities found, creating issue"
|
|
|
|
echo "results=found" >> $GITHUB_OUTPUT
|
|
|
|
else
|
|
|
|
echo "No vulnerabilities found, halting"
|
|
|
|
echo "results=nothing" >> $GITHUB_OUTPUT
|
|
|
|
fi
|
|
|
|
- name: Upload vulnerability scan report
|
2024-09-02 23:01:25 +02:00
|
|
|
uses: actions/upload-artifact@50769540e7f4bd5e21e526ee35c689e35e0d6874 # v4.4.0
|
2024-07-31 14:02:29 +05:30
|
|
|
if: steps.parse-results.outputs.results == 'found'
|
|
|
|
with:
|
|
|
|
name: nancy-results.json
|
|
|
|
path: nancy-results.json
|
|
|
|
if-no-files-found: error
|
|
|
|
|
|
|
|
open-issue:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
if: needs.nancy-scan.result == 'success'
|
|
|
|
needs: nancy-scan
|
|
|
|
permissions:
|
|
|
|
issues: write
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
|
|
|
|
- name: Download scan results
|
2024-09-02 23:01:25 +02:00
|
|
|
uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8
|
2024-07-31 14:02:29 +05:30
|
|
|
with:
|
|
|
|
name: nancy-results.json
|
|
|
|
- name: Set scan output
|
|
|
|
id: set-scan-output
|
|
|
|
run: echo "results=$(cat nancy-results.json | jq -c)" >> $GITHUB_OUTPUT
|
|
|
|
- uses: JasonEtco/create-an-issue@1b14a70e4d8dc185e5cc76d3bec9eab20257b2c5 # v2.9.2
|
|
|
|
env:
|
|
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
RESULTS: ${{ steps.set-scan-output.outputs.results }}
|
|
|
|
with:
|
|
|
|
filename: .github/ISSUE_TEMPLATE/VULN-TEMPLATE.md
|
|
|
|
|