Class: Resolv
- Inherits:
-
Object
- Object
- Resolv
- Defined in:
- lib/resolv.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
- VERSION =
"0.5.0"
- 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
-
.each_address(name, &block) ⇒ Object
Iterates over all IP addresses for
name
. -
.each_name(address, &proc) ⇒ Object
Iterates over all hostnames for
address
. -
.getaddress(name) ⇒ Object
Looks up the first IP address for
name
. -
.getaddresses(name) ⇒ Object
Looks up all IP address for
name
. -
.getname(address) ⇒ Object
Looks up the hostname of
address
. -
.getnames(address) ⇒ Object
Looks up all hostnames for
address
.
Instance Method Summary collapse
-
#each_address(name) ⇒ Object
Iterates over all IP addresses for
name
. -
#each_name(address) ⇒ Object
Iterates over all hostnames for
address
. -
#getaddress(name) ⇒ Object
Looks up the first IP address for
name
. -
#getaddresses(name) ⇒ Object
Looks up all IP address for
name
. -
#getname(address) ⇒ Object
Looks up the hostname of
address
. -
#getnames(address) ⇒ Object
Looks up all hostnames for
address
. -
#initialize(resolvers = nil, use_ipv6: nil) ⇒ Resolv
constructor
Creates a new Resolv using
resolvers
.
Constructor Details
Class Method Details
.each_address(name, &block) ⇒ Object
Iterates over all IP addresses for name
.
59 60 61 |
# File 'lib/resolv.rb', line 59 def self.each_address(name, &block) DefaultResolver.each_address(name, &block) end |
.each_name(address, &proc) ⇒ Object
Iterates over all hostnames for address
.
80 81 82 |
# File 'lib/resolv.rb', line 80 def self.each_name(address, &proc) DefaultResolver.each_name(address, &proc) end |
.getaddress(name) ⇒ Object
Looks up the first IP address for name
.
45 46 47 |
# File 'lib/resolv.rb', line 45 def self.getaddress(name) DefaultResolver.getaddress(name) end |
.getaddresses(name) ⇒ Object
Looks up all IP address for name
.
52 53 54 |
# File 'lib/resolv.rb', line 52 def self.getaddresses(name) DefaultResolver.getaddresses(name) end |
.getname(address) ⇒ Object
Looks up the hostname of address
.
66 67 68 |
# File 'lib/resolv.rb', line 66 def self.getname(address) DefaultResolver.getname(address) end |
.getnames(address) ⇒ Object
Looks up all hostnames for address
.
73 74 75 |
# File 'lib/resolv.rb', line 73 def self.getnames(address) DefaultResolver.getnames(address) end |
Instance Method Details
#each_address(name) ⇒ Object
Iterates over all IP addresses for name
.
111 112 113 114 115 116 117 118 119 120 121 122 123 124 |
# File 'lib/resolv.rb', line 111 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
.
146 147 148 149 150 151 152 153 154 155 |
# File 'lib/resolv.rb', line 146 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
.
94 95 96 97 |
# File 'lib/resolv.rb', line 94 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
.
102 103 104 105 106 |
# File 'lib/resolv.rb', line 102 def getaddresses(name) ret = [] each_address(name) {|address| ret << address} return ret end |
#getname(address) ⇒ Object
Looks up the hostname of address
.
129 130 131 132 |
# File 'lib/resolv.rb', line 129 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
.
137 138 139 140 141 |
# File 'lib/resolv.rb', line 137 def getnames(address) ret = [] each_name(address) {|name| ret << name} return ret end |