# Generated by Django 4.2.7 on 2026-02-05 12:54

from django.conf import settings
from django.db import migrations, models
import django.db.models.deletion


class Migration(migrations.Migration):

    dependencies = [
        ("products", "0009_product_available_from_alter_product_status"),
        migrations.swappable_dependency(settings.AUTH_USER_MODEL),
        ("accounts", "0009_vendorprofile_total_menus_and_more"),
        ("payments", "0005_vendorsubscription_plan_type"),
    ]

    operations = [
        migrations.CreateModel(
            name="MpesaLinkingRequest",
            fields=[
                (
                    "id",
                    models.BigAutoField(
                        auto_created=True,
                        primary_key=True,
                        serialize=False,
                        verbose_name="ID",
                    ),
                ),
                (
                    "account_type",
                    models.CharField(
                        choices=[("paybill", "Paybill"), ("till", "Till Number")],
                        max_length=10,
                    ),
                ),
                ("business_short_code", models.CharField(max_length=20)),
                ("_consumer_key_encrypted", models.BinaryField()),
                ("_consumer_secret_encrypted", models.BinaryField()),
                ("_passkey_encrypted", models.BinaryField()),
                (
                    "status",
                    models.CharField(
                        choices=[
                            ("pending", "Pending"),
                            ("approved", "Approved"),
                            ("rejected", "Rejected"),
                        ],
                        default="pending",
                        max_length=20,
                    ),
                ),
                ("rejection_reason", models.TextField(blank=True, null=True)),
                ("reviewed_at", models.DateTimeField(blank=True, null=True)),
                ("created_at", models.DateTimeField(auto_now_add=True)),
                ("updated_at", models.DateTimeField(auto_now=True)),
                (
                    "reviewed_by",
                    models.ForeignKey(
                        blank=True,
                        null=True,
                        on_delete=django.db.models.deletion.SET_NULL,
                        related_name="reviewed_mpesa_requests",
                        to=settings.AUTH_USER_MODEL,
                    ),
                ),
                (
                    "vendor",
                    models.ForeignKey(
                        on_delete=django.db.models.deletion.CASCADE,
                        related_name="mpesa_linking_requests",
                        to="accounts.vendorprofile",
                    ),
                ),
            ],
            options={
                "db_table": "mpesa_linking_requests",
                "ordering": ["-created_at"],
            },
        ),
        migrations.CreateModel(
            name="VendorMpesaCredentials",
            fields=[
                (
                    "id",
                    models.BigAutoField(
                        auto_created=True,
                        primary_key=True,
                        serialize=False,
                        verbose_name="ID",
                    ),
                ),
                (
                    "account_type",
                    models.CharField(
                        choices=[("paybill", "Paybill"), ("till", "Till Number")],
                        max_length=10,
                    ),
                ),
                ("business_short_code", models.CharField(max_length=20)),
                ("_consumer_key_encrypted", models.BinaryField()),
                ("_consumer_secret_encrypted", models.BinaryField()),
                ("_passkey_encrypted", models.BinaryField()),
                ("is_active", models.BooleanField(default=True)),
                ("created_at", models.DateTimeField(auto_now_add=True)),
                ("updated_at", models.DateTimeField(auto_now=True)),
                (
                    "linking_request",
                    models.OneToOneField(
                        null=True,
                        on_delete=django.db.models.deletion.SET_NULL,
                        related_name="active_credentials",
                        to="payments.mpesalinkingrequest",
                    ),
                ),
                (
                    "vendor",
                    models.OneToOneField(
                        on_delete=django.db.models.deletion.CASCADE,
                        related_name="mpesa_credentials",
                        to="accounts.vendorprofile",
                    ),
                ),
            ],
            options={
                "db_table": "vendor_mpesa_credentials",
            },
        ),
        migrations.CreateModel(
            name="MpesaPayment",
            fields=[
                (
                    "id",
                    models.BigAutoField(
                        auto_created=True,
                        primary_key=True,
                        serialize=False,
                        verbose_name="ID",
                    ),
                ),
                ("amount", models.DecimalField(decimal_places=2, max_digits=10)),
                ("phone_number", models.CharField(max_length=15)),
                ("account_reference", models.CharField(max_length=50)),
                ("transaction_desc", models.CharField(max_length=200)),
                (
                    "merchant_request_id",
                    models.CharField(blank=True, max_length=100, null=True),
                ),
                (
                    "checkout_request_id",
                    models.CharField(
                        blank=True, db_index=True, max_length=100, null=True
                    ),
                ),
                (
                    "mpesa_receipt_number",
                    models.CharField(
                        blank=True, db_index=True, max_length=50, null=True
                    ),
                ),
                (
                    "status",
                    models.CharField(
                        choices=[
                            ("pending", "Pending"),
                            ("processing", "Processing"),
                            ("completed", "Completed"),
                            ("failed", "Failed"),
                            ("cancelled", "Cancelled"),
                            ("timeout", "Timeout"),
                        ],
                        default="pending",
                        max_length=20,
                    ),
                ),
                ("result_code", models.CharField(blank=True, max_length=10, null=True)),
                ("result_desc", models.TextField(blank=True, null=True)),
                ("callback_data", models.JSONField(blank=True, null=True)),
                ("created_at", models.DateTimeField(auto_now_add=True, db_index=True)),
                ("updated_at", models.DateTimeField(auto_now=True)),
                ("completed_at", models.DateTimeField(blank=True, null=True)),
                (
                    "buyer",
                    models.ForeignKey(
                        null=True,
                        on_delete=django.db.models.deletion.SET_NULL,
                        related_name="mpesa_payments_made",
                        to=settings.AUTH_USER_MODEL,
                    ),
                ),
                (
                    "product",
                    models.ForeignKey(
                        null=True,
                        on_delete=django.db.models.deletion.SET_NULL,
                        related_name="mpesa_payments",
                        to="products.product",
                    ),
                ),
                (
                    "vendor",
                    models.ForeignKey(
                        on_delete=django.db.models.deletion.CASCADE,
                        related_name="mpesa_payments_received",
                        to="accounts.vendorprofile",
                    ),
                ),
            ],
            options={
                "db_table": "mpesa_payments",
                "ordering": ["-created_at"],
                "indexes": [
                    models.Index(
                        fields=["vendor", "status"],
                        name="mpesa_payme_vendor__7ad565_idx",
                    ),
                    models.Index(
                        fields=["buyer", "status"],
                        name="mpesa_payme_buyer_i_0637d1_idx",
                    ),
                    models.Index(
                        fields=["status", "created_at"],
                        name="mpesa_payme_status_733d12_idx",
                    ),
                ],
            },
        ),
    ]
