File:
[LON-CAPA] /
loncom /
cgi /
userstatus.pl
Revision
1.12:
download - view:
text,
annotated -
select for diffs
Thu Aug 25 19:43:40 2005 UTC (19 years, 1 month ago) by
albertel
Branches:
MAIN
CVS tags:
version_2_1_X,
version_2_1_3,
version_2_1_2,
version_2_1_1,
version_2_1_0,
version_2_0_X,
version_2_0_99_1,
version_2_0_2,
version_2_0_1,
HEAD
- don't count public users as reall users
1: #!/usr/bin/perl
2: $|=1;
3: # User Status
4: # $Id: userstatus.pl,v 1.12 2005/08/25 19:43:40 albertel Exp $
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:
29:
30: use strict;
31: use lib '/home/httpd/lib/perl/';
32: use LONCAPA::Configuration;
33:
34: use HTTP::Headers;
35: use IO::File;
36:
37:
38: my %usercount;
39: my @actl=('Active','Moderately Active','Inactive');
40:
41:
42: print "Content-type: text/html\n\n";
43:
44: # -------------------- Read loncapa.conf (and by default, loncapa_apache.conf).
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"; }
53: if ($since>1800) { $color="#666666"; $userclass=$actl[1]; }
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}={};
66: }
67: $usercount{$cat}{$scope}{$class}++;
68: }
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; }
83: if ($filename=~/^publicuser_/) { next; }
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;
93: ($userinfo{'user.name'},undef,$userinfo{'user.domain'})=
94: split('_',$filename);
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) {
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();
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'}).
116: ' <b>Browser</b>: '.$userinfo{'browser.type'}.
117: " on ".$userinfo{'browser.os'}."<b>Client:</b> ".
118: $userinfo{'request.host'}."<br />\n<b>Role: </b>".
119: $userinfo{'request.role'}." ";
120: }
121: &add_count('Browser',$userinfo{'browser.type'},$userinfo{'browser.version'});
122: &add_count('OS',$userinfo{'browser.os'},$userinfo{'browser.type'});
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);
152: &show('OS',%usercount);
153:
154: # print "\n</pre>";
155: print "<b>Load Average:<b> ".$loadavg;
156: print "</body></html>";
157: } else {
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}.'&';
168: }
169: print 'loadavg='.$loadavg;
170: }
171: }
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: }
189: }
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");
210: }
211:
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>