aboutsummaryrefslogtreecommitdiff
path: root/lib/mauve/calendar_interface.rb
diff options
context:
space:
mode:
Diffstat (limited to 'lib/mauve/calendar_interface.rb')
-rw-r--r--lib/mauve/calendar_interface.rb221
1 files changed, 107 insertions, 114 deletions
diff --git a/lib/mauve/calendar_interface.rb b/lib/mauve/calendar_interface.rb
index 20c884c..4479bf4 100644
--- a/lib/mauve/calendar_interface.rb
+++ b/lib/mauve/calendar_interface.rb
@@ -15,132 +15,125 @@ module Mauve
# @author yann Golanski.
class CalendarInterface
- TIMEOUT = 7
-
- public
-
- # Gets a list of ssologin on support.
- #
- # Class method.
- #
- # @param [String] url A Calendar API url.
- # @return [Array] A list of all the username on support.
- def self.get_users_on_support(url)
- result = get_URL(url)
- logger = Log4r::Logger.new "Mauve::CalendarInterface"
- logger.debug("Cheching who is on support: #{result}")
- return result
- end
+ class << self
- # Check to see if the user is on support.
- #
- # Class method.
- #
- # @param [String] url A Calendar API url.
- # @param [String] usr User single sign on.
- # @return [Boolean] True if on support, false otherwise.
- def self.is_user_on_support?(url, usr)
- logger = Log4r::Logger.new "Mauve::CalendarInterface"
- list = get_URL(url)
- if true == list.include?("nobody")
- logger.error("Nobody is on support thus alerts are ignored.")
- return false
+ def logger
+ @logger ||= Log4r::Logger.new(self.to_s)
end
- result = list.include?(usr)
- logger.debug("Cheching if #{usr} is on support: #{result}")
- return result
- end
- # Check to see if the user is on holiday.
- #
- # Class method.
- #
- # @param [String] url A Calendar API url.
- # @param [String] usr User single sign on.
- # @return [Boolean] True if on holiday, false otherwise.
- def self.is_user_on_holiday?(url, usr)
- list = get_URL(url)
- return false if true == list.nil? or true == list.empty?
- pattern = /[\d]{4}-[\d]{2}-[\d]{2}\s[\d]{2}:[\d]{2}:[\d]{2}/
- result = (list[0].match(pattern))? true : false
- logger = Log4r::Logger.new "Mauve::CalendarInterface"
- logger.debug("Cheching if #{usr} is on holiday: #{result}")
- return result
- end
+ # Gets a list of ssologin on support.
+ #
+ # Class method.
+ #
+ # @param [String] url A Calendar API url.
+ # @return [Array] A list of all the username on support.
+ def get_users_on_support(url)
+ result = do_get(url)
-
- private
-
- # Gets a URL from the wide web.
- #
- # Must NOT crash Mauveserver.
- #
- # Class method.
- #
- # @TODO: boot this in its own class since list of ips will need it too.
- #
- # @param [String] url A Calendar API url.
- # @retur [Array] An array of strings, each newline creates an new item.
- def self.get_URL (uri_str, limit = 11)
-
- logger = Log4r::Logger.new "Mauve::CalendarInterface"
-
- if 0 == limit
- logger.warn("HTTP redirect deeper than 11 on #{uri_str}.")
- return false
- end
-
- begin
- uri_str = 'http://' + uri_str unless uri_str.match(uri_str)
- url = URI.parse(uri_str)
- http = Net::HTTP.new(url.host, url.port)
- http.open_timeout = TIMEOUT
- http.read_timeout = TIMEOUT
- if (url.scheme == "https")
- http.use_ssl = true
- http.verify_mode = OpenSSL::SSL::VERIFY_NONE
- end
- response = nil
- if nil == url.query
- response = http.start { http.get(url.path) }
+ if result.is_a?(String)
+ result = result.split("\n")
else
- response = http.start { http.get("#{url.path}?#{url.query}") }
+ result = []
end
- case response
- when Net::HTTPRedirection
- then
- newURL = response['location'].match(/^http/)?
- response['Location']:
- uri_str+response['Location']
- self.getURL(newURL, limit-1)
+
+ return result
+ end
+
+ # Check to see if the user is on support.
+ #
+ # Class method.
+ #
+ # @param [String] url A Calendar API url.
+ # @param [String] usr User single sign on.
+ # @return [Boolean] True if on support, false otherwise.
+ def is_user_on_support?(url, usr)
+ return get_users_on_support(url).include?(usr)
+ end
+
+ # Check to see if the user is on holiday.
+ #
+ # Class method.
+ #
+ # @param [String] url A Calendar API url.
+ # @param [String] usr User single sign on.
+ # @return [Boolean] True if on holiday, false otherwise.
+ def is_user_on_holiday?(url, usr)
+ result = do_get(url)
+
+ if result.is_a?(String) and result =~ /^\d{4}(-\d\d){2}[ T](\d\d:){2}\d\d/
+ return result
else
- return response.body.split("\n")
+ return false
end
- rescue Errno::EHOSTUNREACH => ex
- logger.warn("no route to host.")
- return Array.new
- rescue Timeout::Error => ex
- logger.warn("time out reached.")
- return Array.new
- rescue ArgumentError => ex
- unless uri_str.match(/\/$/)
- logger.debug("Potential missing '/' at the end of hostname #{uri_str}")
- uri_str += "/"
- retry
- else
- str = "ArgumentError raise: #{ex.message} #{ex.backtrace.join("\n")}"
- logger.fatal(str)
- return Array.new
- #raise ex
+ end
+
+
+ private
+
+ # Grab a URL from the wide web.
+ #
+ # @TODO: boot this in its own class since list of ips will need it too.
+ #
+ # @param [String] uri -- a URL
+ # @return [String or nil] -- the contents of the URI or nil if an error has been encountered.
+ #
+ def do_get (uri, limit = 11)
+
+ if 0 == limit
+ logger.warn("HTTP redirect too deep for #{uri}.")
+ return nil
+ end
+
+ begin
+ uri = URI.parse(uri) unless uri.is_a?(URI::HTTP)
+
+ raise ArgumentError, "#{uri_str.inspect} doesn't look like an HTTP uri" unless uri.is_a?(URI::HTTP)
+
+ http = Net::HTTP.new(uri.host, uri.port)
+
+ http.open_timeout = http.read_timeout = TIMEOUT
+
+ if (uri.scheme == "https")
+ http.use_ssl = true
+ http.verify_mode = OpenSSL::SSL::VERIFY_NONE
+ end
+
+ response = http.start { http.get(uri.request_uri()) }
+
+ if response.is_a?(Net::HTTPOK)
+ return response.body
+
+ elsif response.is_a?(Net::HTTPRedirection) and response.has_key?('Location')
+ location = response['Location']
+
+ #
+ # Bodge locations..
+ #
+ if location =~ /^\//
+ location = uri.class.build([uri.userinfo, uri.host, uri.port, nil, nil, nil]).to_s + location
+ end
+
+ return do_get(location, limit-1)
+
+ else
+ logger.warn("Request to #{uri.to_s} returned #{response.code} #{response.message}.")
+ return nil
+
+ end
+
+ rescue Timeout::Error => ex
+ logger.error("Time out reached during fetch of #{uri.to_s}.")
+
+ rescue StandardError => ex
+ logger.error("Time out reached during fetch of #{uri.to_s}.")
+
end
- rescue => ex
- str = "ArgumentError raise: #{ex.message} #{ex.backtrace.join("\n")}"
- logger.fatal(str)
- return Array.new
- #raise ex
+
+ return nil
end
end
+
end
end