Class: Resolv::DNS::Resource::IN::SRV

Inherits:
Resolv::DNS::Resource show all
Defined in:
lib/resolv.rb

Overview

SRV resource record defined in RFC 2782

These records identify the hostname and port that a service is available at.

The format is:

_Service._Proto.Name TTL Class SRV Priority Weight Port Target

The fields specific to SRV are defined in RFC 2782 as meaning:

  • priority The priority of this target host. A client MUST attempt to contact the target host with the lowest-numbered priority it can reach; target hosts with the same priority SHOULD be tried in an order defined by the weight field. The range is 0-65535. Note that it is not widely implemented and should be set to zero.

  • weight A server selection mechanism. The weight field specifies a relative weight for entries with the same priority. Larger weights SHOULD be given a proportionately higher probability of being selected. The range of this number is 0-65535. Domain administrators SHOULD use Weight 0 when there isn???t any server selection to do, to make the RR easier to read for humans (less noisy). Note that it is not widely implemented and should be set to zero.

  • port The port on this target host of this service. The range is 0- 65535.

  • target The domain name of the target host. A target of ???.??? means that the service is decidedly not available at this domain.

Constant Summary

Constants inherited from Resolv::DNS::Resource

ClassHash, ClassInsensitiveTypes, ClassValue

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Resolv::DNS::Resource

#==, #eql?, get_class, #hash

Constructor Details

#initialize(priority, weight, port, target) ⇒ SRV

Create a SRV resource record.



1731
1732
1733
1734
1735
1736
# File 'lib/resolv.rb', line 1731

def initialize(priority, weight, port, target)
  @priority = priority.to_int
  @weight = weight.to_int
  @port = port.to_int
  @target = Name.create(target)
end

Instance Attribute Details

#portObject (readonly)

Returns the value of attribute port



1738
1739
1740
# File 'lib/resolv.rb', line 1738

def port
  @port
end

#priorityObject (readonly)

Returns the value of attribute priority



1738
1739
1740
# File 'lib/resolv.rb', line 1738

def priority
  @priority
end

#targetObject (readonly)

Returns the value of attribute target



1738
1739
1740
# File 'lib/resolv.rb', line 1738

def target
  @target
end

#weightObject (readonly)

Returns the value of attribute weight



1738
1739
1740
# File 'lib/resolv.rb', line 1738

def weight
  @weight
end

Class Method Details

.decode_rdata(msg) ⇒ Object



1747
1748
1749
1750
1751
1752
1753
# File 'lib/resolv.rb', line 1747

def self.decode_rdata(msg)
  priority, = msg.get_unpack("n")
  weight,   = msg.get_unpack("n")
  port,     = msg.get_unpack("n")
  target    = msg.get_name
  return self.new(priority, weight, port, target)
end

Instance Method Details

#encode_rdata(msg) ⇒ Object



1740
1741
1742
1743
1744
1745
# File 'lib/resolv.rb', line 1740

def encode_rdata(msg)
  msg.put_pack("n", @priority)
  msg.put_pack("n", @weight)
  msg.put_pack("n", @port)
  msg.put_name(@target)
end