# Generated by Django 4.2.7 on 2025-09-14 20:10 from django.conf import settings import django.contrib.auth.models import django.contrib.auth.validators from django.db import migrations, models import django.db.models.deletion import django.utils.timezone class Migration(migrations.Migration): initial = True dependencies = [ ('auth', '0012_alter_user_first_name_max_length'), ] operations = [ migrations.CreateModel( name='User', fields=[ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('password', models.CharField(max_length=128, verbose_name='password')), ('last_login', models.DateTimeField(blank=True, null=True, verbose_name='last login')), ('is_superuser', models.BooleanField(default=False, help_text='Designates that this user has all permissions without explicitly assigning them.', verbose_name='superuser status')), ('username', models.CharField(error_messages={'unique': 'A user with that username already exists.'}, help_text='Required. 150 characters or fewer. Letters, digits and @/./+/-/_ only.', max_length=150, unique=True, validators=[django.contrib.auth.validators.UnicodeUsernameValidator()], verbose_name='username')), ('is_staff', models.BooleanField(default=False, help_text='Designates whether the user can log into this admin site.', verbose_name='staff status')), ('is_active', models.BooleanField(default=True, help_text='Designates whether this user should be treated as active. Unselect this instead of deleting accounts.', verbose_name='active')), ('date_joined', models.DateTimeField(default=django.utils.timezone.now, verbose_name='date joined')), ('email', models.EmailField(max_length=254, unique=True)), ('first_name', models.CharField(max_length=30)), ('last_name', models.CharField(max_length=30)), ('avatar', models.ImageField(blank=True, null=True, upload_to='avatars/')), ('is_verified', models.BooleanField(default=False)), ('created_at', models.DateTimeField(auto_now_add=True)), ('updated_at', models.DateTimeField(auto_now=True)), ('last_login_ip', models.GenericIPAddressField(blank=True, null=True)), ('smtp_host', models.CharField(blank=True, max_length=255)), ('smtp_port', models.IntegerField(default=587)), ('smtp_username', models.CharField(blank=True, max_length=255)), ('smtp_password', models.BinaryField(blank=True)), ('smtp_use_tls', models.BooleanField(default=True)), ('imap_host', models.CharField(blank=True, max_length=255)), ('imap_port', models.IntegerField(default=993)), ('imap_username', models.CharField(blank=True, max_length=255)), ('imap_password', models.BinaryField(blank=True)), ('imap_use_ssl', models.BooleanField(default=True)), ('groups', models.ManyToManyField(blank=True, help_text='The groups this user belongs to. A user will get all permissions granted to each of their groups.', related_name='user_set', related_query_name='user', to='auth.group', verbose_name='groups')), ('user_permissions', models.ManyToManyField(blank=True, help_text='Specific permissions for this user.', related_name='user_set', related_query_name='user', to='auth.permission', verbose_name='user permissions')), ], options={ 'db_table': 'users', }, managers=[ ('objects', django.contrib.auth.models.UserManager()), ], ), migrations.CreateModel( name='UserProfile', fields=[ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('signature', models.TextField(blank=True)), ('auto_reply_enabled', models.BooleanField(default=False)), ('auto_reply_message', models.TextField(blank=True)), ('timezone', models.CharField(default='UTC', max_length=50)), ('language', models.CharField(default='en', max_length=10)), ('theme', models.CharField(default='light', max_length=20)), ('emails_per_page', models.IntegerField(default=20)), ('auto_save_drafts', models.BooleanField(default=True)), ('show_images', models.BooleanField(default=True)), ('mark_as_read_delay', models.IntegerField(default=3)), ('created_at', models.DateTimeField(auto_now_add=True)), ('updated_at', models.DateTimeField(auto_now=True)), ('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='profile', to=settings.AUTH_USER_MODEL)), ], options={ 'db_table': 'user_profiles', }, ), migrations.CreateModel( name='LoginAttempt', fields=[ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('email', models.EmailField(max_length=254)), ('ip_address', models.GenericIPAddressField()), ('user_agent', models.TextField()), ('success', models.BooleanField(default=False)), ('failure_reason', models.CharField(blank=True, max_length=100)), ('timestamp', models.DateTimeField(auto_now_add=True)), ('user', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)), ], options={ 'db_table': 'login_attempts', 'ordering': ['-timestamp'], }, ), migrations.CreateModel( name='EmailVerification', fields=[ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('token', models.CharField(max_length=100, unique=True)), ('created_at', models.DateTimeField(auto_now_add=True)), ('expires_at', models.DateTimeField()), ('is_used', models.BooleanField(default=False)), ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)), ], options={ 'db_table': 'email_verifications', }, ), ]