| Net-Packet documentation | Contained in the Net-Packet distribution. |
Net::Packet::RAW - empty layer 2 object
#
# Usually, you do not use this module directly
#
# No constants for RAW
require Net::Packet::RAW;
# Build a layer
my $layer = Net::Packet::RAW->new;
$layer->pack;
print 'RAW: '.unpack('H*', $layer->raw)."\n";
# Read a raw layer
my $layer = Net::Packet::RAW->new(raw => $raw);
print $layer->print."\n";
print 'PAYLOAD: '.unpack('H*', $layer->payload)."\n"
if $layer->payload;
This modules implements the encoding and decoding of the raw layer 2.
See also Net::Packet::Layer and Net::Packet::Layer2 for other attributes and methods.
Object constructor. No default values, because no attributes.
Packs all attributes into a raw format, in order to inject to network. Returns 1 on success, undef otherwise.
Unpacks raw data from network and stores attributes into the object. Returns 1 on success, undef otherwise.
Patrice <GomoR> Auffret
Copyright (c) 2004-2009, Patrice <GomoR> Auffret
You may distribute this module under the terms of the Artistic license. See LICENSE.Artistic file in the source distribution archive.
NetPacket, Net::RawIP, Net::RawSock
| Net-Packet documentation | Contained in the Net-Packet distribution. |
# # $Id: RAW.pm 1640 2009-11-09 17:58:27Z gomor $ # package Net::Packet::RAW; use strict; use warnings; require Net::Packet::Layer2; our @ISA = qw(Net::Packet::Layer2); __PACKAGE__->cgBuildIndices; use Net::Packet::Consts qw(:layer); no strict 'vars'; sub pack { shift->[$__raw] = '' } sub unpack { my $self = shift; $self->[$__payload] = $self->[$__raw]; 1; } sub encapsulate { my $self = shift; return NP_LAYER_NONE() if ! $self->[$__payload]; # With RAW layer, we must guess which type is the first layer my $payload = CORE::unpack('H*', $self->[$__payload]); # XXX: may not work on big-endian arch if ($payload =~ /^4/) { return NP_LAYER_IPv4(); } elsif ($payload =~ /^6/) { return NP_LAYER_IPv6(); } elsif ($payload =~ /^0001....06/) { return NP_LAYER_ARP(); } return NP_LAYER_UNKNOWN(); } 1; __END__