name: Security Scan on: push: branches: [ master, main ] pull_request: branches: [ master, main ] schedule: - cron: '0 0 * * 0' # Weekly on Sunday permissions: contents: read security-events: write jobs: gosec: name: Security Scan (gosec) runs-on: ubuntu-latest steps: - name: Checkout code uses: actions/checkout@v4 - name: Run Gosec Security Scanner uses: securego/gosec@master with: args: '-no-fail -fmt json -out gosec-report.json ./...' - name: Upload SARIF file uses: github/codeql-action/upload-sarif@v3 if: always() with: sarif_file: gosec-report.json govulncheck: name: Vulnerability Check (govulncheck) runs-on: ubuntu-latest steps: - name: Checkout code uses: actions/checkout@v4 - name: Set up Go uses: actions/setup-go@v5 with: go-version: '1.23' - name: Run govulncheck run: | go install golang.org/x/vuln/cmd/govulncheck@latest govulncheck ./...