# Generated by Django 5.2.5 on 2025-11-05 06:43

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


class Migration(migrations.Migration):

    initial = True

    dependencies = [
    ]

    operations = [
        migrations.CreateModel(
            name='AppVersion',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('createdAt', models.DateTimeField(auto_now_add=True)),
                ('updatedAt', models.DateTimeField(auto_now=True)),
                ('versionCode', models.CharField(max_length=50)),
                ('deviceType', models.CharField(choices=[('Android', 'Android'), ('IOS', 'Ios'), ('Other', 'Other')], max_length=10)),
                ('deletedAt', models.DateTimeField(blank=True, null=True)),
            ],
            options={
                'abstract': False,
            },
        ),
        migrations.CreateModel(
            name='Category',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('description', models.TextField()),
                ('image', models.ImageField(upload_to='category/')),
            ],
        ),
        migrations.CreateModel(
            name='Device',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('createdAt', models.DateTimeField(auto_now_add=True)),
                ('updatedAt', models.DateTimeField(auto_now=True)),
                ('deviceToken', models.CharField(max_length=256)),
                ('deviceType', models.CharField(choices=[('Android', 'Android'), ('IOS', 'Ios'), ('Other', 'Other')], max_length=10)),
                ('isSubscription', models.BooleanField(default=False)),
                ('expireAt', models.DateTimeField(blank=True, null=True)),
                ('lastPurchaseToken', models.CharField(blank=True, max_length=256, null=True)),
                ('originalTransactionId', models.TextField(blank=True, null=True)),
                ('appleTransactionId', models.TextField(blank=True, null=True)),
                ('productId', models.CharField(blank=True, max_length=256, null=True)),
            ],
            options={
                'abstract': False,
            },
        ),
        migrations.CreateModel(
            name='Plan',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('createdAt', models.DateTimeField(auto_now_add=True)),
                ('updatedAt', models.DateTimeField(auto_now=True)),
                ('name', models.CharField(max_length=99)),
                ('price', models.DecimalField(decimal_places=2, default=0, max_digits=5)),
                ('description', models.JSONField(default=list)),
                ('unlockCategory', models.IntegerField(default=0)),
                ('type', models.IntegerField(choices=[(1, 'Free Access'), (2, 'Basic Premium'), (3, 'Full Access')], default=1)),
                ('productId', models.CharField(max_length=100, unique=True)),
                ('period', models.CharField(blank=True, choices=[('FREE', 'Free'), ('YEAR', 'Year')], max_length=256, null=True)),
            ],
            options={
                'abstract': False,
            },
        ),
        migrations.CreateModel(
            name='Team',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('name', models.CharField(choices=[('Diaper Team', 'Diaper'), ('Dumpster Team', 'Dumpster')], max_length=20, unique=True)),
            ],
        ),
        migrations.CreateModel(
            name='Craptitude',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('roundNumber', models.PositiveIntegerField()),
                ('diaperPrefix', models.CharField(max_length=256)),
                ('dumpsterPrefix', models.CharField(max_length=256)),
                ('category', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.category')),
            ],
            options={
                'unique_together': {('category', 'roundNumber')},
            },
        ),
        migrations.CreateModel(
            name='AppleTransaction',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('createdAt', models.DateTimeField(auto_now_add=True)),
                ('updatedAt', models.DateTimeField(auto_now=True)),
                ('productId', models.CharField(max_length=255)),
                ('appleTransactionId', models.CharField(blank=True, max_length=255, null=True)),
                ('originalTransactionId', models.CharField(max_length=255)),
                ('webOrderLineItemId', models.CharField(blank=True, max_length=255, null=True)),
                ('appleReceipt', models.TextField(blank=True, null=True)),
                ('startAt', models.DateTimeField()),
                ('expireAt', models.DateTimeField()),
                ('environment', models.CharField(blank=True, max_length=50, null=True)),
                ('transactionReason', models.CharField(blank=True, max_length=50, null=True)),
                ('notificationType', models.CharField(blank=True, max_length=50, null=True)),
                ('device', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='api.device')),
            ],
            options={
                'abstract': False,
            },
        ),
        migrations.CreateModel(
            name='AndroidTransaction',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('createdAt', models.DateTimeField(auto_now_add=True)),
                ('updatedAt', models.DateTimeField(auto_now=True)),
                ('productId', models.CharField(max_length=255)),
                ('orderId', models.CharField(max_length=255)),
                ('purchaseToken', models.CharField(max_length=255)),
                ('notificationType', models.IntegerField()),
                ('startAt', models.DateTimeField()),
                ('expireAt', models.DateTimeField()),
                ('device', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.device')),
            ],
            options={
                'abstract': False,
            },
        ),
        migrations.CreateModel(
            name='GameSession',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('createdAt', models.DateTimeField(auto_now_add=True)),
                ('updatedAt', models.DateTimeField(auto_now=True)),
                ('category', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.category')),
                ('craptitude', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.craptitude')),
                ('device', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.device')),
            ],
            options={
                'abstract': False,
            },
        ),
        migrations.CreateModel(
            name='CraptitudeHistory',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('createdAt', models.DateTimeField(auto_now_add=True)),
                ('updatedAt', models.DateTimeField(auto_now=True)),
                ('levelCompleted', models.IntegerField(default=0)),
                ('session', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.gamesession')),
            ],
            options={
                'abstract': False,
            },
        ),
        migrations.CreateModel(
            name='Player',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('createdAt', models.DateTimeField(auto_now_add=True)),
                ('updatedAt', models.DateTimeField(auto_now=True)),
                ('name', models.CharField(max_length=256)),
                ('session', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.gamesession')),
                ('team', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.team')),
            ],
            options={
                'abstract': False,
            },
        ),
        migrations.CreateModel(
            name='Sentence',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('createdAt', models.DateTimeField(auto_now_add=True)),
                ('updatedAt', models.DateTimeField(auto_now=True)),
                ('text', models.TextField()),
                ('player', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.player')),
                ('session', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.gamesession')),
                ('team', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.team')),
            ],
            options={
                'abstract': False,
            },
        ),
        migrations.CreateModel(
            name='Rating',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('createdAt', models.DateTimeField(auto_now_add=True)),
                ('updatedAt', models.DateTimeField(auto_now=True)),
                ('diaperScore', models.PositiveIntegerField()),
                ('dumpsterScore', models.PositiveIntegerField()),
                ('session', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.gamesession')),
                ('sentence', models.ManyToManyField(to='api.sentence')),
            ],
            options={
                'abstract': False,
            },
        ),
        migrations.CreateModel(
            name='Transaction',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('createdAt', models.DateTimeField(auto_now_add=True)),
                ('updatedAt', models.DateTimeField(auto_now=True)),
                ('productId', models.CharField(max_length=50)),
                ('orderId', models.CharField(max_length=50)),
                ('originalTransactionId', models.TextField()),
                ('appleTransactionId', models.TextField()),
                ('purchaseToken', models.TextField()),
                ('amount', models.FloatField(default=0)),
                ('startAt', models.DateTimeField()),
                ('expireAt', models.DateTimeField(null=True)),
                ('notificationType', models.CharField(max_length=50)),
                ('device', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.device')),
                ('plan', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.plan')),
            ],
            options={
                'abstract': False,
            },
        ),
    ]
