"""
Add published and release_date fields

This migration adds:
1. Question.published - DateField tracking when question was made public (NULL = unpublished)
2. Model.release_date - DateField tracking when model was released (NULL = TBD/TODO)

Publishing questions is irreversible - once published, questions:
- Become visible to all logged-in users
- Are excluded from benchmark results/leaderboard
- Model answers from models released after publication date are not graded

Model release dates are populated for all existing models.
"""

from django.db import migrations


def add_published_and_release_date_fields(apps, schema_editor):
    """Add published field to questions table and release_date to models table."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Adding new fields...")

        # Add published field to questions table
        print("  Adding 'published' field to questions table...")
        cursor.execute("""
            ALTER TABLE questions
            ADD COLUMN published DATE DEFAULT NULL
        """)
        print("    ✅ Added questions.published (NULL = unpublished)")

        # Add release_date field to models table
        print("  Adding 'release_date' field to models table...")
        cursor.execute("""
            ALTER TABLE models
            ADD COLUMN release_date DATE DEFAULT NULL
        """)
        print("    ✅ Added models.release_date")

        # Populate release dates for all models
        print("  Populating model release dates...")

        release_dates = {
            'gpt-4o-2024-11-20': '2024-11-20',
            'grok-3': '2025-02-17',
            'o3-2025-04-16': '2025-04-16',
            'o4-mini-2025-04-16': '2025-04-16',
            'accounts/fireworks/models/qwen3-235b-a22b': '2025-05-06',
            'claude-sonnet-4-20250514': '2025-05-22',
            'gemini-2.5-pro': '2025-06-17',
            'gemini-2.5-flash': '2025-06-17',
            'grok-4': '2025-07-09',
            'grok-4-0709': '2025-07-09',
            'accounts/fireworks/models/gpt-oss-120b': '2025-08-05',
            'claude-opus-4-1-20250805': '2025-08-05',
            'gpt-5': '2025-08-07',
            'gpt-5-pro': '2025-08-07',
            'grok-4-fast-reasoning': '2025-09-19',
            'accounts/fireworks/models/deepseek-v3p1-terminus': '2025-09-22',
            'accounts/fireworks/models/kimi-k2-thinking': '2025-11-06',
            'gpt-5.1': '2025-11-12',
            'gemini-3-pro-preview': '2025-11-18',
        }

        updated_count = 0
        for model_name, release_date in release_dates.items():
            cursor.execute(f"""
                UPDATE models
                SET release_date = '{release_date}'
                WHERE model_name = '{model_name}'
            """)
            if cursor.rowcount > 0:
                updated_count += 1

        print(f"    ✅ Updated release dates for {updated_count} models")
        print("✅ Fields added successfully!")


def reverse_add_published_and_release_date_fields(apps, schema_editor):
    """Remove published and release_date fields."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Removing fields...")

        # Remove published field from questions table
        cursor.execute("""
            ALTER TABLE questions
            DROP COLUMN published
        """)
        print("  ✅ Removed questions.published")

        # Remove release_date field from models table
        cursor.execute("""
            ALTER TABLE models
            DROP COLUMN release_date
        """)
        print("  ✅ Removed models.release_date")

        print("✅ Fields removed successfully!")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0026_add_gemini_3_pro_preview'),
    ]

    operations = [
        migrations.RunSQL(
            sql="""
                ALTER TABLE questions ADD COLUMN published DATE DEFAULT NULL;
                ALTER TABLE models ADD COLUMN release_date DATE DEFAULT NULL;

                -- Populate release dates for all models
                UPDATE models SET release_date = '2024-11-20' WHERE model_name = 'gpt-4o-2024-11-20';
                UPDATE models SET release_date = '2025-02-17' WHERE model_name = 'grok-3';
                UPDATE models SET release_date = '2025-04-16' WHERE model_name = 'o3-2025-04-16';
                UPDATE models SET release_date = '2025-04-16' WHERE model_name = 'o4-mini-2025-04-16';
                UPDATE models SET release_date = '2025-05-06' WHERE model_name = 'accounts/fireworks/models/qwen3-235b-a22b';
                UPDATE models SET release_date = '2025-05-22' WHERE model_name = 'claude-sonnet-4-20250514';
                UPDATE models SET release_date = '2025-06-17' WHERE model_name = 'gemini-2.5-pro';
                UPDATE models SET release_date = '2025-06-17' WHERE model_name = 'gemini-2.5-flash';
                UPDATE models SET release_date = '2025-07-09' WHERE model_name = 'grok-4';
                UPDATE models SET release_date = '2025-07-09' WHERE model_name = 'grok-4-0709';
                UPDATE models SET release_date = '2025-08-05' WHERE model_name = 'accounts/fireworks/models/gpt-oss-120b';
                UPDATE models SET release_date = '2025-08-05' WHERE model_name = 'claude-opus-4-1-20250805';
                UPDATE models SET release_date = '2025-08-07' WHERE model_name = 'gpt-5';
                UPDATE models SET release_date = '2025-08-07' WHERE model_name = 'gpt-5-pro';
                UPDATE models SET release_date = '2025-09-19' WHERE model_name = 'grok-4-fast-reasoning';
                UPDATE models SET release_date = '2025-09-22' WHERE model_name = 'accounts/fireworks/models/deepseek-v3p1-terminus';
                UPDATE models SET release_date = '2025-11-06' WHERE model_name = 'accounts/fireworks/models/kimi-k2-thinking';
                UPDATE models SET release_date = '2025-11-12' WHERE model_name = 'gpt-5.1';
                UPDATE models SET release_date = '2025-11-18' WHERE model_name = 'gemini-3-pro-preview';
            """,
            reverse_sql="""
                ALTER TABLE questions DROP COLUMN published;
                ALTER TABLE models DROP COLUMN release_date;
            """,
        ),
    ]
