class UptimeRobot::Client ENDPOINT = 'http://api.uptimerobot.com' USER_AGENT = "Ruby UptimeRobot Client #{UptimeRobot::VERSION}" METHODS = [ :getAccountDetails, :getMonitors, :newMonitor, :editMonitor, :deleteMonitor, :getAlertContacts, :newAlertContact, :deleteAlertContact ] DEFAULT_ADAPTERS = [ Faraday::Adapter::NetHttp, Faraday::Adapter::Test ] OPTIONS = [ :apiKey, :raise_no_monitors_error, :skip_unescape_monitor ] def initialize(options) @options = {} OPTIONS.each do |key| @options[key] = options.delete(key) end raise ArgumentError, ':apiKey is required' unless @options[:apiKey] options[:url] ||= ENDPOINT @conn = Faraday.new(options) do |faraday| faraday.request :url_encoded faraday.response :json, :content_type => /\bjson$/ faraday.response :raise_error yield(faraday) if block_given? unless DEFAULT_ADAPTERS.any? {|i| faraday.builder.handlers.include?(i) } faraday.adapter Faraday.default_adapter end end @conn.headers[:user_agent] = USER_AGENT end private def method_missing(method_name, *args, &block) unless METHODS.include?(method_name) raise NoMethodError, "undefined method: #{method_name}" end len = args.length params = args.first unless len.zero? or (len == 1 and params.kind_of?(Hash)) raise ArgumentError, "invalid argument: #{args}" end request(method_name, params || {}, &block) end def request(method_name, params = {}) params.update( :apiKey => @options[:apiKey], :format => 'json', :noJsonCallback => 1 ) response = @conn.get do |req| req.url "/#{method_name}" req.params = params yield(req) if block_given? end json = response.body validate_response!(json) if method_name == :getMonitors and not @options[:skip_unescape_monitor] unescape_monitor!(json) end json end def validate_response!(json) if json['stat'] != 'ok' if json['id'] == '212' if @options[:raise_no_monitors_error] raise UptimeRobot::Error.new(json) else json.update( 'total' => '0', 'monitors' => {'monitor' => []} ) end else raise UptimeRobot::Error.new(json) end end end def unescape_monitor!(json) json['monitors']['monitor'].each do |monitor| %w(friendlyname keywordvalue httpusername httppassword).each do |key| value = monitor[key] || '' next if value.empty? monitor[key] = CGI.unescapeHTML(value) end end end end