"""
Add tool emulation for Fireworks models

Fireworks AI models (DeepSeek V3, GPT-OSS, Qwen3) don't natively support
structured tool calls through the OpenAI-compatible API. They need tool
emulation enabled.

Tool emulation encodes tool schemas in XML tags and parses tool calls from
model text output, which is necessary for models that don't have native
tool calling support in the Fireworks API.
"""

from django.db import migrations


def add_tool_emulation(apps, schema_editor):
    """Add emulate_tools model arg to all Fireworks models."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Adding tool emulation 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")
            return

        company_id = result[0]

        # Get all Fireworks models
        cursor.execute(f"SELECT id, model_name FROM models WHERE company_id = {company_id}")
        models = cursor.fetchall()

        for model_id, model_name in models:
            # Add emulate_tools model arg
            cursor.execute(f"""
                INSERT INTO model_args
                (model_id, arg_name, arg_value, created_at, updated_at)
                VALUES
                ({model_id}, 'emulate_tools', 'true', datetime('now'), datetime('now'))
            """)

            short_name = model_name.split('/')[-1]
            print(f"  ✅ Added emulate_tools=true for {short_name}")

        print("✅ Tool emulation enabled for all Fireworks models!")
        print("\nThis allows models without native tool support to use tools")
        print("via XML-encoded schemas and text parsing.")


def reverse_tool_emulation(apps, schema_editor):
    """Remove emulate_tools model arg from Fireworks models."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Removing tool emulation from Fireworks models...")

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

        company_id = result[0]

        # Get all Fireworks models
        cursor.execute(f"SELECT id, model_name FROM models WHERE company_id = {company_id}")
        models = cursor.fetchall()

        for model_id, model_name in models:
            cursor.execute(f"""
                DELETE FROM model_args
                WHERE model_id = {model_id}
                AND arg_name = 'emulate_tools'
            """)

            if cursor.rowcount > 0:
                short_name = model_name.split('/')[-1]
                print(f"  ✅ Removed emulate_tools from {short_name}")

        print("✅ Tool emulation removed!")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0018_fix_fireworks_model_names'),
    ]

    operations = [
        migrations.RunPython(
            add_tool_emulation,
            reverse_tool_emulation,
        ),
    ]
