Skip to content

Instantly share code, notes, and snippets.

@julianeon
Last active December 28, 2015 16:58
Show Gist options
  • Save julianeon/7532201 to your computer and use it in GitHub Desktop.
Save julianeon/7532201 to your computer and use it in GitHub Desktop.
Ruby script to trigger incidents using the API.
# Ruby 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.
require 'json'
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_name_optional"
subject="Insert a title here to summarize your incident; use the hash format below to include details."
details_hash={"insert_thing1" => "insert_detail1", "insert_thing2" => "insert_detail2"}
def curl_command_post_schedules(token_string,schedule_json,endpoint)
curl_command='curl -H "Content-type: application/json" -X POST -d '+schedule_json+' "'+endpoint+'"'
end
def hash_to_json(hash)
string=""
hash.each do |key,value|
string+="\"#{key}\": \"#{value}\", "
end
string
end
sched_json= '\'{
"service_key": "'+service_access_key+'",
"event_type": "trigger",
"description": "'+subject+'",
"details": { '+hash_to_json(details_hash)+' }
}\''
# "incident_key": "'+incident_key+'",
#this can be included if you'd like to define the incident key; just remove the # to uncomment, and paste the line
#below the "service_key" line
curl_string = curl_command_post_schedules(api_key,sched_json,endpoint)
puts curl_string
system(curl_string)
def pipe_to_script(curl_string)
IO.popen(curl_string).each do |line|
parsed=JSON.parse(line)
puts parsed
end
end
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment