DRF permissions - visitors can view but is_manager can POST, PUT, DELETE request
permissions.py from rest_framework.permissions import BasePermission from rest_framework import permissions class UnAuthenticatedOrReadOnly(BasePermission): def has_permission(self, request, view): if request.user.is_authenticated: if request.method in permissions.SAFE_METHODS: return True # Allow unauthenticated users to perform GET and RETRIEVE return request.user.is_manager # Only manager users can perform POST, PUT, DELETE return request.method in permissions.SAFE_METHODS # Allow unauthenticated users to perform GET and RETRIEVE def has_object_permission(self, request, view, obj): if request.user.is_authenticated: return request.user.is_manager # Only manager users...