"""
Set reasoning_effort to 'high' for Fireworks models and optimize Qwen 3 parameters

This migration:
1. Sets reasoning_effort='high' for Fireworks models only
2. Applies Qwen 3 recommended parameters from Fireworks AI blog post:
   - reasoning_effort='high' (enables thinking mode)
   - temperature=0.6 (optimal for thinking mode)
   - top_p=0.95 (optimal for thinking mode)
   - top_k=20 (optimal for thinking mode)

Reference: https://fireworks.ai/blog/qwen-3

Fireworks AI supports reasoning_effort with values: 'none', 'low', 'medium', 'high'
"""

from django.db import migrations


def set_reasoning_params(apps, schema_editor):
    """Set reasoning_effort='high' for Fireworks models and optimize Qwen 3 parameters."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Setting reasoning_effort='high' for Fireworks models...")

        # Get Fireworks company ID
        cursor.execute("SELECT id FROM companies WHERE company_name = 'fireworks'")
        result = cursor.fetchone()
        if not result:
            print("  ⚠️  Fireworks company not found, skipping")
            return

        fireworks_company_id = result[0]

        # Get all Fireworks models
        cursor.execute("""
            SELECT id, model_name, display_name
            FROM models
            WHERE company_id = %s
            ORDER BY id
        """, [fireworks_company_id])
        models = cursor.fetchall()

        for model_id, model_name, display_name in models:
            # Set reasoning_effort='high' for Fireworks models
            cursor.execute("""
                SELECT id FROM reasoning_args
                WHERE model_id = %s AND arg_name = 'reasoning_effort'
            """, [model_id])

            existing = cursor.fetchone()

            if existing:
                cursor.execute("""
                    UPDATE reasoning_args
                    SET arg_value = 'high',
                        updated_at = datetime('now')
                    WHERE model_id = %s AND arg_name = 'reasoning_effort'
                """, [model_id])
                print(f"  ✅ Updated reasoning_effort='high' for {display_name}")
            else:
                cursor.execute("""
                    INSERT INTO reasoning_args
                    (model_id, arg_name, arg_value, created_at, updated_at)
                    VALUES
                    (%s, 'reasoning_effort', 'high', datetime('now'), datetime('now'))
                """, [model_id])
                print(f"  ✅ Added reasoning_effort='high' for {display_name}")

            # Apply Qwen 3 recommended parameters for thinking mode
            if 'qwen' in model_name.lower():
                print(f"\n  🔧 Applying Qwen 3 optimized parameters for {display_name}...")

                # Set temperature=0.6 (recommended for thinking mode)
                cursor.execute("""
                    SELECT id FROM reasoning_args
                    WHERE model_id = %s AND arg_name = 'temperature'
                """, [model_id])

                if cursor.fetchone():
                    cursor.execute("""
                        UPDATE reasoning_args
                        SET arg_value = '0.6',
                            updated_at = datetime('now')
                        WHERE model_id = %s AND arg_name = 'temperature'
                    """, [model_id])
                else:
                    cursor.execute("""
                        INSERT INTO reasoning_args
                        (model_id, arg_name, arg_value, created_at, updated_at)
                        VALUES
                        (%s, 'temperature', '0.6', datetime('now'), datetime('now'))
                    """, [model_id])
                print(f"    ✅ Set temperature=0.6")

                # Set top_p=0.95 (recommended for thinking mode)
                cursor.execute("""
                    SELECT id FROM reasoning_args
                    WHERE model_id = %s AND arg_name = 'top_p'
                """, [model_id])

                if cursor.fetchone():
                    cursor.execute("""
                        UPDATE reasoning_args
                        SET arg_value = '0.95',
                            updated_at = datetime('now')
                        WHERE model_id = %s AND arg_name = 'top_p'
                    """, [model_id])
                else:
                    cursor.execute("""
                        INSERT INTO reasoning_args
                        (model_id, arg_name, arg_value, created_at, updated_at)
                        VALUES
                        (%s, 'top_p', '0.95', datetime('now'), datetime('now'))
                    """, [model_id])
                print(f"    ✅ Set top_p=0.95")

                # Set top_k=20 (recommended for thinking mode)
                cursor.execute("""
                    SELECT id FROM reasoning_args
                    WHERE model_id = %s AND arg_name = 'top_k'
                """, [model_id])

                if cursor.fetchone():
                    cursor.execute("""
                        UPDATE reasoning_args
                        SET arg_value = '20',
                            updated_at = datetime('now')
                        WHERE model_id = %s AND arg_name = 'top_k'
                    """, [model_id])
                else:
                    cursor.execute("""
                        INSERT INTO reasoning_args
                        (model_id, arg_name, arg_value, created_at, updated_at)
                        VALUES
                        (%s, 'top_k', '20', datetime('now'), datetime('now'))
                    """, [model_id])
                print(f"    ✅ Set top_k=20")

        print(f"\n✅ Set reasoning_effort='high' for {len(models)} Fireworks model(s)!")
        qwen_count = sum(1 for _, model_name, _ in models if 'qwen' in model_name.lower())
        if qwen_count > 0:
            print(f"✅ Applied Qwen 3 optimized parameters to {qwen_count} model(s)")


def reverse_reasoning_effort(apps, schema_editor):
    """Remove reasoning_effort setting from Fireworks models (revert to default)."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Removing reasoning_effort settings from Fireworks models...")

        # Get Fireworks company ID
        cursor.execute("SELECT id FROM companies WHERE company_name = 'fireworks'")
        result = cursor.fetchone()
        if not result:
            print("  ⚠️  Fireworks company not found, skipping")
            return

        fireworks_company_id = result[0]

        # Delete reasoning_effort for Fireworks models only
        cursor.execute("""
            DELETE FROM reasoning_args
            WHERE arg_name = 'reasoning_effort'
            AND model_id IN (
                SELECT id FROM models WHERE company_id = %s
            )
        """, [fireworks_company_id])

        deleted_count = cursor.rowcount
        print(f"✅ Removed reasoning_effort from {deleted_count} Fireworks model(s)")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0020_fix_deepseek_model_name'),
    ]

    operations = [
        migrations.RunPython(
            set_reasoning_params,
            reverse_reasoning_effort,
        ),
    ]
