# give access to RestClient @processed_headers module RestClient;class Request;attr_accessor :processed_headers;end;end module ApiAuth module RequestDrivers # :nodoc: class RestClientRequest # :nodoc: include ApiAuth::Helpers def initialize(request) @request = request @headers = fetch_headers true end def set_auth_header(header) @request.headers.merge!({ "Authorization" => header }) @headers = fetch_headers save_headers # enforce update of processed_headers based on last updated headers @request end def calculated_md5 if @request.payload body = @request.payload.read else body = '' end Digest::MD5.base64digest(body) end def populate_content_md5 if [:post, :put].include?(@request.method) @request.headers["Content-MD5"] = calculated_md5 end end def md5_mismatch? if [:post, :put].include?(@request.method) calculated_md5 != content_md5 else false end end def fetch_headers capitalize_keys @request.headers end def content_type value = find_header(%w(CONTENT-TYPE CONTENT_TYPE HTTP_CONTENT_TYPE)) value.nil? ? "" : value end def content_md5 value = find_header(%w(CONTENT-MD5 CONTENT_MD5)) value.nil? ? "" : value end def request_uri @request.url end def set_date @request.headers.merge!({ "DATE" => Time.now.utc.httpdate }) end def timestamp value = find_header(%w(DATE HTTP_DATE)) value.nil? ? "" : value end def authorization_header find_header %w(Authorization AUTHORIZATION HTTP_AUTHORIZATION) end private def find_header(keys) keys.map {|key| @headers[key] }.compact.first end def save_headers @request.processed_headers = @request.make_headers(@headers) end end end end