| Net-DNS documentation | Contained in the Net-DNS distribution. |
Net::DNS::RR::NAPTR - DNS NAPTR resource record
use Net::DNS::RR;
Class for DNS Naming Authority Pointer (NAPTR) resource records.
print "order = ", $rr->order, "\n";
Returns the order field.
print "preference = ", $rr->preference, "\n";
Returns the preference field.
print "flags = ", $rr->flags, "\n";
Returns the flags field.
print "service = ", $rr->service, "\n";
Returns the service field.
print "regexp = ", $rr->regexp, "\n";
Returns the regexp field.
print "replacement = ", $rr->replacement, "\n";
Returns the replacement field.
Copyright (c) 1997-2002 Michael Fuhr.
Portions Copyright (c) 2002-2004 Chris Reinhardt. Portions Copyright (c) 2005 Olaf Kolkman NLnet Labs.
All rights reserved. This program is free software; you may redistribute it and/or modify it under the same terms as Perl itself.
Net::DNS::RR::NAPTR is based on code contributed by Ryan Moats.
perl(1), Net::DNS, Net::DNS::Resolver, Net::DNS::Packet, Net::DNS::Header, Net::DNS::Question, Net::DNS::RR, RFC 2168
| Net-DNS documentation | Contained in the Net-DNS distribution. |
package Net::DNS::RR::NAPTR; # # $Id: NAPTR.pm 801 2009-10-02 16:02:37Z olaf $ # use strict; BEGIN { eval { require bytes; } } use vars qw(@ISA $VERSION); @ISA = qw(Net::DNS::RR); $VERSION = (qw$LastChangedRevision: 801 $)[1]; __PACKAGE__->set_rrsort_func("order", sub { my ($a,$b)=($Net::DNS::a,$Net::DNS::b); $a->{'order'} <=> $b->{'order'} || $a->{'preference'} <=> $b->{'preference'} } ); __PACKAGE__->set_rrsort_func("default_sort", __PACKAGE__->get_rrsort_func("order") ); __PACKAGE__->set_rrsort_func("preference", sub { my ($a,$b)=($Net::DNS::a,$Net::DNS::b); $a->{"preference"} <=> $b->{"preference"} || $a->{"order"} <=> $b->{"order"} } ); sub new { my ($class, $self, $data, $offset) = @_; if ($self->{"rdlength"} > 0) { ($self->{"order"} ) = unpack("\@$offset n", $$data); $offset += Net::DNS::INT16SZ(); ($self->{"preference"}) = unpack("\@$offset n", $$data); $offset += Net::DNS::INT16SZ(); my ($len) = unpack("\@$offset C", $$data); ++$offset; ($self->{"flags"}) = unpack("\@$offset a$len", $$data); $offset += $len; $len = unpack("\@$offset C", $$data); ++$offset; ($self->{"service"}) = unpack("\@$offset a$len", $$data); $offset += $len; $len = unpack("\@$offset C", $$data); ++$offset; ($self->{"regexp"}) = unpack("\@$offset a$len", $$data); $offset += $len; ($self->{"replacement"}) = Net::DNS::Packet::dn_expand($data, $offset); } return bless $self, $class; } sub new_from_string { my ($class, $self, $string) = @_; if ($string && $string =~ /^ (\d+) \s+ (\d+) \s+ (['"]) (.*?) \3 \s+ (['"]) (.*?) \5 \s+ (['"]) (.*?) \7 \s+ (\S+) $/xo) { $self->{"order"} = $1; $self->{"preference"} = $2; $self->{"flags"} = $4; $self->{"service"} = $6; $self->{"regexp"} = $8; $self->{"replacement"} = Net::DNS::stripdot($9); } return bless $self, $class; } sub rdatastr { my $self = shift; my $rdatastr; if (exists $self->{"order"}) { $rdatastr = $self->{"order"} . ' ' . $self->{"preference"} . ' "' . $self->{"flags"} . '" "' . $self->{"service"} . '" "' . $self->{"regexp"} . '" ' . $self->{"replacement"} . '.'; } else { $rdatastr = ''; } return $rdatastr; } sub rr_rdata { my ($self, $packet, $offset) = @_; my $rdata = ""; if (exists $self->{"order"}) { $rdata .= pack("n2", $self->{"order"}, $self->{"preference"}); $rdata .= pack("C", length $self->{"flags"}); $rdata .= $self->{"flags"}; $rdata .= pack("C", length $self->{"service"}); $rdata .= $self->{"service"}; $rdata .= pack("C", length $self->{"regexp"}); $rdata .= $self->{"regexp"}; $rdata .= $self->_name2wire ($self->{"replacement"}); } return $rdata; } sub _normalize_dnames { my $self=shift; $self->_normalize_ownername(); $self->{'replacement'}=Net::DNS::stripdot($self->{'replacement'}) if defined $self->{'replacement'}; } 1; __END__