feat: add nightly grype vuln scan to kaniko executor image (#2970)
This commit is contained in:
parent
65f8ec4caf
commit
8009be9f1e
|
|
@ -0,0 +1,47 @@
|
|||
name: Nightly Vulnerability Scan
|
||||
|
||||
on:
|
||||
schedule:
|
||||
# Schedule to run every night at midnight
|
||||
- cron: '0 0 * * *'
|
||||
|
||||
jobs:
|
||||
vulnerability-scan:
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v2
|
||||
|
||||
- name: Set up Grype
|
||||
run: |
|
||||
# Install Grype
|
||||
curl -sSfL https://raw.githubusercontent.com/anchore/grype/main/install.sh | sh -s -- -b /usr/local/bin
|
||||
|
||||
- name: Get latest commit SHA of Kaniko project
|
||||
id: get-commit
|
||||
run: |
|
||||
LATEST_COMMIT_SHA=$(git rev-parse HEAD)
|
||||
echo "Latest commit SHA: $LATEST_COMMIT_SHA"
|
||||
echo "::set-output name=sha::$LATEST_COMMIT_SHA"
|
||||
|
||||
- name: Scan the latest CI/CD image
|
||||
run: |
|
||||
IMAGE_ID="gcr.io/kaniko-project/executor:${{ steps.get-commit.outputs.sha }}"
|
||||
echo "Scanning image $IMAGE_ID"
|
||||
grype $IMAGE_ID > grype-output.txt
|
||||
|
||||
- name: Check for vulnerabilities and create an issue
|
||||
run: |
|
||||
if grep -q 'No vulnerabilities found' grype-output.txt; then
|
||||
echo "No vulnerabilities found."
|
||||
else
|
||||
# Create a GitHub issue using GitHub CLI or another method
|
||||
gh issue create --title "Vulnerabilities Found in Nightly Scan" --body "Vulnerabilities found in the latest image scan. Please check the attached report." --file grype-output.txt
|
||||
fi
|
||||
|
||||
- name: Upload scan result as artifact (optional)
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: grype-scan-report
|
||||
path: grype-output.txt
|
||||
Loading…
Reference in New Issue