File:  [LON-CAPA] / loncom / debugging_tools / activity_to_accesscount.pl
Revision 1.1: download - view: text, annotated - select for diffs
Fri Nov 14 18:24:40 2003 UTC (20 years, 8 months ago) by matthew
Branches: MAIN
CVS tags: HEAD
Activity log parser / access count taker.  Sends some data to STDERR and
most to STDOUT.

    1: #!/usr/bin/perl -w
    2: #
    3: use strict;
    4: 
    5: sub unescape {
    6:     my $str=shift;
    7:     $str =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C",hex($1))/eg;
    8:     return $str;
    9: }
   10: 
   11: my %resourceaccess;
   12: 
   13: sub main {
   14:     my $file=$ARGV[0];
   15:     print STDERR "Using $file\n";
   16:     my $line;
   17:     open FILEID,'<'.$file;
   18:     my @allaccess;
   19:     print STDERR "Access by resource\n\n";
   20:     my $numlines = 0;
   21:     while ($line=<FILEID>) {
   22:         $numlines++;
   23:         if (int($numlines / 1000)*1000 == $numlines) {
   24:             if (int($numlines / 10000)*10000 == $numlines) {
   25:                 print STDERR '*';
   26:             } else {
   27:                 print STDERR '.';
   28:             }
   29:             if (int($numlines / 50000)*50000 == $numlines) {
   30:                 print STDERR $/;
   31:             }
   32:         }
   33:         next if ($line eq '' || $line !~ /:/);
   34:         chomp($line);
   35:         my ($time,$machine,$what)=split(':',$line);
   36: 	$what=&unescape($what);
   37:         my @accesses = split(/(\d{10}):/,$what);
   38:         shift(@accesses);
   39: 	while (@accesses) {
   40:             my $date = shift(@accesses);
   41:             my $access = shift(@accesses);
   42:             next if (! defined($access) || $access eq '' || 
   43:                      ! defined($date)   || $date   eq '');
   44:             $access =~ s/(\&$|^:)//g;
   45:             my ($resource,$who,$domain,$post,@posts)=split(':',$access);
   46: 	    if (!$resource) {
   47:                 next; 
   48:             }
   49:             $resource = &unescape($resource);
   50:             if ($resource !~ m:/: || $resource =~ m:/prtspool/:) {
   51:                 next;
   52:             }
   53:             if ($resource =~ /___\d+___/) {
   54:                 (undef,$resource) = split(/___\d+___/,$resource);
   55:             }
   56:             next if ($resource =~ m:^/(res/adm|adm)/:);
   57:             $resource =~ s:^/?res/?::;
   58:             $resourceaccess{$resource}++;            
   59: 	}
   60:     }
   61:     print STDERR 'done.'.$/;
   62:     while (my ($resource,$count) = each(%resourceaccess)) {
   63:         print sprintf("%10.0f",$count).':'.$resource."\n";
   64:     }
   65: }
   66: 
   67: main;

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>