"""
Fix Fireworks Model Names

The initial migration used incorrect model name format. Inspect AI expects
model names in the format 'accounts/fireworks/models/<model-name>' without
the 'fireworks/' prefix, as Inspect AI automatically adds that prefix.

This migration corrects:
- fireworks/accounts/fireworks/models/deepseek-v3p1-terminus → accounts/fireworks/models/deepseek-v3
- fireworks/accounts/fireworks/models/gpt-oss-120b → accounts/fireworks/models/gpt-oss-120b
- fireworks/accounts/fireworks/models/qwen3-235b-a22b → accounts/fireworks/models/qwen3-235b-a22b

Note: deepseek-v3p1-terminus was corrected to deepseek-v3 as that's the actual model name on Fireworks.
"""

from django.db import migrations


def fix_fireworks_model_names(apps, schema_editor):
    """Fix the Fireworks model names to use correct format."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Fixing Fireworks model names...")

        # Model name corrections
        corrections = [
            {
                'old_name': 'fireworks/accounts/fireworks/models/deepseek-v3p1-terminus',
                'new_name': 'accounts/fireworks/models/deepseek-v3',
                'new_display': 'DeepSeek V3',
                'short_name': 'deepseek-v3'
            },
            {
                'old_name': 'fireworks/accounts/fireworks/models/gpt-oss-120b',
                'new_name': 'accounts/fireworks/models/gpt-oss-120b',
                'new_display': 'GPT-OSS 120B',
                'short_name': 'gpt-oss-120b'
            },
            {
                'old_name': 'fireworks/accounts/fireworks/models/qwen3-235b-a22b',
                'new_name': 'accounts/fireworks/models/qwen3-235b-a22b',
                'new_display': 'Qwen3 235B A22B',
                'short_name': 'qwen3-235b-a22b'
            }
        ]

        for correction in corrections:
            old_name = correction['old_name']
            new_name = correction['new_name']
            new_display = correction['new_display']
            short_name = correction['short_name']

            # Check if old model exists
            cursor.execute(f"SELECT id FROM models WHERE model_name = '{old_name}'")
            result = cursor.fetchone()

            if result:
                model_id = result[0]
                # Update the model name and display name
                cursor.execute(f"""
                    UPDATE models
                    SET model_name = '{new_name}',
                        display_name = '{new_display}'
                    WHERE id = {model_id}
                """)
                print(f"  ✅ Updated '{short_name}' model name")
            else:
                print(f"  ⚠️  Model '{old_name}' not found, skipping")

        print("✅ Fireworks model names fixed!")
        print("\nCorrected model names:")
        print("  - accounts/fireworks/models/deepseek-v3")
        print("  - accounts/fireworks/models/gpt-oss-120b")
        print("  - accounts/fireworks/models/qwen3-235b-a22b")


def reverse_fix_fireworks_model_names(apps, schema_editor):
    """Revert the model name fixes."""
    from django.db import connection

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

        # Reverse corrections
        corrections = [
            {
                'old_name': 'accounts/fireworks/models/deepseek-v3',
                'new_name': 'fireworks/accounts/fireworks/models/deepseek-v3p1-terminus',
                'new_display': 'DeepSeek V3.1 Terminus'
            },
            {
                'old_name': 'accounts/fireworks/models/gpt-oss-120b',
                'new_name': 'fireworks/accounts/fireworks/models/gpt-oss-120b',
                'new_display': 'GPT-OSS 120B'
            },
            {
                'old_name': 'accounts/fireworks/models/qwen3-235b-a22b',
                'new_name': 'fireworks/accounts/fireworks/models/qwen3-235b-a22b',
                'new_display': 'Qwen3 235B A22B'
            }
        ]

        for correction in corrections:
            old_name = correction['old_name']
            new_name = correction['new_name']
            new_display = correction['new_display']

            cursor.execute(f"SELECT id FROM models WHERE model_name = '{old_name}'")
            result = cursor.fetchone()

            if result:
                model_id = result[0]
                cursor.execute(f"""
                    UPDATE models
                    SET model_name = '{new_name}',
                        display_name = '{new_display}'
                    WHERE id = {model_id}
                """)
                print(f"  ✅ Reverted '{old_name}'")

        print("✅ Revert complete!")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0017_add_fireworks_models'),
    ]

    operations = [
        migrations.RunPython(
            fix_fireworks_model_names,
            reverse_fix_fireworks_model_names,
        ),
    ]
