Class: Faraday::Adapter::HTTPClient
Constant Summary
CONTENT_LENGTH
Instance Attribute Summary
Attributes included from Parallelism
#supports_parallel
Instance Method Summary
collapse
#save_response
#inherited, #supports_parallel?
#all_loaded_constants, #autoload_all, #load_autoloaded_constants
Methods inherited from Middleware
dependency, inherited, #initialize, loaded?, new
#fetch_middleware, #load_middleware, #lookup_middleware, #middleware_mutex, #register_middleware
Instance Method Details
#call(env) ⇒ Object
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
# File 'lib/faraday/adapter/httpclient.rb', line 10
def call(env)
super
client.transparent_gzip_decompression = true
if req = env[:request]
if proxy = req[:proxy]
configure_proxy proxy
end
if bind = req[:bind]
configure_socket bind
end
configure_timeouts req
end
if env[:url].scheme == 'https' && ssl = env[:ssl]
configure_ssl ssl
end
env[:body] = env[:body].read if env[:body].respond_to? :read
resp = client.request env[:method], env[:url],
:body => env[:body],
:header => env[:request_headers]
save_response env, resp.status, resp.body, resp.
@app.call env
rescue ::HTTPClient::TimeoutError, Errno::ETIMEDOUT
raise Faraday::Error::TimeoutError, $!
rescue ::HTTPClient::BadResponseError => err
if err.message.include?('status 407')
raise Faraday::Error::ConnectionFailed, %{407 "Proxy Authentication Required "}
else
raise Faraday::Error::ClientError, $!
end
rescue Errno::ECONNREFUSED, EOFError
raise Faraday::Error::ConnectionFailed, $!
rescue => err
if defined?(OpenSSL) && OpenSSL::SSL::SSLError === err
raise Faraday::SSLError, err
else
raise
end
end
|
6
7
8
|
# File 'lib/faraday/adapter/httpclient.rb', line 6
def client
@client ||= ::HTTPClient.new
end
|
66
67
68
69
70
71
|
# File 'lib/faraday/adapter/httpclient.rb', line 66
def configure_proxy(proxy)
client.proxy = proxy[:uri]
if proxy[:user] && proxy[:password]
client.set_proxy_auth proxy[:user], proxy[:password]
end
end
|
61
62
63
64
|
# File 'lib/faraday/adapter/httpclient.rb', line 61
def configure_socket(bind)
client.socket_local.host = bind[:host]
client.socket_local.port = bind[:port]
end
|
73
74
75
76
77
78
79
80
81
82
83
|
# File 'lib/faraday/adapter/httpclient.rb', line 73
def configure_ssl(ssl)
ssl_config = client.ssl_config
ssl_config.verify_mode = ssl_verify_mode(ssl)
ssl_config.cert_store = ssl_cert_store(ssl)
ssl_config.add_trust_ca ssl[:ca_file] if ssl[:ca_file]
ssl_config.add_trust_ca ssl[:ca_path] if ssl[:ca_path]
ssl_config.client_cert = ssl[:client_cert] if ssl[:client_cert]
ssl_config.client_key = ssl[:client_key] if ssl[:client_key]
ssl_config.verify_depth = ssl[:verify_depth] if ssl[:verify_depth]
end
|
85
86
87
88
89
90
91
92
93
94
95
96
|
# File 'lib/faraday/adapter/httpclient.rb', line 85
def configure_timeouts(req)
if req[:timeout]
client.connect_timeout = req[:timeout]
client.receive_timeout = req[:timeout]
client.send_timeout = req[:timeout]
end
if req[:open_timeout]
client.connect_timeout = req[:open_timeout]
client.send_timeout = req[:open_timeout]
end
end
|
#ssl_cert_store(ssl) ⇒ Object
98
99
100
101
102
103
104
|
# File 'lib/faraday/adapter/httpclient.rb', line 98
def ssl_cert_store(ssl)
return ssl[:cert_store] if ssl[:cert_store]
cert_store = OpenSSL::X509::Store.new
cert_store.set_default_paths
cert_store
end
|
#ssl_verify_mode(ssl) ⇒ Object
106
107
108
109
110
111
112
113
114
|
# File 'lib/faraday/adapter/httpclient.rb', line 106
def ssl_verify_mode(ssl)
ssl[:verify_mode] || begin
if ssl.fetch(:verify, true)
OpenSSL::SSL::VERIFY_PEER | OpenSSL::SSL::VERIFY_FAIL_IF_NO_PEER_CERT
else
OpenSSL::SSL::VERIFY_NONE
end
end
end
|