Class: HTTPClient::SSLSocketWrap
- Inherits:
-
Object
- Object
- HTTPClient::SSLSocketWrap
- Defined in:
- lib/httpclient/session.rb
Overview
Wraps up OpenSSL::SSL::SSLSocket and offers debugging features.
Instance Method Summary collapse
- #<<(str) ⇒ Object
- #close ⇒ Object
- #closed? ⇒ Boolean
- #eof? ⇒ Boolean
- #flush ⇒ Object
- #gets(*args) ⇒ Object
-
#initialize(socket, context, debug_dev = nil) ⇒ SSLSocketWrap
constructor
A new instance of SSLSocketWrap.
- #peer_cert ⇒ Object
- #post_connection_check(host) ⇒ Object
- #read(*args) ⇒ Object
- #readpartial(*args) ⇒ Object
- #ssl_cipher ⇒ Object
- #ssl_connect(hostname = nil) ⇒ Object
- #ssl_state ⇒ Object
- #ssl_version ⇒ Object
- #sync ⇒ Object
- #sync=(sync) ⇒ Object
Constructor Details
#initialize(socket, context, debug_dev = nil) ⇒ SSLSocketWrap
Returns a new instance of SSLSocketWrap.
289 290 291 292 293 294 295 296 297 |
# File 'lib/httpclient/session.rb', line 289 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 |
Instance Method Details
#<<(str) ⇒ Object
369 370 371 372 373 |
# File 'lib/httpclient/session.rb', line 369 def <<(str) rv = @ssl_socket.write(str) debug(str) rv end |
#close ⇒ Object
338 339 340 341 |
# File 'lib/httpclient/session.rb', line 338 def close @ssl_socket.close @socket.close end |
#closed? ⇒ Boolean
343 344 345 |
# File 'lib/httpclient/session.rb', line 343 def closed? @socket.closed? end |
#eof? ⇒ Boolean
347 348 349 |
# File 'lib/httpclient/session.rb', line 347 def eof? @ssl_socket.eof? end |
#flush ⇒ Object
375 376 377 |
# File 'lib/httpclient/session.rb', line 375 def flush @ssl_socket.flush end |
#gets(*args) ⇒ Object
351 352 353 354 355 |
# File 'lib/httpclient/session.rb', line 351 def gets(*args) str = @ssl_socket.gets(*args) debug(str) str end |
#peer_cert ⇒ Object
334 335 336 |
# File 'lib/httpclient/session.rb', line 334 def peer_cert @ssl_socket.peer_cert end |
#post_connection_check(host) ⇒ Object
306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 |
# File 'lib/httpclient/session.rb', line 306 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 |
#read(*args) ⇒ Object
357 358 359 360 361 |
# File 'lib/httpclient/session.rb', line 357 def read(*args) str = @ssl_socket.read(*args) debug(str) str end |
#readpartial(*args) ⇒ Object
363 364 365 366 367 |
# File 'lib/httpclient/session.rb', line 363 def readpartial(*args) str = @ssl_socket.readpartial(*args) debug(str) str end |
#ssl_cipher ⇒ Object
326 327 328 |
# File 'lib/httpclient/session.rb', line 326 def ssl_cipher @ssl_socket.cipher end |
#ssl_connect(hostname = nil) ⇒ Object
299 300 301 302 303 304 |
# File 'lib/httpclient/session.rb', line 299 def ssl_connect(hostname = nil) if hostname && @ssl_socket.respond_to?(:hostname=) @ssl_socket.hostname = hostname end @ssl_socket.connect end |
#ssl_state ⇒ Object
330 331 332 |
# File 'lib/httpclient/session.rb', line 330 def ssl_state @ssl_socket.state end |
#ssl_version ⇒ Object
322 323 324 |
# File 'lib/httpclient/session.rb', line 322 def ssl_version @ssl_socket.ssl_version if @ssl_socket.respond_to?(:ssl_version) end |
#sync ⇒ Object
379 380 381 |
# File 'lib/httpclient/session.rb', line 379 def sync @ssl_socket.sync end |
#sync=(sync) ⇒ Object
383 384 385 |
# File 'lib/httpclient/session.rb', line 383 def sync=(sync) @ssl_socket.sync = sync end |