Skip to content

Instantly share code, notes, and snippets.

@julianeon
Last active December 28, 2015 17:29
Show Gist options
  • Save julianeon/7535729 to your computer and use it in GitHub Desktop.
Save julianeon/7535729 to your computer and use it in GitHub Desktop.
Python script to trigger incidents using the API.
# Python script to create events using the API.
#
# Copyright (c) 2014, PagerDuty, Inc. <info@pagerduty.com>
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
# * Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
# * Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
# * Neither the name of PagerDuty Inc nor the
# names of its contributors may be used to endorse or promote products
# derived from this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
# DISCLAIMED. IN NO EVENT SHALL PAGERDUTY INC BE LIABLE FOR ANY
# DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
import os
subdomain="insert_subdomain"
api_key="insert_api_key"
endpoint="https://events.pagerduty.com/generic/2010-04-15/create_event.json"
service_access_key="insert_access_key"
incident_key="insert_incident_key"
subject="Insert a title here to summarize your incident; use the dictionary format below to include details."
details_dict={"insert_thing1":"insert_detail1", "insert_thing2":"insert_detail2"}
print details_dict
def curl_command_post_schedules(token_string,schedule_json,endpoint):
curl_command="curl -H \"Content-type: application/json\" -X POST -d " + schedule_json + " \"" + endpoint + "\""
return curl_command
def dict_to_json(hash):
string=""
for key in details_dict:
string+="\"" + key + "\": \"" + details_dict[key] + "\", "
return string
sched_dict=dict_to_json(details_dict)
sched_json= "'{ \
\"service_key\": \"" + service_access_key + "\", \
\"incident_key\": \"" + incident_key + "\", \
\"event_type\": \"trigger\", \
\"description\": \"" + subject + "\", \
\"details\": {" + sched_dict + "} }'"
curl_string = curl_command_post_schedules(api_key,sched_json,endpoint)
print curl_string
os.system(curl_string)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment