Gazelle/sections/ajax/community_stats.php

68 lines
2.2 KiB
PHP
Raw Permalink Normal View History

2013-06-17 08:01:02 +00:00
<?
if (!isset($_GET['userid']) || !is_number($_GET['userid'])) {
json_die('failure');
}
$UserID = $_GET['userid'];
$CommStats = array(
'leeching' => false,
'seeding' => false,
'snatched' => false,
'usnatched' => false,
'downloaded' => false,
'udownloaded' => false,
'seedingperc' => false,
);
$User = Users::user_info($UserID);
function check_paranoia_here($Setting) {
global $User;
return check_paranoia($Setting, $User['Paranoia'], $User['Class'], $User['ID']);
}
if (check_paranoia_here('seeding+') || check_paranoia_here('leeching+')) {
$DB->query("
2013-07-10 00:08:53 +00:00
SELECT IF(remaining = 0, 'Seeding', 'Leeching') AS Type, COUNT(x.uid)
2013-06-17 08:01:02 +00:00
FROM xbt_files_users AS x
2013-07-10 00:08:53 +00:00
INNER JOIN torrents AS t ON t.ID = x.fid
WHERE x.uid = '$UserID'
AND x.active = 1
2013-06-17 08:01:02 +00:00
GROUP BY Type");
$PeerCount = $DB->to_array(0, MYSQLI_NUM, false);
if (check_paranoia('seeding+')) {
2013-06-20 08:01:00 +00:00
$Seeding = isset($PeerCount['Seeding']) ? $PeerCount['Seeding'][1] : 0;
$CommStats['seeding'] = number_format($Seeding);
2013-06-17 08:01:02 +00:00
}
if (check_paranoia('leeching+')) {
2013-06-20 08:01:00 +00:00
$CommStats['leeching'] = isset($PeerCount['Leeching']) ? number_format($PeerCount['Leeching'][1]) : 0;
2013-06-17 08:01:02 +00:00
}
}
if (check_paranoia_here('snatched+')) {
$DB->query("
SELECT COUNT(x.uid), COUNT(DISTINCT x.fid)
FROM xbt_snatched AS x
2013-07-10 00:08:53 +00:00
INNER JOIN torrents AS t ON t.ID = x.fid
2013-06-17 08:01:02 +00:00
WHERE x.uid = '$UserID'");
list($Snatched, $UniqueSnatched) = $DB->next_record(MYSQLI_NUM, false);
2013-06-20 08:01:00 +00:00
$CommStats['snatched'] = number_format($Snatched);
2013-06-17 08:01:02 +00:00
if (check_perms('site_view_torrent_snatchlist', $User['Class'])) {
2013-06-20 08:01:00 +00:00
$CommStats['usnatched'] = number_format($UniqueSnatched);
2013-06-17 08:01:02 +00:00
}
2013-09-23 08:00:51 +00:00
if (check_paranoia_here('seeding+') && check_paranoia_here('snatched+') && $UniqueSnatched > 0) {
2013-06-20 08:01:00 +00:00
$CommStats['seedingperc'] = 100 * min(1, round($Seeding / $UniqueSnatched, 2));
2013-06-17 08:01:02 +00:00
}
}
if (check_perms('site_view_torrent_snatchlist', $Class)) {
$DB->query("
SELECT COUNT(ud.UserID), COUNT(DISTINCT ud.TorrentID)
FROM users_downloads AS ud
2013-07-10 00:08:53 +00:00
JOIN torrents AS t ON t.ID = ud.TorrentID
WHERE ud.UserID = '$UserID'");
2013-06-17 08:01:02 +00:00
list($NumDownloads, $UniqueDownloads) = $DB->next_record(MYSQLI_NUM, false);
2013-06-20 08:01:00 +00:00
$CommStats['downloaded'] = number_format($NumDownloads);
$CommStats['udownloaded'] = number_format($UniqueDownloads);
2013-06-17 08:01:02 +00:00
}
json_die('success', $CommStats);