"""
Add grok-4-fast-reasoning Model

This migration adds the new grok-4-fast-reasoning model to the evaluation system.

Model Configuration:
- Model name: grok-4-fast-reasoning
- Display name: Grok 4 Fast Reasoning
- Company: grok (ID: 4)
- Tier: 4 (Experimental Models)
- Framework: inspect
- Active: True
- No model_args or reasoning_args (following pattern of existing Grok models)

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_grok_4_fast_reasoning(apps, schema_editor):
    """Add grok-4-fast-reasoning 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 grok-4-fast-reasoning model...")

        # Get the grok company ID
        cursor.execute("SELECT id FROM companies WHERE company_name = 'grok'")
        result = cursor.fetchone()
        if not result:
            raise ValueError("Grok company not found in database")
        company_id = result[0]
        print(f"  Using company 'grok' (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 = 'grok-4-fast-reasoning'")
        if cursor.fetchone():
            print("  ⚠️  Model 'grok-4-fast-reasoning' 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
            ('grok-4-fast-reasoning', 'Grok 4 Fast Reasoning', {company_id}, {tier_id}, 'inspect', 1)
        """)

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

        # No model_args or reasoning_args to add (following grok-3 and grok-4-0709 pattern)
        # Grok models currently don't support reasoning_effort parameter
        print("  Note: No model_args or reasoning_args configured (Grok models currently have none)")

        print("✅ grok-4-fast-reasoning model added successfully!")


def reverse_add_grok_4_fast_reasoning(apps, schema_editor):
    """Remove grok-4-fast-reasoning model from the database."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Removing grok-4-fast-reasoning model...")

        # Delete the model (CASCADE will handle model_args and reasoning_args if any)
        cursor.execute("DELETE FROM models WHERE model_name = 'grok-4-fast-reasoning'")

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


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0013_remove_unused_models'),
    ]

    operations = [
        migrations.RunPython(
            add_grok_4_fast_reasoning,
            reverse_add_grok_4_fast_reasoning,
        ),
    ]
