mirror of
https://github.com/appwrite/appwrite
synced 2026-05-23 08:58:35 +00:00
88 lines
2.5 KiB
YAML
88 lines
2.5 KiB
YAML
name: Nightly Security Scan
|
|
on:
|
|
schedule:
|
|
- cron: '0 0 * * *' # 12am UTC daily runtime
|
|
workflow_dispatch:
|
|
|
|
jobs:
|
|
update-trivy-db:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Setup oras
|
|
uses: oras-project/setup-oras@v1
|
|
|
|
- name: Get current date
|
|
id: date
|
|
run: echo "date=$(date +'%Y-%m-%d')" >> $GITHUB_OUTPUT
|
|
|
|
- name: Download and extract the vulnerability DB
|
|
run: |
|
|
mkdir -p $GITHUB_WORKSPACE/.cache/trivy/db
|
|
oras pull ghcr.io/aquasecurity/trivy-db:2
|
|
tar -xzf db.tar.gz -C $GITHUB_WORKSPACE/.cache/trivy/db
|
|
rm db.tar.gz
|
|
|
|
- name: Download and extract the Java DB
|
|
run: |
|
|
mkdir -p $GITHUB_WORKSPACE/.cache/trivy/java-db
|
|
oras pull ghcr.io/aquasecurity/trivy-java-db:1
|
|
tar -xzf javadb.tar.gz -C $GITHUB_WORKSPACE/.cache/trivy/java-db
|
|
rm javadb.tar.gz
|
|
|
|
- name: Cache DBs
|
|
uses: actions/cache/save@v4
|
|
with:
|
|
path: ${{ github.workspace }}/.cache/trivy
|
|
key: cache-trivy-${{ steps.date.outputs.date }}
|
|
|
|
scan-image:
|
|
name: Scan Docker Image
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Check out code
|
|
uses: actions/checkout@v4
|
|
with:
|
|
submodules: recursive
|
|
|
|
- name: Build the Docker image
|
|
run: docker build . -t appwrite_image:latest
|
|
|
|
- name: Run Trivy vulnerability scanner on image
|
|
uses: aquasecurity/trivy-action@0.28.0
|
|
with:
|
|
image-ref: 'appwrite_image:latest'
|
|
format: 'sarif'
|
|
output: 'trivy-image-results.sarif'
|
|
ignore-unfixed: 'false'
|
|
severity: 'CRITICAL,HIGH'
|
|
env:
|
|
TRIVY_SKIP_DB_UPDATE: true
|
|
TRIVY_SKIP_JAVA_DB_UPDATE: true
|
|
|
|
- name: Upload Docker Image Scan Results
|
|
uses: github/codeql-action/upload-sarif@v2
|
|
with:
|
|
sarif_file: 'trivy-image-results.sarif'
|
|
|
|
scan-code:
|
|
name: Scan Code
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Check out code
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Run Trivy vulnerability scanner on filesystem
|
|
uses: aquasecurity/trivy-action@0.28.0
|
|
with:
|
|
scan-type: 'fs'
|
|
format: 'sarif'
|
|
output: 'trivy-fs-results.sarif'
|
|
severity: 'CRITICAL,HIGH'
|
|
env:
|
|
TRIVY_SKIP_DB_UPDATE: true
|
|
TRIVY_SKIP_JAVA_DB_UPDATE: true
|
|
|
|
- name: Upload Code Scan Results
|
|
uses: github/codeql-action/upload-sarif@v2
|
|
with:
|
|
sarif_file: 'trivy-fs-results.sarif'
|