# Generated by Django 4.2.30 on 2026-06-11 01:24

from django.db import migrations, models


class Migration(migrations.Migration):

    initial = True

    dependencies = [
    ]

    operations = [
        migrations.CreateModel(
            name='AuditLog',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('created_at', models.DateTimeField(auto_now_add=True, help_text='Fecha y hora de creación del registro (UTC)', verbose_name='Creado en')),
                ('updated_at', models.DateTimeField(auto_now=True, help_text='Fecha y hora de la última modificación (UTC)', verbose_name='Modificado en')),
                ('accion', models.CharField(choices=[('LOGIN_OK', 'Login exitoso'), ('LOGIN_FALLIDO', 'Login fallido'), ('LOGOUT', 'Logout'), ('REGISTRO_DOCENTE', 'Registro docente'), ('REGISTRO_ALUMNO', 'Registro alumno'), ('DOCENTE_APROBADO', 'Docente aprobado'), ('DOCENTE_RECHAZADO', 'Docente rechazado'), ('SESION_ABIERTA', 'Sesión abierta'), ('SESION_CERRADA', 'Sesión cerrada'), ('PREGUNTA_ACTIVADA', 'Pregunta activada'), ('RESPUESTA_ENVIADA', 'Respuesta enviada'), ('RESPUESTA_SOSPECHOSA', 'Respuesta sospechosa'), ('CODIGO_GENERADO', 'Código generado'), ('TOKEN_GENERADO', 'Token de registro generado'), ('TOKEN_USADO', 'Token de registro usado'), ('CANJE_FICHA', 'Canje de ficha'), ('NOTA_ASIGNADA', 'Nota asignada'), ('AJUSTE_FICHAS', 'Ajuste manual de fichas'), ('IP_BLOQUEADA', 'IP bloqueada')], db_index=True, max_length=25)),
                ('ip', models.GenericIPAddressField(blank=True, null=True, verbose_name='IP de origen')),
                ('detalle', models.TextField(blank=True, verbose_name='Detalle adicional')),
                ('user_agent', models.CharField(blank=True, max_length=500)),
                ('endpoint', models.CharField(blank=True, max_length=200)),
            ],
            options={
                'verbose_name': 'Log de auditoría',
                'verbose_name_plural': 'Logs de auditoría',
                'db_table': 'security_auditlog',
                'ordering': [],
                'abstract': False,
            },
        ),
        migrations.CreateModel(
            name='IPBlocklist',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('created_at', models.DateTimeField(auto_now_add=True, help_text='Fecha y hora de creación del registro (UTC)', verbose_name='Creado en')),
                ('updated_at', models.DateTimeField(auto_now=True, help_text='Fecha y hora de la última modificación (UTC)', verbose_name='Modificado en')),
                ('ip', models.GenericIPAddressField(unique=True)),
                ('motivo', models.CharField(max_length=200)),
                ('bloqueada_hasta', models.DateTimeField()),
                ('intentos', models.PositiveSmallIntegerField(default=0)),
            ],
            options={
                'verbose_name': 'IP bloqueada',
                'db_table': 'security_ipblocklist',
                'ordering': ['-created_at'],
                'abstract': False,
            },
        ),
    ]
