D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
proc
/
self
/
root
/
lib64
/
perl5
/
vendor_perl
/
Net
/
DNS
/
RR
/
Filename :
LP.pm
back
Copy
package Net::DNS::RR::LP; # # $Id: LP.pm 1096 2012-12-28 13:35:15Z willem $ # use vars qw($VERSION); $VERSION = (qw$LastChangedRevision: 1096 $)[1]; # Unchanged since 1050 use base Net::DNS::RR; =head1 NAME Net::DNS::RR::LP - DNS LP resource record =cut use strict; use integer; sub decode_rdata { ## decode rdata from wire-format octet string my $self = shift; my ( $data, $offset ) = @_; $self->{preference} = unpack( "\@$offset n", $$data ); $self->{locator} = decode Net::DNS::DomainName($data,$offset+2 ); } sub encode_rdata { ## encode rdata as wire-format octet string my $self = shift; return '' unless $self->{locator}; my $rdata = pack 'n', $self->preference; $rdata .= $self->{locator}->encode(); } sub format_rdata { ## format rdata portion of RR string. my $self = shift; return '' unless $self->{locator}; join ' ', $self->preference, $self->{locator}->string; } sub parse_rdata { ## populate RR from rdata in argument list my $self = shift; $self->$_(shift) for qw(preference locator); } sub preference { my $self = shift; $self->{preference} = shift if @_; return 0 + ( $self->{preference} || 0 ); } sub locator { my $self = shift; $self->{locator} = new Net::DNS::DomainName(shift) if @_; $self->{locator}->name if defined wantarray; } sub fqdn { &locator; } __PACKAGE__->set_rrsort_func( ## sort RRs in numerically ascending order. 'preference', sub { my ( $a, $b ) = ( $Net::DNS::a, $Net::DNS::b ); $a->{preference} <=> $b->{preference}; } ); __PACKAGE__->set_rrsort_func( 'default_sort', __PACKAGE__->get_rrsort_func('preference') ); 1; __END__ =head1 SYNOPSIS use Net::DNS; $rr = new Net::DNS::RR('name IN LP preference locator'); $rr = new Net::DNS::RR( name => 'example.com', type => 'LP', preference => 10, locator => 'locator.example.com' ); =head1 DESCRIPTION Class for DNS Locator Pointer (LP) resource records. The LP DNS resource record (RR) is used to hold the name of a subnetwork for ILNP. The name is an FQDN which can then be used to look up L32 or L64 records. LP is, effectively, a Locator Pointer to L32 and/or L64 records. =head1 METHODS The available methods are those inherited from the base class augmented by the type-specific methods defined in this package. Use of undocumented package features or direct access to internal data structures is discouraged and could result in program termination or other unpredictable behaviour. =head2 preference $preference = $rr->preference; A 16 bit unsigned integer in network byte order that indicates the relative preference for this LP record among other LP records associated with this owner name. Lower values are preferred over higher values. =head2 locator $locator = $rr->locator; The Locator field contains the DNS target name that is used to reference L32 and/or L64 records. =head1 COPYRIGHT Copyright (c)2012 Dick Franks. Package template (c)2009,2012 O.M.Kolkman and R.W.Franks. All rights reserved. This program is free software; you may redistribute it and/or modify it under the same terms as Perl itself. =head1 SEE ALSO L<perl>, L<Net::DNS>, L<Net::DNS::RR>, RFC6742 =cut