aboutsummaryrefslogtreecommitdiff
path: root/lib/mauve/notifiers/pushover.rb
diff options
context:
space:
mode:
Diffstat (limited to 'lib/mauve/notifiers/pushover.rb')
-rw-r--r--lib/mauve/notifiers/pushover.rb114
1 files changed, 114 insertions, 0 deletions
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
+