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.
295 296 297 298 299 300 301 302 303 |
# File 'lib/httpclient/session.rb', line 295 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
375 376 377 378 379 |
# File 'lib/httpclient/session.rb', line 375 def <<(str) rv = @ssl_socket.write(str) debug(str) rv end |
#close ⇒ Object
344 345 346 347 |
# File 'lib/httpclient/session.rb', line 344 def close @ssl_socket.close @socket.close end |
#closed? ⇒ Boolean
349 350 351 |
# File 'lib/httpclient/session.rb', line 349 def closed? @socket.closed? end |
#eof? ⇒ Boolean
353 354 355 |
# File 'lib/httpclient/session.rb', line 353 def eof? @ssl_socket.eof? end |
#flush ⇒ Object
381 382 383 |
# File 'lib/httpclient/session.rb', line 381 def flush @ssl_socket.flush end |
#gets(*args) ⇒ Object
357 358 359 360 361 |
# File 'lib/httpclient/session.rb', line 357 def gets(*args) str = @ssl_socket.gets(*args) debug(str) str end |
#peer_cert ⇒ Object
340 341 342 |
# File 'lib/httpclient/session.rb', line 340 def peer_cert @ssl_socket.peer_cert end |
#post_connection_check(host) ⇒ Object
312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 |
# File 'lib/httpclient/session.rb', line 312 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
363 364 365 366 367 |
# File 'lib/httpclient/session.rb', line 363 def read(*args) str = @ssl_socket.read(*args) debug(str) str end |
#readpartial(*args) ⇒ Object
369 370 371 372 373 |
# File 'lib/httpclient/session.rb', line 369 def readpartial(*args) str = @ssl_socket.readpartial(*args) debug(str) str end |
#ssl_cipher ⇒ Object
332 333 334 |
# File 'lib/httpclient/session.rb', line 332 def ssl_cipher @ssl_socket.cipher end |
#ssl_connect(hostname = nil) ⇒ Object
305 306 307 308 309 310 |
# File 'lib/httpclient/session.rb', line 305 def ssl_connect(hostname = nil) if hostname && @ssl_socket.respond_to?(:hostname=) @ssl_socket.hostname = hostname end @ssl_socket.connect end |
#ssl_state ⇒ Object
336 337 338 |
# File 'lib/httpclient/session.rb', line 336 def ssl_state @ssl_socket.state end |
#ssl_version ⇒ Object
328 329 330 |
# File 'lib/httpclient/session.rb', line 328 def ssl_version @ssl_socket.ssl_version if @ssl_socket.respond_to?(:ssl_version) end |
#sync ⇒ Object
385 386 387 |
# File 'lib/httpclient/session.rb', line 385 def sync @ssl_socket.sync end |
#sync=(sync) ⇒ Object
389 390 391 |
# File 'lib/httpclient/session.rb', line 389 def sync=(sync) @ssl_socket.sync = sync end |