# clinician_wrapper.py
# Human-in-the-loop wrapper for escalation: queues requests, sends webhook, or logs for clinician review.
# Minimal generic implementation: (1) persist to file/DB, (2) optionally POST to configured webhook.

from typing import Dict, Any, Optional
import json
import os
import time
import logging
import requests

logger = logging.getLogger(__name__)


class ClinicianWrapper:
    """
    Simple wrapper that sends escalated cases to:
      - a local file-based queue (JSONL)
      - optionally a clinician webhook (HTTP POST)
    """

    def __init__(self, queue_path: str = "escalation_queue.jsonl", webhook_url: Optional[str] = None, api_key: Optional[str] = None):
        self.queue_path = queue_path
        self.webhook_url = webhook_url
        self.api_key = api_key
        # ensure file exists
        os.makedirs(os.path.dirname(queue_path) or ".", exist_ok=True)
        open(self.queue_path, "a").close()

    def enqueue(self, record: Dict[str, Any]) -> str:
        """
        Persist record to queue file with timestamp; returns a record_id.
        """
        record_id = f"es-{int(time.time()*1000)}"
        record_copy = dict(record)
        record_copy["_record_id"] = record_id
        record_copy["_timestamp"] = time.time()
        with open(self.queue_path, "a", encoding="utf8") as f:
            f.write(json.dumps(record_copy, ensure_ascii=False) + "\n")
        logger.info("Enqueued escalation %s", record_id)

        # optionally POST to webhook
        if self.webhook_url:
            try:
                headers = {"Content-Type": "application/json"}
                if self.api_key:
                    headers["Authorization"] = f"Bearer {self.api_key}"
                resp = requests.post(self.webhook_url, json=record_copy, headers=headers, timeout=5.0)
                logger.info("Webhook POST status %s for record %s", resp.status_code, record_id)
            except Exception as e:
                logger.exception("Failed to POST to webhook: %s", e)
        return record_id

    def escalate(self, conversation: Dict[str, Any], reason: str, metadata: Optional[Dict[str, Any]] = None) -> str:
        """
        High-level API to escalate an interaction. Returns record id.
        """
        rec = {
            "conversation": conversation,
            "reason": reason,
            "meta": metadata or {}
        }
        return self.enqueue(rec)
