Net-Frame-Layer-RIPng
view release on metacpan or search on metacpan
lib/Net/Frame/Layer/RIPng/v1.pm view on Meta::CPAN
#
# $Id: v1.pm 49 2009-05-31 13:15:34Z VinsWorldcom $
#
package Net::Frame::Layer::RIPng::v1;
use strict; use warnings;
use Net::Frame::Layer qw(:consts :subs);
our @ISA = qw(Net::Frame::Layer Exporter);
our %EXPORT_TAGS = (
consts => [qw(
NF_RIPNG_METRIC_INFINITY
)],
);
our @EXPORT_OK = (
@{$EXPORT_TAGS{consts}},
);
use constant NF_RIPNG_METRIC_INFINITY => 16;
our @AS = qw(
prefix
routeTag
prefixLength
metric
);
__PACKAGE__->cgBuildIndices;
__PACKAGE__->cgBuildAccessorsScalar(\@AS);
sub new {
shift->SUPER::new(
prefix => '::',
routeTag => 0,
prefixLength => 64,
metric => 1,
@_,
);
}
sub full {
shift->SUPER::new(
prefix => '::',
routeTag => 0,
prefixLength => 0,
metric => NF_RIPNG_METRIC_INFINITY,
@_,
);
}
sub getLength { 20 }
sub pack {
my $self = shift;
$self->raw($self->SUPER::pack('a16nCC',
inet6Aton($self->prefix),
$self->routeTag,
$self->prefixLength,
$self->metric
)) or return;
return $self->raw;
}
sub unpack {
my $self = shift;
my ($prefix, $routeTag, $prefixLength, $metric, $payload) =
$self->SUPER::unpack('a16nCC a*', $self->raw)
or return;
$self->prefix(inet6Ntoa($prefix));
$self->routeTag($routeTag);
$self->prefixLength($prefixLength);
$self->metric($metric);
$self->payload($payload);
return $self;
}
sub encapsulate {
my $self = shift;
return $self->nextLayer if $self->nextLayer;
if ($self->payload) {
return "RIPng::v1";
}
NF_LAYER_NONE;
}
sub print {
my $self = shift;
my $l = $self->layer;
my $buf = sprintf
"$l: prefix:%s\n".
"$l: routeTag:%d prefixLength:%d metric:%d",
$self->prefix,
$self->routeTag, $self->prefixLength, $self->metric;
return $buf;
}
1;
__END__
=head1 NAME
Net::Frame::Layer::RIPng::v1 - Routing Information Protocol ng v1 layer object
=head1 SYNOPSIS
use Net::Frame::Layer::RIP::v1 qw(:consts);
my $ripngv1 = Net::Frame::Layer::RIPng::v1->new(
prefix => '::',
routeTag => 0,
prefixLength => 64,
metric => 1,
);
$ripngv1->pack;
print 'RAW: '.$ripngv1->dump."\n";
# Read a raw layer
my $layer = Net::Frame::Layer::RIPng::v1->new(raw => $raw);
print $layer->print."\n";
print 'PAYLOAD: '.unpack('H*', $layer->payload)."\n"
if $layer->payload;
=head1 DESCRIPTION
This modules implements the encoding and decoding of the RIPng v1 layer.
RFC: ftp://ftp.rfc-editor.org/in-notes/rfc2080.txt
See also B<Net::Frame::Layer> for other attributes and methods.
=head1 ATTRIBUTES
=over 4
=item B<prefix>
IPv6 prefix.
=item B<routeTag>
Attribute assigned to a route for separating routes within RIP domain.
=item B<prefixLength>
IPv6 prefix length of B<prefix>.
=item B<metric>
Metric for C<prefix>.
=back
The following are inherited attributes. See B<Net::Frame::Layer> for more information.
=over 4
=item B<raw>
=item B<payload>
=item B<nextLayer>
=back
=head1 METHODS
=over 4
=item B<new>
=item B<new> (hash)
Object constructor. You can pass attributes that will overwrite default ones. See B<SYNOPSIS> for default values.
=item B<full>
=item B<full> (hash)
Object constructor. Same as B<new> but with RIPng Request header, requests full routing table. You can pass attributes that will overwrite default ones. Default values: all fields 0 with B<NF_RIPNG_METRIC_INFINITY> set.
=back
The following are inherited methods. Some of them may be overriden in this layer, and some others may not be meaningful in this layer. See B<Net::Frame::Layer> for more information.
=over 4
=item B<layer>
=item B<computeLengths>
=item B<pack>
=item B<unpack>
=item B<encapsulate>
=item B<getLength>
=item B<getPayloadLength>
=item B<print>
=item B<dump>
=back
=head1 CONSTANTS
Load them: use Net::Frame::Layer::RIPng::v1 qw(:consts);
=over 4
=item B<NF_RIPNG_METRIC_INFINITY>
Infinity metric (16).
=back
=head1 SEE ALSO
L<Net::Frame::Layer>
=head1 AUTHOR
Michael Vincent
=head1 COPYRIGHT AND LICENSE
Copyright (c) 2012, Michael Vincent
You may distribute this module under the terms of the Artistic license.
See LICENSE.Artistic file in the source distribution archive.
=cut
( run in 2.373 seconds using v1.01-cache-2.11-cpan-39bf76dae61 )