mirror of
https://github.com/i701/sarlink-portal-api.git
synced 2025-07-07 12:16:30 +00:00
refactor(billing): Enhance TopupSerializer to include detailed user information and update ListCreateTopupView queryset filtering 🔨
This commit is contained in:
@ -1,7 +1,6 @@
|
|||||||
from rest_framework import serializers
|
from rest_framework import serializers
|
||||||
from .models import Payment, Topup
|
from .models import Payment, Topup
|
||||||
from devices.serializers import DeviceSerializer
|
from devices.serializers import DeviceSerializer
|
||||||
from api.serializers import CustomReadOnlyUserSerializer
|
|
||||||
|
|
||||||
|
|
||||||
class PaymentSerializer(serializers.ModelSerializer):
|
class PaymentSerializer(serializers.ModelSerializer):
|
||||||
@ -21,7 +20,18 @@ class UpdatePaymentSerializer(serializers.ModelSerializer):
|
|||||||
|
|
||||||
|
|
||||||
class TopupSerializer(serializers.ModelSerializer):
|
class TopupSerializer(serializers.ModelSerializer):
|
||||||
user = CustomReadOnlyUserSerializer(read_only=True)
|
user = serializers.SerializerMethodField()
|
||||||
|
|
||||||
|
def get_user(self, obj):
|
||||||
|
user = obj.user
|
||||||
|
if user:
|
||||||
|
return {
|
||||||
|
"id": user.id,
|
||||||
|
"name": user.first_name + " " + user.last_name,
|
||||||
|
"id_card": user.id_card,
|
||||||
|
"mobile": user.mobile,
|
||||||
|
}
|
||||||
|
return None
|
||||||
|
|
||||||
class Meta: # type: ignore
|
class Meta: # type: ignore
|
||||||
model = Topup
|
model = Topup
|
||||||
|
@ -281,6 +281,12 @@ class ListCreateTopupView(StaffEditorPermissionMixin, generics.ListCreateAPIView
|
|||||||
serializer = TopupSerializer(topup)
|
serializer = TopupSerializer(topup)
|
||||||
return Response(serializer.data, status=status.HTTP_201_CREATED)
|
return Response(serializer.data, status=status.HTTP_201_CREATED)
|
||||||
|
|
||||||
|
def get_queryset(self):
|
||||||
|
queryset = super().get_queryset()
|
||||||
|
if getattr(self.request.user, "is_admin") or self.request.user.is_superuser:
|
||||||
|
return queryset
|
||||||
|
return queryset.filter(user=self.request.user)
|
||||||
|
|
||||||
|
|
||||||
class VerifyTopupPaymentAPIView(StaffEditorPermissionMixin, generics.UpdateAPIView):
|
class VerifyTopupPaymentAPIView(StaffEditorPermissionMixin, generics.UpdateAPIView):
|
||||||
queryset = Topup.objects.all()
|
queryset = Topup.objects.all()
|
||||||
@ -311,6 +317,7 @@ class VerifyTopupPaymentAPIView(StaffEditorPermissionMixin, generics.UpdateAPIVi
|
|||||||
topup.paid = True
|
topup.paid = True
|
||||||
# topup.paid_at = timezone.now() # Assuming Topup model has paid_at field
|
# topup.paid_at = timezone.now() # Assuming Topup model has paid_at field
|
||||||
topup.mib_reference = mib_resp["transaction"]["ref"] or ""
|
topup.mib_reference = mib_resp["transaction"]["ref"] or ""
|
||||||
|
topup.paid_at = timezone.now()
|
||||||
topup.save()
|
topup.save()
|
||||||
return True
|
return True
|
||||||
|
|
||||||
@ -332,10 +339,11 @@ class VerifyTopupPaymentAPIView(StaffEditorPermissionMixin, generics.UpdateAPIVi
|
|||||||
"benefName": f"{user.first_name} {user.last_name}", # type: ignore
|
"benefName": f"{user.first_name} {user.last_name}", # type: ignore
|
||||||
"accountNo": user.acc_no, # type: ignore
|
"accountNo": user.acc_no, # type: ignore
|
||||||
"absAmount": topup_instance.amount,
|
"absAmount": topup_instance.amount,
|
||||||
"time": localtime(timezone.now() + timedelta(minutes=5)).strftime(
|
"time": localtime(
|
||||||
"%Y-%m-%d %H:%M"
|
topup_instance.created_at + timedelta(minutes=5)
|
||||||
),
|
).strftime("%Y-%m-%d %H:%M"),
|
||||||
}
|
}
|
||||||
|
print("payment payload in view ->", data)
|
||||||
topup_status = self.verify_transfer_topup(data, topup_instance)
|
topup_status = self.verify_transfer_topup(data, topup_instance)
|
||||||
if topup_status:
|
if topup_status:
|
||||||
return Response(
|
return Response(
|
||||||
|
Reference in New Issue
Block a user