You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
182 lines
6.9 KiB
182 lines
6.9 KiB
# Copyright (C) 2005-2025 Splunk Inc. All Rights Reserved.
|
|
|
|
import sys
|
|
import json
|
|
|
|
from splunk.clilib.bundle_paths import make_splunkhome_path
|
|
|
|
sys.path.append(make_splunkhome_path(['etc', 'apps', 'SA-ITOA', 'lib']))
|
|
import itsi_path
|
|
|
|
from ITOA.setup_logging import getLogger
|
|
from itsi.event_management.sdk.custom_group_action_base import CustomGroupActionBase
|
|
from ITOA.event_management.notable_event_ticketing import ExternalTicket
|
|
from ITOA.event_management.notable_event_utils import ActionDispatchConfiguration
|
|
|
|
|
|
class LinkTicket(CustomGroupActionBase):
|
|
"""
|
|
Class that performs Link Ticket action on notable events group.
|
|
|
|
Until 2.6.x, link ticket was handled via SA-ITOA event management
|
|
rest interface for ticketing.
|
|
Post 2.6.x, link ticket will be handled as a real alert action,
|
|
where this script will act as an link ticket action script
|
|
for alerts.
|
|
"""
|
|
|
|
TICKET_SYSTEM_KEY = 'ticket_system'
|
|
TICKET_ID_KEY = 'ticket_id'
|
|
TICKET_URL_KEY = 'ticket_url'
|
|
TICKET_OPERATION_KEY = 'operation'
|
|
TICKET_KWARGS_KEY = 'kwargs'
|
|
|
|
def __init__(self, settings):
|
|
"""
|
|
Initialize the object
|
|
@type settings: dict/basestring
|
|
@param settings: incoming settings for this alert action that splunkd
|
|
passes via stdin.
|
|
|
|
@returns Nothing
|
|
"""
|
|
self.logger = getLogger(logger_name="itsi.event_action.link_ticket")
|
|
|
|
super(LinkTicket, self).__init__(settings, self.logger)
|
|
|
|
self.action_dispatch_config = ActionDispatchConfiguration(self.get_session_key(), self.logger)
|
|
self.ticket_system = None
|
|
self.ticket_id = None
|
|
self.ticket_url = None
|
|
self.ticket_operation = None
|
|
self.kwargs = {}
|
|
|
|
def get_ticket_info(self):
|
|
"""
|
|
Gets ticketing information from configs and
|
|
sets class variables.
|
|
"""
|
|
config = self.get_config()
|
|
self.ticket_system = config.get(self.TICKET_SYSTEM_KEY, None)
|
|
self.ticket_id = config.get(self.TICKET_ID_KEY, None)
|
|
self.ticket_url = config.get(self.TICKET_URL_KEY, None)
|
|
self.ticket_operation = config.get(self.TICKET_OPERATION_KEY, None)
|
|
if self.ticket_system == 'Jira Cloud' and self.ticket_operation == 'upsert':
|
|
self.ticket_system = 'JSM'
|
|
|
|
temp = config.get(self.TICKET_KWARGS_KEY, None)
|
|
if temp is not None and len(temp.strip()) != 0:
|
|
try:
|
|
self.kwargs = json.loads(temp)
|
|
except Exception as e:
|
|
self.logger.error('Invalid kwargs provided for creating ticket. Exception: %s', e)
|
|
sys.exit(1)
|
|
|
|
def upsert_ticket(self, events):
|
|
"""
|
|
Updates/creates ticket for single or multiple events
|
|
using ExternalTicket module.
|
|
|
|
@param events: list of event ids
|
|
"""
|
|
session_key = self.get_session_key()
|
|
if len(events) == 1:
|
|
external_ticket = ExternalTicket(
|
|
events[0], session_key, self.logger,
|
|
action_dispatch_config=self.action_dispatch_config,
|
|
current_user_name=self.settings.get('owner', None)
|
|
)
|
|
external_ticket.upsert(self.ticket_system, self.ticket_id, self.ticket_url, **self.kwargs)
|
|
elif len(events) > 1:
|
|
ExternalTicket.bulk_upsert(
|
|
events, self.ticket_system, self.ticket_id, self.ticket_url,
|
|
session_key, self.logger, action_dispatch_config=self.action_dispatch_config,
|
|
current_user_name=self.settings.get('owner', None),
|
|
**self.kwargs)
|
|
else:
|
|
self.logger.info("No associated events to upsert ticket.")
|
|
|
|
def delete_ticket(self, events):
|
|
"""
|
|
Deletes ticket for single event using ExternalTicket module.
|
|
@param event_id: id of event
|
|
"""
|
|
session_key = self.get_session_key()
|
|
if len(events) == 1:
|
|
external_ticket = ExternalTicket(
|
|
events[0], session_key, self.logger,
|
|
action_dispatch_config=self.action_dispatch_config,
|
|
current_user_name=self.settings.get('owner', None)
|
|
)
|
|
external_ticket.delete(self.ticket_system, self.ticket_id)
|
|
elif len(events) > 1:
|
|
ExternalTicket.bulk_delete(
|
|
events, self.ticket_system,
|
|
self.ticket_id, session_key, self.logger,
|
|
action_dispatch_config=self.action_dispatch_config,
|
|
current_user_name=self.settings.get('owner', None)
|
|
)
|
|
else:
|
|
self.logger.info("No associated events to delete ticket.")
|
|
|
|
def execute(self):
|
|
"""
|
|
Performs two types of ticketing action, create/update and delete.
|
|
1. create/update ticket: fetches groups from result file and perform
|
|
create/update ticket for each group.
|
|
2. delete ticket: fetches group from result file and performs delete
|
|
ticket for single group.
|
|
"""
|
|
self.logger.debug('Received settings from splunkd=`%s`', json.dumps(self.settings))
|
|
|
|
try:
|
|
self.get_ticket_info()
|
|
|
|
if self.ticket_operation == 'upsert':
|
|
if self.ticket_system is None:
|
|
self.logger.error('Ticket System must be defined to create or update ticket.')
|
|
sys.exit(1)
|
|
if self.ticket_url is None:
|
|
self.logger.error('Ticket URL must be defined to create or update ticket.')
|
|
sys.exit(1)
|
|
if self.ticket_id is None:
|
|
self.logger.error('Ticket ID must be defined to create or update ticket.')
|
|
sys.exit(1)
|
|
|
|
groups = []
|
|
for data in self.get_group():
|
|
group_id = self.extract_group_or_event_id(data)
|
|
groups.append(group_id)
|
|
|
|
self.upsert_ticket(groups)
|
|
|
|
elif self.ticket_operation == 'delete':
|
|
if self.ticket_system is None:
|
|
self.logger.error('Ticket System must be provided to delete ticket.')
|
|
sys.exit(1)
|
|
if self.ticket_id is None:
|
|
self.logger.error('Ticket ID must be provided to delete ticket.')
|
|
sys.exit(1)
|
|
|
|
# assuming, delete ticket is only applicable for single event
|
|
groups = []
|
|
for data in self.get_group():
|
|
group_id = self.extract_group_or_event_id(data)
|
|
groups.append(group_id)
|
|
self.delete_ticket(groups)
|
|
|
|
except ValueError:
|
|
pass # best case, try every event.
|
|
|
|
except Exception as e:
|
|
self.logger.error('Failed to execute link ticket action.')
|
|
self.logger.exception(e)
|
|
sys.exit(1)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
if len(sys.argv) > 1 and sys.argv[1] == '--execute':
|
|
input_params = sys.stdin.read()
|
|
link_ticket = LinkTicket(input_params)
|
|
link_ticket.execute()
|