"""
OpenAI-compatible API backend.

Works with:
  - OpenAI API (GPT-4o-mini etc.)  — set api_key or OPENAI_API_KEY env var
  - vLLM OpenAI-compatible server  — set base_url="http://localhost:8000/v1", api_key="EMPTY"
  - Any other OpenAI-compatible endpoint

Install: pip install openai
"""
from __future__ import annotations

import os

from meta_rg.backends.base import BaseBackend


class OpenAIBackend(BaseBackend):
    def __init__(
        self,
        model: str = "gpt-4o-mini",
        base_url: str | None = None,
        api_key: str | None = None,
        temperature: float = 0.7,
        max_tokens: int = 256,
        system_prompt: str | None = None,
        **_,
    ) -> None:
        try:
            from openai import OpenAI
        except ImportError as e:
            raise ImportError("pip install openai") from e

        self.model = model
        self.temperature = temperature
        self.max_tokens = max_tokens
        self.system_prompt = system_prompt

        self.client = OpenAI(
            api_key=api_key or os.environ.get("OPENAI_API_KEY", "EMPTY"),
            base_url=base_url,
        )

    def generate(self, prompt_text: str) -> str:
        messages = []
        if self.system_prompt:
            messages.append({"role": "system", "content": self.system_prompt})
        messages.append({"role": "user", "content": prompt_text})

        response = self.client.chat.completions.create(
            model=self.model,
            messages=messages,
            temperature=self.temperature,
            max_tokens=self.max_tokens,
        )
        return response.choices[0].message.content or ""
