You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
For a particular model, Application, I have an ApplicationViewSet that includes a list view and detail view. I have logic that determines whether or not the current user has permission to read a particular Application record, and I need to apply this logic so that the current user can only access the detail view if they have permission to view that particular record, and so that the list view only returns records for which the current user has permission to access.
I'm trying to figure out how I can apply the permission logic to both the list view and detail view without duplicating it.
class Application(models.Model):
department = models.ForeignKey(Department, null=True, on_delete=models.SET_NULL, related_name='applications')
@staticmethod
@authenticated_users
@allow_staff_or_superuser
def has_read_permission(request):
return True
@authenticated_users
@allow_staff_or_superuser
def has_object_read_permission(self, request):
if request.user.is_manager:
return self.department in request.user.manager.departments.all()
return self.applicant.user == request.user
filters.py
class ApplicationFilterBackend(DRYPermissionFiltersBase):
def filter_list_queryset(self, request, queryset, view):
if request.user.is_manager:
return queryset.filter(Q(department__in=request.user.manager.departments.all()))
return queryset.filter(Q(applicant__user=request.user))
This works, but as you can see, my permission logic is duplicated in Application.has_object_read_permission and ApplicationFilterBackend.filter_list_queryset. Is there any way to avoid this?
The text was updated successfully, but these errors were encountered:
Currently, there isn't a way to avoid this. I thought about this a lot when I was designing this permissions package. List permissions are fundamentally different from and of the other crud operations because list permissions are filters. Unfortunately, I wasn't able to come up with a simple way to cover both with the same code.
@dbkaplan Fair enough, yeah the effect of the permission logic is definitely fundamentally different for list permissions (applying filters to a query rather than returning a boolean response), it's just a shame that the exact same permission logic has to be manually duplicated and kept consistent in two different places in order to apply that logic to both the list permissions and object permissions. Unfortunately I can't think of a good way to get around it either though.
For a particular model,
Application
, I have anApplicationViewSet
that includes a list view and detail view. I have logic that determines whether or not the current user has permission to read a particularApplication
record, and I need to apply this logic so that the current user can only access the detail view if they have permission to view that particular record, and so that the list view only returns records for which the current user has permission to access.I'm trying to figure out how I can apply the permission logic to both the list view and detail view without duplicating it.
Here's what I'm currently doing:
views.py
models.py
filters.py
This works, but as you can see, my permission logic is duplicated in
Application.has_object_read_permission
andApplicationFilterBackend.filter_list_queryset
. Is there any way to avoid this?The text was updated successfully, but these errors were encountered: