class HTTPClient::SSLSocketWrap
Wraps up OpenSSL::SSL::SSLSocket and offers debugging features.
def <<(str)
def <<(str) rv = @ssl_socket.write(str) debug(str) rv end
def check_mask(value, mask)
def check_mask(value, mask) value & mask == mask end
def close
def close @ssl_socket.close @socket.close end
def closed?
def closed? @socket.closed? end
def create_openssl_socket(socket)
def create_openssl_socket(socket) ssl_socket = nil if OpenSSL::SSL.const_defined?("SSLContext") ctx = OpenSSL::SSL::SSLContext.new @context.set_context(ctx) ssl_socket = OpenSSL::SSL::SSLSocket.new(socket, ctx) else ssl_socket = OpenSSL::SSL::SSLSocket.new(socket) @context.set_context(ssl_socket) end ssl_socket end
def debug(str)
def debug(str) @debug_dev << str if @debug_dev && str end
def eof?
def eof? @ssl_socket.eof? end
def flush
def flush @ssl_socket.flush end
def gets(*args)
def gets(*args) str = @ssl_socket.gets(*args) debug(str) str end
def initialize(socket, context, debug_dev = nil)
def initialize(socket, context, debug_dev = nil) unless SSLEnabled raise ConfigurationError.new('Ruby/OpenSSL module is required') end @context = context @socket = socket @ssl_socket = create_openssl_socket(@socket) @debug_dev = debug_dev end
def peer_cert
def peer_cert @ssl_socket.peer_cert end
def post_connection_check(host)
def post_connection_check(host) verify_mode = @context.verify_mode || OpenSSL::SSL::VERIFY_NONE if verify_mode == OpenSSL::SSL::VERIFY_NONE return elsif @ssl_socket.peer_cert.nil? and check_mask(verify_mode, OpenSSL::SSL::VERIFY_FAIL_IF_NO_PEER_CERT) raise OpenSSL::SSL::SSLError.new('no peer cert') end hostname = host.host if @ssl_socket.respond_to?(:post_connection_check) and RUBY_VERSION > "1.8.4" @ssl_socket.post_connection_check(hostname) else @context.post_connection_check(@ssl_socket.peer_cert, hostname) end end
def read(*args)
def read(*args) str = @ssl_socket.read(*args) debug(str) str end
def readpartial(*args)
def readpartial(*args) str = @ssl_socket.readpartial(*args) debug(str) str end
def ssl_connect
def ssl_connect @ssl_socket.connect end
def sync
def sync @ssl_socket.sync end
def sync=(sync)
def sync=(sync) @ssl_socket.sync = sync end