home *** CD-ROM | disk | FTP | other *** search
/ PC Professionell 2004 December / PCpro_2004_12.ISO / files / webserver / xampp / xampp-perl-addon-1.4.9-installer.exe / NAPTR.pm < prev    next >
Encoding:
Perl POD Document  |  2004-01-04  |  3.8 KB  |  181 lines

  1. package Net::DNS::RR::NAPTR;
  2. #
  3. # $Id: NAPTR.pm,v 2.101 2004/01/04 04:31:10 ctriv Exp $
  4. #
  5. use strict;
  6. use vars qw(@ISA $VERSION);
  7.  
  8. use Net::DNS;
  9. use Net::DNS::Packet;
  10.  
  11. @ISA     = qw(Net::DNS::RR);
  12. $VERSION = (qw$Revision: 2.101 $)[1];
  13.  
  14. sub new {
  15.     my ($class, $self, $data, $offset) = @_;
  16.  
  17.     if ($self->{"rdlength"} > 0) {
  18.         ($self->{"order"} ) = unpack("\@$offset n", $$data);
  19.         $offset += &Net::DNS::INT16SZ;
  20.         
  21.         ($self->{"preference"}) = unpack("\@$offset n", $$data);
  22.         $offset += &Net::DNS::INT16SZ;
  23.         
  24.         my ($len) = unpack("\@$offset C", $$data);
  25.         ++$offset;
  26.         ($self->{"flags"}) = unpack("\@$offset a$len", $$data);
  27.         $offset += $len;
  28.         
  29.         $len = unpack("\@$offset C", $$data);
  30.         ++$offset;
  31.         ($self->{"service"}) = unpack("\@$offset a$len", $$data);
  32.         $offset += $len;
  33.         
  34.         $len = unpack("\@$offset C", $$data);
  35.         ++$offset;
  36.         ($self->{"regexp"}) = unpack("\@$offset a$len", $$data);
  37.         $offset += $len;
  38.         
  39.         ($self->{"replacement"}) = Net::DNS::Packet::dn_expand($data, $offset);
  40.     }
  41.   
  42.     return bless $self, $class;
  43. }
  44.  
  45. sub new_from_string {
  46.     my ($class, $self, $string) = @_;
  47.  
  48.     if ($string && $string =~ /^      (\d+)      \s+
  49.                           (\d+)      \s+
  50.                      ['"] (.*?) ['"] \s+
  51.                      ['"] (.*?) ['"] \s+
  52.                      ['"] (.*?) ['"] \s+
  53.                           (\S+) $/x) {
  54.  
  55.         $self->{"order"}       = $1;
  56.         $self->{"preference"}  = $2;
  57.         $self->{"flags"}       = $3;
  58.         $self->{"service"}     = $4;
  59.         $self->{"regexp"}      = $5;
  60.         $self->{"replacement"} = $6;
  61.         $self->{"replacement"} =~ s/\.+$//;
  62.     }
  63.  
  64.     return bless $self, $class;
  65. }
  66.  
  67. sub rdatastr {
  68.     my $self = shift;
  69.     my $rdatastr;
  70.  
  71.     if (exists $self->{"order"}) {
  72.         $rdatastr = $self->{"order"}       . ' '   .
  73.                     $self->{"preference"}  . ' "'  .
  74.                     $self->{"flags"}       . '" "' .
  75.                     $self->{"service"}     . '" "' .
  76.                     $self->{"regexp"}      . '" '  .
  77.                     $self->{"replacement"} . '.';
  78.     }
  79.     else {
  80.         $rdatastr = '';
  81.     }
  82.  
  83.     return $rdatastr;
  84. }
  85.  
  86. sub rr_rdata {
  87.     my ($self, $packet, $offset) = @_;
  88.     my $rdata = "";
  89.  
  90.     if (exists $self->{"order"}) {
  91.  
  92.         $rdata .= pack("n2", $self->{"order"}, $self->{"preference"});
  93.  
  94.         $rdata .= pack("C", length $self->{"flags"});
  95.         $rdata .= $self->{"flags"};
  96.  
  97.         $rdata .= pack("C", length $self->{"service"});
  98.         $rdata .= $self->{"service"};
  99.  
  100.         $rdata .= pack("C", length $self->{"regexp"});
  101.         $rdata .= $self->{"regexp"};
  102.  
  103.         $rdata .= $packet->dn_comp($self->{"replacement"},
  104.                        $offset + length $rdata);
  105.     }
  106.  
  107.     return $rdata;
  108. }
  109.  
  110. 1;
  111. __END__
  112.  
  113. =head1 NAME
  114.  
  115. Net::DNS::RR::NAPTR - DNS NAPTR resource record
  116.  
  117. =head1 SYNOPSIS
  118.  
  119. C<use Net::DNS::RR>;
  120.  
  121. =head1 DESCRIPTION
  122.  
  123. Class for DNS Naming Authority Pointer (NAPTR) resource records.
  124.  
  125. =head1 METHODS
  126.  
  127. =head2 order
  128.  
  129.     print "order = ", $rr->order, "\n";
  130.  
  131. Returns the order field.
  132.  
  133. =head2 preference
  134.  
  135.     print "preference = ", $rr->preference, "\n";
  136.  
  137. Returns the preference field.
  138.  
  139. =head2 flags
  140.  
  141.     print "flags = ", $rr->flags, "\n";
  142.  
  143. Returns the flags field.
  144.  
  145. =head2 service
  146.  
  147.     print "service = ", $rr->service, "\n";
  148.  
  149. Returns the service field.
  150.  
  151. =head2 regexp
  152.  
  153.     print "regexp = ", $rr->regexp, "\n";
  154.  
  155. Returns the regexp field.
  156.  
  157. =head2 replacement
  158.  
  159.     print "replacement = ", $rr->replacement, "\n";
  160.  
  161. Returns the replacement field.
  162.  
  163. =head1 COPYRIGHT
  164.  
  165. Copyright (c) 1997-2002 Michael Fuhr. 
  166.  
  167. Portions Copyright (c) 2002-2003 Chris Reinhardt.
  168.  
  169. All rights reserved.  This program is free software; you may redistribute
  170. it and/or modify it under the same terms as Perl itself.
  171.  
  172. B<Net::DNS::RR::NAPTR> is based on code contributed by Ryan Moats.
  173.  
  174. =head1 SEE ALSO
  175.  
  176. L<perl(1)>, L<Net::DNS>, L<Net::DNS::Resolver>, L<Net::DNS::Packet>,
  177. L<Net::DNS::Header>, L<Net::DNS::Question>, L<Net::DNS::RR>,
  178. RFC 2168
  179.  
  180. =cut
  181.