module AWS::Core::Signature::Version3
def self.included base
def self.included base base.send(:include, Signer) end
def add_authorization! credentials
def add_authorization! credentials headers["x-amz-date"] ||= (headers["date"] ||= Time.now.httpdate) headers["host"] ||= host headers["x-amz-security-token"] = credentials.session_token if credentials.session_token # compute the authorization headers["x-amzn-authorization"] = "AWS3 "+ "AWSAccessKeyId=#{credentials.access_key_id},"+ "Algorithm=HmacSHA256,"+ "SignedHeaders=#{headers_to_sign.join(';')},"+ "Signature=#{signature(credentials)}" end
def canonical_headers
def canonical_headers headers_to_sign.map do |name| value = headers[name] "#{name.downcase.strip}:#{value.strip}\n" end.sort.join end
def headers_to_sign
def headers_to_sign headers.keys.select do |header| header == "host" || header == "content-encoding" || header =~ /^x-amz/ end end
def signature credentials
def signature credentials Signer.sign(credentials.secret_access_key, string_to_sign) end
def string_to_sign
def string_to_sign OpenSSL::Digest::SHA256.digest([ http_method, "/", "", canonical_headers, body ].join("\n")) end