OXIESEC PANEL
- Current Dir:
/
/
usr
/
share
/
doc
/
lsof
/
examples
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
10/21/2019 03:49:18 PM
rwxr-xr-x
📄
00MANIFEST
1.76 KB
06/14/2004 02:32:48 PM
rw-r--r--
📄
00README
2 KB
10/28/2015 04:57:17 PM
rw-r--r--
📄
big_brother.perl5.gz
2.03 KB
10/28/2015 04:57:17 PM
rw-r--r--
📄
count_pf.perl
1.81 KB
10/28/2015 04:57:17 PM
rwxr-xr-x
📄
count_pf.perl5
1.97 KB
10/28/2015 04:57:17 PM
rwxr-xr-x
📄
identd.perl5
3.23 KB
10/28/2015 04:57:17 PM
rwxr-xr-x
📄
idrlogin.perl.gz
2.17 KB
10/28/2015 04:57:17 PM
rw-r--r--
📄
idrlogin.perl5.gz
2.22 KB
10/28/2015 04:57:17 PM
rw-r--r--
📄
list_NULf.perl5.gz
1.79 KB
10/28/2015 04:57:17 PM
rw-r--r--
📄
list_fields.awk.gz
1.72 KB
09/23/1997 02:32:42 PM
rw-r--r--
📄
list_fields.perl.gz
1.71 KB
10/28/2015 04:57:17 PM
rw-r--r--
📄
shared.perl5.gz
3.49 KB
10/28/2015 04:57:17 PM
rw-r--r--
📄
sort_res.perl5
3.63 KB
10/28/2015 04:57:17 PM
rwxr-xr-x
📄
watch_a_file.perl
2.18 KB
10/28/2015 04:57:17 PM
rwxr-xr-x
📄
xusers.awk
3.88 KB
03/10/1997 08:10:01 PM
rwxr-xr-x
Editing: watch_a_file.perl
Close
#!/usr/bin/perl # # watch_a_file.perl -- use lsof -F output to watch a specific file # (or file system) # # usage: watch_a_file.perl file_name ## Interrupt handler sub interrupt { wait; print "\n"; exit 0; } ## Start main program $Pn = "watch_a_file"; # Check file argument. if ($#ARGV != 0) { print "$#ARGV\n"; die "$Pn usage: file_name\n"; } $fnm = $ARGV[0]; if (! -r $fnm) { die "$Pn: can't read $fnm\n"; } # Do setup. $RPT = 15; # lsof repeat time $| = 1; # unbuffer output $SIG{'INT'} = 'interrupt'; # catch interrupt # Set path to lsof. if (($LSOF = &isexec("../lsof")) eq "") { # Try .. first if (($LSOF = &isexec("lsof")) eq "") { # Then try . and $PATH print "can't execute $LSOF\n"; exit 1 } } # Read lsof -nPF output from a pipe and gather the PIDs of the processes # and file descriptors to watch. open(P, "$LSOF -nPFpf $fnm|") || die "$Pn: can't pipe to $LSOF\n"; $curpid = -1; $pids = ""; while (<P>) { chop; if (/^p(.*)/) { $curpid = $1; next; } # Identify process. if (/^f/) { if ($curpid > 0) { if ($pids eq "") { $pids = $curpid; } else { $pids = $pids . "," . $curpid; } $curpid = -1; } } } close(P); wait; if ($pids eq "") { die "$Pn: no processes using $fnm located.\n"; } print "watch_file: $fnm being used by processes:\n\t$pids\n\n"; # Read repeated lsof output from a pipe and display. $pipe = "$LSOF -ap $pids -r $RPT $fnm"; open(P, "$pipe|") || die "$Pn: can't pipe: $pipe\n"; while (<P>) { print $_; } close(P); print "$Pn: unexpected EOF from \"$pipe\"\n"; exit 1; ## isexec($path) -- is $path executable # # $path = absolute or relative path to file to test for executabiity. # Paths that begin with neither '/' nor '.' that arent't found as # simple references are also tested with the path prefixes of the # PATH environment variable. sub isexec { my ($path) = @_; my ($i, @P, $PATH); $path =~ s/^\s+|\s+$//g; if ($path eq "") { return(""); } if (($path =~ m#^[\/\.]#)) { if (-x $path) { return($path); } return(""); } $PATH = $ENV{PATH}; @P = split(":", $PATH); for ($i = 0; $i <= $#P; $i++) { if (-x "$P[$i]/$path") { return("$P[$i]/$path"); } } return(""); }