2015-08-27 02:26:42 +05:30
#!/usr/bin/python
# -*- coding: utf-8 -*-
#
# This file is part of Ansible
#
# Ansible is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Ansible is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
DOCUMENTATION = '''
module : pagerduty_alert
short_description : Trigger , acknowledge or resolve PagerDuty incidents
description :
- This module will let you trigger , acknowledge or resolve a PagerDuty incident by sending events
version_added : " 1.9 "
author :
- " Amanpreet Singh (@aps-sids) "
requirements :
- PagerDuty API access
options :
2015-08-27 18:02:45 +05:30
name :
description :
- PagerDuty unique subdomain .
required : true
2015-08-27 02:26:42 +05:30
service_key :
description :
- The GUID of one of your " Generic API " services .
- This is the " service key " listed on a Generic API ' s service detail page.
required : true
2015-08-27 18:02:45 +05:30
state :
2015-08-27 02:26:42 +05:30
description :
- Type of event to be sent .
required : true
choices :
2015-08-27 18:02:45 +05:30
- ' triggered '
- ' acknowledged '
- ' resolved '
api_key :
description :
- The pagerduty API key ( readonly access ) , generated on the pagerduty site .
required : true
2015-08-27 02:26:42 +05:30
desc :
description :
2015-08-27 18:02:45 +05:30
- For C ( triggered ) I ( state ) - Required . Short description of the problem that led to this trigger . This field ( or a truncated version ) will be used when generating phone calls , SMS messages and alert emails . It will also appear on the incidents tables in the PagerDuty UI . The maximum length is 1024 characters .
- For C ( acknowledged ) or C ( resolved ) I ( state ) - Text that will appear in the incident ' s log associated with this event.
2015-08-27 02:26:42 +05:30
required : false
default : Created via Ansible
incident_key :
description :
2015-08-27 18:02:45 +05:30
- Identifies the incident to which this I ( state ) should be applied .
- For C ( triggered ) I ( state ) - If there ' s no open (i.e. unresolved) incident with this key, a new one will be created. If there ' s already an open incident with a matching key , this event will be appended to that incident ' s log. The event key provides an easy way to " de-dup " problem reports.
- For C ( acknowledged ) or C ( resolved ) I ( state ) - This should be the incident_key you received back when the incident was first opened by a trigger event . Acknowledge events referencing resolved or nonexistent incidents will be discarded .
2015-08-27 02:26:42 +05:30
required : false
client :
description :
- The name of the monitoring client that is triggering this event .
required : false
client_url :
description :
- The URL of the monitoring client that is triggering this event .
required : false
'''
EXAMPLES = '''
# Trigger an incident with just the basic options
- pagerduty_alert :
2015-08-27 18:02:45 +05:30
name : companyabc
2015-08-27 02:26:42 +05:30
service_key = xxx
2015-08-27 18:02:45 +05:30
api_key : yourapikey
state = triggered
2015-08-27 02:26:42 +05:30
desc = " problem that led to this trigger "
# Trigger an incident with more options
- pagerduty_alert :
service_key = xxx
2015-08-27 18:02:45 +05:30
api_key = yourapikey
state = triggered
2015-08-27 02:26:42 +05:30
desc = " problem that led to this trigger "
incident_key = somekey
client = " Sample Monitoring Service "
client_url = http : / / service . example . com
# Acknowledge an incident based on incident_key
- pagerduty_alert :
service_key = xxx
2015-08-27 18:02:45 +05:30
api_key = yourapikey
state = acknowledged
2015-08-27 02:26:42 +05:30
incident_key = somekey
desc = " some text for incident ' s log "
# Resolve an incident based on incident_key
- pagerduty_alert :
service_key = xxx
2015-08-27 18:02:45 +05:30
api_key = yourapikey
state = resolved
2015-08-27 02:26:42 +05:30
incident_key = somekey
desc = " some text for incident ' s log "
'''
2015-08-27 18:02:45 +05:30
def check ( module , name , state , service_key , api_key , incident_key = None ) :
url = " https:// %s .pagerduty.com/api/v1/incidents " % name
headers = {
" Content-type " : " application/json " ,
" Authorization " : " Token token= %s " % api_key
}
data = {
" service_key " : service_key ,
" incident_key " : incident_key ,
" sort_by " : " incident_number:desc "
}
response , info = fetch_url ( module , url , method = ' get ' ,
headers = headers , data = json . dumps ( data ) )
if info [ ' status ' ] != 200 :
module . fail_json ( msg = " failed to check current incident status. "
" Reason: %s " % info [ ' msg ' ] )
json_out = json . loads ( response . read ( ) ) [ " incidents " ] [ 0 ]
if state != json_out [ " status " ] :
return json_out , True
return json_out , False
2015-08-27 02:26:42 +05:30
def send_event ( module , service_key , event_type , desc ,
incident_key = None , client = None , client_url = None ) :
url = " https://events.pagerduty.com/generic/2010-04-15/create_event.json "
headers = {
" Content-type " : " application/json "
}
data = {
" service_key " : service_key ,
" event_type " : event_type ,
" incident_key " : incident_key ,
" description " : desc ,
" client " : client ,
" client_url " : client_url
}
response , info = fetch_url ( module , url , method = ' post ' ,
headers = headers , data = json . dumps ( data ) )
if info [ ' status ' ] != 200 :
module . fail_json ( msg = " failed to %s . Reason: %s " %
( event_type , info [ ' msg ' ] ) )
json_out = json . loads ( response . read ( ) )
2015-08-27 18:02:45 +05:30
return json_out
2015-08-27 02:26:42 +05:30
def main ( ) :
module = AnsibleModule (
argument_spec = dict (
2015-08-27 18:02:45 +05:30
name = dict ( required = True ) ,
2015-08-27 02:26:42 +05:30
service_key = dict ( required = True ) ,
2015-08-27 18:02:45 +05:30
api_key = dict ( required = True ) ,
state = dict ( required = True ,
choices = [ ' triggered ' , ' acknowledged ' , ' resolved ' ] ) ,
2015-08-27 02:26:42 +05:30
client = dict ( required = False , default = None ) ,
client_url = dict ( required = False , default = None ) ,
desc = dict ( required = False , default = ' Created via Ansible ' ) ,
incident_key = dict ( required = False , default = None )
2015-08-27 18:02:45 +05:30
) ,
supports_check_mode = True
2015-08-27 02:26:42 +05:30
)
2015-08-27 18:02:45 +05:30
name = module . params [ ' name ' ]
2015-08-27 02:26:42 +05:30
service_key = module . params [ ' service_key ' ]
2015-08-27 18:02:45 +05:30
api_key = module . params [ ' api_key ' ]
state = module . params [ ' state ' ]
2015-08-27 02:26:42 +05:30
client = module . params [ ' client ' ]
client_url = module . params [ ' client_url ' ]
desc = module . params [ ' desc ' ]
incident_key = module . params [ ' incident_key ' ]
2015-08-27 18:02:45 +05:30
state_event_dict = {
' triggered ' : ' trigger ' ,
' acknowledged ' : ' acknowledge ' ,
' resolved ' : ' resolve '
}
event_type = state_event_dict [ state ]
2015-08-27 02:26:42 +05:30
if event_type != ' trigger ' and incident_key is None :
module . fail_json ( msg = " incident_key is required for "
" acknowledge or resolve events " )
2015-08-27 18:02:45 +05:30
out , changed = check ( module , name , state ,
service_key , api_key , incident_key )
if not module . check_mode and changed is True :
out = send_event ( module , service_key , event_type , desc ,
incident_key , client , client_url )
2015-08-27 02:26:42 +05:30
2015-08-27 18:02:45 +05:30
module . exit_json ( result = out , changed = changed )
2015-08-27 02:26:42 +05:30
# import module snippets
from ansible . module_utils . basic import *
from ansible . module_utils . urls import *
if __name__ == ' __main__ ' :
main ( )