# Migration to update CHECK constraint on models table to allow 'non-agentic'
from django.db import migrations


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0022_add_non_agentic_support'),
    ]

    operations = [
        migrations.RunSQL(
            # Update CHECK constraint on models table to allow 'non-agentic'
            # SQLite doesn't support ALTER TABLE ... DROP CONSTRAINT, so we need to recreate the table
            sql="""
            -- Create new table with updated constraint
            CREATE TABLE models_new(
                id INTEGER PRIMARY KEY AUTOINCREMENT,
                company_id INTEGER,
                model_name TEXT,
                instructions TEXT,
                tier_id INTEGER REFERENCES model_tiers(id),
                framework_type TEXT CHECK (framework_type IN ('inspect', 'cli', 'non-agentic')),
                is_active BOOLEAN DEFAULT 1,
                display_name TEXT,
                FOREIGN KEY(company_id) REFERENCES companies(id)
            );

            -- Copy data from old table
            INSERT INTO models_new SELECT * FROM models;

            -- Drop old table
            DROP TABLE models;

            -- Rename new table
            ALTER TABLE models_new RENAME TO models;
            """,
            reverse_sql="""
            -- Recreate table with original constraint (reverse migration)
            CREATE TABLE models_new(
                id INTEGER PRIMARY KEY AUTOINCREMENT,
                company_id INTEGER,
                model_name TEXT,
                instructions TEXT,
                tier_id INTEGER REFERENCES model_tiers(id),
                framework_type TEXT CHECK (framework_type IN ('inspect', 'cli')),
                is_active BOOLEAN DEFAULT 1,
                display_name TEXT,
                FOREIGN KEY(company_id) REFERENCES companies(id)
            );

            -- Copy data
            INSERT INTO models_new SELECT * FROM models;

            -- Drop old table
            DROP TABLE models;

            -- Rename new table
            ALTER TABLE models_new RENAME TO models;
            """
        ),
    ]
