Files
Portfolio/.github/workflows/security-audit.yml
KuchtaVR6 7f82be8377
All checks were successful
Security Audit / Security Vulnerability Scan (pull_request) Successful in 21s
Code Quality Check / Lint & Type Check (pull_request) Successful in 20s
feat: fix pipeline
2026-02-28 12:38:49 +00:00

74 lines
1.7 KiB
YAML

name: Security Audit
on:
push:
branches:
- main
- master
- develop
pull_request:
branches:
- main
- master
- develop
schedule:
- cron: '0 0 * * 1'
jobs:
security-audit:
name: Security Vulnerability Scan
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: '18'
- name: Setup pnpm
uses: pnpm/action-setup@v4
with:
version: 10
- name: Get pnpm store directory
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV
- name: Setup pnpm cache
uses: actions/cache@v4
with:
path: ${{ env.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-
- name: Install dependencies
run: pnpm install --frozen-lockfile
- name: Run pnpm audit
run: pnpm audit --audit-level=moderate
continue-on-error: true
- name: Generate security report
run: pnpm run security:check
- name: Check for outdated dependencies
run: pnpm outdated || true
- name: Upload security report
uses: actions/upload-artifact@v3
if: always()
with:
name: security-report
path: security-report.json
retention-days: 30
- name: Notify on high/critical vulnerabilities
if: failure()
run: |
echo "::error::Security vulnerabilities detected! Check the security report artifact for details."