"""
Add gpt-5-pro Model

This migration adds the new gpt-5-pro model to the evaluation system.

Model Configuration:
- Model name: gpt-5-pro
- Display name: GPT-5 Pro
- Company: openai (ID varies by database)
- Tier: 4 (Experimental Models)
- Framework: inspect
- Active: True
- Reasoning args:
  - reasoning_effort: "high" (only supported value for GPT-5 Pro)
  - reasoning_summary: "auto"

GPT-5 Pro Details:
- Released: October 6, 2025 (OpenAI DevDay)
- Max output tokens: 272,000 (vs 128,000 for standard GPT-5)
- Requires Responses API (automatically handled by Inspect AI)
- Optimized for deep reasoning tasks

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_gpt_5_pro(apps, schema_editor):
    """Add gpt-5-pro 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 gpt-5-pro model...")

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

        # Get Tier 4 ID
        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 = 'gpt-5-pro'")
        if cursor.fetchone():
            print("  ⚠️  Model 'gpt-5-pro' 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
            ('gpt-5-pro', 'GPT-5 Pro', {company_id}, {tier_id}, 'inspect', 1)
        """)

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

        # Add reasoning args (GPT-5 Pro requires reasoning_effort="high")
        print("  Adding reasoning_args...")

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

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

        print("✅ gpt-5-pro model added successfully!")


def reverse_add_gpt_5_pro(apps, schema_editor):
    """Remove gpt-5-pro model from the database."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Removing gpt-5-pro model...")

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

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


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0015_allow_multiple_grading_sessions'),
    ]

    operations = [
        migrations.RunPython(
            add_gpt_5_pro,
            reverse_add_gpt_5_pro,
        ),
    ]
