"""
Add gemini-3-pro-preview Model

This migration adds the new Gemini 3 Pro Preview model to the evaluation system.

Model Configuration:
- Model name: gemini-3-pro-preview
- Display name: Gemini 3 Pro Preview
- Company: google (ID varies by database)
- Tier: 4 (Experimental Models)
- Framework: inspect
- Active: True
- Reasoning args:
  - thinking_level: "high" (for maximum reasoning depth on complex tasks)

Gemini 3 Pro Preview Details:
- Released: 2025
- Context window: 1M input / 64k output
- Knowledge cutoff: January 2025
- Most intelligent model in the Gemini family to date
- Built on state-of-the-art reasoning foundation
- Designed for agentic workflows, autonomous coding, and complex multimodal tasks
- Uses dynamic thinking by default
- Temperature should remain at default 1.0 (not explicitly set)

This migration is designed to be reproducible and serves as a template for adding
future models via data migrations.
"""

from django.db import migrations


def add_gemini_3_pro_preview(apps, schema_editor):
    """Add gemini-3-pro-preview model to the database."""
    # Use raw connection to avoid Django's parameter formatting issues in migrations
    from django.db import connection

    with connection.cursor() as cursor:
        print("Adding gemini-3-pro-preview model...")

        # Get the google company ID
        cursor.execute("SELECT id FROM companies WHERE company_name = 'google'")
        result = cursor.fetchone()
        if not result:
            raise ValueError("Google company not found in database")
        company_id = result[0]
        print(f"  Using company 'google' (ID: {company_id})")

        # Get Tier 4 ID (Experimental Models)
        cursor.execute("SELECT id FROM model_tiers WHERE tier_number = 4")
        result = cursor.fetchone()
        if not result:
            raise ValueError("Tier 4 not found in database")
        tier_id = result[0]
        print(f"  Using Tier 4 (ID: {tier_id})")

        # Check if model already exists
        cursor.execute("SELECT id FROM models WHERE model_name = 'gemini-3-pro-preview'")
        if cursor.fetchone():
            print("  ⚠️  Model 'gemini-3-pro-preview' already exists, skipping creation")
            return

        # Insert the new model using direct string formatting to avoid Django param issues
        cursor.execute(f"""
            INSERT INTO models
            (model_name, display_name, company_id, tier_id, framework_type, is_active)
            VALUES
            ('gemini-3-pro-preview', 'Gemini 3 Pro Preview', {company_id}, {tier_id}, 'inspect', 1)
        """)

        # Get the newly created model ID
        model_id = cursor.lastrowid
        print(f"  ✅ Created model 'gemini-3-pro-preview' (ID: {model_id})")

        # Add reasoning args (Gemini 3 Pro uses thinking_level="high" for complex tasks)
        print("  Adding reasoning_args...")

        cursor.execute(f"""
            INSERT INTO reasoning_args
            (model_id, arg_name, arg_value, created_at, updated_at)
            VALUES
            ({model_id}, 'thinking_level', '"high"', datetime('now'), datetime('now'))
        """)
        print("    ✅ Added thinking_level='high'")

        print("✅ gemini-3-pro-preview model added successfully!")


def reverse_add_gemini_3_pro_preview(apps, schema_editor):
    """Remove gemini-3-pro-preview model from the database."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Removing gemini-3-pro-preview model...")

        # Delete the model (CASCADE will handle reasoning_args automatically)
        cursor.execute("DELETE FROM models WHERE model_name = 'gemini-3-pro-preview'")

        if cursor.rowcount > 0:
            print("✅ gemini-3-pro-preview model removed successfully!")
        else:
            print("  ⚠️  Model 'gemini-3-pro-preview' not found, nothing to remove")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0025_add_non_agentic_models'),
    ]

    operations = [
        migrations.RunPython(
            add_gemini_3_pro_preview,
            reverse_add_gemini_3_pro_preview,
        ),
    ]
