From 008a2a22717974ffe51891d291f6e28e42efeeae Mon Sep 17 00:00:00 2001 From: Keannu Bernasol Date: Thu, 16 Jan 2025 19:54:49 +0800 Subject: [PATCH] Add delete user endpoint --- docmanager_backend/accounts/permissions.py | 9 +++++++++ docmanager_backend/accounts/urls.py | 3 ++- docmanager_backend/accounts/views.py | 16 ++++++++++++++++ 3 files changed, 27 insertions(+), 1 deletion(-) create mode 100644 docmanager_backend/accounts/views.py diff --git a/docmanager_backend/accounts/permissions.py b/docmanager_backend/accounts/permissions.py index e2be857..4636fce 100644 --- a/docmanager_backend/accounts/permissions.py +++ b/docmanager_backend/accounts/permissions.py @@ -29,3 +29,12 @@ class IsHead(BasePermission): def has_permission(self, request, view): return bool(request.user and request.user.role == "head") + + +class IsAdmin(BasePermission): + """ + Allows access only to users with admin role + """ + + def has_permission(self, request, view): + return bool(request.user and request.user.role == "admin") diff --git a/docmanager_backend/accounts/urls.py b/docmanager_backend/accounts/urls.py index 613165c..cd51b53 100644 --- a/docmanager_backend/accounts/urls.py +++ b/docmanager_backend/accounts/urls.py @@ -1,7 +1,8 @@ from django.urls import include, path - +from .views import CustomUserDeleteView urlpatterns = [ path("", include("djoser.urls")), path("", include("djoser.urls.jwt")), + path("users/delete//", CustomUserDeleteView.as_view()), ] diff --git a/docmanager_backend/accounts/views.py b/docmanager_backend/accounts/views.py new file mode 100644 index 0000000..a8b24f1 --- /dev/null +++ b/docmanager_backend/accounts/views.py @@ -0,0 +1,16 @@ +from rest_framework import generics +from .serializers import CustomUserSerializer +from rest_framework.permissions import IsAuthenticated +from accounts.permissions import IsAdmin +from .models import CustomUser + + +class CustomUserDeleteView(generics.DestroyAPIView): + """ + Used by admin to delete users. Accepts the user id as a URL parameter + """ + + http_method_names = ["delete"] + serializer_class = CustomUserSerializer + queryset = CustomUser.objects.all() + permission_classes = [IsAuthenticated, IsAdmin]