class HTTP::Timeout::Null
def connect(socket_class, host, port, nodelay = false)
def connect(socket_class, host, port, nodelay = false) @socket = socket_class.open(host, port) @socket.setsockopt(Socket::IPPROTO_TCP, Socket::TCP_NODELAY, 1) if nodelay end
def connect_ssl
def connect_ssl @socket.connect end
def initialize(options = {})
def initialize(options = {}) @options = options end
def readpartial(size)
def readpartial(size) @socket.readpartial(size) rescue EOFError :eof end
def rescue_readable
def rescue_readable yield rescue IO::WaitReadable retry if IO.select([socket], nil, nil, read_timeout) raise TimeoutError, "Read timed out after #{read_timeout} seconds" end
def rescue_writable
def rescue_writable yield rescue IO::WaitWritable retry if IO.select(nil, [socket], nil, write_timeout) raise TimeoutError, "Write timed out after #{write_timeout} seconds" end
def start_tls(host, ssl_socket_class, ssl_context)
def start_tls(host, ssl_socket_class, ssl_context) @socket = ssl_socket_class.new(socket, ssl_context) @socket.hostname = host if @socket.respond_to? :hostname= @socket.sync_close = true if @socket.respond_to? :sync_close= connect_ssl return unless ssl_context.verify_mode == OpenSSL::SSL::VERIFY_PEER @socket.post_connection_check(host) end
def write(data)
def write(data) @socket.write(data) end