# Migration to add all non-agentic test models using raw SQL
import json
from django.db import migrations


def add_non_agentic_models(apps, schema_editor):
    """
    Add 6 new non-agentic models for ablation testing.

    Models:
    1. GPT-5 (code interpreter)
    2. GPT-5 (web search)
    3. GPT-5 (code interpreter + web search)
    4. GPT-5 Pro (web search)
    5. Grok 4 (no tools)
    6. Gemini 2.5 Pro (no tools)
    7. DeepSeek V3.1 Terminus (no tools)

    Uses raw SQL since Model is unmanaged.
    """
    db = schema_editor.connection

    with db.cursor() as cursor:
        # Get company IDs
        cursor.execute("SELECT id FROM companies WHERE company_name = 'openai'")
        openai_id = cursor.fetchone()[0]

        # Get or create xAI company
        cursor.execute("SELECT id FROM companies WHERE company_name = 'xai'")
        xai_row = cursor.fetchone()
        if not xai_row:
            cursor.execute(
                "INSERT INTO companies (company_name, api_key) VALUES ('xai', 'XAI_API_KEY')"
            )
            xai_id = cursor.lastrowid
            print("  Created company: xai")
        else:
            xai_id = xai_row[0]
            print("  Found existing company: xai")

        # Get or create Google company
        cursor.execute("SELECT id FROM companies WHERE company_name = 'google'")
        google_row = cursor.fetchone()
        if not google_row:
            cursor.execute(
                "INSERT INTO companies (company_name, api_key) VALUES ('google', 'GOOGLE_API_KEY')"
            )
            google_id = cursor.lastrowid
            print("  Created company: google")
        else:
            google_id = google_row[0]
            print("  Found existing company: google")

        # Get Fireworks company ID (for DeepSeek)
        cursor.execute("SELECT id FROM companies WHERE company_name = 'fireworks'")
        fireworks_row = cursor.fetchone()
        if not fireworks_row:
            print("  ❌ Error: Fireworks company not found in database.")
            return
        fireworks_id = fireworks_row[0]

        # Get Tier 4 ID
        cursor.execute("SELECT id FROM model_tiers WHERE tier_number = 4")
        tier_id = cursor.fetchone()[0]

        print("\n🔧 Adding 7 non-agentic models...")

        # Model definitions
        models = [
            {
                'name': 'gpt-5',
                'display_name': 'GPT-5 (code interpreter)',
                'company_id': openai_id,
                'tools': [{"type": "code_interpreter"}],
                'reasoning_effort': 'high'
            },
            {
                'name': 'gpt-5',
                'display_name': 'GPT-5 (web search)',
                'company_id': openai_id,
                'tools': [{"type": "web_search"}],
                'reasoning_effort': 'high'
            },
            {
                'name': 'gpt-5',
                'display_name': 'GPT-5 (code interpreter + web search)',
                'company_id': openai_id,
                'tools': [{"type": "code_interpreter"}, {"type": "web_search"}],
                'reasoning_effort': 'high'
            },
            {
                'name': 'gpt-5-pro',
                'display_name': 'GPT-5 Pro (web search)',
                'company_id': openai_id,
                'tools': [{"type": "web_search"}],
                'reasoning_effort': 'high'
            },
            {
                'name': 'grok-4',
                'display_name': 'Grok 4 (no tools)',
                'company_id': xai_id,
                'tools': [],
                'reasoning_effort': None  # Grok doesn't use reasoning parameter
            },
            {
                'name': 'gemini-2.5-pro',
                'display_name': 'Gemini 2.5 Pro (no tools)',
                'company_id': google_id,
                'tools': [],
                'reasoning_effort': None  # Gemini uses ThinkingConfig instead
            },
            {
                'name': 'accounts/fireworks/models/deepseek-v3p1-terminus',
                'display_name': 'DeepSeek V3.1 Terminus (no tools)',
                'company_id': fireworks_id,
                'tools': [],
                'reasoning_effort': 'high'  # DeepSeek supports reasoning
            }
        ]

        for model_def in models:
            # Check if model already exists
            cursor.execute(
                f"SELECT id FROM models WHERE display_name = '{model_def['display_name']}'"
            )
            existing = cursor.fetchone()

            if existing:
                print(f"  ⚠️  Model '{model_def['display_name']}' already exists, skipping...")
                continue

            # Create model
            cursor.execute(f"""
                INSERT INTO models (company_id, model_name, display_name, tier_id, framework_type, is_active)
                VALUES ({model_def['company_id']}, '{model_def['name']}', '{model_def['display_name']}',
                        {tier_id}, 'non-agentic', 1)
            """)
            model_id = cursor.lastrowid

            # Add reasoning args
            if model_def['reasoning_effort']:
                # Reasoning effort
                json_value = json.dumps(model_def['reasoning_effort']).replace("'", "''")
                cursor.execute(f"""
                    INSERT INTO reasoning_args (model_id, arg_name, arg_value, created_at, updated_at)
                    VALUES ({model_id}, 'reasoning_effort', '{json_value}', datetime('now'), datetime('now'))
                """)

            # Tools configuration
            json_value = json.dumps(model_def['tools']).replace("'", "''")
            cursor.execute(f"""
                INSERT INTO reasoning_args (model_id, arg_name, arg_value, created_at, updated_at)
                VALUES ({model_id}, 'tools', '{json_value}', datetime('now'), datetime('now'))
            """)

            print(f"  ✅ Created: {model_def['display_name']}")

        print("\n✅ All non-agentic models configured successfully!")


def remove_non_agentic_models(apps, schema_editor):
    """Remove non-agentic models (reverse migration)."""
    db = schema_editor.connection

    with db.cursor() as cursor:
        model_names = [
            'GPT-5 (code interpreter)',
            'GPT-5 (web search)',
            'GPT-5 (code interpreter + web search)',
            'GPT-5 Pro (web search)',
            'Grok 4 (no tools)',
            'Gemini 2.5 Pro (no tools)',
            'DeepSeek V3.1 Terminus (no tools)'
        ]

        for display_name in model_names:
            cursor.execute(f"SELECT id FROM models WHERE display_name = '{display_name}'")
            row = cursor.fetchone()

            if row:
                model_id = row[0]

                # Delete args
                cursor.execute(f"DELETE FROM model_args WHERE model_id = {model_id}")
                cursor.execute(f"DELETE FROM reasoning_args WHERE model_id = {model_id}")

                # Delete model
                cursor.execute(f"DELETE FROM models WHERE id = {model_id}")

                print(f"  Removed: {display_name}")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0024_add_gpt5_no_tools'),
    ]

    operations = [
        migrations.RunPython(add_non_agentic_models, remove_non_agentic_models),
    ]
