package Net::Ping;# Authors: karrer@bernina.ethz.ch (Andreas Karrer)#          pmarquess@bfsec.bt.co.uk (Paul Marquess)require 5.002 ;require Exporter;use strict ;use vars qw(@ISA @EXPORT $VERSION $tcp_proto $echo_port) ;@ISA = qw(Exporter);@EXPORT = qw(ping pingecho);$VERSION = 1.01;use Socket 'PF_INET', 'AF_INET', 'SOCK_STREAM';use Carp ;$tcp_proto = (getprotobyname('tcp'))[2];$echo_port = (getservbyname('echo', 'tcp'))[2];sub ping {    croak "ping not implemented yet. Use pingecho()";}sub pingecho {    croak "usage: pingecho host [timeout]"         unless @_ == 1 or @_ == 2 ;    my ($host, $timeout) = @_;    my ($saddr, $ip);    my ($ret) ;    local (*PINGSOCK);    # check if $host is alive by connecting to its echo port, within $timeout    # (default 5) seconds. returns 1 if OK, 0 if no answer, 0 if host not found    $timeout = 5 unless $timeout;    if ($host =~ /^\s*((\d+\.){3}\d+)\s*$/)      { $ip = pack ('C4', split (/\./, $1)) }    else      { $ip = (gethostbyname($host))[4] }    return 0 unless $ip;		# "no such host"    $saddr = pack('S n a4 x8', AF_INET, $echo_port, $ip);    $SIG{'ALRM'} = sub { die } ;    alarm($timeout);        $ret = 0;    eval <<'EOM' ;    return unless socket(PINGSOCK, PF_INET, SOCK_STREAM, $tcp_proto) ;    return unless connect(PINGSOCK, $saddr) ;    $ret=1 ;EOM    alarm(0);    close(PINGSOCK);    $ret;}   1;__END__=cut=head1 NAMENet::Ping, pingecho - check a host for upness=head1 SYNOPSIS    use Net::Ping;    print "'jimmy' is alive and kicking\n" if pingecho('jimmy', 10) ;=head1 DESCRIPTIONThis module contains routines to test for the reachability of remote hosts.Currently the only routine implemented is pingecho(). pingecho() uses a TCP echo (I<not> an ICMP one) to determine if theremote host is reachable. This is usually adequate to tell that a remotehost is available to rsh(1), ftp(1), or telnet(1) onto.=head2 Parameters=over 5=item hostnameThe remote host to check, specified either as a hostname or as an IP address.=item timeoutThe timeout in seconds. If not specified it will default to 5 seconds.=back=head1 WARNINGpingecho() uses alarm to implement the timeout, so don't set another alarmwhile you are using it.