name: Security
on:
push:
branches:
- "main"
- "release"
paths:
- "src/**"
- "Cargo.toml"
- "Cargo.lock"
- "deny.toml"
- "rustfmt.toml"
- ".github/workflows/security.yml"
pull_request:
branches:
- "main"
- "release"
paths:
- "src/**"
- "Cargo.toml"
- "Cargo.lock"
- "deny.toml"
- "rustfmt.toml"
- ".github/workflows/security.yml"
schedule:
- cron: "0 2 * * *"
workflow_dispatch:
env:
CARGO_TERM_COLOR: always
jobs:
security-audit:
name: Security Audit
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v6
- name: Install Rust toolchain
uses: dtolnay/rust-toolchain@stable
- name: Cache dependencies
uses: Swatinem/rust-cache@v2
- name: Install cargo-audit
uses: taiki-e/install-action@v2
with:
tool: cargo-audit
- name: Run cargo audit
run: cargo audit --deny warnings
- name: Install cargo-deny
uses: taiki-e/install-action@v2
with:
tool: cargo-deny
- name: Run cargo deny
run: cargo deny check all