From 53bdb301664ac56e266f735809998cd618b380d2 Mon Sep 17 00:00:00 2001 From: koalasat Date: Sat, 29 Jun 2024 17:09:04 +0200 Subject: [PATCH] Fix endpoint fields --- api/migrations/0048_alter_order_reference.py | 19 +++++++++++++++++++ api/serializers.py | 7 +++++++ api/views.py | 4 ---- docker-tests.yml | 14 +++++++------- docs/assets/schemas/api-latest.yaml | 5 +++++ 5 files changed, 38 insertions(+), 11 deletions(-) create mode 100644 api/migrations/0048_alter_order_reference.py diff --git a/api/migrations/0048_alter_order_reference.py b/api/migrations/0048_alter_order_reference.py new file mode 100644 index 00000000..cf8fa076 --- /dev/null +++ b/api/migrations/0048_alter_order_reference.py @@ -0,0 +1,19 @@ +# Generated by Django 5.0.6 on 2024-06-29 14:07 + +import api.models.order +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('api', '0047_notification'), + ] + + operations = [ + migrations.AlterField( + model_name='order', + name='reference', + field=models.UUIDField(default=api.models.order.custom_uuid, editable=False), + ), + ] diff --git a/api/serializers.py b/api/serializers.py index e5d77754..74cf125f 100644 --- a/api/serializers.py +++ b/api/serializers.py @@ -491,10 +491,17 @@ class OrderDetailSerializer(serializers.ModelSerializer): class ListNotificationSerializer(serializers.ModelSerializer): + status = serializers.SerializerMethodField( + help_text="The `status` of the order when the notification was trigered", + ) class Meta: model = Notification fields = ("title", "description", "order_id", "status") + def get_status(self, notification) -> int: + return notification.order.status + + class OrderPublicSerializer(serializers.ModelSerializer): maker_nick = serializers.CharField(required=False) diff --git a/api/views.py b/api/views.py index bd7ddd89..a03dbd33 100644 --- a/api/views.py +++ b/api/views.py @@ -761,11 +761,7 @@ class NotificationsView(ListAPIView): notification_data = [] for notification in queryset: data = self.serializer_class(notification).data - data["title"] = str(notification.title) - data["description"] = str(notification.description) data["order_id"] = notification.order.id - data["status"] = notification.order.status - notification_data.append(data) return Response(notification_data, status=status.HTTP_200_OK) diff --git a/docker-tests.yml b/docker-tests.yml index 0a4af45e..975747e8 100644 --- a/docker-tests.yml +++ b/docker-tests.yml @@ -15,7 +15,7 @@ version: '3.9' services: bitcoind: image: ruimarinho/bitcoin-core:${BITCOIND_VERSION:-24.0.1}-alpine - container_name: btc + container_name: test-btc restart: always ports: - "8000:8000" @@ -50,7 +50,7 @@ services: coordinator-LND: image: lightninglabs/lnd:${LND_VERSION:-v0.17.0-beta} - container_name: coordinator-LND + container_name: test-coordinator-LND restart: always volumes: - bitcoin:/root/.bitcoin/ @@ -83,7 +83,7 @@ services: coordinator-CLN: image: elementsproject/lightningd:${CLN_VERSION:-v24.05} restart: always - container_name: coordinator-CLN + container_name: test-coordinator-CLN environment: LIGHTNINGD_NETWORK: 'regtest' volumes: @@ -97,7 +97,7 @@ services: robot-LND: image: lightninglabs/lnd:${LND_VERSION:-v0.17.0-beta} - container_name: robot-LND + container_name: test-robot-LND restart: always volumes: - bitcoin:/root/.bitcoin/ @@ -129,7 +129,7 @@ services: redis: image: redis:${REDIS_VERSION:-7.2.1}-alpine - container_name: redis + container_name: test-redis restart: always volumes: - redisdata:/data @@ -141,7 +141,7 @@ services: args: DEVELOPMENT: True image: backend-image - container_name: coordinator + container_name: test-coordinator restart: always environment: DEVELOPMENT: True @@ -171,7 +171,7 @@ services: postgres: image: postgres:${POSTGRES_VERSION:-14.2}-alpine - container_name: sql + container_name: test-sql restart: always environment: POSTGRES_PASSWORD: 'example' diff --git a/docs/assets/schemas/api-latest.yaml b/docs/assets/schemas/api-latest.yaml index 60c5c933..8aa93469 100644 --- a/docs/assets/schemas/api-latest.yaml +++ b/docs/assets/schemas/api-latest.yaml @@ -1106,8 +1106,13 @@ components: order_id: type: integer readOnly: true + status: + type: integer + readOnly: true + description: The `status` of the order when the notification was trigered required: - order_id + - status ListOrder: type: object properties: