import asyncio
from fastapi import APIRouter
from langchain_google_genai import ChatGoogleGenerativeAI
import google.generativeai as genai
import google
from model import Generated

api_router = APIRouter()


@api_router.post('/generated')
async def generated(generated: Generated):
    async def generate_response():
        genai.configure(api_key=generated.api_key)
        client = ChatGoogleGenerativeAI(
            model=generated.model_name,
            google_api_key=generated.api_key,
        )
        return client.invoke(generated.content)

    if generated.model_type == "gemini":
        try:
            response = await asyncio.wait_for(generate_response(), timeout=generated.timeout)
            try:
                input_tokens = response.usage_metadata['input_tokens']
                output_tokens = response.usage_metadata['output_tokens']
            except:
                print("ERROR in tokens")
                input_tokens = 0
                output_tokens = 0
            return {
                "status": 'ok',
                "text": response.content,
                "error": None,
                "input_tokens": input_tokens,
                "output_tokens": output_tokens
            }
        except asyncio.TimeoutError:
            return {
                "status": 'error',
                "text": None,
                "error": 'Timeout',
                "input_tokens": None,
                "output_tokens": None
            }
        except google.api_core.exceptions.ResourceExhausted as e:
            return {
                "status": 'error',
                "text": None,
                'error': str(e),
                "input_tokens": None,
                "output_tokens": None
            }
    else:
        return {
            "status": 'error',
            "text": None,
            'error': f"Unknown model type: {generated.model_type}",
            "input_tokens": None,
            "output_tokens": None
        }
