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