From 1e3d511adf393365fa300373ce15c8f48c8734f9 Mon Sep 17 00:00:00 2001 From: hanshuaikang <1758504262@qq.com> Date: Tue, 2 Jan 2024 20:40:08 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E8=8A=82=E7=82=B9=E6=94=AF=E6=8C=81?= =?UTF-8?q?=E9=85=8D=E7=BD=AE=E5=AE=A1=E6=89=B9=E7=BB=93=E6=9E=9C=E4=B8=BA?= =?UTF-8?q?=E6=8B=92=E7=BB=9D=E6=97=B6=E8=87=AA=E5=8A=A8=E7=BB=88=E6=AD=A2?= =?UTF-8?q?=E5=8D=95=E6=8D=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../components/collections/itsm_sign.py | 13 +++++++++++-- itsm/ticket/models/ticket.py | 2 +- 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/itsm/pipeline_plugins/components/collections/itsm_sign.py b/itsm/pipeline_plugins/components/collections/itsm_sign.py index 50888a7a1..a80ecb681 100644 --- a/itsm/pipeline_plugins/components/collections/itsm_sign.py +++ b/itsm/pipeline_plugins/components/collections/itsm_sign.py @@ -25,7 +25,7 @@ import logging -from itsm.component.constants import NODE_APPROVE_RESULT +from itsm.component.constants import NODE_APPROVE_RESULT, TERMINATED from itsm.ticket.models import Ticket, Status, TicketGlobalVariable, SignTask from pipeline.component_framework.component import Component @@ -88,12 +88,12 @@ def schedule(self, data, parent_data, callback_data=None): operator = callback_data["operator"] fields = callback_data["fields"] source = callback_data["source"] - variables = data.outputs.get("variables") finish_condition = data.outputs.get("finish_condition") code_key = data.outputs.get("code_key") ticket = Ticket.objects.get(id=ticket_id) node_status = Status.objects.get(ticket_id=ticket_id, state_id=state_id) + state = ticket.state(state_id) try: ticket.do_in_sign_state(node_status, fields, operator, source) @@ -117,6 +117,15 @@ def schedule(self, data, parent_data, callback_data=None): data.set_outputs("params_%s" % field["key"], field["value"]) self.do_before_exit(ticket, state_id, operator) + if key_value[ + code_key[NODE_APPROVE_RESULT] + ] == "false" and state.get( + "enable_terminate_ticket_when_rejected", False + ): + logger.info( + "[sign] enable_terminate_ticket_when_rejected is true ticket closed" + ) + ticket.close(close_status=TERMINATED, operator="system") self.finish_schedule() finally: self.final_execute(node_status, operator) diff --git a/itsm/ticket/models/ticket.py b/itsm/ticket/models/ticket.py index 7bf283af4..c4d6cdb9c 100644 --- a/itsm/ticket/models/ticket.py +++ b/itsm/ticket/models/ticket.py @@ -2948,7 +2948,7 @@ def set_finished( # TODO: 临时处理, 后面会放在母子单解绑逻辑中 ticket.current_status = close_status ticket.node_status.filter(status__in=Status.RUNNING_STATUS).update( - status=FINISHED + status=close_status ) ticket.current_task_processors = "" ticket.current_processors = ""