import http.client
import json
import time
import uuid
from typing import List, Dict, Any, Union
from services.base_model import Truncate


class Qwen3HttpProcessor(Truncate):
    def __init__(self, model_path: str = "Qwen/Qwen3-235B-A22B-Instruct-2507", **kwargs):
        super().__init__(model_path)
        self.host = kwargs.get("host", "YOUR_API_HOST")
        self.api_key = kwargs.get("api_key", "YOUR_API_KEY")
        self.timeout = kwargs.get("timeout", 120)
        self.max_retries = kwargs.get("max_retries", 3)
        self.session_id = None

    def initialize_model(self) -> None:
        pass

    def _extract_text(self, content: Union[str, List[Dict[str, Any]]]) -> str:
        if isinstance(content, str):
            return content
        if isinstance(content, list):
            return "\n".join(item["text"] for item in content if item.get("type") == "text")
        return ""

    def _send_request(self, messages: List[Dict[str, str]], **kwargs) -> str:
        payload = {
            "model": self.model_path,
            "messages": messages,
            "temperature": kwargs.get("temperature", 0.0),
            "max_tokens": kwargs.get("max_new_tokens", 1024),
            "stream": False,
        }

        headers = {
            "Authorization": f"Bearer {self.api_key}",
            "Content-Type": "application/json"
        }

        for attempt in range(self.max_retries):
            conn = None
            try:
                conn = http.client.HTTPSConnection(self.host, timeout=self.timeout)
                conn.request("POST", "/v1/chat/completions", json.dumps(payload), headers)
                res = conn.getresponse()
                data = res.read()

                if res.status == 200:
                    resp = json.loads(data.decode("utf-8"))
                    if resp.get("choices"):
                        return resp["choices"][0]["message"]["content"].strip()
                    return "[ERROR] Empty choices in response"

                err_msg = data.decode('utf-8', errors='replace')
                if attempt == self.max_retries - 1:
                    return f"[ERROR] HTTP {res.status} after {self.max_retries} retries: {err_msg}"

            except Exception as e:
                if attempt == self.max_retries - 1:
                    return f"[ERROR] Failed after {self.max_retries} retries: {str(e)}"
            finally:
                if conn:
                    conn.close()

            time.sleep(0.5 * (2 ** attempt))

        return "[ERROR] Unexpected error"

    def generate(self, messages: List[Dict[str, Any]], **kwargs) -> str:
        normalized = []
        for msg in messages:
            text = self._extract_text(msg["content"])
            if text.strip():
                normalized.append({"role": msg["role"], "content": text.strip()})
        if not any(m["role"] == "system" for m in normalized):
            normalized.insert(0, {"role": "system", "content": "You are a helpful assistant."})
        return self._send_request(normalized, **kwargs)

    def batch_generate(self, messages_list: List[List[Dict[str, Any]]], **kwargs) -> List[str]:
        return [self.generate(msgs, **kwargs) for msgs in messages_list]
