Class: Resolv::DNS::Resource::IN::WKS

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

Overview

Well Known Service resource.

Constant Summary collapse

TypeValue =
11
ClassValue =
IN::ClassValue

Constants inherited from Resolv::DNS::Resource

ClassHash, ClassInsensitiveTypes

Instance Attribute Summary collapse

Attributes inherited from Resolv::DNS::Resource

#ttl

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Resolv::DNS::Resource

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

Constructor Details

#initialize(address, protocol, bitmap) ⇒ WKS

Returns a new instance of WKS.



1915
1916
1917
1918
1919
# File 'lib/resolv.rb', line 1915

def initialize(address, protocol, bitmap)
  @address = IPv4.create(address)
  @protocol = protocol
  @bitmap = bitmap
end

Instance Attribute Details

#addressObject (readonly)

The host these services run on.



1924
1925
1926
# File 'lib/resolv.rb', line 1924

def address
  @address
end

#bitmapObject (readonly)

A bit map of enabled services on this host.

If protocol is 6 (TCP) then the 26th bit corresponds to the SMTP service (port 25). If this bit is set, then an SMTP server should be listening on TCP port 25; if zero, SMTP service is not supported.



1939
1940
1941
# File 'lib/resolv.rb', line 1939

def bitmap
  @bitmap
end

#protocolObject (readonly)

IP protocol number for these services.



1929
1930
1931
# File 'lib/resolv.rb', line 1929

def protocol
  @protocol
end

Class Method Details

.decode_rdata(msg) ⇒ Object

:nodoc:



1947
1948
1949
1950
1951
1952
# File 'lib/resolv.rb', line 1947

def self.decode_rdata(msg) # :nodoc:
  address = IPv4.new(msg.get_bytes(4))
  protocol, = msg.get_unpack("n")
  bitmap = msg.get_bytes
  return self.new(address, protocol, bitmap)
end

Instance Method Details

#encode_rdata(msg) ⇒ Object

:nodoc:



1941
1942
1943
1944
1945
# File 'lib/resolv.rb', line 1941

def encode_rdata(msg) # :nodoc:
  msg.put_bytes(@address.address)
  msg.put_pack("n", @protocol)
  msg.put_bytes(@bitmap)
end