import hmac
import hashlib
from orchestrator.config import SECRET_KEY
def sign_payload(payload: str) -> str:
"""Signs a string payload using HMAC-SHA256."""
return hmac.new(SECRET_KEY.encode(), payload.encode(), hashlib.sha256).hexdigest()
def sign_browser_action(action_type: str, url: str, session_id: str) -> str:
"""Signs a browser action based on its key identify fields."""
sign_base = f"{action_type}:{url}:{session_id}"
return sign_payload(sign_base)
def verify_signature(payload: str, signature: str) -> bool:
"""Verifies a signature against a payload using HMAC-SHA256."""
expected = sign_payload(payload)
return hmac.compare_digest(signature, expected)