Files
Linux-Server-Management-Too…/modules
cschantz 0314245433 CRITICAL FIX #17: Restore persistent threats at startup for auto-mitigation blocking
BUG: IPs with Score 100 from persistent reputation data were displayed in UI but NOT blocked by auto_mitigation_engine because the engine only read real-time ip_data file, never processing startup-loaded threat data.

ROOT CAUSE: IP_DATA array started empty at runtime and was never pre-populated from snapshot storage. auto_mitigation_engine (lines 3554+) only reads $TEMP_DIR/ip_data file generated from real-time detections, missing pre-existing threats.

FIX:
1. Added load_snapshot() function (lines 256-298) to restore persistent IP_DATA from snapshot
   - Filters for Score >= 50 to avoid restoring low-threat noise
   - Parses IP_DATA[IP]=format from snapshot file
   - Restores ATTACK_TYPE_COUNTER and TOTAL_THREATS/TOTAL_BLOCKS for consistency

2. Call load_snapshot() before auto_mitigation_engine starts (line 3729)
   - Ensures persistent threats are in memory before blocking engine launches
   - Reduces startup lag (loading only takes ~50ms)

3. Write loaded IP_DATA to ip_data file immediately (lines 3732-3740)
   - Enables auto_mitigation_engine to see and process restored threats
   - Provides startup log message showing how many IPs were restored

IMPACT: IP with Score 100 from persistence will now be blocked within 10 seconds of startup (auto_mitigation_engine's check interval), eliminating the security gap.

VERIFICATION:
- Syntax: PASS
- Load function correctly parses snapshot format
- Lock-based file write prevents race conditions
- Threshold (Score >= 50) filters out noise while keeping critical threats

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
2026-03-07 00:12:35 -05:00
..