-
Notifications
You must be signed in to change notification settings - Fork 8
Expand file tree
/
Copy pathpeerlist.php
More file actions
144 lines (119 loc) · 5.74 KB
/
peerlist.php
File metadata and controls
144 lines (119 loc) · 5.74 KB
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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
<?php
require_once("include/bittorrent.php");
require_once "include/user_functions.php";
require_once "include/bt_client_functions.php";
require_once "include/html_functions.php";
dbconn(false);
loggedinorreturn();
$id = (int)$_GET["id"];
if (!isset($id) || !is_valid_id($id))
die();
function dltable($name, $arr, $torrent)
{
global $CURUSER;
if (!count($arr))
return $s = "<div align='left'><b>No $name data available</b></div>\n";
$s = "\n";
$s .= "<table width='100%' class='main' border='1' cellspacing='0' cellpadding='5'>\n";
$s .= "<tr><td colspan='11' class='colhead'>" . count($arr) . " $name</td></tr>" .
"<tr><td class='colhead'>User/IP</td>" .
"<td class='colhead' align='center'>Connectable</td>".
"<td class='colhead' align='right'>Uploaded</td>".
"<td class='colhead' align='right'>Rate</td>".
"<td class='colhead' align='right'>Downloaded</td>" .
"<td class='colhead' align='right'>Rate</td>" .
"<td class='colhead' align='right'>Ratio</td>" .
"<td class='colhead' align='right'>Complete</td>" .
"<td class='colhead' align='right'>Connected</td>" .
"<td class='colhead' align='right'>Idle</td>" .
"<td class='colhead' align='left'>Client</td></tr>\n";
$now = time();
//$moderator = (isset($CURUSER) && get_user_class() >= UC_MODERATOR);
//$mod = get_user_class() >= UC_MODERATOR;
foreach ($arr as $e) {
// user/ip/port
// check if anyone has this ip
//($unr = mysql_query("SELECT username, privacy FROM users WHERE id=$e[userid] ORDER BY last_access DESC LIMIT 1")) or die;
//$una = mysql_fetch_assoc($unr);
if ($e["privacy"] == "strong") continue;
$s .= "<tr>\n";
if ($e["username"])
$s .= "<td><a href='userdetails.php?id=$e[userid]'><b>$e[username]</b></a></td>\n";
else
$s .= "<td>" . ($mod ? $e["ip"] : preg_replace('/\.\d+$/', ".xxx", $e["ip"])) . "</td>\n";
$secs = max(1, ($now - $e["st"]) - ($now - $e["la"]));
//$revived = $e["revived"] == "yes";
$s .= "<td align='center'>" . ($e['connectable'] == "yes" ? "Yes" : "<font color='red'>No</font>") . "</td>\n";
$s .= "<td align='right'>" . mksize($e["uploaded"]) . "</td>\n";
$s .= "<td align='right'><span style=\"white-space: nowrap;\">" . mksize(($e["uploaded"] - $e["uploadoffset"]) / $secs) . "/s</span></td>\n";
$s .= "<td align='right'>" . mksize($e["downloaded"]) . "</td>\n";
if ($e["seeder"] == "no")
$s .= "<td align='right'><span style=\"white-space: nowrap;\">" . mksize(($e["downloaded"] - $e["downloadoffset"]) / $secs) . "/s</span></td>\n";
else
$s .= "<td align='right'><span style=\"white-space: nowrap;\">" . mksize(($e["downloaded"] - $e["downloadoffset"]) / max(1, $e["finishedat"] - $e['st'])) . "/s</span></td>\n";
if ($e["downloaded"])
{
$ratio = floor(($e["uploaded"] / $e["downloaded"]) * 1000) / 1000;
$s .= "<td align=\"right\"><font color='" . get_ratio_color($ratio) . "'>" . number_format($ratio, 3) . "</font></td>\n";
}
else
if ($e["uploaded"])
$s .= "<td align='right'>Inf.</td>\n";
else
$s .= "<td align='right'>---</td>\n";
$s .= "<td align='right'>" . sprintf("%.2f%%", 100 * (1 - ($e["to_go"] / $torrent["size"]))) . "</td>\n";
$s .= "<td align='right'>" . mkprettytime($now - $e["st"]) . "</td>\n";
$s .= "<td align='right'>" . mkprettytime($now - $e["la"]) . "</td>\n";
$s .= "<td align='left'>" . htmlspecialchars(getagent($e["agent"], $e['peer_id'])) . "</td>\n";
$s .= "</tr>\n";
}
$s .= "</table>\n";
return $s;
}
$res = mysql_query("SELECT * FROM torrents WHERE id = $id")
or sqlerr();
if(mysql_num_rows($res) == 0)
stderr('Error', 'Nothing to see here, move along!');
$row = mysql_fetch_assoc($res);
$downloaders = array();
$seeders = array();
//$subres = mysql_query("SELECT u.username, u.privacy, p.seeder, p.finishedat, p.downloadoffset, p.uploadoffset, p.ip, p.port, p.uploaded, p.downloaded, p.to_go, UNIX_TIMESTAMP( p.started ) AS st, p.connectable, p.agent, UNIX_TIMESTAMP( p.last_action ) AS la, p.userid, p.peer_id
$subres = mysql_query("SELECT u.username, u.privacy, p.seeder, p.finishedat, p.downloadoffset, p.uploadoffset, p.ip, p.port, p.uploaded, p.downloaded, p.to_go, p.started AS st, p.connectable, p.agent, p.last_action AS la, p.userid, p.peer_id
FROM peers p
LEFT JOIN users u ON p.userid = u.id
WHERE p.torrent = $id") or sqlerr();
if(mysql_num_rows($subres) == 0)
stderr('Warning', 'No downloader/uploader data available!');
while ($subrow = mysql_fetch_assoc($subres)) {
if ($subrow["seeder"] == "yes")
$seeders[] = $subrow;
else
$downloaders[] = $subrow;
}
function leech_sort($a,$b) {
if ( isset( $_GET["usort"] ) ) return seed_sort($a,$b);
$x = $a["to_go"];
$y = $b["to_go"];
if ($x == $y)
return 0;
if ($x < $y)
return -1;
return 1;
}
function seed_sort($a,$b) {
$x = $a["uploaded"];
$y = $b["uploaded"];
if ($x == $y)
return 0;
if ($x < $y)
return 1;
return -1;
}
usort($seeders, "seed_sort");
usort($downloaders, "leech_sort");
stdhead('Details');
print "<h1>Peerlist for <a href='$BASEURL/details.php?id=$id'>".htmlentities($row['name'])."</a></h1>";
print dltable("Seeder(s)<a name='seeders'></a>", $seeders, $row);
print '<br />' . dltable("Leecher(s)<a name='leechers'></a>", $downloaders, $row);
stdfoot();
?>