|
|
|
@ -26,11 +26,15 @@ logger = get_logger(__name__)
|
|
|
|
|
|
|
|
|
|
class UserViewSet(IDInFilterMixin, BulkModelViewSet): |
|
|
|
|
queryset = User.objects.exclude(role="App") |
|
|
|
|
# queryset = User.objects.all().exclude(role="App").order_by("date_joined") |
|
|
|
|
serializer_class = UserSerializer |
|
|
|
|
permission_classes = (IsSuperUserOrAppUser, IsAuthenticated) |
|
|
|
|
permission_classes = (IsSuperUser,) |
|
|
|
|
filter_fields = ('username', 'email', 'name', 'id') |
|
|
|
|
|
|
|
|
|
def get_permissions(self): |
|
|
|
|
if self.action == "retrieve": |
|
|
|
|
self.permission_classes = (IsSuperUserOrAppUser,) |
|
|
|
|
return super().get_permissions() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ChangeUserPasswordApi(generics.RetrieveUpdateAPIView): |
|
|
|
|
permission_classes = (IsSuperUser,) |
|
|
|
@ -57,7 +61,6 @@ class UserResetPasswordApi(generics.UpdateAPIView):
|
|
|
|
|
def perform_update(self, serializer): |
|
|
|
|
# Note: we are not updating the user object here. |
|
|
|
|
# We just do the reset-password stuff. |
|
|
|
|
import uuid |
|
|
|
|
from .utils import send_reset_password_mail |
|
|
|
|
user = self.get_object() |
|
|
|
|
user.password_raw = str(uuid.uuid4()) |
|
|
|
@ -68,6 +71,7 @@ class UserResetPasswordApi(generics.UpdateAPIView):
|
|
|
|
|
class UserResetPKApi(generics.UpdateAPIView): |
|
|
|
|
queryset = User.objects.all() |
|
|
|
|
serializer_class = UserSerializer |
|
|
|
|
permission_classes = (IsAuthenticated,) |
|
|
|
|
|
|
|
|
|
def perform_update(self, serializer): |
|
|
|
|
from .utils import send_reset_ssh_key_mail |
|
|
|
@ -91,6 +95,7 @@ class UserUpdatePKApi(generics.UpdateAPIView):
|
|
|
|
|
class UserGroupViewSet(IDInFilterMixin, BulkModelViewSet): |
|
|
|
|
queryset = UserGroup.objects.all() |
|
|
|
|
serializer_class = UserGroupSerializer |
|
|
|
|
permission_classes = (IsSuperUser,) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class UserGroupUpdateUserApi(generics.RetrieveUpdateAPIView): |
|
|
|
|