feat: add python-security-checks reusable workflow
Dedicated security-only workflow using python:VERSION-slim. Runs Bandit (or any security tool) without pytest or coverage. Supports python_version, install_command, security_command, and working_directory inputs with sensible defaults. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
35
.gitea/workflows/python-security-checks.yml
Normal file
35
.gitea/workflows/python-security-checks.yml
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
name: Reusable Python Security Checks
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_call:
|
||||||
|
inputs:
|
||||||
|
python_version:
|
||||||
|
type: string
|
||||||
|
default: "3.14"
|
||||||
|
install_command:
|
||||||
|
type: string
|
||||||
|
default: 'python -m pip install "bandit[toml]"'
|
||||||
|
security_command:
|
||||||
|
type: string
|
||||||
|
default: "python -m bandit -r app -c pyproject.toml"
|
||||||
|
working_directory:
|
||||||
|
type: string
|
||||||
|
default: "."
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
security:
|
||||||
|
runs-on: docker
|
||||||
|
container:
|
||||||
|
image: python:${{ inputs.python_version }}-slim
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Install security tools
|
||||||
|
working-directory: ${{ inputs.working_directory }}
|
||||||
|
run: ${{ inputs.install_command }}
|
||||||
|
|
||||||
|
- name: Run security scan
|
||||||
|
working-directory: ${{ inputs.working_directory }}
|
||||||
|
run: ${{ inputs.security_command }}
|
||||||
Reference in New Issue
Block a user