Class: Resolv

Inherits:
Object
  • Object
show all
Defined in:
lib/logstash/patches/resolv_9270.rb

Overview

Resolv is a thread-aware DNS resolver library written in Ruby. Resolv can handle multiple DNS requests concurrently without blocking the entire Ruby interpreter.

See also resolv-replace.rb to replace the libc resolver with Resolv.

Resolv can look up various DNS resources using the DNS module directly.

Examples:

p Resolv.getaddress "www.ruby-lang.org"
p Resolv.getname "210.251.121.214"

Resolv::DNS.open do |dns|
  ress = dns.getresources "www.ruby-lang.org", Resolv::DNS::Resource::IN::A
  p ress.map(&:address)
  ress = dns.getresources "ruby-lang.org", Resolv::DNS::Resource::IN::MX
  p ress.map { |r| [r.exchange.to_s, r.preference] }
end

Bugs

  • NIS is not supported.

  • /etc/nsswitch.conf is not supported.

Defined Under Namespace

Modules: LOC Classes: DNS, Hosts, IPv4, IPv6, MDNS, ResolvError, ResolvTimeout

Constant Summary collapse

WINDOWS =

Tests whether we’re running on Windows

/mswin|cygwin|mingw|bccwin/ =~ RUBY_PLATFORM || ::RbConfig::CONFIG['host_os'] =~ /mswin/
DefaultResolver =

Default resolver to use for Resolv class methods.

self.new
AddressRegex =

Address Regexp to use for matching IP addresses.

/(?:#{IPv4::Regex})|(?:#{IPv6::Regex})/

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(resolvers = [Hosts.new, DNS.new]) ⇒ Resolv

Creates a new Resolv using resolvers.



98
99
100
# File 'lib/logstash/patches/resolv_9270.rb', line 98

def initialize(resolvers=[Hosts.new, DNS.new])
  @resolvers = resolvers
end

Class Method Details

.each_address(name, &block) ⇒ Object

Iterates over all IP addresses for name.



70
71
72
# File 'lib/logstash/patches/resolv_9270.rb', line 70

def self.each_address(name, &block)
  DefaultResolver.each_address(name, &block)
end

.each_name(address, &proc) ⇒ Object

Iterates over all hostnames for address.



91
92
93
# File 'lib/logstash/patches/resolv_9270.rb', line 91

def self.each_name(address, &proc)
  DefaultResolver.each_name(address, &proc)
end

.getaddress(name) ⇒ Object

Looks up the first IP address for name.



56
57
58
# File 'lib/logstash/patches/resolv_9270.rb', line 56

def self.getaddress(name)
  DefaultResolver.getaddress(name)
end

.getaddresses(name) ⇒ Object

Looks up all IP address for name.



63
64
65
# File 'lib/logstash/patches/resolv_9270.rb', line 63

def self.getaddresses(name)
  DefaultResolver.getaddresses(name)
end

.getname(address) ⇒ Object

Looks up the hostname of address.



77
78
79
# File 'lib/logstash/patches/resolv_9270.rb', line 77

def self.getname(address)
  DefaultResolver.getname(address)
end

.getnames(address) ⇒ Object

Looks up all hostnames for address.



84
85
86
# File 'lib/logstash/patches/resolv_9270.rb', line 84

def self.getnames(address)
  DefaultResolver.getnames(address)
end

Instance Method Details

#each_address(name) ⇒ Object

Iterates over all IP addresses for name.



122
123
124
125
126
127
128
129
130
131
132
133
134
135
# File 'lib/logstash/patches/resolv_9270.rb', line 122

def each_address(name)
  if AddressRegex =~ name
    yield name
    return
  end
  yielded = false
  @resolvers.each {|r|
    r.each_address(name) {|address|
      yield address.to_s
      yielded = true
    }
    return if yielded
  }
end

#each_name(address) ⇒ Object

Iterates over all hostnames for address.



157
158
159
160
161
162
163
164
165
166
# File 'lib/logstash/patches/resolv_9270.rb', line 157

def each_name(address)
  yielded = false
  @resolvers.each {|r|
    r.each_name(address) {|name|
      yield name.to_s
      yielded = true
    }
    return if yielded
  }
end

#getaddress(name) ⇒ Object

Looks up the first IP address for name.

Raises:



105
106
107
108
# File 'lib/logstash/patches/resolv_9270.rb', line 105

def getaddress(name)
  each_address(name) {|address| return address}
  raise ResolvError.new("no address for #{name}")
end

#getaddresses(name) ⇒ Object

Looks up all IP address for name.



113
114
115
116
117
# File 'lib/logstash/patches/resolv_9270.rb', line 113

def getaddresses(name)
  ret = []
  each_address(name) {|address| ret << address}
  return ret
end

#getname(address) ⇒ Object

Looks up the hostname of address.

Raises:



140
141
142
143
# File 'lib/logstash/patches/resolv_9270.rb', line 140

def getname(address)
  each_name(address) {|name| return name}
  raise ResolvError.new("no name for #{address}")
end

#getnames(address) ⇒ Object

Looks up all hostnames for address.



148
149
150
151
152
# File 'lib/logstash/patches/resolv_9270.rb', line 148

def getnames(address)
  ret = []
  each_name(address) {|name| ret << name}
  return ret
end