Class: Faraday::Adapter::HTTPClient
Constant Summary
CONTENT_LENGTH
Instance Attribute Summary
Attributes included from Parallelism
#supports_parallel
Instance Method Summary
collapse
adapter?, #prepend_proxy_auth_string, #save_response
#all_loaded_constants, #autoload_all, #load_autoloaded_constants
#lookup_middleware, #register_middleware
#inherited, #supports_parallel?
Methods inherited from Middleware
adapter?, dependency, inherited, #initialize, loaded?, new
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
|
# File 'lib/faraday/adapter/httpclient.rb', line 10
def call(env)
super
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
raise Faraday::Error::TimeoutError, $!
end
|
6
7
8
|
# File 'lib/faraday/adapter/httpclient.rb', line 6
def client
@client ||= ::HTTPClient.new
end
|
49
50
51
52
53
54
|
# File 'lib/faraday/adapter/httpclient.rb', line 49
def configure_proxy(proxy)
client.proxy = proxy[:uri]
if proxy[:user] && proxy[:password]
client.set_proxy_auth proxy[:user], proxy[:password]
end
end
|
44
45
46
47
|
# File 'lib/faraday/adapter/httpclient.rb', line 44
def configure_socket(bind)
client.socket_local.host = bind[:host]
client.socket_local.port = bind[:port]
end
|
56
57
58
59
60
61
62
63
64
65
66
|
# File 'lib/faraday/adapter/httpclient.rb', line 56
def configure_ssl(ssl)
ssl_config = client.ssl_config
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.cert_store = ssl[:cert_store] if ssl[:cert_store]
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]
ssl_config.verify_mode = ssl_verify_mode(ssl)
end
|
68
69
70
71
72
73
74
75
76
77
78
79
|
# File 'lib/faraday/adapter/httpclient.rb', line 68
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_verify_mode(ssl) ⇒ Object
81
82
83
84
85
86
87
88
89
|
# File 'lib/faraday/adapter/httpclient.rb', line 81
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
|