Annotation of loncom/cgi/userstatus.pl, revision 1.12
1.1 www 1: #!/usr/bin/perl
2: $|=1;
3: # User Status
1.12 ! albertel 4: # $Id: userstatus.pl,v 1.11 2004/09/22 15:00:04 albertel Exp $
1.7 albertel 5: #
6: # Copyright Michigan State University Board of Trustees
7: #
8: # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
9: #
10: # LON-CAPA is free software; you can redistribute it and/or modify
11: # it under the terms of the GNU General Public License as published by
12: # the Free Software Foundation; either version 2 of the License, or
13: # (at your option) any later version.
14: #
15: # LON-CAPA is distributed in the hope that it will be useful,
16: # but WITHOUT ANY WARRANTY; without even the implied warranty of
17: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18: # GNU General Public License for more details.
19: #
20: # You should have received a copy of the GNU General Public License
21: # along with LON-CAPA; if not, write to the Free Software
22: # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
23: #
24: # /home/httpd/html/adm/gpl.txt
25: #
26: # http://www.lon-capa.org/
27: #
28:
1.1 www 29:
1.5 albertel 30: use strict;
1.1 www 31: use lib '/home/httpd/lib/perl/';
32: use LONCAPA::Configuration;
33:
34: use HTTP::Headers;
35: use IO::File;
36:
1.5 albertel 37:
38: my %usercount;
39: my @actl=('Active','Moderately Active','Inactive');
40:
1.1 www 41:
1.3 www 42: print "Content-type: text/html\n\n";
43:
1.1 www 44: # -------------------- Read loncapa.conf (and by default, loncapa_apache.conf).
1.5 albertel 45: &main();
46:
47: sub analyze_time {
48: my ($since)=@_;
49: my $color="#000000";
50: my $userclass=$actl[0];
51: if ($since>300) { $color="#222222"; }
52: if ($since>600) { $color="#444444"; }
1.8 albertel 53: if ($since>1800) { $color="#666666"; $userclass=$actl[1]; }
1.5 albertel 54: if ($since>7200) { $color="#888888"; }
55: if ($since>21600) { $color="#AAAAAA"; $userclass=$actl[2]; }
56: return ($color,$userclass);
57: }
58:
59: sub add_count {
60: my ($cat,$scope,$class)=@_;
61: if (!defined($usercount{$cat})) {
62: $usercount{$cat}={};
63: }
64: if (!defined($usercount{$cat}{$scope})) {
65: $usercount{$cat}{$scope}={};
1.1 www 66: }
1.5 albertel 67: $usercount{$cat}{$scope}{$class}++;
1.1 www 68: }
1.5 albertel 69:
70: sub main {
71: my $perlvar=LONCAPA::Configuration::read_conf('loncapa.conf');
72: delete $$perlvar{'lonReceipt'}; # remove since sensitive and not needed
73: delete $$perlvar{'lonSqlAccess'}; # remove since sensitive and not needed
74:
75: my $oneline=($ENV{'QUERY_STRING'} eq 'simple');
76: my $justsummary=($ENV{'QUERY_STRING'} eq 'summary');
77: unless ($oneline) { print "<html><body bgcolor=#FFFFFF>\n<h1>User Status ".localtime()."</h1>"; }
78:
79: opendir(DIR,$$perlvar{'lonIDsDir'});
80: my @allfiles=(sort(readdir(DIR)));
81: foreach my $filename (@allfiles) {
82: if ($filename=~/^\./) { next; }
1.12 ! albertel 83: if ($filename=~/^publicuser_/) { next; }
1.5 albertel 84: my ($dev,$ino,$mode,$nlink,
85: $uid,$gid,$rdev,$size,
86: $atime,$mtime,$ctime,
87: $blksize,$blocks)=stat($$perlvar{'lonIDsDir'}.'/'.$filename);
88: my $now=time;
89: my $since=$now-$mtime;
90: my $sinceacc=$now-$atime;
91: unless ($oneline || $justsummary) { print ("\n\n<hr />"); }
92: my %userinfo;
1.11 albertel 93: ($userinfo{'user.name'},undef,$userinfo{'user.domain'})=
94: split('_',$filename);
1.5 albertel 95: my ($color,$userclass)=&analyze_time($since);
96: &add_count('Overall','all',$userclass);
97: &add_count('Domain',$userinfo{'user.domain'},$userclass);
98:
99: unless ($oneline) {
1.11 albertel 100: my $fh=IO::File->new($$perlvar{'lonIDsDir'}.'/'.$filename);
101: while (my $line=<$fh>) {
102: chomp($line);
103: my ($name,$value)=split(/\=/,$line);
104: $userinfo{$name}=$value;
105: }
106: $fh->close();
1.5 albertel 107: if (!$justsummary) {
108: print '<font color="'.$color.'">';
109: print '<h3>'.$userinfo{'environment.lastname'}.', '.
110: $userinfo{'environment.firstname'}.' '.
111: $userinfo{'environment.middlename'}.' '.
112: $userinfo{'environment.generation'}." (".
113: $userinfo{'user.name'}."\@".$userinfo{'user.domain'}.
114: ")</h3>\n<b>Login time:</b> ".
115: localtime($userinfo{'user.login.time'}).
1.9 albertel 116: ' <b>Browser</b>: '.$userinfo{'browser.type'}.
117: " on ".$userinfo{'browser.os'}."<b>Client:</b> ".
1.5 albertel 118: $userinfo{'request.host'}."<br />\n<b>Role: </b>".
119: $userinfo{'request.role'}." ";
120: }
121: &add_count('Browser',$userinfo{'browser.type'},$userinfo{'browser.version'});
1.10 albertel 122: &add_count('OS',$userinfo{'browser.os'},$userinfo{'browser.type'});
1.5 albertel 123: if ($userinfo{'request.course.id'}) {
124: my $cid=$userinfo{'request.course.id'};
125: my $coursename= $userinfo{'course.'.$cid.'.description'}.
126: ' ('.$cid.')';
127: if (!$justsummary) { print "<b>Course:</b> ".$coursename; }
128: &add_count('Course',$coursename,$userclass);
129: } else {
130: if (!$justsummary) { print "Not in a course."; }
131: &add_count('Course','No Course',$userclass);
132: }
133: if (!$justsummary) {
134: print "<br /><b>Last Transaction:</b> ".localtime($mtime).
135: " (".$since." secs ago) <br /><b>Last Access:</b> ".
136: localtime($atime)." (".$sinceacc." secs ago)";
137: print ("</font>");
138: }
139: }
140: }
141: closedir(DIR);
142: open (LOADAVGH,"/proc/loadavg");
143: my $loadavg=<LOADAVGH>;
144: close(LOADAVGH);
145: unless ($oneline) {
146: print "<hr /><h2>User Counts</h2>";
147: # print "<pre>\n";
148: &showact('Overall',%usercount);
149: &showact('Domain',%usercount);
150: &showact('Course',%usercount);
151: &show('Browser',%usercount);
1.9 albertel 152: &show('OS',%usercount);
1.5 albertel 153:
154: # print "\n</pre>";
155: print "<b>Load Average:<b> ".$loadavg;
156: print "</body></html>";
157: } else {
1.6 albertel 158: foreach my $l1 (sort keys %usercount) {
159: foreach my $l2 (sort keys %{$usercount{$l1}}) {
160: foreach my $l3 (sort keys %{$usercount{$l1}{$l2}}) {
161: print $l1.'_'.$l2.'_'.$l3.'='.$usercount{$l1}{$l2}{$l3}.'&';
162: }
163: }
164: }
165: #clusterstatus values
166: foreach my $act (@actl) {
167: print "$act=".$usercount{'Overall'}{'all'}{$act}.'&';
1.5 albertel 168: }
169: print 'loadavg='.$loadavg;
170: }
1.1 www 171: }
1.5 albertel 172:
173: sub show {
174: my ($cat,%usercount)=@_;
175: print("<h3>$cat</h3>\n");
176: foreach my $type (sort(keys(%{$usercount{$cat}}))) {
177: print("<table border='1'><tr><th>$type</th><th>");
178: print(join("</th><th>",sort(keys(%{$usercount{$cat}{$type}}))));
179: my $temp;
180: my $count=0;
181: foreach my $version (sort(keys(%{$usercount{$cat}{$type}}))) {
182: $temp.="<td>".$usercount{$cat}{$type}{$version}.
183: "</td>";
184: $count+=$usercount{$cat}{$type}{$version};
185: }
186: print("</th></tr><tr><td>$count</td>");
187: print($temp."</tr></table>\n");
188: }
1.3 www 189: }
1.5 albertel 190:
191: sub showact {
192: my ($cat,%usercount)=@_;
193: print("<h3>$cat</h3>\n");
194:
195: print("<table border='1'><tr><th></th><th>");
196: print(join("</th><th>",('Any',@actl)));
197: print("</th></tr>");
198: foreach my $type (sort(keys(%{$usercount{$cat}}))) {
199: print("<tr><td>$type</td>");
200: my $temp;
201: my $count=0;
202: foreach my $activity (@actl) {
203: $temp.="<td> ".$usercount{$cat}{$type}{$activity}."</td>";
204: $count+=$usercount{$cat}{$type}{$activity};
205: }
206: print("<td>$count</td>");
207: print($temp);
208: }
209: print("</tr></table>\n");
1.3 www 210: }
1.5 albertel 211:
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>