mirror of https://github.com/jumpserver/jumpserver
perf: 修改 access key
parent
ce976f215f
commit
1daf1acaf3
|
@ -7,6 +7,8 @@ from rest_framework.response import Response
|
||||||
|
|
||||||
from common.api import JMSModelViewSet
|
from common.api import JMSModelViewSet
|
||||||
from rbac.permissions import RBACPermission
|
from rbac.permissions import RBACPermission
|
||||||
|
from ..const import ConfirmType
|
||||||
|
from ..permissions import UserConfirmation
|
||||||
from ..serializers import AccessKeySerializer, AccessKeyCreateSerializer
|
from ..serializers import AccessKeySerializer, AccessKeyCreateSerializer
|
||||||
|
|
||||||
|
|
||||||
|
@ -27,20 +29,20 @@ class AccessKeyViewSet(JMSModelViewSet):
|
||||||
|
|
||||||
if self.action == 'create':
|
if self.action == 'create':
|
||||||
self.permission_classes = [
|
self.permission_classes = [
|
||||||
RBACPermission,
|
RBACPermission, UserConfirmation.require(ConfirmType.PASSWORD)
|
||||||
]
|
]
|
||||||
return super().get_permissions()
|
return super().get_permissions()
|
||||||
|
|
||||||
def create(self, request, *args, **kwargs):
|
|
||||||
serializer = self.get_serializer(data=request.data)
|
|
||||||
serializer.is_valid(raise_exception=True)
|
|
||||||
key = self.perform_create(serializer)
|
|
||||||
serializer = self.get_serializer(instance=key)
|
|
||||||
return Response(serializer.data, status=201)
|
|
||||||
|
|
||||||
def perform_create(self, serializer):
|
def perform_create(self, serializer):
|
||||||
user = self.request.user
|
user = self.request.user
|
||||||
if user.access_keys.count() >= 10:
|
if user.access_keys.count() >= 10:
|
||||||
raise serializers.ValidationError(_('Access keys can be created at most 10'))
|
raise serializers.ValidationError(_('Access keys can be created at most 10'))
|
||||||
key = user.create_access_key()
|
key = user.create_access_key()
|
||||||
return key
|
return key
|
||||||
|
|
||||||
|
def create(self, request, *args, **kwargs):
|
||||||
|
serializer = self.get_serializer(data=request.data)
|
||||||
|
serializer.is_valid(raise_exception=True)
|
||||||
|
key = self.perform_create(serializer)
|
||||||
|
serializer = self.get_serializer(instance=key)
|
||||||
|
return Response(serializer.data, status=201)
|
||||||
|
|
Loading…
Reference in New Issue