import json
import os
import base64
import vertexai
from vertexai.generative_models import GenerativeModel, Part, FinishReason, Image
import vertexai.preview.generative_models as generative_models
# disable warnings
import warnings
warnings.filterwarnings("ignore")

os.environ['GOOGLE_APPLICATION_CREDENTIALS'] ='api_keys/gemini_key.json'
api_key = json.load(open("api_keys/gemini_key.json"))

safety_settings = { 
        generative_models.HarmCategory.HARM_CATEGORY_HATE_SPEECH:generative_models.HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE,
        generative_models.HarmCategory.HARM_CATEGORY_DANGEROUS_CONTENT: generative_models.HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE,
        generative_models.HarmCategory.HARM_CATEGORY_SEXUALLY_EXPLICIT: generative_models.HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE, 
        generative_models.HarmCategory.HARM_CATEGORY_HARASSMENT: generative_models.HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE,
} 



def generate(model_name, contents, generation_config={"max_output_tokens": 16384, "temperature": 0.7}):
    vertexai.init(project=api_key["project_name"], location=api_key["location"])
    model = GenerativeModel(model_name)

    response = model.generate_content(contents, generation_config=generation_config, safety_settings=safety_settings)
    # convert to dict
    # print(response)
    usage_metadata = response.usage_metadata
    metadata = {
        "prompt_token_count": usage_metadata.prompt_token_count,
        "candidates_token_count": usage_metadata.candidates_token_count,
        "thoughts_token_count": usage_metadata.thoughts_token_count,
    }
    try:
        return response.text, metadata
    except ValueError:
        return None, metadata

if __name__ == "__main__":
    print(generate("gemini-2.5-flash", [
        # Part.from_image(Image.load_from_file("unit_test/data/screenshots/screenshot_001.png")),
        # "Tell me what is in this image."
        "Hello, say this is a test"
    ]))
