use strict;
use Socket;
+use File::Basename;
use vars qw($MAC_PROCESS $PS_STR $MATCH_STR $ASIP_PORT_NO $ASIP_PORT $LSOF);
# Written for linux; may have to be modified for your brand of Unix.
-
# Support for FreeBSD added by Joe Clarke <marcus@marcuscom.com>.
-# Support could probably be extended for *BSD, but I do not have Net or
-# OpenBSD machines to test with. Code has also been cleaned up and made
-# to compile under strict.
-#
-# The new lsof call should also be quicker as it does not involve a
-# second pipeline.
-#
+# Support Solaris added by Frank Lahm <franklahm@googlemail.com>.
# Support has also been added for 16 character usernames.
+if ($ARGV[0] =~ /^(-v|-version|--version)$/ ) {
+ printf ("%s \(Netatalk @NETATALK_VERSION@\)\n", basename($0));
+ exit(1);
+} elsif ($ARGV[0] =~ /^(-h|-help|--help)$/ ) {
+ printf ("usage: %s \[-v|-version|--version|-h|-help|--help\]\n", basename($0));
+ printf ("Show users connecting via AFP\n");
+ exit(1);
+}
+
$MAC_PROCESS = "afpd";
if ($^O eq "freebsd" || $^O eq "openbsd") {
$PS_STR = "-awwxouser,pid,ppid,start,command";
$MATCH_STR = '(\w+)\s+(\d+)\s+(\d+)\s+([\d\w:]+)';
+} elsif ($^O eq "solaris") {
+ $PS_STR = "-eo user,pid,ppid,c,stime,tty,time,comm";
+ $MATCH_STR = '\s*(\w+)\s+(\d+)\s+(\d+)\s+\d+\s+([\d\w:]+)';
} else {
- $PS_STR = "-ef";
+ $PS_STR = "-eo user:32,pid,ppid,c,stime,tty,time,cmd";
$MATCH_STR = '\s*(\w+)\s+(\d+)\s+(\d+)\s+\d+\s+([\d\w:]+)';
}
$ASIP_PORT = "afpovertcp";
$pid = $1;
$addr = $2;
$host = gethostbyaddr(pack('C4', split (/\./, $addr)), AF_INET);
- ($host) = ($host =~ /(^[\w\d\-]+)/);
+ ($host) = ( $host =~ /(^(\d+\.){3}\d+|[\w\d\-]+)/ );
$mac{$pid} = $host;
}
print
"PID UID Username Name Logintime Mac\n";
close(SOCKSTAT);
+} elsif ($^O eq "solaris") {
+ if ($< != 0) {
+ print "must be run as root\n";
+ exit(1);
+ }
+ print "PID UID Username Name Logintime Mac\n";
} elsif ($LSOF == 1) {
open(LSOF, "lsof -i :$ASIP_PORT |");
my ($pid, $host);
$pid = $1;
$host = $2;
- ($host) = ($host =~ /(^[\w\d\-]+)/);
+ ($host) = ( $host =~ /(^(\d+\.){3}\d+|[\w\d\-]+)/ );
$mac{$pid} = $host;
}
print
while (<PS>) {
next if ($_ !~ /$MAC_PROCESS/);
- my ($user, $pid, $ppid, $time, $name, $uid, $t);
+ my ($user, $pid, $ppid, $time, $name, $uid, $t, $ip);
$_ =~ /$MATCH_STR/;
$user = $1;
$pid = $2;
$time = $4;
if ($ppid != 1) {
+ if ($^O eq "solaris") {
+ open(PFILES, "pfiles $pid |");
+ while (<PFILES>) {
+ next if ($_ !~ /port: $ASIP_PORT_NO/);
+ while (<PFILES>) {
+ next if ($_ !~ /peername/);
+ if ($_ =~ /AF_INET (.*) port/) {
+ $ip = $1;
+ if ($ip =~ /::ffff:(.*)/ ) {
+ $ip = $1;
+ }
+ }
+ $mac{$pid} = $ip;
+ last;
+ }
+ last;
+ }
+ close(PFILES);
+ }
+
($t, $t, $uid, $t, $t, $t, $name, $t, $t) = getpwnam($user);
+ ($name) = ( $name =~ /(^[^,]+)/ );
printf "%-8d %-8d %-16s %-20s %-9s %s\n", $pid, $uid, $user,
$name, $time, $mac{$pid};
}