3 require_once('../mitsql.cfg.php');
4 require_once('mitsql.lib.php');
6 if ((isAdmin() || isImpersonating()) && isset($i_impersonate)) {
7 impersonate($i_impersonate);
12 if (!isAdmin()) redirectStart();
14 empty($i_pagesize) && $i_pagesize=20;
15 empty($i_page) && $i_page=1;
16 empty($i_sortby) && $i_sortby='dSignup';
17 empty($i_sortorder) && $i_sortorder=0;
18 !isset($i_search) && $i_search='';
20 if ($i_sortorder>0) $sortSQL = 'ASC'; else $sortSQL = 'DESC';
22 $i_pagesize = mysql_escape_string($i_pagesize);
23 $i_page = mysql_escape_string($i_page);
24 $i_search = mysql_escape_string($i_search);
25 $i_sortby = mysql_escape_string($i_sortby);
27 $sql_search = empty($i_search)?'':" AND Username LIKE '%$i_search%' ";
29 $columns = array('','Username','Name','nBytes','nBytesHard','nBytesOver','dSignup');
32 $sqlc = "SELECT COUNT(*) as c FROM User WHERE bEnabled=1 $sql_search";
33 $r = fetchRows(DBSelect($sqlc));
35 count($r) && $userCount = array_shift($r);
37 $sql = "SELECT User.UserId,Username,Name,dSignup,dLastCheck,nBytes,nBytesSoft,nBytesHard,
38 IF(nBytes>nBytesHard,nBytes-nBytesHard,0) as nBytesOver
41 NATURAL JOIN UserQuota
44 ORDER BY $i_sortby $sortSQL";
46 $sql .= ' LIMIT '.($i_page-1)*$i_pagesize.','.$i_pagesize;
47 $pageArray = range(1,ceil($userCount/$i_pagesize));
48 $pageCount = count($pageArray);
50 $users = fetchRows(DBSelect($sql),'UserId');
52 include 'tpl/head.php';
57 border: 1px solid black;
58 padding: 0px 2px 0px 2px;
63 echo '<em>',$userCount,' users</em> | ';
64 if ($i_page > 1) $tPagePrev = ' <a href="'.$URI.newQS('page',$i_page-1).'">Prev</a>'; else $tPagePrev = 'First';
65 if ($i_page < $pageCount) $tPageNext = ' <a href="'.$URI.newQS('page',$i_page+1).'">Next</a>'; else $tPageNext = 'Last';
66 if (!empty($tPageNext) && empty($tPagePrev)) echo($tPageNext);
67 elseif (empty($tPageNext) && !empty($tPagePrev)) echo($tPagePrev);
68 else echo "$tPagePrev | $tPageNext";
72 foreach($pageArray as $availablePage) {
73 echo ' <a href="'.$URI.newQS('page',$availablePage).'">'.$availablePage.'</a>';
77 echo ' | Page '.$i_page.' of '.$pageCount.' by '.$i_sortby;
80 <form method=get id=search name=search>
81 <input type=text name=search value="<?=$i_search?>" />
82 <input type=submit value="Search" />
83 <input type=button value="Clear" onClick="document.forms['search']['search'].value = ''; document.forms['search'].submit();" />
86 echo '<table cellspacing="0" cellpadding="0" class="usertable">';
88 foreach($columns as $column) {
89 if (!empty($column)) {
90 $qsa = array('sortby'=>$column);
91 if ($column==$i_sortby)
92 $qsa['sortorder']=abs($i_sortorder-1);
93 echo '<td><a href="'.$URI.newQSA($qsa).'">'.$column.'</a></td>';
94 } else echo '<td></td>';
97 foreach($users as $id=>$user) {
101 '<a href="do/admin/main',newQSA(array('impersonate'=>$id)),'">',
103 '</a></td><td><a href="http://web.mit.edu/bin/cgicso?query='.$user['Username'].'" target="_new">',
106 sprintSize($user['nBytes']),
108 sprintSize($user['nBytesHard']),
110 sprintSize($user['nBytesOver']),
114 // $user['dLastCheck'],
119 include 'tpl/foot.php';