"""
Fix DeepSeek Model Name Back to Terminus

Migration 0018 incorrectly changed the model name from deepseek-v3p1-terminus
to deepseek-v3. The correct name on Fireworks is deepseek-v3p1-terminus.

This migration corrects:
- accounts/fireworks/models/deepseek-v3 → accounts/fireworks/models/deepseek-v3p1-terminus

The prefix (accounts/fireworks/models/) is correct and stays the same.
"""

from django.db import migrations


def fix_deepseek_name(apps, schema_editor):
    """Change deepseek-v3 back to deepseek-v3p1-terminus."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Fixing DeepSeek model name...")

        # Check if model exists with wrong name
        cursor.execute("SELECT id FROM models WHERE model_name = 'accounts/fireworks/models/deepseek-v3'")
        result = cursor.fetchone()

        if result:
            model_id = result[0]
            # Update to correct name
            cursor.execute("""
                UPDATE models
                SET model_name = 'accounts/fireworks/models/deepseek-v3p1-terminus',
                    display_name = 'DeepSeek V3.1 Terminus'
                WHERE id = %s
            """, [model_id])
            print(f"  ✅ Updated model name to 'accounts/fireworks/models/deepseek-v3p1-terminus'")
        else:
            print("  ⚠️  Model 'accounts/fireworks/models/deepseek-v3' not found, skipping")

        print("✅ DeepSeek model name fixed!")


def reverse_fix_deepseek_name(apps, schema_editor):
    """Revert deepseek-v3p1-terminus back to deepseek-v3."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Reverting DeepSeek model name...")

        cursor.execute("SELECT id FROM models WHERE model_name = 'accounts/fireworks/models/deepseek-v3p1-terminus'")
        result = cursor.fetchone()

        if result:
            model_id = result[0]
            cursor.execute("""
                UPDATE models
                SET model_name = 'accounts/fireworks/models/deepseek-v3',
                    display_name = 'DeepSeek V3'
                WHERE id = %s
            """, [model_id])
            print(f"  ✅ Reverted to 'accounts/fireworks/models/deepseek-v3'")

        print("✅ Revert complete!")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0019_add_fireworks_tool_emulation'),
    ]

    operations = [
        migrations.RunPython(
            fix_deepseek_name,
            reverse_fix_deepseek_name,
        ),
    ]
