]> andersk Git - sql-web.git/blame - admin/main.php
admin usertable paging and sort
[sql-web.git] / admin / main.php
CommitLineData
1426e302
JP
1<?php
2
3require_once('../mitsql.cfg.php');
e47be57b 4require_once('mitsql.lib.php');
1426e302 5
224df904 6if ((isAdmin() || isImpersonating()) && isset($i_impersonate)) {
d1f4316d 7 impersonate($i_impersonate);
224df904 8 redirectStart();
d1f4316d
JP
9 exit;
10}
11
224df904
JP
12if (!isAdmin()) redirectStart();
13
77bd9685
JP
14empty($i_pagesize) && $i_pagesize=20;
15empty($i_page) && $i_page=1;
16empty($i_sortby) && $i_sortby='dSignup';
17empty($i_sortorder) && $i_sortorder=0;
18
19if ($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);
31count($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
1050fbb7
JP
35 FROM User
36 NATURAL JOIN UserStat
d02b16c4 37 NATURAL JOIN UserQuota
1050fbb7 38 WHERE bEnabled=1
77bd9685
JP
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
d1f4316d
JP
45$users = fetchRows(DBSelect($sql),'UserId');
46
47include 'tpl/head.php';
48
d02b16c4
JP
49?>
50<style>
51table.usertable td {
52 border: 1px solid black;
77bd9685 53 padding: 0px 2px 0px 2px;
d02b16c4
JP
54}
55</style>
56<?php
57
77bd9685
JP
58echo '<em>',$userCount,' users</em> | ';
59if ($i_page > 1) $tPagePrev = ' <a href="'.$URI.newQS('page',$i_page-1).'">Prev</a>'; else $tPagePrev = 'First';
60if ($i_page < $pageCount) $tPageNext = ' <a href="'.$URI.newQS('page',$i_page+1).'">Next</a>'; else $tPageNext = 'Last';
61if (!empty($tPageNext) && empty($tPagePrev)) echo($tPageNext);
62elseif (empty($tPageNext) && !empty($tPagePrev)) echo($tPagePrev);
63else echo "$tPagePrev | $tPageNext";
64
65/*
66echo ' | Skip to: ';
67foreach($pageArray as $availablePage) {
68 echo ' <a href="'.$URI.newQS('page',$availablePage).'">'.$availablePage.'</a>';
69}
70*/
71
72echo ' | Page '.$i_page.' of '.$pageCount.' by '.$i_sortby;
73
d02b16c4 74echo '<table cellspacing="0" cellpadding="0" class="usertable">';
77bd9685
JP
75echo '<thead>';
76foreach($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}
84echo '</thead>';
d1f4316d 85foreach($users as $id=>$user) {
1050fbb7
JP
86 echo '<tr><td>',
87 $user['UserId'],
88 '</td><td>',
89 '<a href="do/admin/main',newQSA(array('impersonate'=>$id)),'">',
90 $user['Username'],
77bd9685 91 '</a></td><td><a href="http://web.mit.edu/bin/cgicso?query='.$user['Username'].'" target="_new">',
1050fbb7 92 $user['Name'],
77bd9685 93 '</a></td><td>',
1050fbb7
JP
94 sprintSize($user['nBytes']),
95 '</td><td>',
d02b16c4
JP
96 sprintSize($user['nBytesHard']),
97 '</td><td>',
77bd9685 98 sprintSize($user['nBytesOver']),
d02b16c4 99 '</td><td>',
77bd9685
JP
100 $user['dSignup'],
101// '</td><td>',
102// $user['dLastCheck'],
1050fbb7 103 '</td></tr>';
d1f4316d 104}
1050fbb7 105echo '</table>';
d1f4316d
JP
106
107include 'tpl/foot.php';
108
1426e302 109?>
This page took 0.058417 seconds and 5 git commands to generate.