123456789_123456789_123456789_123456789_123456789_

Class: Resolv::DNS::Requester::ConnectedUDP

Do not use. This class is for internal use only.
Relationships & Source Files
Namespace Children
Classes:
Super Chains via Extension / Inclusion / Inheritance
Class Chain:
Instance Chain:
Inherits: Resolv::DNS::Requester
Defined in: lib/resolv.rb

Class Method Summary

Instance Method Summary

Constructor Details

.new(host, port = Port) ⇒ ConnectedUDP

[ GitHub ]

  
# File 'lib/resolv.rb', line 843

def initialize(host, port=Port)
  super()
  @host = host
  @port = port
  @mutex = Thread::Mutex.new
  @initialized = false
end

Instance Method Details

#close

[ GitHub ]

  
# File 'lib/resolv.rb', line 882

def close
  @mutex.synchronize do
    if @initialized
      super
      @senders.each_key {|from, id|
        DNS.free_request_id(@host, @port, id)
      }
      @initialized = false
    end
  end
end

#lazy_initialize

[ GitHub ]

  
# File 'lib/resolv.rb', line 851

def lazy_initialize
  @mutex.synchronize {
    next if @initialized
    @initialized = true
    is_ipv6 = @host.index(':')
    sock = UDPSocket.new(is_ipv6 ? Socket::AF_INET6 : Socket::AF_INET)
    @socks = [sock]
    sock.do_not_reverse_lookup = true
    DNS.bind_random_port(sock, is_ipv6 ? "::" : "0.0.0.0")
    sock.connect(@host, @port)
  }
  self
end

#recv_reply(readable_socks)

[ GitHub ]

  
# File 'lib/resolv.rb', line 865

def recv_reply(readable_socks)
  lazy_initialize
  reply = readable_socks[0].recv(UDPSize)
  return reply, nil
end

#sender(msg, data, host = @host, port = @port)

[ GitHub ]

  
# File 'lib/resolv.rb', line 871

def sender(msg, data, host=@host, port=@port)
  lazy_initialize
  unless host == @host && port == @port
    raise RequestError.new("host/port don't match: #{host}:#{port}")
  end
  id = DNS.allocate_request_id(@host, @port)
  request = msg.encode
  request[0,2] = [id].pack('n')
  return @senders[[nil,id]] = Sender.new(request, data, @socks[0])
end