Class: OpenSSL::SSL::SSLServer
| Relationships & Source Files | |
| Super Chains via Extension / Inclusion / Inheritance | |
| Instance Chain: 
          self,
          SocketForwarder
         | |
| Inherits: | Object | 
| Defined in: | ext/openssl/lib/openssl/ssl.rb | 
Overview
SSLServer represents a TCP/IP server socket with Secure Sockets Layer.
Class Method Summary
- 
    
      .new(svr, ctx)  ⇒ SSLServer 
    
    constructor
    Creates a new instance of SSLServer.
Instance Attribute Summary
- 
    
      #start_immediately  
    
    rw
    When true then #accept works exactly the same as TCPServer#accept
SocketForwarder - Included
Instance Method Summary
- 
    
      #accept  
    
    Works similar to TCPServer#accept.
- 
    
      #close  
    
    See IO#closefor details.
- 
    
      #listen(backlog = 5)  
    
    See TCPServer#listenfor details.
- 
    
      #shutdown(how = Socket::SHUT_RDWR)  
    
    See BasicSocket#shutdownfor details.
- 
    
      #to_io  
    
    Returns the TCPServer passed to the SSLServerwhen initialized.
SocketForwarder - Included
Constructor Details
    .new(svr, ctx)  ⇒ SSLServer 
  
Creates a new instance of SSLServer.
- 
srvis an instance of TCPServer.
- 
ctxis an instance of SSLContext.
# File 'ext/openssl/lib/openssl/ssl.rb', line 346
def initialize(svr, ctx) @svr = svr @ctx = ctx unless ctx.session_id_context # see #6137 - session id may not exceed 32 bytes prng = ::Random.new($0.hash) session_id = prng.bytes(16).unpack('H*')[0] @ctx.session_id_context = session_id end @start_immediately = true end
Instance Attribute Details
#start_immediately (rw)
When true then #accept works exactly the same as TCPServer#accept
# File 'ext/openssl/lib/openssl/ssl.rb', line 341
attr_accessor :start_immediately
Instance Method Details
#accept
Works similar to TCPServer#accept.
# File 'ext/openssl/lib/openssl/ssl.rb', line 374
def accept # Socket#accept returns [socket, addrinfo]. # TCPServer#accept returns a socket. # The following comma strips addrinfo. sock, = @svr.accept begin ssl = OpenSSL::SSL::SSLSocket.new(sock, @ctx) ssl.sync_close = true ssl.accept if @start_immediately ssl rescue Exception => ex if ssl ssl.close else sock.close end raise ex end end
#close
See IO#close for details.
# File 'ext/openssl/lib/openssl/ssl.rb', line 395
def close @svr.close end
#listen(backlog = 5)
See TCPServer#listen for details.
# File 'ext/openssl/lib/openssl/ssl.rb', line 364
def listen(backlog=5) @svr.listen(backlog) end
#shutdown(how = Socket::SHUT_RDWR)
See BasicSocket#shutdown for details.
# File 'ext/openssl/lib/openssl/ssl.rb', line 369
def shutdown(how=Socket::SHUT_RDWR) @svr.shutdown(how) end
#to_io
Returns the TCPServer passed to the SSLServer when initialized.
# File 'ext/openssl/lib/openssl/ssl.rb', line 359
def to_io @svr end