import http.client
import json
import base64
from typing import List, Dict, Any
from services.base_model import Truncate


class DoubaoSeed(Truncate):
    def __init__(self, model_path: str = "doubao-seed-1-6-250615", **kwargs):
        super().__init__(model_path, **kwargs)
        self.api_key = kwargs.get("api_key", "YOUR_API_KEY")
        self.base_url = kwargs.get("base_url", "YOUR_API_BASE_URL").strip()
        self.model_name = model_path
        self.timeout = kwargs.get("timeout", 1800)
        self.max_retries = kwargs.get("max_retries", 3)

    def initialize_model(self):
        pass

    def _video_to_base64(self, path: str) -> str:
        with open(path, "rb") as f:
            return base64.b64encode(f.read()).decode("utf-8")

    def generate(self, messages: List[Dict[str, Any]], **kwargs) -> str:
        log = kwargs.get("logfile", lambda msg: None)

        processed = []
        for msg in messages:
            new_content = []
            for item in msg["content"]:
                if item["type"] == "video":
                    b64 = self._video_to_base64(item["video"])
                    new_content.append({
                        "type": "video_url",
                        "video_url": {
                            "url": f"data:video/mp4;base64,{b64}",
                            "fps": item.get("fps", 1)
                        }
                    })
                elif item["type"] == "text":
                    new_content.append(item)
                else:
                    raise ValueError(f"Unsupported content type: {item['type']}")
            processed.append({"role": msg["role"], "content": new_content})

        if not any(m["role"] == "system" for m in processed):
            processed.insert(0, {
                "role": "system",
                "content": [{"type": "text", "text": "You are a helpful assistant."}]
            })

        temperature = kwargs.get("temperature", 0.0)
        max_tokens = kwargs.get("max_new_tokens", None)
        
        payload_dict = {
            "model": self.model_name,
            "messages": processed,
            "stream": False,
            "temperature": temperature
        }
        
        if max_tokens is not None:
            payload_dict["max_tokens"] = max_tokens
        
        payload = json.dumps(payload_dict)
        
        headers = {
            'Authorization': f'Bearer {self.api_key}',
            'Content-Type': 'application/json'
        }
        
        for attempt in range(self.max_retries):
            try:
                conn = http.client.HTTPSConnection(self.base_url, timeout=self.timeout)
                conn.request("POST", "/v1/chat/completions", payload, headers)
                res = conn.getresponse()
                data = res.read()
                conn.close()
                
                response_json = json.loads(data.decode("utf-8"))
                
                if res.status != 200:
                    error_msg = response_json.get("error", {}).get("message", "Unknown error")
                    log(f"API Error (status {res.status}): {error_msg}")
                    if attempt < self.max_retries - 1:
                        continue
                    return f"[ERROR] API returned status {res.status}: {error_msg}"
                
                if "choices" in response_json and len(response_json["choices"]) > 0:
                    content = response_json["choices"][0]["message"]["content"]
                    if content:
                        return content.strip()
                    else:
                        return "[ERROR] Empty response from API"
                else:
                    return "[ERROR] Empty response from API"
                    
            except http.client.HTTPException as e:
                log(f"HTTP Error (attempt {attempt + 1}/{self.max_retries}): {str(e)}")
                if attempt < self.max_retries - 1:
                    continue
                return f"[ERROR] {str(e)}"
                
            except json.JSONDecodeError as e:
                log(f"JSON Decode Error: {str(e)}")
                return f"[ERROR] {str(e)}"
                
            except Exception as e:
                log(f"Unexpected Error (attempt {attempt + 1}/{self.max_retries}): {str(e)}")
                if attempt < self.max_retries - 1:
                    continue
                return f"[ERROR] {str(e)}"
        
        return f"[ERROR] Max retries exceeded"

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