2023-01-16 11:02:09 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
2023-10-30 06:24:34 +00:00
|
|
|
from rest_framework import status, mixins
|
|
|
|
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.const import AutomationTypes
|
2024-03-21 03:05:04 +00:00
|
|
|
from accounts.filters import ChangeSecretRecordFilterSet
|
2023-10-13 07:33:35 +00:00
|
|
|
from accounts.models import ChangeSecretAutomation, ChangeSecretRecord
|
2023-10-30 06:24:34 +00:00
|
|
|
from accounts.tasks import execute_automation_record_task
|
2024-03-21 03:05:04 +00:00
|
|
|
from authentication.permissions import UserConfirmation, ConfirmType
|
2023-01-16 11:02:09 +00:00
|
|
|
from orgs.mixins.api import OrgBulkModelViewSet, OrgGenericViewSet
|
2024-03-21 03:05:04 +00:00
|
|
|
from rbac.permissions import RBACPermission
|
2023-01-16 11:02:09 +00:00
|
|
|
from .base import (
|
|
|
|
AutomationAssetsListApi, AutomationRemoveAssetApi, AutomationAddAssetApi,
|
|
|
|
AutomationNodeAddRemoveApi, AutomationExecutionViewSet
|
|
|
|
)
|
|
|
|
|
|
|
|
__all__ = [
|
|
|
|
'ChangeSecretAutomationViewSet', 'ChangeSecretRecordViewSet',
|
|
|
|
'ChangSecretExecutionViewSet', 'ChangSecretAssetsListApi',
|
|
|
|
'ChangSecretRemoveAssetApi', 'ChangSecretAddAssetApi',
|
|
|
|
'ChangSecretNodeAddRemoveApi'
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
class ChangeSecretAutomationViewSet(OrgBulkModelViewSet):
|
|
|
|
model = ChangeSecretAutomation
|
2024-03-05 02:47:05 +00:00
|
|
|
filterset_fields = ('name', 'secret_type', 'secret_strategy')
|
|
|
|
search_fields = filterset_fields
|
2023-01-16 11:02:09 +00:00
|
|
|
serializer_class = serializers.ChangeSecretAutomationSerializer
|
|
|
|
|
|
|
|
|
|
|
|
class ChangeSecretRecordViewSet(mixins.ListModelMixin, OrgGenericViewSet):
|
2024-03-21 03:05:04 +00:00
|
|
|
filterset_class = ChangeSecretRecordFilterSet
|
2023-10-13 07:33:35 +00:00
|
|
|
search_fields = ('asset__address',)
|
2023-10-30 06:24:34 +00:00
|
|
|
tp = AutomationTypes.change_secret
|
2024-03-21 03:05:04 +00:00
|
|
|
serializer_classes = {
|
|
|
|
'default': serializers.ChangeSecretRecordSerializer,
|
|
|
|
'secret': serializers.ChangeSecretRecordViewSecretSerializer,
|
|
|
|
}
|
2023-10-30 06:24:34 +00:00
|
|
|
rbac_perms = {
|
|
|
|
'execute': 'accounts.add_changesecretexecution',
|
2024-03-21 03:05:04 +00:00
|
|
|
'secret': 'accounts.view_changesecretrecord',
|
2023-10-30 06:24:34 +00:00
|
|
|
}
|
2023-01-16 11:02:09 +00:00
|
|
|
|
2024-03-21 03:05:04 +00:00
|
|
|
def get_permissions(self):
|
|
|
|
if self.action == 'secret':
|
|
|
|
self.permission_classes = [
|
|
|
|
RBACPermission,
|
|
|
|
UserConfirmation.require(ConfirmType.MFA)
|
|
|
|
]
|
|
|
|
return super().get_permissions()
|
|
|
|
|
2023-01-16 11:02:09 +00:00
|
|
|
def get_queryset(self):
|
2023-10-30 06:24:34 +00:00
|
|
|
return ChangeSecretRecord.objects.all()
|
|
|
|
|
|
|
|
@action(methods=['post'], detail=False, url_path='execute')
|
|
|
|
def execute(self, request, *args, **kwargs):
|
2024-03-21 03:05:04 +00:00
|
|
|
record_ids = request.data.get('record_ids')
|
|
|
|
records = self.get_queryset().filter(id__in=record_ids)
|
|
|
|
execution_count = records.values_list('execution_id', flat=True).distinct().count()
|
|
|
|
if execution_count != 1:
|
2023-10-30 06:24:34 +00:00
|
|
|
return Response(
|
2024-03-21 03:05:04 +00:00
|
|
|
{'detail': 'Only one execution is allowed to execute'},
|
|
|
|
status=status.HTTP_400_BAD_REQUEST
|
2023-10-30 06:24:34 +00:00
|
|
|
)
|
2024-03-21 03:05:04 +00:00
|
|
|
task = execute_automation_record_task.delay(record_ids, self.tp)
|
2023-10-30 06:24:34 +00:00
|
|
|
return Response({'task': task.id}, status=status.HTTP_200_OK)
|
2023-01-16 11:02:09 +00:00
|
|
|
|
2024-03-21 03:05:04 +00:00
|
|
|
@action(methods=['get'], detail=True, url_path='secret')
|
|
|
|
def secret(self, request, *args, **kwargs):
|
|
|
|
instance = self.get_object()
|
|
|
|
serializer = self.get_serializer(instance)
|
|
|
|
return Response(serializer.data)
|
|
|
|
|
2023-01-16 11:02:09 +00:00
|
|
|
|
|
|
|
class ChangSecretExecutionViewSet(AutomationExecutionViewSet):
|
|
|
|
rbac_perms = (
|
|
|
|
("list", "accounts.view_changesecretexecution"),
|
|
|
|
("retrieve", "accounts.view_changesecretexecution"),
|
|
|
|
("create", "accounts.add_changesecretexecution"),
|
|
|
|
)
|
|
|
|
|
|
|
|
tp = AutomationTypes.change_secret
|
|
|
|
|
|
|
|
def get_queryset(self):
|
|
|
|
queryset = super().get_queryset()
|
|
|
|
queryset = queryset.filter(automation__type=self.tp)
|
|
|
|
return queryset
|
|
|
|
|
|
|
|
|
|
|
|
class ChangSecretAssetsListApi(AutomationAssetsListApi):
|
|
|
|
model = ChangeSecretAutomation
|
|
|
|
|
|
|
|
|
|
|
|
class ChangSecretRemoveAssetApi(AutomationRemoveAssetApi):
|
|
|
|
model = ChangeSecretAutomation
|
|
|
|
serializer_class = serializers.ChangeSecretUpdateAssetSerializer
|
|
|
|
|
|
|
|
|
|
|
|
class ChangSecretAddAssetApi(AutomationAddAssetApi):
|
|
|
|
model = ChangeSecretAutomation
|
|
|
|
serializer_class = serializers.ChangeSecretUpdateAssetSerializer
|
|
|
|
|
|
|
|
|
|
|
|
class ChangSecretNodeAddRemoveApi(AutomationNodeAddRemoveApi):
|
|
|
|
model = ChangeSecretAutomation
|
|
|
|
serializer_class = serializers.ChangeSecretUpdateNodeSerializer
|