Net-Write
view release on metacpan or search on metacpan
lib/Net/Write/Layer.pm view on Meta::CPAN
}
elsif ($^O eq 'darwin'
|| $^O eq 'linux'
|| $^O eq 'freebsd'
|| $^O eq 'openbsd'
|| $^O eq 'netbsd'
|| $^O eq 'aix') {
$val = 0;
}
eval "use constant NW_IPPROTO_IP => $val;";
}
sub _setIpProtoIpv6Constant {
my $val = 0;
if (defined(&IPPROTO_IPv6)) {
$val = &IPPROTO_IPv6;
}
elsif ($^O eq 'linux'
|| $^O eq 'freebsd') {
$val = 41;
}
eval "use constant NW_IPPROTO_IPv6 => $val;";
}
sub _setIpProtoRawConstant {
my $val = 255;
if (defined(&IPPROTO_RAW)) {
$val = &IPPROTO_RAW;
}
elsif ($^O eq 'darwin'
|| $^O eq 'linux'
|| $^O eq 'freebsd'
|| $^O eq 'openbsd'
|| $^O eq 'netbsd'
|| $^O eq 'aix') {
$val = 255;
}
eval "use constant NW_IPPROTO_RAW => $val;";
}
sub _setIpHdrInclConstant {
my $val = 2;
if (defined(&IP_HDRINCL)) {
$val = &IP_HDRINCL;
}
elsif ($^O eq 'darwin'
|| $^O eq 'freebsd'
|| $^O eq 'openbsd'
|| $^O eq 'netbsd'
|| $^O eq 'linux'
|| $^O eq 'aix'
|| $^O eq 'cygwin') {
$val = 2;
}
elsif ($^O eq 'hpux') {
$val = 0x1002;
}
eval "use constant NW_IP_HDRINCL => $val;";
}
sub _setAfinet6Constant {
my $val = 10; # Default value, in case we don't know.
# This is the value from a Ubuntu 14.10 system.
eval {
require Socket;
Socket->import(qw(AF_INET6));
};
if (! $@) { # AF_INET6 constant found in Socket module.
$val = Socket::AF_INET6();
}
else { # No AF_INET6 in Socket module, we try with Socket6.
eval {
require Socket6;
Socket6->import(qw(AF_INET6));
};
if (! $@) { # AF_INET6 constant found in Socket6 module.
$val = Socket6::AF_INET6();
}
}
# If constant is not found, we stick to the default value.
eval "use constant NW_AF_INET6 => $val;";
}
sub _setInetPtonSub {
no strict 'refs';
eval {
require Socket;
Socket->import(qw(AF_INET6 inet_pton));
};
if (! $@) { # Socket supports AF_INET6 family and inet_pton.
*{__PACKAGE__.'::nw_inet_pton'} = \&Socket::inet_pton;
return 1;
}
eval {
require Socket6;
Socket6->import(qw(AF_INET6 inet_pton));
};
if (! $@) { # Socket6 supports AF_INET6 family and inet_pton.
*{__PACKAGE__.'::nw_inet_pton'} = \&Socket6::inet_pton;
return 1;
}
die("[-] Net::Write: inet_pton: not supported by Socket nor Socket6: ".
"try upgrading your Perl version or Socket/Socket6 modules.\n");
}
sub _setGetaddrinfoSub {
no strict 'refs';
# Try to use getaddrinfo() from main Socket module.
eval {
require Socket;
Socket->import(qw(AF_INET AF_INET6 getaddrinfo));
};
if (! $@) { # Socket supports AF_INET6 family and getaddrinfo.
*{__PACKAGE__.'::nw_getsaddr'} = sub {
lib/Net/Write/Layer.pm view on Meta::CPAN
my @res = Socket6::getaddrinfo($dest, "", $family, $socktype)
or return _croak("@{[(caller(0))[3]]}: getaddrinfo: $!");
if (@res >= 5) {
my $saddr = $res[3];
return $saddr;
}
return _croak("@{[(caller(0))[3]]}: getaddrinfo: error: $!");
};
return 1;
}
# If still not found, we rely on Socket::GetAddrInfo()
eval("use Socket::GetAddrInfo qw(getaddrinfo);");
if ($@) {
chomp($@);
die("[-] Net::Write: getaddrinfo: not supported, try installing ".
"Socket::GetAddrInfo [$@]\n");
}
else {
*{__PACKAGE__.'::nw_getsaddr'} = sub {
my ($dest, $family, $protocol, $socktype) = @_;
#print STDERR "*** Fallback on Socket::GetAddrInfo support\n";
my %hints = ( family => $family );
my ($err, @res) = Socket::GetAddrInfo::getaddrinfo($dest, "", \%hints);
if ($err) {
return _croak("@{[(caller(0))[3]]}: getaddrinfo: $err");
}
my $ai = $res[0];
if (! defined($ai)) {
return _croak("@{[(caller(0))[3]]}: getaddrinfo: ai undefined");
}
return $ai->{addr}; # return sockaddr struct
};
}
return 1;
}
BEGIN {
my $osname = {
cygwin => \&_checkWin32,
MSWin32 => \&_checkWin32,
};
{
no strict 'refs';
*{__PACKAGE__.'::_check'} = $osname->{$^O} || \&_checkOther;
}
_setIpProtoIpConstant();
_setIpProtoIpv6Constant();
_setIpProtoRawConstant();
_setIpHdrInclConstant();
_setAfinet6Constant();
_setInetPtonSub();
_setGetaddrinfoSub();
}
no strict 'vars';
use Socket qw(SOCK_RAW);
use IO::Socket;
use Net::Pcap;
use constant NW_AF_INET => AF_INET();
use constant NW_AF_UNSPEC => AF_UNSPEC();
use constant NW_IPPROTO_ICMPv4 => 1;
use constant NW_IPPROTO_TCP => 6;
use constant NW_IPPROTO_UDP => 17;
use constant NW_IPPROTO_ICMPv6 => 58;
our %EXPORT_TAGS = (
constants => [qw(
NW_AF_INET
NW_AF_INET6
NW_AF_UNSPEC
NW_IPPROTO_IP
NW_IPPROTO_IPv6
NW_IPPROTO_ICMPv4
NW_IPPROTO_TCP
NW_IPPROTO_UDP
NW_IPPROTO_ICMPv6
NW_IP_HDRINCL
NW_IPPROTO_RAW
)],
subs => [qw(
nw_inet_pton
nw_getsaddr
)],
);
our @EXPORT_OK = (
@{$EXPORT_TAGS{constants}},
@{$EXPORT_TAGS{subs}},
);
sub _checkWin32 {
return 1;
}
sub _checkOther {
if ($>) {
print STDERR "[-] Must be EUID 0 (or equivalent) to open a device for ".
"writing.\n";
return;
}
return 1;
}
sub new {
my $self = shift->SUPER::new(
@_,
( run in 0.759 second using v1.01-cache-2.11-cpan-39bf76dae61 )