"""
Add GPT-5.1 Model

This migration adds the new GPT-5.1 model to the evaluation system.

Model Configuration:
- Model name: gpt-5.1
- Display name: GPT-5.1
- Company: openai
- Tier: 4 (Experimental Models)
- Framework: inspect
- Active: True
- Reasoning args:
  - reasoning_effort: "high" (maximum reasoning capability for complex math problems)
  - text_verbosity: "high" (detailed explanations for mathematical proofs)
  - max_tokens: 100000 (standard for complex mathematical proofs)

GPT-5.1 Details:
- Newest flagship model in the GPT-5 family
- Replaces the previous gpt-5 model
- Key features:
  * New "none" reasoning effort setting for lower latency (default)
  * Configurable verbosity (low, medium, high) - default is medium
  * New tools: apply_patch and shell for coding use cases
  * Custom tools with freeform text inputs
  * Preambles for tool-calling transparency
- Does NOT support temperature or top_p parameters (will raise error)
- Uses Responses API exclusively for chain-of-thought passing between turns
- Optimized for complex reasoning, broad world knowledge, and code-heavy or multi-step agentic tasks

Note: For mathematical evaluation, we set reasoning_effort to "high" and text_verbosity to "high"
to maximize performance on research-level problems, even though the defaults are "none" and "medium".

Reference: https://platform.openai.com/docs/guides/latest-model

This migration is designed to be reproducible and follows the established
pattern for adding OpenAI reasoning models.
"""

from django.db import migrations


def add_gpt_5_1(apps, schema_editor):
    """Add gpt-5.1 model to the database."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Adding gpt-5.1 model...")

        # Step 1: 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})")

        # Step 2: 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})")

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

        # Step 4: Insert the new model
        cursor.execute(f"""
            INSERT INTO models
            (model_name, display_name, company_id, tier_id, framework_type, is_active)
            VALUES
            ('gpt-5.1', 'GPT-5.1', {company_id}, {tier_id}, 'inspect', 1)
        """)

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

        # Step 5: Add reasoning args with high reasoning and verbosity for mathematical problems
        print("  Adding reasoning_args...")

        # Add reasoning_effort='high' for maximum reasoning capability on complex math
        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'")

        # Add text_verbosity='high' for detailed mathematical explanations
        cursor.execute(f"""
            INSERT INTO reasoning_args
            (model_id, arg_name, arg_value, created_at, updated_at)
            VALUES
            ({model_id}, 'text_verbosity', '"high"', datetime('now'), datetime('now'))
        """)
        print("    ✅ Added text_verbosity='high'")

        # Add max_tokens=100000 (standard for complex mathematical problems)
        cursor.execute(f"""
            INSERT INTO reasoning_args
            (model_id, arg_name, arg_value, created_at, updated_at)
            VALUES
            ({model_id}, 'max_tokens', '100000', datetime('now'), datetime('now'))
        """)
        print("    ✅ Added max_tokens=100000")

        print("✅ gpt-5.1 model added successfully!")
        print("\nNext steps:")
        print("  1. Ensure OPENAI_API_KEY is set in .env file")
        print("  2. Run: python manage.py populate_model_queue --model gpt-5.1")


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

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

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

        if cursor.rowcount > 0:
            print("  ✅ Removed model 'gpt-5.1'")
        else:
            print("  ⚠️  Model 'gpt-5.1' not found")

        print("✅ gpt-5.1 cleanup complete!")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0026_add_gemini_3_pro_preview'),
    ]

    operations = [
        migrations.RunPython(
            add_gpt_5_1,
            reverse_add_gpt_5_1,
        ),
    ]