Store event_id in OrderSyncQueue, always fill not_before, log unhandled exceptions

This commit is contained in:
Mira Weller
2025-05-07 15:41:41 +02:00
parent 114304855f
commit 922d3cd629
6 changed files with 56 additions and 35 deletions

View File

@@ -1,4 +1,4 @@
# Generated by Django 4.2.16 on 2025-04-01 14:52
# Generated by Django 4.2.16 on 2025-05-07 13:01
import django.db.models.deletion
from django.db import migrations, models
@@ -11,33 +11,6 @@ class Migration(migrations.Migration):
]
operations = [
migrations.CreateModel(
name="OrderSyncQueue",
fields=[
(
"id",
models.BigAutoField(
auto_created=True, primary_key=True, serialize=False
),
),
("sync_provider", models.CharField(max_length=128)),
("triggered_by", models.CharField(max_length=128)),
("triggered", models.DateTimeField(auto_now_add=True)),
("failed_attempts", models.PositiveIntegerField(default=0)),
("not_before", models.DateTimeField(blank=True, null=True)),
(
"order",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="queued_sync_jobs",
to="pretixbase.order",
),
),
],
options={
"unique_together": {("order", "sync_provider")},
},
),
migrations.CreateModel(
name="OrderSyncResult",
fields=[
@@ -79,9 +52,45 @@ class Migration(migrations.Migration):
"indexes": [
models.Index(
fields=["order", "sync_provider"],
name="pretixbase__order_i_23d278_idx",
name="pretixbase__order_i_3e3c84_idx",
)
],
},
),
migrations.CreateModel(
name="OrderSyncQueue",
fields=[
(
"id",
models.BigAutoField(
auto_created=True, primary_key=True, serialize=False
),
),
("sync_provider", models.CharField(max_length=128)),
("triggered_by", models.CharField(max_length=128)),
("triggered", models.DateTimeField(auto_now_add=True)),
("failed_attempts", models.PositiveIntegerField(default=0)),
("not_before", models.DateTimeField(db_index=True)),
(
"event",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="queued_sync_jobs",
to="pretixbase.event",
),
),
(
"order",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="queued_sync_jobs",
to="pretixbase.order",
),
),
],
options={
"ordering": ("triggered",),
"unique_together": {("order", "sync_provider")},
},
),
]