hipaa-guardian
HIPAA Guardian
A comprehensive PHI/PII detection and HIPAA compliance skill for AI agents, with a strong focus on developer code security patterns. Detects all 18 HIPAA Safe Harbor identifiers in data files and source code, provides risk scoring, maps findings to HIPAA regulations, and generates audit reports with remediation guidance.
Capabilities
- PHI/PII Detection - Scan data files for the 18 HIPAA Safe Harbor identifiers
- Code Scanning - Detect PHI in source code, comments, test fixtures, configs
- Auth Gate Detection - Find API endpoints exposing PHI without authentication
- Log Safety Audit - Detect PHI leaking into log statements
- Classification - Classify findings as PHI, PII, or sensitive_nonPHI
- Risk Scoring - Score findings 0-100 based on sensitivity and exposure
- HIPAA Mapping - Map each finding to specific HIPAA rules
- Audit Reports - Generate findings.json, audit reports, and playbooks
- Remediation - Provide step-by-step remediation with code examples
- Control Checks - Validate security controls are in place
Usage
/hipaa-guardian [command] [path] [options]
Commands
scan <path>- Scan files or directories for PHI/PIIscan-code <path>- Scan source code for PHI leakagescan-auth <path>- Check API endpoints for missing authentication before PHI accessscan-logs <path>- Detect PHI patterns in logging statementsscan-response <path>- Check API responses for unmasked PHI exposureaudit <path>- Generate full HIPAA compliance audit reportcontrols <path>- Check security controls in a projectreport- Generate report from existing findings
Options
--format <type>- Output format: json, markdown, csv (default: markdown)--output <file>- Write results to file--severity <level>- Minimum severity: low, medium, high, critical--include <patterns>- File patterns to include--exclude <patterns>- File patterns to exclude--synthetic- Treat all data as synthetic (default for safety)
Workflow
When invoked, follow this workflow:
Step 1: Determine Scan Scope
Ask the user to specify:
- Target path (file, directory, or glob pattern)
- Scan type (data files, source code, or both)
- Whether data is synthetic/test data or potentially real PHI
Step 2: File Discovery
Use Glob to find relevant files:
# For data files
Glob: **/*.{json,csv,txt,log,xml,hl7,fhir}
# For source code
Glob: **/*.{py,js,ts,tsx,java,cs,go,rb,sql,sh}
# For config files
Glob: **/*.{env,yaml,yml,json,xml,ini,conf}
Step 3: PHI Detection
For each file, scan for the 18 HIPAA identifiers using patterns from references/detection-patterns.md:
- Names - Patient, provider, relative names
- Geographic - Addresses, cities, ZIP codes
- Dates - DOB, admission, discharge, death dates
- Phone Numbers - All formats
- Fax Numbers - All formats
- Email Addresses - All formats
- SSN - Social Security Numbers
- MRN - Medical Record Numbers
- Health Plan IDs - Insurance identifiers
- Account Numbers - Financial accounts
- License Numbers - Driver's license, professional
- Vehicle IDs - VIN, license plates
- Device IDs - Serial numbers, UDI
- URLs - Web addresses
- IP Addresses - Network identifiers
- Biometric - Fingerprints, retinal, voice
- Photos - Full-face images
- Other Unique IDs - Any other identifying numbers
Step 4: Classification
Classify each finding:
- PHI - Health information linkable to individual
- PII - Personally identifiable but not health-related
- sensitive_nonPHI - Sensitive but not individually identifiable
Step 5: Risk Scoring
Calculate risk score (0-100) using methodology from references/risk-scoring.md:
Risk Score = (Sensitivity × 0.35) + (Exposure × 0.25) +
(Volume × 0.20) + (Identifiability × 0.20)
Step 6: HIPAA Mapping
Map findings to HIPAA rules from references:
references/privacy-rule.md- 45 CFR 164.500-534references/security-rule.md- 45 CFR 164.302-318references/breach-rule.md- 45 CFR 164.400-414
Step 7: Generate Output
Create structured output following examples/sample-finding.json format:
{
"id": "F-YYYYMMDD-NNNN",
"timestamp": "ISO-8601",
"file": "path/to/file",
"line": 123,
"field": "field.path",
"value_hash": "sha256:...",
"classification": "PHI|PII|sensitive_nonPHI",
"identifier_type": "ssn|mrn|dob|...",
"confidence": 0.95,
"risk_score": 85,
"hipaa_rules": [...],
"remediation": [...],
"status": "open"
}
Code Scanning
When scanning source code, look for:
1. Hardcoded PHI in Source
- String literals containing SSN, MRN, names, dates
- Variable assignments with sensitive values
- Database seed/fixture data
2. PHI in Comments
- Example data in code comments
- TODO comments with patient info
- Documentation strings with real data
3. Test Data Leakage
- Test fixtures with real PHI
- Mock data files with actual patient info
- Integration test data
4. Configuration Files
.envfiles with PHI- Connection strings with embedded credentials
- API responses cached with PHI
5. SQL Files
- INSERT statements with PHI
- Sample queries with real patient data
- Database dumps
See references/code-scanning.md for detailed patterns.
Security Control Checks
Verify these controls are in place:
Access Controls
- Role-based access control (RBAC) implemented
- Minimum necessary access principle applied
- Access logging enabled
Encryption
- Data encrypted at rest (AES-256)
- Data encrypted in transit (TLS 1.2+)
- Encryption keys properly managed
Audit Controls
- Audit logging implemented
- Log integrity protected
- Retention policies defined
Code Security
-
.gitignoreexcludes sensitive files - Pre-commit hooks scan for PHI
- Secrets management in place
- Data masking in logs
Output Formats
findings.json
Structured array of all findings with full metadata.
audit_report.md
Human-readable report with:
- Executive summary
- Findings by severity
- HIPAA compliance status
- Risk assessment
- Recommendations
playbook.md
Step-by-step remediation guide:
- Prioritized actions
- Code examples
- Verification steps
Security Guardrails
- Default Synthetic Mode - Assumes data is synthetic unless confirmed otherwise
- No PHI Storage - Never stores detected PHI values, only hashes
- Redaction - All example outputs redact actual values
- Warning Prompts - Warns before processing potentially real PHI
- Audit Trail - Logs all scans (without PHI values)
References
references/hipaa-identifiers.md- All 18 HIPAA Safe Harbor identifiersreferences/detection-patterns.md- Regex patterns for PHI detectionreferences/code-scanning.md- Code scanning patterns and rulesreferences/healthcare-formats.md- FHIR, HL7, CDA detection patternsreferences/privacy-rule.md- HIPAA Privacy Rule (45 CFR 164.500-534)references/security-rule.md- HIPAA Security Rule (45 CFR 164.302-318)references/breach-rule.md- Breach Notification Rule (45 CFR 164.400-414)references/risk-scoring.md- Risk scoring methodologyreferences/auth-patterns.md- Authentication gate patterns for PHI endpointsreferences/logging-safety.md- PHI-safe logging patterns and filtersreferences/api-security.md- API response masking and field-level auth
CI/CD Integration
Pre-Commit Hook Installation
# Install the pre-commit hook
cp scripts/pre-commit-hook.sh .git/hooks/pre-commit
chmod +x .git/hooks/pre-commit
# Or using pre-commit framework
# Add to .pre-commit-config.yaml:
repos:
- repo: local
hooks:
- id: hipaa-guardian
name: HIPAA Guardian PHI Scan
entry: python scripts/detect-phi.py
language: python
types: [file]
pass_filenames: true
Environment Variables
# Configure pre-commit behavior
export HIPAA_BLOCK_ON_CRITICAL=true # Block commits with critical findings
export HIPAA_BLOCK_ON_HIGH=true # Block commits with high severity findings
export HIPAA_SCAN_DATA=true # Scan data files
export HIPAA_SCAN_CODE=true # Scan source code
export HIPAA_VERBOSE=false # Enable verbose output
GitHub Actions Integration
# .github/workflows/hipaa-scan.yml
name: HIPAA PHI Scan
on: [push, pull_request]
jobs:
scan:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v5
with:
python-version: '3.11'
- name: Run PHI Scan
run: |
python scripts/detect-phi.py . --format markdown --output phi-report.md
- name: Upload Report
uses: actions/upload-artifact@v4
with:
name: phi-scan-report
path: phi-report.md
Healthcare Data Format Support
Supported Formats
| Format | Extensions | Detection |
|---|---|---|
| FHIR R4 | .fhir.json, .fhir.xml |
Resource type, identifiers |
| HL7 v2.x | .hl7, .hl7v2 |
MSH, PID, DG1 segments |
| CDA/C-CDA | .cda, .ccda, .ccd |
ClinicalDocument, patientRole |
| X12 EDI | .x12, .edi, .837 |
Transaction set headers |
High-Risk FHIR Resources
Patient- Demographics, identifiers, contactsCondition- Diagnoses, health conditionsObservation- Lab results, vitalsMedicationRequest- PrescriptionsDiagnosticReport- Test results
HL7 v2 PHI Segments
PID- Patient Identification (SSN in PID-19)DG1- Diagnosis InformationOBX- Observation/Result ValuesIN1- Insurance Information
Examples
examples/sample-finding.json- Example finding output formatexamples/sample-audit-report.md- Example audit reportexamples/synthetic-phi-data.json- Test data for validation
Scripts
scripts/detect-phi.py- PHI/PII detection in data files (supports FHIR, HL7, CDA formats)scripts/scan-code.py- Code scanning for PHI leakagescripts/scan-auth.py- Authentication gate detection for PHI endpointsscripts/scan-logs.py- PHI detection in logging statementsscripts/scan-response.py- API response PHI exposure detectionscripts/generate-report.py- Report generation scriptscripts/validate-controls.sh- Control validation scriptscripts/pre-commit-hook.sh- Git pre-commit hook for CI/CD integration