# -*- coding: utf-8 -*-
from typing import Any, Dict
from openai import OpenAI, NotFoundError
from config import OPENAI_API_KEY, OPENAI_BASE_URL, OPENAI_MODEL, OPENAI_TEMPERATURE

_client = OpenAI(api_key=OPENAI_API_KEY, base_url=OPENAI_BASE_URL, timeout=30.0)

def extract_json_object(text: str) -> Dict[str, Any]:
    s = (text or "").strip()
    try: 
        obj = __import__("json").loads(s)
        return obj if isinstance(obj, dict) else {}
    except Exception:
        pass
    stack, start = [], None
    for i, ch in enumerate(s):
        if ch == "{":
            if not stack: start = i
            stack.append("{")
        elif ch == "}":
            if stack:
                stack.pop()
                if not stack and start is not None:
                    frag = s[start:i+1]
                    try:
                        obj = __import__("json").loads(frag)
                        return obj if isinstance(obj, dict) else {}
                    except Exception:
                        pass
    return {}

def chat_json(system_msg: str, user_msg: str, temperature: float = OPENAI_TEMPERATURE) -> Dict[str, Any]:
    try:
        resp = _client.chat.completions.create(
            model=OPENAI_MODEL, temperature=temperature,
            messages=[{"role":"system","content":system_msg},{"role":"user","content":user_msg}]
        )
    except NotFoundError as e:
        raise RuntimeError(
            "Chat Completions 404"
        ) from e
    except Exception:
        return {}
    content = resp.choices[0].message.content if resp and resp.choices else ""
    return extract_json_object(content or "")
