class Mongo::Address::IPv4
Sets up resolution with IPv4 support if the address is an ip address.
@since 2.0.0
Constants
- MATCH
The regular expression to use to match an IPv4 ip address.
@since 2.0.0
- SPLIT
Split value constant.
@since 2.1.0
Attributes
@return [ String ] host The host.
@return [ String ] #host_name The original host name.
@return [ Integer ] port The port.
Public Class Methods
Initialize the IPv4 resolver.
@example Initialize the resolver.
IPv4.new("127.0.0.1", 27017, 'localhost')
@param [ String ] host The host. @param [ Integer ] port The port.
@since 2.0.0
# File lib/mongo/address/ipv4.rb, line 69 def initialize(host, port, host_name=nil) @host = host @port = port @host_name = host_name end
Parse an IPv4 address into its host and port.
@example Parse the address.
IPv4.parse("127.0.0.1:28011")
@param [ String ] address The address to parse.
@return [ Array<String, Integer> ] The host and port pair.
@since 2.0.0
# File lib/mongo/address/ipv4.rb, line 53 def self.parse(address) parts = address.split(SPLIT) host = parts[0] port = (parts[1] || 27017).to_i [ host, port ] end
Public Instance Methods
Get a socket for the provided address type, given the options.
@example Get an IPv4 socket.
ipv4.socket(5, :ssl => true)
@param [ Float ] timeout The socket timeout. @param [ Hash ] ssl_options SSL options.
@return [ Pool::Socket::SSL, Pool::Socket::TCP ] The socket.
@since 2.0.0
# File lib/mongo/address/ipv4.rb, line 86 def socket(timeout, ssl_options = {}) unless ssl_options.empty? Socket::SSL.new(host, port, host_name, timeout, Socket::PF_INET, ssl_options) else Socket::TCP.new(host, port, timeout, Socket::PF_INET) end end