mirror of
https://github.com/lostisland/faraday.git
synced 2025-11-28 00:03:35 -05:00
84 lines
2.7 KiB
Ruby
84 lines
2.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Faraday
|
|
class Adapter
|
|
# Net::HTTP::Persistent adapter.
|
|
class NetHttpPersistent < NetHttp
|
|
dependency 'net/http/persistent'
|
|
|
|
private
|
|
|
|
def net_http_connection(env)
|
|
@cached_connection ||=
|
|
if Net::HTTP::Persistent.instance_method(:initialize)
|
|
.parameters.first == %i[key name]
|
|
options = { name: 'Faraday' }
|
|
if @connection_options.key?(:pool_size)
|
|
options[:pool_size] = @connection_options[:pool_size]
|
|
end
|
|
Net::HTTP::Persistent.new(options)
|
|
else
|
|
Net::HTTP::Persistent.new('Faraday')
|
|
end
|
|
|
|
proxy_uri = proxy_uri(env)
|
|
if @cached_connection.proxy_uri != proxy_uri
|
|
@cached_connection.proxy = proxy_uri
|
|
end
|
|
@cached_connection
|
|
end
|
|
|
|
def proxy_uri(env)
|
|
proxy_uri = nil
|
|
if (proxy = env[:request][:proxy])
|
|
proxy_uri = if proxy[:uri].is_a?(::URI::HTTP)
|
|
proxy[:uri].dup
|
|
else
|
|
::URI.parse(proxy[:uri].to_s)
|
|
end
|
|
proxy_uri.user = proxy_uri.password = nil
|
|
# awful patch for net-http-persistent 2.8
|
|
# not unescaping user/password
|
|
if proxy[:user]
|
|
(class << proxy_uri; self; end).class_eval do
|
|
define_method(:user) { proxy[:user] }
|
|
define_method(:password) { proxy[:password] }
|
|
end
|
|
end
|
|
end
|
|
proxy_uri
|
|
end
|
|
|
|
def perform_request(http, env)
|
|
http.request env[:url], create_request(env)
|
|
rescue Errno::ETIMEDOUT => e
|
|
raise Faraday::TimeoutError, e
|
|
rescue Net::HTTP::Persistent::Error => e
|
|
raise Faraday::TimeoutError, e if e.message.include? 'Timeout'
|
|
|
|
if e.message.include? 'connection refused'
|
|
raise Faraday::ConnectionFailed, e
|
|
end
|
|
|
|
raise
|
|
end
|
|
|
|
def configure_ssl(http, ssl)
|
|
http_set(http, :verify_mode, ssl_verify_mode(ssl))
|
|
http_set(http, :cert_store, ssl_cert_store(ssl))
|
|
|
|
http_set(http, :certificate, ssl[:client_cert]) if ssl[:client_cert]
|
|
http_set(http, :private_key, ssl[:client_key]) if ssl[:client_key]
|
|
http_set(http, :ca_file, ssl[:ca_file]) if ssl[:ca_file]
|
|
http_set(http, :ssl_version, ssl[:version]) if ssl[:version]
|
|
http_set(http, :min_version, ssl[:min_version]) if ssl[:min_version]
|
|
http_set(http, :max_version, ssl[:max_version]) if ssl[:max_version]
|
|
end
|
|
|
|
def http_set(http, attr, value)
|
|
http.send("#{attr}=", value) if http.send(attr) != value
|
|
end
|
|
end
|
|
end
|
|
end
|