# Generated migration for Phase 3: Multi-session grading support
# This migration drops the UNIQUE(question_id, grader_id) constraint from model_grading_sessions
# to allow multiple independent grading sessions per grader per question.

from django.db import migrations


def drop_unique_constraint(apps, schema_editor):
    """
    Drop the UNIQUE constraint on (question_id, grader_id) from model_grading_sessions.

    This enables multiple parallel grading sessions, where each "Release for Grading"
    action creates a new independent session with alphabetically-continuing aliases.

    Example workflow:
    - Session 1: Released answers get aliases A-E (can be finalized independently)
    - Session 2: Later released answers get aliases F-G-H (separate session)
    """
    from django.db import connection

    with connection.cursor() as cursor:
        # SQLite doesn't support DROP CONSTRAINT directly, so we need to recreate the table

        # Step 1: Create new table without the UNIQUE constraint
        cursor.execute("""
            CREATE TABLE model_grading_sessions_new (
                id INTEGER PRIMARY KEY AUTOINCREMENT,
                question_id INTEGER NOT NULL REFERENCES questions(id),
                grader_id INTEGER NOT NULL REFERENCES accounts_customuser(id),
                session_status TEXT DEFAULT 'active',
                created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
                finalized_at DATETIME,
                grader_notes TEXT
            )
        """)

        # Step 2: Copy all existing data
        cursor.execute("""
            INSERT INTO model_grading_sessions_new
                (id, question_id, grader_id, session_status, created_at, finalized_at, grader_notes)
            SELECT id, question_id, grader_id, session_status, created_at, finalized_at, grader_notes
            FROM model_grading_sessions
        """)

        # Step 3: Drop old table
        cursor.execute("DROP TABLE model_grading_sessions")

        # Step 4: Rename new table to original name
        cursor.execute("ALTER TABLE model_grading_sessions_new RENAME TO model_grading_sessions")

        # Step 5: Recreate indices for foreign keys
        cursor.execute("""
            CREATE INDEX idx_model_grading_sessions_question
            ON model_grading_sessions(question_id)
        """)
        cursor.execute("""
            CREATE INDEX idx_model_grading_sessions_grader
            ON model_grading_sessions(grader_id)
        """)


def restore_unique_constraint(apps, schema_editor):
    """
    Reverse migration: restore the UNIQUE constraint.

    WARNING: This will fail if multiple sessions exist for any grader/question pair.
    Manual cleanup would be required before running this reverse migration.
    """
    from django.db import connection

    with connection.cursor() as cursor:
        # Recreate table with UNIQUE constraint
        cursor.execute("""
            CREATE TABLE model_grading_sessions_new (
                id INTEGER PRIMARY KEY AUTOINCREMENT,
                question_id INTEGER NOT NULL REFERENCES questions(id),
                grader_id INTEGER NOT NULL REFERENCES accounts_customuser(id),
                session_status TEXT DEFAULT 'active',
                created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
                finalized_at DATETIME,
                grader_notes TEXT,
                UNIQUE(question_id, grader_id)
            )
        """)

        # Try to copy data back (will fail if duplicates exist)
        cursor.execute("""
            INSERT INTO model_grading_sessions_new
                (id, question_id, grader_id, session_status, created_at, finalized_at, grader_notes)
            SELECT id, question_id, grader_id, session_status, created_at, finalized_at, grader_notes
            FROM model_grading_sessions
        """)

        # Drop old table and rename
        cursor.execute("DROP TABLE model_grading_sessions")
        cursor.execute("ALTER TABLE model_grading_sessions_new RENAME TO model_grading_sessions")

        # Recreate indices
        cursor.execute("""
            CREATE INDEX idx_model_grading_sessions_question
            ON model_grading_sessions(question_id)
        """)
        cursor.execute("""
            CREATE INDEX idx_model_grading_sessions_grader
            ON model_grading_sessions(grader_id)
        """)


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0014_add_grok_4_fast_reasoning'),
    ]

    operations = [
        migrations.RunPython(drop_unique_constraint, restore_unique_constraint),
    ]
