prepare for new payments module
parent
775b96ae9f
commit
18ffc0af5f
@ -0,0 +1,99 @@
|
||||
# Generated by Django 3.2.4 on 2021-07-21 19:31
|
||||
|
||||
from datetime import timedelta
|
||||
from django.conf import settings
|
||||
from django.db import migrations, models
|
||||
import django.db.models.deletion
|
||||
import jsonfield.fields
|
||||
|
||||
def field_to_plan_id(model_name, field_name):
|
||||
def fun(apps, schema_editor):
|
||||
keys = settings.PLANS.keys()
|
||||
model = apps.get_model('payments', model_name)
|
||||
for s in model.objects.all():
|
||||
d = getattr(s, field_name)
|
||||
if s.plan_id is not None:
|
||||
continue
|
||||
s.plan_id = str(round(d / timedelta(days=30))) + 'm'
|
||||
if s.plan_id not in keys:
|
||||
raise Exception(f"unknown plan: {s.plan_id}")
|
||||
s.save()
|
||||
return fun
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
|
||||
('payments', '0007_auto_20201114_1730'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.RenameField("Subscription", 'period', 'plan_id'),
|
||||
|
||||
# Add plan_id to payments and convert from the time field
|
||||
migrations.AddField(
|
||||
model_name='payment',
|
||||
name='plan_id',
|
||||
field=models.CharField(choices=[('1m', 'Every 1 month'), ('3m', 'Every 3 months'), ('6m', 'Every 6 months'), ('12m', 'Every 12 months')], max_length=16, null=True),
|
||||
),
|
||||
migrations.RunPython(field_to_plan_id('Payment', 'time'), lambda x, y: ()),
|
||||
|
||||
# Make those two columns non-null once converted
|
||||
migrations.AlterField(
|
||||
model_name='payment',
|
||||
name='plan_id',
|
||||
field=models.CharField(choices=[('1m', 'Every 1 month'), ('3m', 'Every 3 months'), ('6m', 'Every 6 months'), ('12m', 'Every 12 months')], max_length=16),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='subscription',
|
||||
name='plan_id',
|
||||
field=models.CharField(choices=[('1m', 'Every 1 month'), ('3m', 'Every 3 months'), ('6m', 'Every 6 months'), ('12m', 'Every 12 months')], max_length=16),
|
||||
),
|
||||
|
||||
migrations.AddField(
|
||||
model_name='payment',
|
||||
name='ip_address',
|
||||
field=models.GenericIPAddressField(blank=True, null=True),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='payment',
|
||||
name='refund_date',
|
||||
field=models.DateTimeField(blank=True, null=True),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='payment',
|
||||
name='refund_text',
|
||||
field=models.CharField(blank=True, max_length=200),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='subscription',
|
||||
name='next_payment_date',
|
||||
field=models.DateTimeField(blank=True, null=True),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='payment',
|
||||
name='backend_data',
|
||||
field=jsonfield.fields.JSONField(blank=True),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='payment',
|
||||
name='backend_id',
|
||||
field=models.CharField(choices=[('bitcoin', 'Bitcoin'), ('paypal', 'PayPal'), ('stripe', 'Stripe')], max_length=16),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='payment',
|
||||
name='user',
|
||||
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='subscription',
|
||||
name='backend_data',
|
||||
field=jsonfield.fields.JSONField(blank=True),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='subscription',
|
||||
name='backend_id',
|
||||
field=models.CharField(choices=[('bitcoin', 'Bitcoin'), ('paypal', 'PayPal'), ('stripe', 'Stripe')], max_length=16),
|
||||
),
|
||||
]
|
Loading…
Reference in New Issue