# Align `businesses` and `users` with legacy INSERT column lists; rename PKs to business_id / user_id.

import django.db.models.deletion
from django.db import migrations, models
from django.db.models import F
from django.utils import timezone


def copy_business_name_from_name(apps, schema_editor):
    Business = apps.get_model("users", "Business")
    Business.objects.all().update(business_name=F("name"))


def set_businesses_autoincrement_mysql(apps, schema_editor):
    if schema_editor.connection.vendor != "mysql":
        return
    with schema_editor.connection.cursor() as cursor:
        cursor.execute("ALTER TABLE businesses AUTO_INCREMENT = 2000")


class Migration(migrations.Migration):

    dependencies = [
        ("users", "0002_businesses_users_mysql_schema"),
    ]

    operations = [
        migrations.RemoveConstraint(
            model_name="user",
            name="uq_users_business_username",
        ),
        migrations.AddField(
            model_name="business",
            name="business_name",
            field=models.CharField(max_length=255, null=True),
        ),
        migrations.RunPython(copy_business_name_from_name, migrations.RunPython.noop),
        migrations.RemoveField(
            model_name="business",
            name="name",
        ),
        migrations.AlterField(
            model_name="business",
            name="business_name",
            field=models.CharField(max_length=255, default=""),
            preserve_default=False,
        ),
        migrations.AddField(
            model_name="business",
            name="avail_min",
            field=models.IntegerField(blank=True, null=True),
        ),
        migrations.AddField(
            model_name="business",
            name="remain_min",
            field=models.IntegerField(blank=True, null=True),
        ),
        migrations.AddField(
            model_name="business",
            name="contact_name",
            field=models.CharField(blank=True, max_length=255),
        ),
        migrations.AddField(
            model_name="business",
            name="gst_no",
            field=models.CharField(blank=True, max_length=64),
        ),
        migrations.AddField(
            model_name="business",
            name="contact_number",
            field=models.CharField(blank=True, max_length=64),
        ),
        migrations.AddField(
            model_name="business",
            name="contact_email",
            field=models.CharField(blank=True, max_length=255),
        ),
        migrations.AddField(
            model_name="business",
            name="username",
            field=models.CharField(blank=True, max_length=150),
        ),
        migrations.AddField(
            model_name="business",
            name="password",
            field=models.CharField(blank=True, max_length=255),
        ),
        migrations.AddField(
            model_name="business",
            name="pan_no",
            field=models.CharField(blank=True, max_length=32),
        ),
        migrations.AddField(
            model_name="business",
            name="business_address",
            field=models.TextField(blank=True),
        ),
        migrations.AddField(
            model_name="business",
            name="status",
            field=models.CharField(blank=True, max_length=50),
        ),
        migrations.AddField(
            model_name="business",
            name="plans",
            field=models.TextField(blank=True),
        ),
        migrations.AddField(
            model_name="business",
            name="business_time",
            field=models.CharField(blank=True, max_length=255),
        ),
        migrations.AddField(
            model_name="business",
            name="retry_attempt",
            field=models.PositiveIntegerField(default=0),
        ),
        migrations.AddField(
            model_name="business",
            name="last_login",
            field=models.DateTimeField(blank=True, null=True),
        ),
        migrations.AddField(
            model_name="business",
            name="remember_token",
            field=models.CharField(blank=True, max_length=255, null=True),
        ),
        migrations.AddField(
            model_name="business",
            name="updated_at",
            field=models.DateTimeField(auto_now=True, default=timezone.now),
            preserve_default=False,
        ),
        migrations.AddField(
            model_name="business",
            name="mcube_bid",
            field=models.CharField(blank=True, max_length=255),
        ),
        migrations.AddField(
            model_name="business",
            name="mcube_agent_id",
            field=models.CharField(blank=True, max_length=255),
        ),
        migrations.AddField(
            model_name="business",
            name="auth_token",
            field=models.TextField(blank=True),
        ),
        migrations.RenameField(
            model_name="business",
            old_name="id",
            new_name="business_id",
        ),
        migrations.RunPython(set_businesses_autoincrement_mysql, migrations.RunPython.noop),
        migrations.AddField(
            model_name="user",
            name="name",
            field=models.CharField(blank=True, max_length=255),
        ),
        migrations.AddField(
            model_name="user",
            name="email",
            field=models.CharField(blank=True, max_length=255),
        ),
        migrations.AddField(
            model_name="user",
            name="email_verified_at",
            field=models.DateTimeField(blank=True, null=True),
        ),
        migrations.AddField(
            model_name="user",
            name="status",
            field=models.CharField(blank=True, max_length=50),
        ),
        migrations.AddField(
            model_name="user",
            name="agent_id",
            field=models.CharField(blank=True, max_length=255, null=True),
        ),
        migrations.AddField(
            model_name="user",
            name="remember_token",
            field=models.CharField(blank=True, max_length=255, null=True),
        ),
        migrations.AddField(
            model_name="user",
            name="updated_at",
            field=models.DateTimeField(auto_now=True, default=timezone.now),
            preserve_default=False,
        ),
        migrations.RenameField(
            model_name="user",
            old_name="id",
            new_name="user_id",
        ),
        migrations.RenameField(
            model_name="user",
            old_name="password_hash",
            new_name="password",
        ),
        migrations.AddConstraint(
            model_name="user",
            constraint=models.UniqueConstraint(
                fields=("business", "username"),
                name="uq_users_business_username",
            ),
        ),
        migrations.AlterField(
            model_name="business",
            name="business_id",
            field=models.BigAutoField(primary_key=True, serialize=False),
        ),
        migrations.AlterField(
            model_name="user",
            name="role",
            field=models.CharField(max_length=50),
        ),
        migrations.AlterField(
            model_name="user",
            name="user_id",
            field=models.BigAutoField(primary_key=True, serialize=False),
        ),
    ]
