class Selenium::WebDriver::Remote::Http::Default
@api private
def close
def close @http&.finish end
def http
def http @http ||= begin http = new_http_client if server_url.scheme == 'https' http.use_ssl = true http.verify_mode = OpenSSL::SSL::VERIFY_NONE end http.open_timeout = open_timeout if open_timeout http.read_timeout = read_timeout if read_timeout start(http) http end end
def initialize(open_timeout: nil, read_timeout: nil)
-
read_timeout
(Numeric
) -- - Read timeout (seconds) to apply to HTTP client. -
open_timeout
(Numeric
) -- - Open timeout to apply to HTTP client.
def initialize(open_timeout: nil, read_timeout: nil) @open_timeout = open_timeout @read_timeout = read_timeout super() end
def new_http_client
def new_http_client if use_proxy? url = @proxy.http unless proxy.respond_to?(:http) && url raise Error::WebDriverError, "expected HTTP proxy, got #{@proxy.inspect}" end proxy = URI.parse(url) Net::HTTP.new(server_url.host, server_url.port, proxy.host, proxy.port, proxy.user, proxy.password) else Net::HTTP.new server_url.host, server_url.port end end
def new_request_for(verb, url, headers, payload)
def new_request_for(verb, url, headers, payload) req = Net::HTTP.const_get(verb.to_s.capitalize).new(url.path, headers) req.basic_auth server_url.user, server_url.password if server_url.userinfo req.body = payload if payload req end
def proxy
def proxy @proxy ||= begin proxy = ENV.fetch('http_proxy', nil) || ENV.fetch('HTTP_PROXY', nil) no_proxy = ENV.fetch('no_proxy', nil) || ENV.fetch('NO_PROXY', nil) if proxy proxy = "http://#{proxy}" unless proxy.start_with?('http://') Proxy.new(http: proxy, no_proxy: no_proxy) end end end
def request(verb, url, headers, payload, redirects = 0)
def request(verb, url, headers, payload, redirects = 0) retries = 0 begin request = new_request_for(verb, url, headers, payload) response = response_for(request) rescue Errno::ECONNABORTED, Errno::ECONNRESET, Errno::EADDRINUSE, Errno::EADDRNOTAVAIL # a retry is sometimes needed: # on Windows XP where we may quickly run out of ephemeral ports # when the port becomes temporarily unavailable # # A more robust solution is bumping the MaxUserPort setting # as described here: # # http://msdn.microsoft.com/en-us/library/aa560610%28v=bts.20%29.aspx raise if retries >= MAX_RETRIES retries += 1 sleep 2 retry rescue Errno::ECONNREFUSED => e raise e.class, "using proxy: #{proxy.http}" if use_proxy? raise end if response.is_a? Net::HTTPRedirection WebDriver.logger.debug("Redirect to #{response['Location']}; times: #{redirects}") raise Error::WebDriverError, 'too many redirects' if redirects >= MAX_REDIRECTS request(:get, URI.parse(response['Location']), DEFAULT_HEADERS.dup, nil, redirects + 1) else WebDriver.logger.debug(" <<< #{response.instance_variable_get(:@header).inspect}", id: :header) create_response response.code, response.body, response.content_type end end
def response_for(request)
def response_for(request) http.request request end
def start(http)
def start(http) http.start end
def use_proxy?
def use_proxy? return false if proxy.nil? if proxy.no_proxy ignored = proxy.no_proxy.split(',').any? do |host| host == '*' || host == server_url.host || ( begin IPAddr.new(host).include?(server_url.host) rescue ArgumentError false end ) end !ignored else true end end