cms.c2sgmbh/.github/workflows/security.yml
Martin Porwoll dc906f300e fix(security): replace Gitleaks with native GitHub scanning, update CodeQL to v4
- Remove Gitleaks action (now requires paid license)
- GitHub native secret scanning already enabled with 423 patterns
- Update CodeQL actions from v3 to v4 (v3 deprecated Dec 2026)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-15 22:49:04 +00:00

126 lines
3.4 KiB
YAML

name: Security Scanning
on:
push:
branches: [main, develop]
pull_request:
branches: [main]
schedule:
# Wöchentlich Sonntag um 00:00 UTC
- cron: '0 0 * * 0'
permissions:
contents: read
security-events: write
jobs:
# Secret Scanning - Using GitHub's native secret scanning (enabled in repo settings)
# Gitleaks removed - now requires paid license, GitHub native is more comprehensive
secrets:
name: Secret Scanning
runs-on: ubuntu-latest
steps:
- name: Verify GitHub Secret Scanning
run: |
echo "## Secret Scanning Status" >> $GITHUB_STEP_SUMMARY
echo "✅ GitHub native secret scanning is enabled in repository settings" >> $GITHUB_STEP_SUMMARY
echo "Push protection is active for 423 patterns" >> $GITHUB_STEP_SUMMARY
# Dependency Vulnerability Scanning
dependencies:
name: Dependency Audit
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup pnpm
uses: pnpm/action-setup@v3
with:
version: 9
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: '20'
cache: 'pnpm'
- name: Install dependencies
run: pnpm install --frozen-lockfile
- name: Run audit
run: pnpm audit --audit-level=high
continue-on-error: true
- name: Check for known vulnerabilities
run: |
echo "## Dependency Audit Results" >> $GITHUB_STEP_SUMMARY
pnpm audit --json | jq -r '.advisories | to_entries[] | "- [\(.value.severity)] \(.value.module_name): \(.value.title)"' >> $GITHUB_STEP_SUMMARY 2>/dev/null || echo "No vulnerabilities found" >> $GITHUB_STEP_SUMMARY
# CodeQL Analysis
codeql:
name: CodeQL Analysis
runs-on: ubuntu-latest
permissions:
actions: read
contents: read
security-events: write
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Initialize CodeQL
uses: github/codeql-action/init@v4
with:
languages: javascript-typescript
queries: security-and-quality
- name: Autobuild
uses: github/codeql-action/autobuild@v4
- name: Perform CodeQL Analysis
uses: github/codeql-action/analyze@v4
with:
category: "/language:javascript-typescript"
# Security Unit & Integration Tests
security-tests:
name: Security Tests
runs-on: ubuntu-latest
needs: [secrets, dependencies]
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup pnpm
uses: pnpm/action-setup@v3
with:
version: 9
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: '20'
cache: 'pnpm'
- name: Install dependencies
run: pnpm install --frozen-lockfile
- name: Run security tests
run: pnpm test:security
env:
CSRF_SECRET: test-csrf-secret
PAYLOAD_SECRET: test-payload-secret
PAYLOAD_PUBLIC_SERVER_URL: https://test.example.com
NEXT_PUBLIC_SERVER_URL: https://test.example.com
- name: Upload test results
if: always()
uses: actions/upload-artifact@v4
with:
name: security-test-results
path: |
coverage/
test-results/
retention-days: 7