mirror of
				https://gitlab.crans.org/bde/nk20
				synced 2025-11-04 09:12:11 +01:00 
			
		
		
		
	Parse input of search filters to prevent errors based on invalid regex, fixes #113
Signed-off-by: Yohann D'ANELLO <ynerant@crans.org>
This commit is contained in:
		@@ -2,7 +2,9 @@
 | 
			
		||||
# SPDX-License-Identifier: GPL-3.0-or-later
 | 
			
		||||
 | 
			
		||||
from django_filters.rest_framework import DjangoFilterBackend
 | 
			
		||||
from rest_framework.filters import OrderingFilter, SearchFilter
 | 
			
		||||
from rest_framework.filters import OrderingFilter
 | 
			
		||||
 | 
			
		||||
from api.filters import RegexSafeSearchFilter
 | 
			
		||||
from api.viewsets import ReadProtectedModelViewSet
 | 
			
		||||
 | 
			
		||||
from .serializers import ProfileSerializer, ClubSerializer, MembershipSerializer
 | 
			
		||||
@@ -17,7 +19,7 @@ class ProfileViewSet(ReadProtectedModelViewSet):
 | 
			
		||||
    """
 | 
			
		||||
    queryset = Profile.objects.order_by('id')
 | 
			
		||||
    serializer_class = ProfileSerializer
 | 
			
		||||
    filter_backends = [DjangoFilterBackend, SearchFilter]
 | 
			
		||||
    filter_backends = [DjangoFilterBackend, RegexSafeSearchFilter]
 | 
			
		||||
    filterset_fields = ['user', 'user__first_name', 'user__last_name', 'user__username', 'user__email',
 | 
			
		||||
                        'user__note__alias__name', 'user__note__alias__normalized_name', 'phone_number', "section",
 | 
			
		||||
                        'department', 'promotion', 'address', 'paid', 'ml_events_registration', 'ml_sport_registration',
 | 
			
		||||
@@ -34,7 +36,7 @@ class ClubViewSet(ReadProtectedModelViewSet):
 | 
			
		||||
    """
 | 
			
		||||
    queryset = Club.objects.order_by('id')
 | 
			
		||||
    serializer_class = ClubSerializer
 | 
			
		||||
    filter_backends = [DjangoFilterBackend, SearchFilter]
 | 
			
		||||
    filter_backends = [DjangoFilterBackend, RegexSafeSearchFilter]
 | 
			
		||||
    filterset_fields = ['name', 'email', 'note__alias__name', 'note__alias__normalized_name', 'parent_club',
 | 
			
		||||
                        'parent_club__name', 'require_memberships', 'membership_fee_paid', 'membership_fee_unpaid',
 | 
			
		||||
                        'membership_duration', 'membership_start', 'membership_end', ]
 | 
			
		||||
@@ -49,7 +51,7 @@ class MembershipViewSet(ReadProtectedModelViewSet):
 | 
			
		||||
    """
 | 
			
		||||
    queryset = Membership.objects.order_by('id')
 | 
			
		||||
    serializer_class = MembershipSerializer
 | 
			
		||||
    filter_backends = [DjangoFilterBackend, OrderingFilter, SearchFilter]
 | 
			
		||||
    filter_backends = [DjangoFilterBackend, OrderingFilter, RegexSafeSearchFilter]
 | 
			
		||||
    filterset_fields = ['club__name', 'club__email', 'club__note__alias__name', 'club__note__alias__normalized_name',
 | 
			
		||||
                        'user__username', 'user__last_name', 'user__first_name', 'user__email',
 | 
			
		||||
                        'user__note__alias__name', 'user__note__alias__normalized_name',
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user