The protocol for DRb
over an SSL socket
The URI for a DRb
socket over SSL is: drbssl://<host>:<port>?<option>
. The option is optional
Create a DRb::DRbSSLSocket
instance.
uri
is the URI we are connected to. soc
is the tcp socket we are bound to. config
is our configuration. Either a Hash or SSLConfig
is_established
is a boolean of whether soc
is currently established
This is called automatically based on the DRb
protocol.
# File drb/ssl.rb, line 304 def initialize(uri, soc, config, is_established) @ssl = is_established ? soc : nil super(uri, soc.to_io, config) end
Return an DRb::DRbSSLSocket
instance as a client-side connection, with the SSL connected. This is called from DRb::start_service
or while connecting to a remote object:
DRb.start_service 'drbssl://localhost:0', front, config
uri
is the URI we are connected to, 'drbssl://localhost:0'
above, config
is our configuration. Either a Hash or DRb::DRbSSLSocket::SSLConfig
# File drb/ssl.rb, line 249 def self.open(uri, config) host, port, = parse_uri(uri) soc = TCPSocket.open(host, port) ssl_conf = SSLConfig::new(config) ssl_conf.setup_ssl_context ssl = ssl_conf.connect(soc) self.new(uri, ssl, ssl_conf, true) end
Returns a DRb::DRbSSLSocket
instance as a server-side connection, with the SSL connected. This is called from DRb::start_service
or while connecting to a remote object:
DRb.start_service 'drbssl://localhost:0', front, config
uri
is the URI we are connected to, 'drbssl://localhost:0'
above, config
is our configuration. Either a Hash or DRb::DRbSSLSocket::SSLConfig
# File drb/ssl.rb, line 267 def self.open_server(uri, config) uri = 'drbssl://:0' unless uri host, port, = parse_uri(uri) if host.size == 0 host = getservername soc = open_server_inaddr_any(host, port) else soc = TCPServer.open(host, port) end port = soc.addr[1] if port == 0 @uri = "drbssl://#{host}:#{port}" ssl_conf = SSLConfig.new(config) ssl_conf.setup_certificate ssl_conf.setup_ssl_context self.new(@uri, soc, ssl_conf, false) end