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

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

Overview

SRV resource record defined in RFC 2782

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

Constant Summary collapse

TypeValue =
33
ClassValue =
IN::ClassValue

Constants inherited from Gem::Resolv::DNS::Resource

ClassHash, ClassInsensitiveTypes

Instance Attribute Summary collapse

Attributes inherited from Gem::Resolv::DNS::Resource

#ttl

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Gem::Resolv::DNS::Resource

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

Constructor Details

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

Create a SRV resource record.

See the documentation for #priority, #weight, #port and #target for priority, weight, +port and target respectively.



2743
2744
2745
2746
2747
2748
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 2743

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)

The port on this target host of this service.

The range is 0-65535.



2776
2777
2778
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 2776

def port
  @port
end

#priorityObject (readonly)

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.



2758
2759
2760
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 2758

def priority
  @priority
end

#targetObject (readonly)

The domain name of the target host.

A target of “.” means that the service is decidedly not available at this domain.



2783
2784
2785
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 2783

def target
  @target
end

#weightObject (readonly)

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.



2770
2771
2772
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 2770

def weight
  @weight
end

Class Method Details

.decode_rdata(msg) ⇒ Object

:nodoc:



2792
2793
2794
2795
2796
2797
2798
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 2792

def self.decode_rdata(msg) # :nodoc:
  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

:nodoc:



2785
2786
2787
2788
2789
2790
# File 'lib/rubygems/vendor/resolv/lib/resolv.rb', line 2785

def encode_rdata(msg) # :nodoc:
  msg.put_pack("n", @priority)
  msg.put_pack("n", @weight)
  msg.put_pack("n", @port)
  msg.put_name(@target, compress: false)
end