diff --git a/lib/mauve/configuration_builders/person.rb b/lib/mauve/configuration_builders/person.rb index aac5f69..39b5306 100644 --- a/lib/mauve/configuration_builders/person.rb +++ b/lib/mauve/configuration_builders/person.rb @@ -25,6 +25,7 @@ def builder_setup(username) is_attribute "email" is_attribute "xmpp" is_attribute "hipchat" + is_attribute "pushover" is_flag_attribute "notify_when_on_holiday" is_flag_attribute "notify_when_off_sick" diff --git a/lib/mauve/notifiers.rb b/lib/mauve/notifiers.rb index 383db5e..1195860 100644 --- a/lib/mauve/notifiers.rb +++ b/lib/mauve/notifiers.rb @@ -4,6 +4,7 @@ require 'mauve/notifiers/sms_clockwork' require 'mauve/notifiers/xmpp' require 'mauve/notifiers/hipchat' +require 'mauve/notifiers/pushover' module Mauve # diff --git a/lib/mauve/notifiers/hipchat.rb b/lib/mauve/notifiers/hipchat.rb index 7537bc5..dd549ac 100644 --- a/lib/mauve/notifiers/hipchat.rb +++ b/lib/mauve/notifiers/hipchat.rb @@ -42,7 +42,6 @@ def send_alert(destination, alert, all_alerts, conditions = {}) "notify" => true, } - uri = @gateway.dup # diff --git a/lib/mauve/notifiers/pushover.rb b/lib/mauve/notifiers/pushover.rb new file mode 100644 index 0000000..39caaf6 --- /dev/null +++ b/lib/mauve/notifiers/pushover.rb @@ -0,0 +1,114 @@ +require 'mauve/notifiers/debug' + +module Mauve + module Notifiers + require 'net/https' + require 'json' + require 'cgi' + require 'uri' + + class Pushover + + attr_accessor :token + attr_reader :name + + def initialize(name) + @name = name + end + + def gateway + @gateway + end + + def gateway=(uri) + @gateway = URI.parse(uri) + end + + def send_alert(destination, alert, all_alerts, conditions = {}) + msg = prepare_message(destination, alert, all_alerts, conditions) + + priority = case alert.level + when :urgent + 1 + when :normal + 0 + else + -1 + end + + opts = { + "priority" => priority, + "message" => msg, + "url" => WebInterface.url_for(alert), + "url_title" => "View alert", + "html" => 1, + } + + uri = @gateway.dup + uri.path = "/1/messages.json" + + # + # If the destination is an email, it is a user + # + if destination =~ /@/ + (device,user) = destination.split(/@/,2) + opts['device'] = device + opts['user'] = user + else + opts['user'] = user + end + + uri.query = "auth_token="+CGI::escape(self.token) + + http = Net::HTTP.new(uri.host, uri.port) + + if uri.port == 443 + http.use_ssl = true + http.verify_mode = OpenSSL::SSL::VERIFY_PEER + end + + case alert.update_type + when "cleared" + opts['timestamp'] = alert.cleared_at + when "acknowledged" + opts['timestamp'] = alert.acknowledged_at + else + opts['timestamp'] = alert.raised_at + end + + response, data = http.post(uri.request_uri, opts, { + 'Content-Type' => 'application/json', + 'Content-Length' => opts.length.to_s + }) + + if response.kind_of?(Net::HTTPSuccess) + # + # Woo -- return true! + # + true + else + false + end + + end + + protected + + def prepare_message(destination, alert, all_alerts, conditions={}) + was_suppressed = conditions[:was_suppressed] || false + will_suppress = conditions[:will_suppress] || false + + template_file = File.join(File.dirname(__FILE__),"templates","pushover.html.erb") + + txt = if File.exists?(template_file) + ERB.new(File.read(template_file)).result(binding).chomp + else + logger.error("Could not find #{template_file} template") + alert.to_s + end + end + + end + end +end + diff --git a/lib/mauve/notifiers/templates/pushover.html.erb b/lib/mauve/notifiers/templates/pushover.html.erb new file mode 100644 index 0000000..4506c57 --- /dev/null +++ b/lib/mauve/notifiers/templates/pushover.html.erb @@ -0,0 +1,22 @@ +<%= alert.id%>: <%= alert.update_type.upcase %> (<%= alert.level %>): <% +case alert.update_type +when "cleared" +%><%= alert.cleared_at.to_s_relative %><% +when "acknowledged" +%><%= alert.acknowledged_at.to_s_relative %> by <%= alert.acknowledged_by %> until <%= alert.will_unacknowledge_at.to_s_human %><% +else +%><%= alert.raised_at.to_s_relative %><% +end +%>: <%= alert.subject %> <%= alert.summary %><% +if alert.source != alert.subject +%> -- from <%= alert.source %><% +end +%>.<% +if defined? was_suppressed and defined? will_suppress + if was_suppressed and not will_suppress +%>
Normal service for <%= alert.level %> alerts has resumed.<% + elsif will_suppress and not was_suppressed +%>
Further <%= alert.level %> alerts suppressed until things calm down.<% + end +end +%> diff --git a/lib/mauve/person.rb b/lib/mauve/person.rb index 1e26835..9a5644e 100644 --- a/lib/mauve/person.rb +++ b/lib/mauve/person.rb @@ -18,7 +18,7 @@ def initialize(username) @username = username @password = nil @urgent = @normal = @low = nil - @email = @sms = @xmpp = @hipchat = nil + @email = @sms = @xmpp = @hipchat = @pushover = nil @notify_when_on_holiday = @notify_when_off_sick = false end @@ -92,6 +92,14 @@ def hipchat=(arg) @hipchat = arg end + # Sets up the pushover parameter + # + # + def pushover=(arg) + raise ArgumentError, "pushover expected a string, not a #{arg.class}" unless arg.is_a?(String) + @pushover = arg + end + # Sets the password parameter # #