"""
Add Fireworks AI Models

This migration adds Fireworks AI as a provider and three open source models:
- deepseek-v3p1-terminus
- gpt-oss-120b
- qwen3-235b-a22b

Model Configuration:
- Company: fireworks (new company)
- Tier: 4 (Experimental Models)
- Framework: inspect
- Active: True
- Model name format: fireworks/accounts/fireworks/models/<model-name>

Fireworks AI Provider Details:
- API Key: FIREWORKS_API_KEY (set in .env)
- Base URL: https://api.fireworks.ai/inference/v1
- Uses OpenAI-compatible API via Inspect AI
- Supports tool usage and reasoning

This migration is designed to be reproducible and serves as a template for adding
future Fireworks models via data migrations.
"""

from django.db import migrations


def add_fireworks_models(apps, schema_editor):
    """Add Fireworks AI company and three open source models to the database."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Adding Fireworks AI provider and models...")

        # Step 1: Add Fireworks company
        cursor.execute("SELECT id FROM companies WHERE company_name = 'fireworks'")
        result = cursor.fetchone()
        if result:
            company_id = result[0]
            print(f"  ⚠️  Company 'fireworks' already exists (ID: {company_id})")
        else:
            cursor.execute("""
                INSERT INTO companies
                (company_name, api_key)
                VALUES
                ('fireworks', 'FIREWORKS_API_KEY')
            """)
            company_id = cursor.lastrowid
            print(f"  ✅ Created company 'fireworks' (ID: {company_id})")

        # Step 2: Get Tier 4 ID
        cursor.execute("SELECT id FROM model_tiers WHERE tier_number = 4")
        result = cursor.fetchone()
        if not result:
            raise ValueError("Tier 4 not found in database")
        tier_id = result[0]
        print(f"  Using Tier 4 (ID: {tier_id})")

        # Step 3: Add the three models
        models_to_add = [
            {
                'model_name': 'fireworks/accounts/fireworks/models/deepseek-v3p1-terminus',
                'display_name': 'DeepSeek V3.1 Terminus',
                'short_name': 'deepseek-v3p1-terminus'
            },
            {
                'model_name': 'fireworks/accounts/fireworks/models/gpt-oss-120b',
                'display_name': 'GPT-OSS 120B',
                'short_name': 'gpt-oss-120b'
            },
            {
                'model_name': 'fireworks/accounts/fireworks/models/qwen3-235b-a22b',
                'display_name': 'Qwen3 235B A22B',
                'short_name': 'qwen3-235b-a22b'
            }
        ]

        for model_config in models_to_add:
            model_name = model_config['model_name']
            display_name = model_config['display_name']
            short_name = model_config['short_name']

            # Check if model already exists
            cursor.execute(f"SELECT id FROM models WHERE model_name = '{model_name}'")
            if cursor.fetchone():
                print(f"  ⚠️  Model '{short_name}' already exists, skipping")
                continue

            # Insert the new model
            cursor.execute(f"""
                INSERT INTO models
                (model_name, display_name, company_id, tier_id, framework_type, is_active)
                VALUES
                ('{model_name}', '{display_name}', {company_id}, {tier_id}, 'inspect', 1)
            """)

            model_id = cursor.lastrowid
            print(f"  ✅ Created model '{short_name}' (ID: {model_id})")

            # Add standard reasoning args for all models
            print(f"    Adding reasoning_args for {short_name}...")

            cursor.execute(f"""
                INSERT INTO reasoning_args
                (model_id, arg_name, arg_value, created_at, updated_at)
                VALUES
                ({model_id}, 'max_tokens', '100000', datetime('now'), datetime('now'))
            """)
            print(f"      ✅ Added max_tokens=100000")

        print("✅ Fireworks AI models added successfully!")
        print("\nNext steps:")
        print("  1. Ensure FIREWORKS_API_KEY is set in .env file")
        print("  2. Run: python manage.py populate_model_queue --model <model-name>")
        print("     Available models:")
        for model in models_to_add:
            print(f"       - {model['model_name']}")


def reverse_add_fireworks_models(apps, schema_editor):
    """Remove Fireworks AI models and company from the database."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Removing Fireworks AI models...")

        # Delete the models (CASCADE will handle reasoning_args automatically)
        models_to_remove = [
            'fireworks/accounts/fireworks/models/deepseek-v3p1-terminus',
            'fireworks/accounts/fireworks/models/gpt-oss-120b',
            'fireworks/accounts/fireworks/models/qwen3-235b-a22b'
        ]

        for model_name in models_to_remove:
            cursor.execute(f"DELETE FROM models WHERE model_name = '{model_name}'")
            if cursor.rowcount > 0:
                print(f"  ✅ Removed model '{model_name}'")
            else:
                print(f"  ⚠️  Model '{model_name}' not found")

        # Delete the Fireworks company
        cursor.execute("DELETE FROM companies WHERE company_name = 'fireworks'")
        if cursor.rowcount > 0:
            print("  ✅ Removed company 'fireworks'")
        else:
            print("  ⚠️  Company 'fireworks' not found")

        print("✅ Fireworks AI cleanup complete!")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0016_add_gpt_5_pro'),
    ]

    operations = [
        migrations.RunPython(
            add_fireworks_models,
            reverse_add_fireworks_models,
        ),
    ]
