2023-03-15 06:46:32 +00:00
|
|
|
from django_filters import rest_framework as drf_filters
|
2023-05-09 07:29:02 +00:00
|
|
|
from rest_framework.decorators import action
|
|
|
|
from rest_framework.response import Response
|
2023-01-16 11:02:09 +00:00
|
|
|
|
|
|
|
from accounts import serializers
|
|
|
|
from accounts.models import AccountTemplate
|
2023-04-21 08:58:40 +00:00
|
|
|
from assets.const import Protocol
|
|
|
|
from common.drf.filters import BaseFilterSet
|
2023-03-15 06:46:32 +00:00
|
|
|
from common.permissions import UserConfirmation, ConfirmType
|
|
|
|
from common.views.mixins import RecordViewLogMixin
|
2023-04-21 08:58:40 +00:00
|
|
|
from orgs.mixins.api import OrgBulkModelViewSet
|
|
|
|
from rbac.permissions import RBACPermission
|
2023-03-15 06:46:32 +00:00
|
|
|
|
|
|
|
|
|
|
|
class AccountTemplateFilterSet(BaseFilterSet):
|
|
|
|
protocols = drf_filters.CharFilter(method='filter_protocols')
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
model = AccountTemplate
|
|
|
|
fields = ('username', 'name')
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def filter_protocols(queryset, name, value):
|
|
|
|
secret_types = set()
|
|
|
|
protocols = value.split(',')
|
|
|
|
protocol_secret_type_map = Protocol.settings()
|
|
|
|
for p in protocols:
|
|
|
|
if p not in protocol_secret_type_map:
|
|
|
|
continue
|
|
|
|
_st = protocol_secret_type_map[p].get('secret_types', [])
|
|
|
|
secret_types.update(_st)
|
2023-04-21 08:58:40 +00:00
|
|
|
if not secret_types:
|
|
|
|
secret_types = ['password']
|
2023-03-15 06:46:32 +00:00
|
|
|
queryset = queryset.filter(secret_type__in=secret_types)
|
|
|
|
return queryset
|
2022-08-19 10:49:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
class AccountTemplateViewSet(OrgBulkModelViewSet):
|
|
|
|
model = AccountTemplate
|
2023-03-15 06:46:32 +00:00
|
|
|
filterset_class = AccountTemplateFilterSet
|
2022-08-19 10:49:00 +00:00
|
|
|
search_fields = ('username', 'name')
|
|
|
|
serializer_classes = {
|
2023-05-09 07:29:02 +00:00
|
|
|
'default': serializers.AccountTemplateSerializer,
|
2022-08-19 10:49:00 +00:00
|
|
|
}
|
2023-05-09 07:29:02 +00:00
|
|
|
rbac_perms = {
|
|
|
|
'su_from_account_templates': 'accounts.view_accounttemplate',
|
|
|
|
}
|
|
|
|
|
|
|
|
@action(methods=['get'], detail=False, url_path='su-from-account-templates')
|
|
|
|
def su_from_account_templates(self, request, *args, **kwargs):
|
|
|
|
pk = request.query_params.get('template_id')
|
|
|
|
template = AccountTemplate.objects.filter(pk=pk).first()
|
|
|
|
templates = AccountTemplate.get_su_from_account_templates(template)
|
|
|
|
templates = self.filter_queryset(templates)
|
|
|
|
serializer = self.get_serializer(templates, many=True)
|
|
|
|
return Response(data=serializer.data)
|
2022-11-28 07:54:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
class AccountTemplateSecretsViewSet(RecordViewLogMixin, AccountTemplateViewSet):
|
|
|
|
serializer_classes = {
|
|
|
|
'default': serializers.AccountTemplateSecretSerializer,
|
|
|
|
}
|
|
|
|
http_method_names = ['get', 'options']
|
2023-01-16 11:02:09 +00:00
|
|
|
permission_classes = [RBACPermission, UserConfirmation.require(ConfirmType.MFA)]
|
2022-11-28 07:54:16 +00:00
|
|
|
rbac_perms = {
|
2023-02-20 02:56:50 +00:00
|
|
|
'list': 'accounts.view_accounttemplatesecret',
|
|
|
|
'retrieve': 'accounts.view_accounttemplatesecret',
|
2022-11-28 07:54:16 +00:00
|
|
|
}
|