"""
Add admin_override column to model_subquestion_answers table.

This migration adds an admin override mechanism for subquestion correctness,
allowing admins to manually override the automatic evaluation result when
parsing failures occur.
"""

from django.db import migrations


def add_admin_override_column(apps, schema_editor):
    """Add admin_override column to model_subquestion_answers table."""
    db = schema_editor.connection
    cursor = db.cursor()
    
    print("Adding admin_override column to model_subquestion_answers table...")
    
    # Check if the column already exists
    cursor.execute("PRAGMA table_info(model_subquestion_answers)")
    columns = [col[1] for col in cursor.fetchall()]
    
    if 'admin_override' not in columns:
        # Add admin_override column 
        # Can be 0 (admin set to false), 1 (admin set to true), or null (not set by admin)
        cursor.execute("""
            ALTER TABLE model_subquestion_answers 
            ADD COLUMN admin_override INTEGER DEFAULT NULL
                CHECK (admin_override IS NULL OR admin_override IN (0, 1))
        """)
        print("  - Added admin_override column successfully")
    else:
        print("  - admin_override column already exists, skipping")
    
    # Create an index on the admin_override column for efficient queries
    cursor.execute("""
        CREATE INDEX IF NOT EXISTS idx_model_subquestion_answers_override 
        ON model_subquestion_answers(admin_override)
        WHERE admin_override IS NOT NULL
    """)
    print("  - Created index on admin_override column")


def remove_admin_override_column(apps, schema_editor):
    """Reverse migration - removes admin_override column."""
    db = schema_editor.connection
    cursor = db.cursor()
    
    print("Removing admin_override column from model_subquestion_answers table...")
    
    # SQLite doesn't support dropping columns directly, so we need to recreate the table
    # First, check if the column exists
    cursor.execute("PRAGMA table_info(model_subquestion_answers)")
    columns = cursor.fetchall()
    column_names = [col[1] for col in columns]
    
    if 'admin_override' in column_names:
        # Create a new table without the admin_override column
        cursor.execute("""
            CREATE TABLE model_subquestion_answers_new (
                id INTEGER PRIMARY KEY AUTOINCREMENT,
                attempt_id INTEGER REFERENCES model_attempts(id) ON DELETE CASCADE,
                subquestion_id INTEGER REFERENCES subquestions(id) ON DELETE CASCADE,
                model_id INTEGER REFERENCES models(id) ON DELETE CASCADE,
                answer TEXT,
                is_correct INTEGER,
                creation_time DATETIME,
                last_modified DATETIME
            )
        """)
        
        # Copy data from old table to new table (excluding admin_override)
        cursor.execute("""
            INSERT INTO model_subquestion_answers_new 
                (id, attempt_id, subquestion_id, model_id, answer, is_correct, creation_time, last_modified)
            SELECT id, attempt_id, subquestion_id, model_id, answer, is_correct, creation_time, last_modified
            FROM model_subquestion_answers
        """)
        
        # Drop the old table
        cursor.execute("DROP TABLE model_subquestion_answers")
        
        # Rename new table to original name
        cursor.execute("ALTER TABLE model_subquestion_answers_new RENAME TO model_subquestion_answers")
        
        # Recreate indexes
        cursor.execute("""
            CREATE INDEX IF NOT EXISTS idx_model_subquestion_answers_attempt 
            ON model_subquestion_answers(attempt_id)
        """)
        
        print("  - Removed admin_override column successfully")
    else:
        print("  - admin_override column doesn't exist, skipping")


class Migration(migrations.Migration):
    
    dependencies = [
        ('model_evaluation', '0005_fix_grading_consolidation'),
    ]
    
    operations = [
        migrations.RunPython(
            add_admin_override_column,
            remove_admin_override_column
        ),
    ]