fix(detection-lifecycle): fix timezone naive/aware mismatch and duplicate technique mapping

- Replace datetime.now(timezone.utc) with datetime.utcnow() in _now() across
  all three Phase 8 files to match DB DateTime column type (naive UTC)
- Guard POST /assets/{id}/techniques/{tid} against duplicate mappings:
  if mapping already exists, update coverage_type/confidence_level instead
  of inserting a duplicate row
This commit is contained in:
kitos
2026-05-19 16:29:04 +02:00
parent 634abc289b
commit 61c26ddd0f
3 changed files with 23 additions and 6 deletions
+2 -2
View File
@@ -1,7 +1,7 @@
"""Decay Engine — calculates confidence scores and expires validations."""
import logging
from datetime import datetime, timezone
from datetime import datetime
from typing import Optional
from uuid import UUID
@@ -20,7 +20,7 @@ logger = logging.getLogger(__name__)
def _now() -> datetime:
return datetime.now(timezone.utc)
return datetime.utcnow()
def get_applicable_policy(db: Session, platform: Optional[str] = None, asset_type: Optional[str] = None, tactic: Optional[str] = None) -> DecayPolicy:
@@ -2,7 +2,7 @@
import hashlib
import logging
from datetime import datetime, timezone
from datetime import datetime
from typing import Optional
from uuid import UUID
@@ -25,7 +25,7 @@ def _compute_rule_hash(content: str) -> str:
def _now() -> datetime:
return datetime.now(timezone.utc)
return datetime.utcnow()
def create_detection_asset(db: Session, data: dict, user_id: UUID) -> DetectionAsset: