#!/usr/bin/perl # Script to help generate find the .scripts-version files use lib '/mit/scripts/sec-tools/perl'; open(FILE, " 40, debug => 0, trace => 0; use POSIX ":sys_wait_h"; # imports WNOHANG # this loop creates new childs, but Proc::Queue makes it wait every # time the limit (50) is reached until enough childs exit # Note that we miss things where one volume is inside another if we # use -xdev. May miss libraries stuff. sub updatable ($) { my $filename = shift; for my $l (`fs la "$filename"`) { return 1 if ($l =~ /^ system:scripts-security-upd rlidwk/); } return 0; } sub old_version ($) { my $dirname = shift; open my $h, "$dirname/.scripts-version"; return (<$h>)[-1]; } sub version ($) { my $dirname = shift; open my $h, "$dirname/.scripts/version"; return (<$h>)[-1]; } sub find ($$) { my $user = shift; my $homedir = shift; open my $files, "find $homedir/web_scripts -xdev -name .scripts-version -o -name .scripts 2>/dev/null |"; open my $out, ">$dump/$user"; while (my $f = <$files>) { chomp $f; my $old_style; $old_style = ($f =~ s!/\.scripts-version$!!); if (! $old_style) { $f =~ s!/\.scripts$!!; } if (! updatable($f)) { print STDERR "not updatable: $f"; next; } $v = $old_style ? old_version($f) : version($f); print $out "$f:$v"; } return 0; } while () { my ($user, $homedir) = /^([^ ]*) (.*)$/; my $f=fork; if(defined ($f) and $f==0) { if ($homedir !~ m|^/afs/athena| && $homedir !~ m|^/afs/sipb| && $homedir !~ m|^/afs/zone|) { print "ignoring foreign-cell $user $homedir\n"; exit(0); } print "$user\n"; $ret = find($user, $homedir); sleep rand 1; exit($ret); } 1 while waitpid(-1, WNOHANG)>0; # avoids memory leaks in Proc::Queue }