mirror of https://github.com/jumpserver/jumpserver
90 lines
3.1 KiB
Python
90 lines
3.1 KiB
Python
# -*- coding: utf-8 -*-
|
|
#
|
|
from rest_framework import status, mixins
|
|
from rest_framework.decorators import action
|
|
from rest_framework.response import Response
|
|
|
|
from accounts import serializers
|
|
from accounts.const import AutomationTypes
|
|
from accounts.models import ChangeSecretAutomation, ChangeSecretRecord
|
|
from accounts.tasks import execute_automation_record_task
|
|
from orgs.mixins.api import OrgBulkModelViewSet, OrgGenericViewSet
|
|
from .base import (
|
|
AutomationAssetsListApi, AutomationRemoveAssetApi, AutomationAddAssetApi,
|
|
AutomationNodeAddRemoveApi, AutomationExecutionViewSet
|
|
)
|
|
from ...filters import ChangeSecretRecordFilterSet
|
|
|
|
__all__ = [
|
|
'ChangeSecretAutomationViewSet', 'ChangeSecretRecordViewSet',
|
|
'ChangSecretExecutionViewSet', 'ChangSecretAssetsListApi',
|
|
'ChangSecretRemoveAssetApi', 'ChangSecretAddAssetApi',
|
|
'ChangSecretNodeAddRemoveApi'
|
|
]
|
|
|
|
|
|
class ChangeSecretAutomationViewSet(OrgBulkModelViewSet):
|
|
model = ChangeSecretAutomation
|
|
filter_fields = ('name', 'secret_type', 'secret_strategy')
|
|
search_fields = filter_fields
|
|
serializer_class = serializers.ChangeSecretAutomationSerializer
|
|
|
|
|
|
class ChangeSecretRecordViewSet(mixins.ListModelMixin, OrgGenericViewSet):
|
|
serializer_class = serializers.ChangeSecretRecordSerializer
|
|
filterset_class = ChangeSecretRecordFilterSet
|
|
search_fields = ('asset__address',)
|
|
tp = AutomationTypes.change_secret
|
|
rbac_perms = {
|
|
'execute': 'accounts.add_changesecretexecution',
|
|
}
|
|
|
|
def get_queryset(self):
|
|
return ChangeSecretRecord.objects.all()
|
|
|
|
@action(methods=['post'], detail=False, url_path='execute')
|
|
def execute(self, request, *args, **kwargs):
|
|
record_id = request.data.get('record_id')
|
|
record = self.get_queryset().filter(pk=record_id)
|
|
if not record:
|
|
return Response(
|
|
{'detail': 'record not found'},
|
|
status=status.HTTP_404_NOT_FOUND
|
|
)
|
|
task = execute_automation_record_task.delay(record_id, self.tp)
|
|
return Response({'task': task.id}, status=status.HTTP_200_OK)
|
|
|
|
|
|
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
|