home *** CD-ROM | disk | FTP | other *** search
- 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.
-
-
-