core: fix pagination not working correctly with applications API

Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
This commit is contained in:
Jens Langhammer 2021-07-26 19:12:23 +02:00
parent 64c8ca9b5d
commit b752540800

View file

@ -145,18 +145,20 @@ class ApplicationViewSet(UsedByMixin, ModelViewSet):
) )
def list(self, request: Request) -> Response: def list(self, request: Request) -> Response:
"""Custom list method that checks Policy based access instead of guardian""" """Custom list method that checks Policy based access instead of guardian"""
self.request.session.pop(USER_LOGIN_AUTHENTICATED, None)
queryset = self._filter_queryset_for_list(self.get_queryset())
self.paginate_queryset(queryset)
should_cache = request.GET.get("search", "") == "" should_cache = request.GET.get("search", "") == ""
superuser_full_list = ( superuser_full_list = (
str(request.GET.get("superuser_full_list", "false")).lower() == "true" str(request.GET.get("superuser_full_list", "false")).lower() == "true"
) )
if superuser_full_list and request.user.is_superuser: if superuser_full_list and request.user.is_superuser:
serializer = self.get_serializer(queryset, many=True) return super().list(request)
return self.get_paginated_response(serializer.data)
# To prevent the user from having to double login when prompt is set to login
# and the user has just signed it. This session variable is set in the UserLoginStage
# and is (quite hackily) removed from the session in applications's API's List method
self.request.session.pop(USER_LOGIN_AUTHENTICATED, None)
queryset = self._filter_queryset_for_list(self.get_queryset())
self.paginate_queryset(queryset)
allowed_applications = [] allowed_applications = []
if not should_cache: if not should_cache: