# services/api_judge.py
"""
API judge model service.
Uses a remote chat-completions style API for query decomposition.
"""

import requests
import json
import os
import time
from typing import Dict, Any, Optional
from config.settings import API_CONFIG


class ApiJudgeModel:
    """Remote API judge model."""
    
    def __init__(self, api_key: str = None, api_url: str = None, model_name: str = None):
        self.api_key = api_key or os.getenv("API_KEY") or API_CONFIG.get("api_key")
        self.api_url = api_url or os.getenv("SCOPE_API_URL") or API_CONFIG.get("api_url")
        self.model_name = model_name or os.getenv("SCOPE_API_MODEL") or API_CONFIG.get("model_name")
        
        # Validate API config
        if not self.api_key:
            raise ValueError("API_KEY is required. Please set it in environment variable or config.")
        if not self.api_url:
            raise ValueError("API URL is required. Please set SCOPE_API_URL or pass api_url.")
        if not self.model_name:
            raise ValueError("API model name is required. Please set SCOPE_API_MODEL or pass model_name.")
        
        print(f"[ApiJudge] Initialized (api model: {self.model_name})")
    
    def generate_response(self, prompt: str, max_new_tokens: int = 512, 
                         temperature: float = 0.0, retry_count: int = 3) -> str:
        """
        Generate a response from the remote API.

        Args:
            prompt: Input prompt.
            max_new_tokens: Max generated tokens.
            temperature: Sampling temperature.
            retry_count: Retry attempts.

        Returns:
            Generated text (may be empty on failure).
        """
        payload = {
            "model": self.model_name,
            "messages": [
                {
                    "role": "user",
                    "content": prompt
                }
            ],
            "max_tokens": max_new_tokens,
            "temperature": temperature,
            "stream": False
        }
        
        headers = {
            "Content-Type": "application/json",
            "Authorization": f"Bearer {self.api_key}"
        }
        
        for attempt in range(retry_count):
            try:
                print(f"[ApiJudge] Sending API request (attempt {attempt + 1}/{retry_count})...")
                
                response = requests.post(self.api_url, json=payload, headers=headers, timeout=60)
                response.raise_for_status()
                
                result = response.json()
                
                # Extract returned text content
                if "choices" in result and len(result["choices"]) > 0:
                    content = result["choices"][0]["message"]["content"]
                    print(f"[ApiJudge] API request successful")
                    return content.strip()
                else:
                    print(f"[ApiJudge] Unexpected API response format: {result}")
                    if attempt == retry_count - 1:
                        return ""
                    
            except requests.exceptions.RequestException as e:
                print(f"[ApiJudge] API request failed (attempt {attempt + 1}): {e}")
                if attempt == retry_count - 1:
                    print(f"[ApiJudge] All API attempts failed, returning empty response")
                    return ""
                
                # Exponential backoff
                wait_time = 2 ** attempt
                print(f"[ApiJudge] Retrying in {wait_time} seconds...")
                time.sleep(wait_time)
                
            except Exception as e:
                print(f"[ApiJudge] Unexpected error: {e}")
                if attempt == retry_count - 1:
                    return ""
                time.sleep(1)
        
        return ""
    
    def get_model_info(self) -> Dict[str, Any]:
        """Return model info (for debugging/telemetry)."""
        return {
            "type": "api",
            "api_url": self.api_url,
            "model_name": self.model_name,
            "api_key_set": bool(self.api_key)
        }


# Global model instance (lazy initialization)
_global_api_judge_model = None


def get_api_judge_model(api_key: str = None) -> ApiJudgeModel:
    """Get a global API judge model instance."""
    global _global_api_judge_model
    if _global_api_judge_model is None:
        _global_api_judge_model = ApiJudgeModel(api_key=api_key)
    return _global_api_judge_model


def create_api_judge_model(api_key: str = None, api_url: str = None, model_name: str = None) -> ApiJudgeModel:
    """Create a new API judge model instance."""
    return ApiJudgeModel(api_key=api_key, api_url=api_url, model_name=model_name)
