mirror of
https://github.com/i701/sarlink-portal-api.git
synced 2025-11-23 01:06:59 +00:00
feat(filters, serializers): add user filtering and enhance user serialization in Payment and Device models ✨
All checks were successful
Build and Push Docker Images / Build and Push Docker Images (push) Successful in 2m46s
All checks were successful
Build and Push Docker Images / Build and Push Docker Images (push) Successful in 2m46s
This commit is contained in:
@@ -8,6 +8,7 @@ class PaymentFilter(django_filters.FilterSet):
|
|||||||
amount = django_filters.RangeFilter(field_name="amount")
|
amount = django_filters.RangeFilter(field_name="amount")
|
||||||
number_of_months = django_filters.RangeFilter(field_name="number_of_months")
|
number_of_months = django_filters.RangeFilter(field_name="number_of_months")
|
||||||
paid = django_filters.BooleanFilter(field_name="paid")
|
paid = django_filters.BooleanFilter(field_name="paid")
|
||||||
|
user = django_filters.CharFilter(method="filter_user_search")
|
||||||
method = django_filters.ChoiceFilter(
|
method = django_filters.ChoiceFilter(
|
||||||
choices=Payment.PAYMENT_TYPES, lookup_expr="iexact"
|
choices=Payment.PAYMENT_TYPES, lookup_expr="iexact"
|
||||||
)
|
)
|
||||||
@@ -16,6 +17,14 @@ class PaymentFilter(django_filters.FilterSet):
|
|||||||
created_at = django_filters.DateFromToRangeFilter()
|
created_at = django_filters.DateFromToRangeFilter()
|
||||||
is_expired = django_filters.BooleanFilter(method="filter_is_expired")
|
is_expired = django_filters.BooleanFilter(method="filter_is_expired")
|
||||||
|
|
||||||
|
def filter_user_search(self, queryset, name, value):
|
||||||
|
return queryset.filter(
|
||||||
|
Q(user__first_name__icontains=value)
|
||||||
|
| Q(user__last_name__icontains=value)
|
||||||
|
| Q(user__id_card__icontains=value)
|
||||||
|
| Q(user__mobile__icontains=value)
|
||||||
|
)
|
||||||
|
|
||||||
def filter_is_expired(self, queryset, name, value):
|
def filter_is_expired(self, queryset, name, value):
|
||||||
"""
|
"""
|
||||||
Filter payments based on whether they are expired or not
|
Filter payments based on whether they are expired or not
|
||||||
@@ -29,7 +38,14 @@ class PaymentFilter(django_filters.FilterSet):
|
|||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Payment
|
model = Payment
|
||||||
fields = "__all__"
|
fields = [
|
||||||
|
"amount",
|
||||||
|
"paid",
|
||||||
|
"method",
|
||||||
|
"user",
|
||||||
|
"created_at",
|
||||||
|
"is_expired",
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
class TopupFilter(django_filters.FilterSet):
|
class TopupFilter(django_filters.FilterSet):
|
||||||
|
|||||||
@@ -1,11 +1,23 @@
|
|||||||
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 AdminDeviceSerializer
|
||||||
|
|
||||||
|
|
||||||
class PaymentSerializer(serializers.ModelSerializer):
|
class PaymentSerializer(serializers.ModelSerializer):
|
||||||
devices = DeviceSerializer(many=True, read_only=True)
|
devices = AdminDeviceSerializer(many=True, read_only=True)
|
||||||
is_expired = serializers.SerializerMethodField()
|
is_expired = serializers.SerializerMethodField()
|
||||||
|
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
|
||||||
|
|
||||||
def get_is_expired(self, obj):
|
def get_is_expired(self, obj):
|
||||||
return obj.is_expired
|
return obj.is_expired
|
||||||
|
|||||||
@@ -58,6 +58,22 @@ class DeviceSerializer(serializers.ModelSerializer):
|
|||||||
fields = "__all__"
|
fields = "__all__"
|
||||||
|
|
||||||
|
|
||||||
|
class AdminDeviceSerializer(serializers.ModelSerializer):
|
||||||
|
pending_payment_id = serializers.SerializerMethodField()
|
||||||
|
|
||||||
|
def get_pending_payment_id(self, obj):
|
||||||
|
unpaid_payment = (
|
||||||
|
Payment.objects.filter(devices=obj, paid=False)
|
||||||
|
.order_by("-created_at")
|
||||||
|
.first()
|
||||||
|
)
|
||||||
|
return unpaid_payment.id if unpaid_payment else None
|
||||||
|
|
||||||
|
class Meta: # type: ignore
|
||||||
|
model = Device
|
||||||
|
fields = "__all__"
|
||||||
|
|
||||||
|
|
||||||
class ReadOnlyDeviceSerializer(serializers.ModelSerializer):
|
class ReadOnlyDeviceSerializer(serializers.ModelSerializer):
|
||||||
user = CustomReadOnlyUserSerializer(read_only=True)
|
user = CustomReadOnlyUserSerializer(read_only=True)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user