from ollama import Client
from pydantic import BaseModel
from typing import Literal
from openai import AzureOpenAI
from azure.identity import DefaultAzureCredential, get_bearer_token_provider


class LLMScore(BaseModel):
    Patient_Demographics: Literal["Yes", "No", "Not mentioned in reference"]
    Performance_Status: Literal["Yes", "No", "Not mentioned in reference"]
    Diagnosis: Literal["Yes", "No", "Not mentioned in reference"]
    Tumor_Staging: Literal["Yes", "No", "Not mentioned in reference"]
    Lymph_Node_Involvement: Literal["Yes", "No", "Not mentioned in reference"]
    Other_Clinical_Details: Literal["Yes", "No", "Not mentioned in reference"]


class OllamaClient:
    def __init__(self, model, host="http://localhost:11434"):
        self.model = model
        self.client = Client(host=host)

    def get_output(self, prompt):
        response = self.client.chat(
            messages=[{"role": "user", "content": prompt}],
            model=self.model,
            format=LLMScore.model_json_schema(),
            options={"num_ctx": 16384},
        )
        output = LLMScore.model_validate_json(response.message.content)
        return output.model_dump()


class AzureOpenAIClient:
    def __init__(self, deployment_name):
        endpoint = (
            ""
        )
        self.deployment = deployment_name
        token_provider = get_bearer_token_provider(
            DefaultAzureCredential(), "https://cognitiveservices.azure.com/.default"
        )
        api_version = "2024-12-01-preview"

        self.client = AzureOpenAI(
            api_version=api_version,
            azure_endpoint=endpoint,
            azure_ad_token_provider=token_provider,
        )

    def get_output(self, prompt):
        messages = [{"role": "user", "content": prompt}]
        response = self.client.chat.completions.parse(
            model=self.deployment, messages=messages, response_format=LLMScore
        )
        return response.choices[0].message.parsed.model_dump()
