Sha256: c5614f991d65ca11bc6556cb07fd7fa3fe6fb63ba6fbc82758c54eee50e11c8a
Contents?: true
Size: 1.7 KB
Versions: 2
Compression:
Stored size: 1.7 KB
Contents
class OpenpayExceptionFactory def OpenpayExceptionFactory::create(exception) LOG.warn("An exception has been raised (original exception class: #{exception.class})") case exception #resource not found #malformed jason, invalid data, invalid request when RestClient::BadRequest, RestClient::ResourceNotFound, RestClient::Conflict, RestClient::PaymentRequired, RestClient::UnprocessableEntity oe=OpenpayTransactionException.new exception.http_body LOG.warn "-OpenpayTransactionException: #{exception.http_body}" @errors=true raise oe #connection, timeouts, network related errors when Errno::EADDRINUSE, Errno::ETIMEDOUT, OpenSSL::SSL::SSLError #since this exceptions are not based on the rest api exceptions #we do not have the json message so we just build the exception #with the original exception message set in e.description and e.message oe=OpenpayConnectionException.new(exception.message,false) LOG.warn exception.message @errors=true raise oe #badgateway-connection error, invalid credentials when RestClient::BadGateway, RestClient::Unauthorized oe=OpenpayConnectionException.new exception.http_body LOG.warn exception.http_body @errors=true raise oe when RestClient::Exception , RestClient::InternalServerError oe=OpenpayException.new exception.http_body LOG.warn exception.http_body @errors=true raise oe else #We won't hide unknown exceptions , those should be raised LOG.warn exception.message raise exception end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
openpay-1.0.5 | lib/openpay/errors/openpay_exception_factory.rb |
openpay-1.0.4 | lib/openpay/errors/openpay_exception_factory.rb |