import os
import openai
from time import sleep


class OpenAIClient:
    def __init__(self):
        OPENAI_MODEL = os.getenv("OPENAI_MODEL")
        assert OPENAI_MODEL is not None, "OPENAI_MODEL is not set."
        self.model = OPENAI_MODEL
        self.client = openai.OpenAI()

    def chat_completion(self, model, messages, temperature=1e-4, max_tokens=1024, n=1):
        assert n == 1, "Only n=1 is supported for now"

        responses = None
        max_retries = 5
        while max_retries > 0:
            try:
                completion = self.client.chat.completions.create(
                    model=model, messages=messages, temperature=temperature, max_tokens=max_tokens, n=n
                )        
                responses = [choice.message.content for choice in completion.choices]
                break

            except Exception as e:
                print(f"Failed to get completion: {e}")
                max_retries -= 1
                if max_retries == 0:
                    raise
                print("Retrying...")
                sleep(15)
                continue

        assert responses is not None, "Failed to get completion"

        return responses


def get_llm_client():
    # Check for OpenAI first.
    OPENAI_MODEL = os.environ.get('OPENAI_MODEL')
    if OPENAI_MODEL is not None:
        print('Using OpenAI client...')
        client = OpenAIClient()
        return client, OPENAI_MODEL

    raise RuntimeError("No valid model found")
