forked from sicalpath/tjupt
-
Notifications
You must be signed in to change notification settings - Fork 2
/
cheaters.php
107 lines (87 loc) · 4.43 KB
/
cheaters.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
<?php
// mod_cheat for torrentbits based tracker
// Copy this file to the same dir as the rest of the tracker stuff...
$top = 100; // Only look at the top xxx most likely...
require "include/bittorrent.php";
dbconn();
loggedinorreturn();
if (get_user_class() < UC_MODERATOR) stderr("Error", "Permission denied.");
stdhead("Cheaters");
begin_frame('Cheaters');
$page = @$_GET['page'];
//$perpage = 100; // currently ignored
$class = @$_GET['c'];
if (!is_valid_user_class($class - 2)) $class = '';
$ratio = @$_GET['r'];
if (!is_valid_id($ratio) && $ratio >= 1 && $ratio <= 7) $ratio = '';
echo '<center><form method="get" action="' . $_SERVER["PHP_SELF"] . '">';
begin_table();
echo '<tr><th colspan="4">Important</th></tr><tr><td colspan="4" class="left">';
echo 'Although the word <b>cheat</b> is used here, it should be kept in mind that this<br />';
echo 'is statistical analysis - "There are lies, damm lies, and statistics!"<br />';
echo 'The value for cheating can and will change quite drastically depending on what<br />';
echo 'is happening, so you should always take into account other factors before<br />';
echo 'issueing a warning.<br />';
echo 'Somebody might get quite a high cheat value, but never cheat in their life - simply<br />';
echo 'from bad luck in when the client updates the tracker - but that will drop again in<br />';
echo 'the future. A true cheater will stay consistantly high...';
echo '</td></tr>';
echo '<tr><th>Class:</th>';
echo '<td><select name="c"><option value="1">(any)</option>';
for ($i = 2; ; ++$i) {
if ($c = get_user_class_name($i - 2)) echo "<option value=\"$i\" " . ($class == $i ? ' selected' : '') . " ><= $c</option>\n";
else break;
}
echo '</select></td>';
echo '<th>Ratio:</th>';
echo '<td><select name="r"><option value="1" ' . ($ratio == 1 ? ' selected' : '') . ' >(any)</option>';
echo '<option value="2" ' . ($ratio == 2 ? ' selected' : '') . ' >>= 1.000</option>';
echo '<option value="3" ' . ($ratio == 3 ? ' selected' : '') . ' >>= 2.000</option>';
echo '<option value="4" ' . ($ratio == 4 ? ' selected' : '') . ' >>= 3.000</option>';
echo '<option value="5" ' . ($ratio == 5 ? ' selected' : '') . ' >>= 4.000</option>';
echo '<option value="6" ' . ($ratio == 6 ? ' selected' : '') . ' >>= 5.000</option>';
echo '</select></td>';
echo '</tr><tr><td colspan="4"><input name="submit" type="submit"></td></tr>';
end_table();
echo '</form>';
$query = 'WHERE enabled = 1 AND downloaded > 0 AND uploaded > 0';
//' AND cheat >= '.$min
if ($class > 2) $query .= ' AND class < ' . ($class - 1);
if ($ratio > 1) $query .= ' AND (uploaded / downloaded) > ' . ($ratio - 1);
$res = sql_query("SELECT COUNT(*),MIN(cheat),MAX(cheat) FROM users $query") or sqlerr();
$arr = mysql_fetch_row($res);
$top = MIN($top, $arr[0]);
$min = $arr[1];
$max = $arr[2];
$pages = ceil($top / 20);
if ($page < 1) $page = 1;
elseif ($page > $pages) $page = $pages;
list($pagertop, $pagerbottom, $limit) = pager(20, $top, "cheaters.php?");
echo $pagertop;
begin_table();
print("<tr><th class=\"left\">User name</th><th>Registered</th><th>Uploaded</th><th>Downloaded</th><th>Ratio</th><th>Cheat Value</th><th>Cheat Spread</th></tr>\n");
$res = sql_query("SELECT * FROM users $query ORDER BY cheat DESC $limit") or sqlerr();
while ($arr = mysql_fetch_assoc($res)) {
if ($arr['added'] == "0000-00-00 00:00:00") $joindate = 'N/A';
else $joindate = get_elapsed_time(strtotime($arr['added'])) . ' ago';
$age = date('U') - date('U', strtotime($arr['added']));
if ($arr["downloaded"] > 0) {
$ratio = number_format($arr["uploaded"] / $arr["downloaded"], 3);
$ratio = "<font color=" . get_ratio_color($ratio) . ">$ratio</font>";
} else {
if ($arr["uploaded"] > 0) $ratio = "Inf.";
else $ratio = "---";
}
if ($arr['added'] == '0000-00-00 00:00:00') $arr['added'] = '-';
echo '<tr><th class="left"><a href="userdetails.php?id=' . $arr['id'] . '"><b>' . $arr['username'] . '</b></a></th>';
echo '<td>' . $joindate . '</td>';
echo '<td class="right">' . mksize($arr['uploaded']) . ' @ ' . mksize($arr['uploaded'] / $age) . 'ps</td>';
echo '<td class="right">' . mksize($arr['downloaded']) . ' @ ' . mksize($arr['downloaded'] / $age) . 'ps</td>';
echo '<td>' . $ratio . '</td>';
echo '<td>' . $arr['cheat'] . '</td>';
echo '<td class="right">' . ceil(($arr['cheat'] - $min) / max(1, ($max - $min)) * 100) . '%</td></tr>' . "\n";
}
end_table();
echo $pagerbottom;
end_frame();
stdfoot();