# Generated by Django 5.2.5 on 2025-09-10 06:30

from django.db import migrations


def drop_deprecated_tables(apps, schema_editor):
    """
    Drop deprecated tables that are no longer used in the system.
    These tables are from old grading systems and other deprecated features.
    """
    with schema_editor.connection.cursor() as cursor:
        # List of tables to drop
        tables_to_drop = [
            'answer_reviews',        # Old grading system - references grading_schemes and model_answers
            'grading_steps',         # Old grading system - must drop before grading_schemes
            'grading_schemes',       # Old grading system - deprecated
            'model_answer_gradings', # Old grading system - empty
            'step_feedback',         # Related to old grading_steps - empty
            'terminal_logs',         # Old logging system - empty
        ]
        
        # Drop each table if it exists
        for table in tables_to_drop:
            try:
                cursor.execute(f"DROP TABLE IF EXISTS {table}")
                print(f"✓ Dropped table: {table}")
            except Exception as e:
                print(f"✗ Could not drop table {table}: {e}")


def recreate_deprecated_tables(apps, schema_editor):
    """
    Reverse migration: Recreate the dropped tables.
    Note: This won't restore the data, just the table structures.
    """
    with schema_editor.connection.cursor() as cursor:
        # Recreate tables with their original schemas
        sql_statements = [
            """CREATE TABLE IF NOT EXISTS grading_schemes(
                id integer primary key autoincrement,
                question_id integer, 
                title text,
                explanation text, 
                foreign key(question_id) references questions(id)
            )""",
            
            """CREATE TABLE IF NOT EXISTS grading_steps(
                id integer primary key autoincrement,
                grading_scheme integer,
                position integer,
                score integer,
                description text,
                foreign key(grading_scheme) references grading_schemes(id)
            )""",
            
            """CREATE TABLE IF NOT EXISTS answer_reviews(
                id integer primary key autoincrement,
                comment text, 
                grading_scheme integer, 
                reviewer integer, 
                answer_id integer, 
                time datetime not null default(current_timestamp), 
                foreign key(grading_scheme) references grading_schemes(id),
                foreign key(reviewer) references participants(id), 
                foreign key(answer_id) references model_answers(id)
            )""",
            
            """CREATE TABLE IF NOT EXISTS model_answer_gradings(
                id integer primary key autoincrement,
                model_answer_id integer,
                grader_id integer,
                grading_scheme_id integer,
                created_at datetime,
                foreign key(model_answer_id) references model_answers(id),
                foreign key(grader_id) references participants(id),
                foreign key(grading_scheme_id) references grading_schemes(id)
            )""",
            
            """CREATE TABLE IF NOT EXISTS step_feedback(
                id integer primary key autoincrement,
                grading_id integer,
                step_id integer,
                score integer,
                feedback text,
                foreign key(grading_id) references model_answer_gradings(id),
                foreign key(step_id) references grading_steps(id)
            )""",
            
            """CREATE TABLE IF NOT EXISTS terminal_logs(
                id integer primary key autoincrement,
                attempt_id integer,
                log_data text,
                created_at datetime,
                foreign key(attempt_id) references model_attempts(id)
            )"""
        ]
        
        for sql in sql_statements:
            try:
                cursor.execute(sql)
            except Exception as e:
                print(f"Warning during reverse migration: {e}")


class Migration(migrations.Migration):

    dependencies = [
        ('questions', '0006_add_benchmark_inclusion_field'),
    ]

    operations = [
        migrations.RunPython(
            drop_deprecated_tables,
            recreate_deprecated_tables,
            elidable=False
        ),
    ]
