Sha256: 6aea1aac0a0ef1f68b3f6a3da89c9009c5c526e06bccbc326e4f9a081aaba347
Contents?: true
Size: 1.89 KB
Versions: 2
Compression:
Stored size: 1.89 KB
Contents
module ActiveMerchant #:nodoc: module PostsData #:nodoc: def self.included(base) base.superclass_delegating_accessor :ssl_strict base.ssl_strict = true base.class_attribute :retry_safe base.retry_safe = false base.superclass_delegating_accessor :open_timeout base.open_timeout = 60 base.superclass_delegating_accessor :read_timeout base.read_timeout = 60 base.superclass_delegating_accessor :logger base.superclass_delegating_accessor :wiredump_device end def ssl_get(endpoint, headers={}) ssl_request(:get, endpoint, nil, headers) end def ssl_post(endpoint, data, headers = {}) ssl_request(:post, endpoint, data, headers) end def ssl_request(method, endpoint, data, headers) handle_response(raw_ssl_request(method, endpoint, data, headers)) end def raw_ssl_request(method, endpoint, data, headers = {}) logger.warn "#{self.class} using ssl_strict=false, which is insecure" if logger unless ssl_strict connection = new_connection(endpoint) connection.open_timeout = open_timeout connection.read_timeout = read_timeout connection.retry_safe = retry_safe connection.verify_peer = ssl_strict connection.logger = logger connection.tag = self.class.name connection.wiredump_device = wiredump_device connection.pem = @options[:pem] if @options connection.pem_password = @options[:pem_password] if @options connection.ignore_http_status = @options[:ignore_http_status] if @options connection.request(method, data, headers) end private def new_connection(endpoint) Connection.new(endpoint) end def handle_response(response) case response.code.to_i when 200...300 response.body else raise ResponseError.new(response) end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
active_utils-1.0.5 | lib/active_utils/common/posts_data.rb |
active_utils-1.0.4 | lib/active_utils/common/posts_data.rb |