import os
import json
from openai import OpenAI

config = json.load(open("api_keys/open_source.json"))


def generate(model="DeepSeek-V3-0324", messages=None, generation_config={"max_output_tokens": 16384, "temperature": 0.0}):
    client = OpenAI(
        api_key=config[model]["api_key"],
        base_url=config[model]["base_url"],
    )
    response = client.chat.completions.create(
        model=config[model]["model"],
        messages=messages,
        max_tokens=generation_config["max_output_tokens"],
        temperature=generation_config["temperature"]
    )
    metadata = {
        "prompt_token_count": response.usage.prompt_tokens,
        "candidates_token_count": response.usage.completion_tokens,
        "thoughts_token_count": 0,
    }
    return response.choices[0].message.content, metadata


if __name__ == "__main__":
    from time import time
    start_time = time()
    context, metadata = generate(model="Kimi-K2-Instruct", messages=[{"role": "user", "content": "Who are you?"}])
    end_time = time()
    print(context)
    print(metadata)
    print(f"Time taken: {end_time - start_time} seconds")