1
0
Fork 0
mirror of https://github.com/fog/fog-aws.git synced 2022-11-09 13:50:52 -05:00
fog--fog-aws/lib/fog/aws/errors.rb

36 lines
1.4 KiB
Ruby
Raw Normal View History

2015-03-28 13:05:19 -04:00
module Fog
module AWS
module Errors
def self.match_error(error)
if !Fog::AWS.json_response?(error.response)
matchers = [
lambda {|s| s.match(/(?:.*<Code>(.*)<\/Code>)(?:.*<Message>(.*)<\/Message>)/m)},
lambda {|s| s.match(/.*<(.+Exception)>(?:.*<Message>(.*)<\/Message>)/m)}
]
[error.message, error.response.body].each(&Proc.new {|s|
matchers.each do |matcher|
match = matcher.call(s)
return {:code => match[1].split('.').last, :message => match[2]} if match
end
})
else
begin
full_msg_error = Fog::JSON.decode(error.response.body)
if (full_msg_error.has_key?('Message') || full_msg_error.has_key?('message')) &&
2015-06-24 11:53:33 -04:00
(error.response.headers.has_key?('x-amzn-ErrorType') || full_msg_error.has_key?('__type'))
matched_error = {
2015-06-24 11:53:33 -04:00
:code => full_msg_error['__type'] || error.response.headers['x-amzn-ErrorType'].split(':').first,
:message => full_msg_error['Message'] || full_msg_error['message']
}
return matched_error
end
rescue Fog::JSON::DecodeError => e
Fog::Logger.warning("Error parsing response json - #{e}")
end
end
2015-03-28 13:05:19 -04:00
{} # we did not match the message or response body
end
end
end
2015-06-24 11:53:33 -04:00
end