from openai import OpenAI

client = OpenAI(
    api_key="your api key",
    base_url="the base url"
)
import sys
sys.path.append("the relative path")
import os
import base64
import argparse
from tqdm import tqdm
import json
from PIL import Image
from io import BytesIO
from openai import OpenAI
from dotenv import load_dotenv
import glob
from pathlib import Path
load_dotenv()

class GPT4o:
    def __init__(self, args):
        self.name = "GPT4o"
        self.temperature = args.temperature
        self.max_tokens = 10000
        # self.image_quality = args.image_quality  # low/high/auto
        
    def encode_image(self, image):
        try:
            if isinstance(image, (str, os.PathLike, Path)):
                img = Image.open(image)
            elif isinstance(image, (bytes, bytearray)):
                img = Image.open(BytesIO(image))
            else:
                raise TypeError("image must be path-like or bytes")

            with img:
                if max(img.size) > 2048:
                    img.thumbnail((2048, 2048))

                exif_data = img.info.get("exif", b"")
                buffer = BytesIO()
                save_args = {"format": "JPEG", "quality": 85}
                if exif_data:
                    save_args["exif"] = exif_data
                img.save(buffer, **save_args)

                return base64.b64encode(buffer.getvalue()).decode("utf-8")

        except Exception as e:
            print(f"Error: {e}")
            return None


    def generate_prompt(self, prompt = None):
        self.prompt = prompt
        return prompt

    def get_answer(self, image_path):

        base64_image = self.encode_image(image_path)
        if not base64_image:
            return ""
            
        messages = [{
            "role": "user",
            "content": [
                {"type": "text", "text": self.prompt},
                {
                    "type": "image_url",
                    "image_url": {
                        "url": f"data:image/jpeg;base64,{base64_image}",
                    }
                }
            ]
        }]
        
        try:
            response = client.chat.completions.create(
                model="gpt-4o",
                messages=messages,
                temperature=self.temperature,
                max_tokens=self.max_tokens,
                top_p=0.9,
                frequency_penalty=0.2,
                presence_penalty=0.5
            )
            return response.choices[0].message.content.strip(), 1, 2
        except Exception as e:
            print(f"Failed: {str(e)}")
            return "", 0, 0