Skip to content

Security Audit

Security Audit #144

Workflow file for this run

name: Security Audit
on:
push:
branches: [main, dev]
pull_request:
branches: [main]
schedule:
# Run weekly on Monday at 00:00 UTC
- cron: '0 0 * * 1'
workflow_dispatch:
env:
CARGO_TERM_COLOR: always
jobs:
# Rust security audit using cargo-audit
cargo-audit:
name: Cargo Security Audit
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v6
- name: Install Rust toolchain
uses: dtolnay/rust-toolchain@stable
- name: Install cargo-audit
run: cargo install cargo-audit
- name: Run cargo-audit
run: cargo audit
continue-on-error: true
# Dependency license and policy checks
cargo-deny:
name: Cargo Deny
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v6
- name: Run cargo-deny
uses: EmbarkStudios/cargo-deny-action@v2
with:
log-level: warn
command: check
arguments: --all-features
continue-on-error: true
# Clippy security lints
clippy-security:
name: Clippy Security Lints
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v6
- name: Install Rust toolchain
uses: dtolnay/rust-toolchain@stable
with:
components: clippy
- name: Cache cargo registry
uses: actions/cache@v5
with:
path: |
~/.cargo/registry
~/.cargo/git
target
key: ${{ runner.os }}-cargo-clippy-${{ hashFiles('**/Cargo.lock') }}
- name: Run clippy with security lints
# Only check library code (not tests) with strict security lints
# Tests legitimately use expect(), unwrap(), panic! for assertions
# Security lints are errors (-D), pedantic warnings don't fail build
run: |
cargo clippy --lib --all-features -- \
-D clippy::unwrap_used \
-D clippy::expect_used \
-D clippy::panic \
-D clippy::todo \
-W clippy::pedantic
# Check for unsafe code
cargo-geiger:
name: Unsafe Code Detection
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v6
- name: Install Rust toolchain
uses: dtolnay/rust-toolchain@stable
- name: Install cargo-geiger
run: cargo install cargo-geiger
- name: Run cargo-geiger
run: cargo geiger --all-features --all-targets || true
# Note: Running with || true to not fail on unsafe usage, just report
# NPM security audit for WASM package
npm-audit:
name: NPM Security Audit
runs-on: ubuntu-latest
defaults:
run:
working-directory: packages/npm
steps:
- name: Checkout code
uses: actions/checkout@v6
- name: Setup Node.js
uses: actions/setup-node@v6
with:
node-version: '20'
cache: 'npm'
cache-dependency-path: packages/npm/package-lock.json
- name: Install dependencies
run: npm ci
- name: Run npm audit
run: npm audit --audit-level=moderate
continue-on-error: true