]> andersk Git - sql-web.git/blob - admin/main.php
admin usertable paging and sort
[sql-web.git] / admin / main.php
1 <?php
2
3 require_once('../mitsql.cfg.php');
4 require_once('mitsql.lib.php');
5
6 if ((isAdmin() || isImpersonating()) && isset($i_impersonate)) {
7         impersonate($i_impersonate);
8         redirectStart();
9         exit;
10 }
11
12 if (!isAdmin()) redirectStart();
13
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
19 if ($i_sortorder>0) $sortSQL = 'ASC'; else $sortSQL = 'DESC';
20
21 $i_pagesize = mysql_escape_string($i_pagesize);
22 $i_page = mysql_escape_string($i_page);
23 $i_sortby = mysql_escape_string($i_sortby);
24
25 $columns = array('','Username','Name','nBytes','nBytesHard','nBytesOver','dSignup');
26
27 $userCount = 0;
28 $sqlc = "SELECT COUNT(*) as c FROM User WHERE bEnabled=1";
29 $r = fetchRows(DBSelect($sqlc));
30 $r = array_shift($r);
31 count($r) && $userCount = array_shift($r);
32
33 $sql = sprintf("SELECT User.UserId,Username,Name,dSignup,dLastCheck,nBytes,nBytesSoft,nBytesHard,
34                                         IF(nBytes>nBytesHard,nBytes-nBytesHard,0) as nBytesOver
35                                 FROM User
36                                 NATURAL JOIN UserStat
37                                 NATURAL JOIN UserQuota
38                                 WHERE bEnabled=1
39                                 ORDER BY $i_sortby $sortSQL");
40
41 $sql .= ' LIMIT '.($i_page-1)*$i_pagesize.','.$i_pagesize;
42 $pageArray = range(1,ceil($userCount/$i_pagesize));
43 $pageCount = count($pageArray);
44
45 $users = fetchRows(DBSelect($sql),'UserId');
46
47 include 'tpl/head.php';
48
49 ?>
50 <style>
51 table.usertable td {
52         border: 1px solid black;
53         padding: 0px 2px 0px 2px;
54 }
55 </style>
56 <?php
57
58 echo '<em>',$userCount,' users</em> | ';
59 if ($i_page > 1) $tPagePrev = ' <a href="'.$URI.newQS('page',$i_page-1).'">Prev</a>'; else $tPagePrev = 'First';
60 if ($i_page < $pageCount) $tPageNext = ' <a href="'.$URI.newQS('page',$i_page+1).'">Next</a>'; else $tPageNext = 'Last';
61 if (!empty($tPageNext) && empty($tPagePrev)) echo($tPageNext);
62 elseif (empty($tPageNext) && !empty($tPagePrev)) echo($tPagePrev);
63 else echo "$tPagePrev | $tPageNext";
64
65 /*
66 echo ' | Skip to: ';
67 foreach($pageArray as $availablePage) {
68         echo ' <a href="'.$URI.newQS('page',$availablePage).'">'.$availablePage.'</a>';
69 }
70 */
71
72 echo ' | Page '.$i_page.' of '.$pageCount.' by '.$i_sortby;
73
74 echo '<table cellspacing="0" cellpadding="0" class="usertable">';
75 echo '<thead>';
76 foreach($columns as $column) {
77         if (!empty($column)) {
78                 $qsa = array('sortby'=>$column);
79                 if ($column==$i_sortby)
80                         $qsa['sortorder']=abs($i_sortorder-1);
81                 echo '<td><a href="'.$URI.newQSA($qsa).'">'.$column.'</a></td>';
82         } else echo '<td></td>';
83 }
84 echo '</thead>';
85 foreach($users as $id=>$user) {
86         echo '<tr><td>',
87                 $user['UserId'],
88                 '</td><td>',
89                 '<a href="do/admin/main',newQSA(array('impersonate'=>$id)),'">',
90                 $user['Username'],
91                 '</a></td><td><a href="http://web.mit.edu/bin/cgicso?query='.$user['Username'].'" target="_new">',
92                 $user['Name'],
93                 '</a></td><td>',
94                 sprintSize($user['nBytes']),
95                 '</td><td>',
96                 sprintSize($user['nBytesHard']),
97                 '</td><td>',
98                 sprintSize($user['nBytesOver']),
99                 '</td><td>',
100                 $user['dSignup'],
101 //              '</td><td>',
102 //              $user['dLastCheck'],
103                 '</td></tr>';
104 }
105 echo '</table>';
106
107 include 'tpl/foot.php';
108
109 ?>
This page took 0.076663 seconds and 5 git commands to generate.