# Migration to add GPT-5 (no tools) test model using raw SQL
import json
from django.db import migrations


def add_gpt5_no_tools(apps, schema_editor):
    """
    Add GPT-5 (no tools) model for initial testing.

    Uses raw SQL since Model and Company are unmanaged models.
    """
    db = schema_editor.connection

    # Get OpenAI company ID (should already exist)
    with db.cursor() as cursor:
        cursor.execute("SELECT id FROM companies WHERE company_name = 'openai'")
        row = cursor.fetchone()

        if not row:
            # OpenAI company doesn't exist - create it
            cursor.execute(
                "INSERT INTO companies (company_name, api_key) VALUES ('openai', 'OPENAI_API_KEY')"
            )
            company_id = cursor.lastrowid
            print("  Created company: openai")
        else:
            company_id = row[0]
            print("  Found existing company: openai")

        # Get Tier 4 ID (should already exist in production database)
        cursor.execute("SELECT id FROM model_tiers WHERE tier_number = 4")
        row = cursor.fetchone()

        if not row:
            print("  ❌ Error: Tier 4 not found in database.")
            return

        tier_id = row[0]

        # Check if model already exists
        cursor.execute(
            "SELECT id FROM models WHERE display_name = 'GPT-5 (no tools)'"
        )
        existing = cursor.fetchone()

        if existing:
            model_id = existing[0]
            print("  Model 'GPT-5 (no tools)' already exists, updating...")

            # Update existing model
            cursor.execute(f"""
                UPDATE models
                SET company_id = {company_id},
                    model_name = 'gpt-5',
                    tier_id = {tier_id},
                    framework_type = 'non-agentic',
                    is_active = 1
                WHERE id = {model_id}
            """)
        else:
            # Create new model
            cursor.execute(f"""
                INSERT INTO models (company_id, model_name, display_name, tier_id, framework_type, is_active)
                VALUES ({company_id}, 'gpt-5', 'GPT-5 (no tools)', {tier_id}, 'non-agentic', 1)
            """)
            model_id = cursor.lastrowid
            print("  ✅ Created model: GPT-5 (no tools)")

        # Clear existing args (in case of re-run)
        cursor.execute(f"DELETE FROM model_args WHERE model_id = {model_id}")
        cursor.execute(f"DELETE FROM reasoning_args WHERE model_id = {model_id}")

        # Add reasoning args
        reasoning_args = {
            'reasoning_effort': 'high',
            'tools': [],
        }

        for arg_name, arg_value in reasoning_args.items():
            # Escape single quotes in JSON for SQL
            json_value = json.dumps(arg_value).replace("'", "''")
            cursor.execute(f"""
                INSERT INTO reasoning_args (model_id, arg_name, arg_value, created_at, updated_at)
                VALUES ({model_id}, '{arg_name}', '{json_value}', datetime('now'), datetime('now'))
            """)
            print(f"    Added reasoning_arg: {arg_name} = {json.dumps(arg_value)}")

        print("  ✅ GPT-5 (no tools) configured successfully!")


def remove_gpt5_no_tools(apps, schema_editor):
    """Remove GPT-5 (no tools) model (reverse migration)."""
    db = schema_editor.connection

    with db.cursor() as cursor:
        # Get model ID
        cursor.execute("SELECT id FROM models WHERE display_name = 'GPT-5 (no tools)'")
        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("  Removed GPT-5 (no tools)")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0023_update_framework_constraint'),
    ]

    operations = [
        migrations.RunPython(add_gpt5_no_tools, remove_gpt5_no_tools),
    ]
