class Minicron::PagerDuty
Allows the sending of pagerduty alerts
Public Class Methods
new()
click to toggle source
Used to set up on the pagerduty client
# File lib/minicron/alert/pagerduty.rb, line 7 def initialize # Get an instance of the Pagerduty client @client = ::Pagerduty.new(Minicron.config['alerts']['pagerduty']['service_key']) end
Public Instance Methods
get_message(options = {})
click to toggle source
Return the message for an alert
@option options [Minicron::Hub::Job] job a job instance @option options [String] kind 'fail' or 'miss' @option options [Integer, nil] schedule_id only applies to 'miss' alerts @option options [Integer, nil] execution_id only used by 'fail' alerts @option options [Integer] job_id used to look up the job name for the alert message @option options [Time] expected_at when the schedule was expected to execute @option options [String] medium the medium to send the alert via
# File lib/minicron/alert/pagerduty.rb, line 21 def get_message(options = {}) case options[:kind] when 'miss' "Job ##{options[:job_id]} failed to execute at its expected time - #{options[:expected_at]}" when 'fail' "Execution ##{options[:execution_id]} of Job ##{options[:job_id]} failed" else fail Exception, "The kind '#{options[:kind]} is not supported!" end end
send(title, message)
click to toggle source
Send a pager duty alert
@param title [String] @param message [String]
# File lib/minicron/alert/pagerduty.rb, line 36 def send(title, message) @client.trigger(title, :message => message) end