faraday 0.12.2 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/CHANGELOG.md +350 -0
- data/LICENSE.md +1 -1
- data/README.md +22 -325
- data/Rakefile +7 -0
- data/examples/client_spec.rb +65 -0
- data/examples/client_test.rb +79 -0
- data/lib/faraday.rb +120 -188
- data/lib/faraday/adapter.rb +84 -22
- data/lib/faraday/adapter/em_http.rb +150 -104
- data/lib/faraday/adapter/em_http_ssl_patch.rb +24 -18
- data/lib/faraday/adapter/em_synchrony.rb +110 -63
- data/lib/faraday/adapter/em_synchrony/parallel_manager.rb +18 -15
- data/lib/faraday/adapter/excon.rb +98 -54
- data/lib/faraday/adapter/httpclient.rb +83 -59
- data/lib/faraday/adapter/net_http_persistent.rb +68 -27
- data/lib/faraday/adapter/patron.rb +86 -37
- data/lib/faraday/adapter/rack.rb +30 -13
- data/lib/faraday/adapter/test.rb +103 -62
- data/lib/faraday/adapter/typhoeus.rb +7 -115
- data/lib/faraday/adapter_registry.rb +30 -0
- data/lib/faraday/autoload.rb +46 -36
- data/lib/faraday/connection.rb +336 -177
- data/lib/faraday/dependency_loader.rb +37 -0
- data/lib/faraday/encoders/flat_params_encoder.rb +105 -0
- data/lib/faraday/encoders/nested_params_encoder.rb +176 -0
- data/lib/faraday/error.rb +126 -37
- data/lib/faraday/file_part.rb +128 -0
- data/lib/faraday/logging/formatter.rb +105 -0
- data/lib/faraday/methods.rb +6 -0
- data/lib/faraday/middleware.rb +19 -25
- data/lib/faraday/middleware_registry.rb +129 -0
- data/lib/faraday/options.rb +39 -193
- data/lib/faraday/options/connection_options.rb +22 -0
- data/lib/faraday/options/env.rb +181 -0
- data/lib/faraday/options/proxy_options.rb +28 -0
- data/lib/faraday/options/request_options.rb +22 -0
- data/lib/faraday/options/ssl_options.rb +59 -0
- data/lib/faraday/param_part.rb +53 -0
- data/lib/faraday/parameters.rb +4 -196
- data/lib/faraday/rack_builder.rb +77 -63
- data/lib/faraday/request.rb +94 -32
- data/lib/faraday/request/authorization.rb +44 -30
- data/lib/faraday/request/basic_authentication.rb +14 -7
- data/lib/faraday/request/instrumentation.rb +45 -27
- data/lib/faraday/request/multipart.rb +86 -48
- data/lib/faraday/request/retry.rb +209 -134
- data/lib/faraday/request/token_authentication.rb +15 -10
- data/lib/faraday/request/url_encoded.rb +43 -23
- data/lib/faraday/response.rb +27 -23
- data/lib/faraday/response/logger.rb +22 -69
- data/lib/faraday/response/raise_error.rb +49 -14
- data/lib/faraday/utils.rb +38 -247
- data/lib/faraday/utils/headers.rb +139 -0
- data/lib/faraday/utils/params_hash.rb +61 -0
- data/lib/faraday/version.rb +5 -0
- data/spec/external_adapters/faraday_specs_setup.rb +14 -0
- data/spec/faraday/adapter/em_http_spec.rb +47 -0
- data/spec/faraday/adapter/em_synchrony_spec.rb +16 -0
- data/spec/faraday/adapter/excon_spec.rb +49 -0
- data/spec/faraday/adapter/httpclient_spec.rb +73 -0
- data/spec/faraday/adapter/net_http_persistent_spec.rb +57 -0
- data/spec/faraday/adapter/net_http_spec.rb +64 -0
- data/spec/faraday/adapter/patron_spec.rb +18 -0
- data/spec/faraday/adapter/rack_spec.rb +8 -0
- data/spec/faraday/adapter/test_spec.rb +260 -0
- data/spec/faraday/adapter/typhoeus_spec.rb +7 -0
- data/spec/faraday/adapter_registry_spec.rb +28 -0
- data/spec/faraday/adapter_spec.rb +55 -0
- data/spec/faraday/composite_read_io_spec.rb +80 -0
- data/spec/faraday/connection_spec.rb +691 -0
- data/spec/faraday/error_spec.rb +60 -0
- data/spec/faraday/middleware_spec.rb +52 -0
- data/spec/faraday/options/env_spec.rb +70 -0
- data/spec/faraday/options/options_spec.rb +297 -0
- data/spec/faraday/options/proxy_options_spec.rb +37 -0
- data/spec/faraday/options/request_options_spec.rb +19 -0
- data/spec/faraday/params_encoders/flat_spec.rb +42 -0
- data/spec/faraday/params_encoders/nested_spec.rb +142 -0
- data/spec/faraday/rack_builder_spec.rb +345 -0
- data/spec/faraday/request/authorization_spec.rb +88 -0
- data/spec/faraday/request/instrumentation_spec.rb +76 -0
- data/spec/faraday/request/multipart_spec.rb +302 -0
- data/spec/faraday/request/retry_spec.rb +242 -0
- data/spec/faraday/request/url_encoded_spec.rb +83 -0
- data/spec/faraday/request_spec.rb +120 -0
- data/spec/faraday/response/logger_spec.rb +220 -0
- data/spec/faraday/response/middleware_spec.rb +68 -0
- data/spec/faraday/response/raise_error_spec.rb +169 -0
- data/spec/faraday/response_spec.rb +75 -0
- data/spec/faraday/utils/headers_spec.rb +82 -0
- data/spec/faraday/utils_spec.rb +56 -0
- data/spec/faraday_spec.rb +37 -0
- data/spec/spec_helper.rb +132 -0
- data/spec/support/disabling_stub.rb +14 -0
- data/spec/support/fake_safe_buffer.rb +15 -0
- data/spec/support/helper_methods.rb +133 -0
- data/spec/support/shared_examples/adapter.rb +105 -0
- data/spec/support/shared_examples/params_encoder.rb +18 -0
- data/spec/support/shared_examples/request_method.rb +262 -0
- data/spec/support/streaming_response_checker.rb +35 -0
- data/spec/support/webmock_rack_app.rb +68 -0
- metadata +109 -10
- data/lib/faraday/adapter/net_http.rb +0 -135
- data/lib/faraday/upload_io.rb +0 -67
@@ -1,135 +0,0 @@
|
|
1
|
-
begin
|
2
|
-
require 'net/https'
|
3
|
-
rescue LoadError
|
4
|
-
warn "Warning: no such file to load -- net/https. Make sure openssl is installed if you want ssl support"
|
5
|
-
require 'net/http'
|
6
|
-
end
|
7
|
-
require 'zlib'
|
8
|
-
|
9
|
-
module Faraday
|
10
|
-
class Adapter
|
11
|
-
class NetHttp < Faraday::Adapter
|
12
|
-
NET_HTTP_EXCEPTIONS = [
|
13
|
-
IOError,
|
14
|
-
Errno::ECONNABORTED,
|
15
|
-
Errno::ECONNREFUSED,
|
16
|
-
Errno::ECONNRESET,
|
17
|
-
Errno::EHOSTUNREACH,
|
18
|
-
Errno::EINVAL,
|
19
|
-
Errno::ENETUNREACH,
|
20
|
-
Errno::EPIPE,
|
21
|
-
Net::HTTPBadResponse,
|
22
|
-
Net::HTTPHeaderSyntaxError,
|
23
|
-
Net::ProtocolError,
|
24
|
-
SocketError,
|
25
|
-
Zlib::GzipFile::Error,
|
26
|
-
]
|
27
|
-
|
28
|
-
NET_HTTP_EXCEPTIONS << OpenSSL::SSL::SSLError if defined?(OpenSSL)
|
29
|
-
NET_HTTP_EXCEPTIONS << Net::OpenTimeout if defined?(Net::OpenTimeout)
|
30
|
-
|
31
|
-
def call(env)
|
32
|
-
super
|
33
|
-
with_net_http_connection(env) do |http|
|
34
|
-
configure_ssl(http, env[:ssl]) if env[:url].scheme == 'https' and env[:ssl]
|
35
|
-
configure_request(http, env[:request])
|
36
|
-
|
37
|
-
begin
|
38
|
-
http_response = perform_request(http, env)
|
39
|
-
rescue *NET_HTTP_EXCEPTIONS => err
|
40
|
-
if defined?(OpenSSL) && OpenSSL::SSL::SSLError === err
|
41
|
-
raise Faraday::SSLError, err
|
42
|
-
else
|
43
|
-
raise Error::ConnectionFailed, err
|
44
|
-
end
|
45
|
-
end
|
46
|
-
|
47
|
-
save_response(env, http_response.code.to_i, http_response.body || '', nil, http_response.message) do |response_headers|
|
48
|
-
http_response.each_header do |key, value|
|
49
|
-
response_headers[key] = value
|
50
|
-
end
|
51
|
-
end
|
52
|
-
end
|
53
|
-
|
54
|
-
@app.call env
|
55
|
-
rescue Timeout::Error, Errno::ETIMEDOUT => err
|
56
|
-
raise Faraday::Error::TimeoutError, err
|
57
|
-
end
|
58
|
-
|
59
|
-
def create_request(env)
|
60
|
-
request = Net::HTTPGenericRequest.new \
|
61
|
-
env[:method].to_s.upcase, # request method
|
62
|
-
!!env[:body], # is there request body
|
63
|
-
:head != env[:method], # is there response body
|
64
|
-
env[:url].request_uri, # request uri path
|
65
|
-
env[:request_headers] # request headers
|
66
|
-
|
67
|
-
if env[:body].respond_to?(:read)
|
68
|
-
request.body_stream = env[:body]
|
69
|
-
else
|
70
|
-
request.body = env[:body]
|
71
|
-
end
|
72
|
-
request
|
73
|
-
end
|
74
|
-
|
75
|
-
def perform_request(http, env)
|
76
|
-
if :get == env[:method] and !env[:body]
|
77
|
-
# prefer `get` to `request` because the former handles gzip (ruby 1.9)
|
78
|
-
http.get env[:url].request_uri, env[:request_headers]
|
79
|
-
else
|
80
|
-
http.request create_request(env)
|
81
|
-
end
|
82
|
-
end
|
83
|
-
|
84
|
-
def with_net_http_connection(env)
|
85
|
-
yield net_http_connection(env)
|
86
|
-
end
|
87
|
-
|
88
|
-
def net_http_connection(env)
|
89
|
-
if proxy = env[:request][:proxy]
|
90
|
-
Net::HTTP::Proxy(proxy[:uri].host, proxy[:uri].port, proxy[:user], proxy[:password])
|
91
|
-
else
|
92
|
-
Net::HTTP
|
93
|
-
end.new(env[:url].host, env[:url].port || (env[:url].scheme == 'https' ? 443 : 80))
|
94
|
-
end
|
95
|
-
|
96
|
-
def configure_ssl(http, ssl)
|
97
|
-
http.use_ssl = true
|
98
|
-
http.verify_mode = ssl_verify_mode(ssl)
|
99
|
-
http.cert_store = ssl_cert_store(ssl)
|
100
|
-
|
101
|
-
http.cert = ssl[:client_cert] if ssl[:client_cert]
|
102
|
-
http.key = ssl[:client_key] if ssl[:client_key]
|
103
|
-
http.ca_file = ssl[:ca_file] if ssl[:ca_file]
|
104
|
-
http.ca_path = ssl[:ca_path] if ssl[:ca_path]
|
105
|
-
http.verify_depth = ssl[:verify_depth] if ssl[:verify_depth]
|
106
|
-
http.ssl_version = ssl[:version] if ssl[:version]
|
107
|
-
end
|
108
|
-
|
109
|
-
def configure_request(http, req)
|
110
|
-
http.read_timeout = http.open_timeout = req[:timeout] if req[:timeout]
|
111
|
-
http.open_timeout = req[:open_timeout] if req[:open_timeout]
|
112
|
-
|
113
|
-
@config_block.call(http) if @config_block
|
114
|
-
end
|
115
|
-
|
116
|
-
def ssl_cert_store(ssl)
|
117
|
-
return ssl[:cert_store] if ssl[:cert_store]
|
118
|
-
# Use the default cert store by default, i.e. system ca certs
|
119
|
-
cert_store = OpenSSL::X509::Store.new
|
120
|
-
cert_store.set_default_paths
|
121
|
-
cert_store
|
122
|
-
end
|
123
|
-
|
124
|
-
def ssl_verify_mode(ssl)
|
125
|
-
ssl[:verify_mode] || begin
|
126
|
-
if ssl.fetch(:verify, true)
|
127
|
-
OpenSSL::SSL::VERIFY_PEER
|
128
|
-
else
|
129
|
-
OpenSSL::SSL::VERIFY_NONE
|
130
|
-
end
|
131
|
-
end
|
132
|
-
end
|
133
|
-
end
|
134
|
-
end
|
135
|
-
end
|
data/lib/faraday/upload_io.rb
DELETED
@@ -1,67 +0,0 @@
|
|
1
|
-
begin
|
2
|
-
require 'composite_io'
|
3
|
-
require 'parts'
|
4
|
-
require 'stringio'
|
5
|
-
rescue LoadError
|
6
|
-
$stderr.puts "Install the multipart-post gem."
|
7
|
-
raise
|
8
|
-
end
|
9
|
-
|
10
|
-
module Faraday
|
11
|
-
# Similar but not compatible with ::CompositeReadIO provided by multipart-post.
|
12
|
-
class CompositeReadIO
|
13
|
-
def initialize(*parts)
|
14
|
-
@parts = parts.flatten
|
15
|
-
@ios = @parts.map { |part| part.to_io }
|
16
|
-
@index = 0
|
17
|
-
end
|
18
|
-
|
19
|
-
def length
|
20
|
-
@parts.inject(0) { |sum, part| sum + part.length }
|
21
|
-
end
|
22
|
-
|
23
|
-
def rewind
|
24
|
-
@ios.each { |io| io.rewind }
|
25
|
-
@index = 0
|
26
|
-
end
|
27
|
-
|
28
|
-
# Read from IOs in order until `length` bytes have been received.
|
29
|
-
def read(length = nil, outbuf = nil)
|
30
|
-
got_result = false
|
31
|
-
outbuf = outbuf ? outbuf.replace("") : ""
|
32
|
-
|
33
|
-
while io = current_io
|
34
|
-
if result = io.read(length)
|
35
|
-
got_result ||= !result.nil?
|
36
|
-
result.force_encoding("BINARY") if result.respond_to?(:force_encoding)
|
37
|
-
outbuf << result
|
38
|
-
length -= result.length if length
|
39
|
-
break if length == 0
|
40
|
-
end
|
41
|
-
advance_io
|
42
|
-
end
|
43
|
-
(!got_result && length) ? nil : outbuf
|
44
|
-
end
|
45
|
-
|
46
|
-
def close
|
47
|
-
@ios.each { |io| io.close }
|
48
|
-
end
|
49
|
-
|
50
|
-
def ensure_open_and_readable
|
51
|
-
# Rubinius compatibility
|
52
|
-
end
|
53
|
-
|
54
|
-
private
|
55
|
-
|
56
|
-
def current_io
|
57
|
-
@ios[@index]
|
58
|
-
end
|
59
|
-
|
60
|
-
def advance_io
|
61
|
-
@index += 1
|
62
|
-
end
|
63
|
-
end
|
64
|
-
|
65
|
-
UploadIO = ::UploadIO
|
66
|
-
Parts = ::Parts
|
67
|
-
end
|