mirror of
https://github.com/torrentpier/torrentpier.git
synced 2025-01-18 17:02:51 -08:00
197 lines
7.8 KiB
PHP
197 lines
7.8 KiB
PHP
<?php
|
||
/**
|
||
* TorrentPier – Bull-powered BitTorrent tracker engine
|
||
*
|
||
* @copyright Copyright (c) 2005-2024 TorrentPier (https://torrentpier.com)
|
||
* @link https://github.com/torrentpier/torrentpier for the canonical source repository
|
||
* @license https://github.com/torrentpier/torrentpier/blob/master/LICENSE MIT License
|
||
*/
|
||
|
||
if (!defined('IN_AJAX')) {
|
||
die(basename(__FILE__));
|
||
}
|
||
|
||
global $bb_cfg, $lang, $userdata, $datastore;
|
||
|
||
if (!$mode = (string)$this->request['mode']) {
|
||
$this->ajax_die('invalid mode (empty)');
|
||
}
|
||
|
||
$html = '';
|
||
switch ($mode) {
|
||
case 'birthday_week':
|
||
$stats = $datastore->get('stats');
|
||
$datastore->enqueue([
|
||
'stats'
|
||
]);
|
||
|
||
$users = [];
|
||
|
||
if ($stats['birthday_week_list']) {
|
||
foreach ($stats['birthday_week_list'] as $week) {
|
||
$users[] = profile_url($week) . ' <span class="small">(' . birthday_age(date('Y-m-d', strtotime('-1 year', strtotime($week['user_birthday'])))) . ')</span>';
|
||
}
|
||
$html = sprintf($lang['BIRTHDAY_WEEK'], $bb_cfg['birthday_check_day'], implode(', ', $users));
|
||
} else {
|
||
$html = sprintf($lang['NOBIRTHDAY_WEEK'], $bb_cfg['birthday_check_day']);
|
||
}
|
||
break;
|
||
|
||
case 'birthday_today':
|
||
$stats = $datastore->get('stats');
|
||
$datastore->enqueue([
|
||
'stats'
|
||
]);
|
||
|
||
$users = [];
|
||
|
||
if ($stats['birthday_today_list']) {
|
||
foreach ($stats['birthday_today_list'] as $today) {
|
||
$users[] = profile_url($today) . ' <span class="small">(' . birthday_age($today['user_birthday']) . ')</span>';
|
||
}
|
||
$html = $lang['BIRTHDAY_TODAY'] . implode(', ', $users);
|
||
} else {
|
||
$html = $lang['NOBIRTHDAY_TODAY'];
|
||
}
|
||
break;
|
||
|
||
case 'get_forum_mods':
|
||
$forum_id = (int)$this->request['forum_id'];
|
||
|
||
$datastore->enqueue([
|
||
'moderators',
|
||
'cat_forums'
|
||
]);
|
||
|
||
$moderators = [];
|
||
$mod = $datastore->get('moderators');
|
||
|
||
if (isset($mod['mod_users'][$forum_id])) {
|
||
foreach ($mod['mod_users'][$forum_id] as $user_id) {
|
||
$moderators[] = '<a href="' . PROFILE_URL . $user_id . '">' . $mod['name_users'][$user_id] . '</a>';
|
||
}
|
||
}
|
||
|
||
if (isset($mod['mod_groups'][$forum_id])) {
|
||
foreach ($mod['mod_groups'][$forum_id] as $group_id) {
|
||
$moderators[] = '<a href="' . GROUP_URL . $group_id . '">' . $mod['name_groups'][$group_id] . '</a>';
|
||
}
|
||
}
|
||
|
||
$html = ': ';
|
||
$html .= ($moderators) ? implode(', ', $moderators) : $lang['NONE'];
|
||
unset($moderators, $mod);
|
||
$datastore->rm('moderators');
|
||
break;
|
||
|
||
case 'null_ratio':
|
||
if (!$bb_cfg['ratio_null_enabled'] || !RATIO_ENABLED) {
|
||
$this->ajax_die($lang['MODULE_OFF']);
|
||
}
|
||
if (empty($this->request['confirmed'])) {
|
||
$this->prompt_for_confirm($lang['BT_NULL_RATIO_ALERT']);
|
||
}
|
||
|
||
$user_id = (int)$this->request['user_id'];
|
||
if (!IS_ADMIN && $user_id != $userdata['user_id']) {
|
||
$this->ajax_die($lang['NOT_AUTHORISED']);
|
||
}
|
||
|
||
$btu = get_bt_userdata($user_id);
|
||
$ratio_nulled = (bool)$btu['ratio_nulled'];
|
||
$user_ratio = get_bt_ratio($btu);
|
||
|
||
if (($user_ratio === null) && !IS_ADMIN) {
|
||
$this->ajax_die($lang['BT_NULL_RATIO_NONE']);
|
||
}
|
||
if ($ratio_nulled && !IS_ADMIN) {
|
||
$this->ajax_die($lang['BT_NULL_RATIO_AGAIN']);
|
||
}
|
||
if (($user_ratio >= $bb_cfg['ratio_to_null']) && !IS_ADMIN) {
|
||
$this->ajax_die(sprintf($lang['BT_NULL_RATIO_NOT_NEEDED'], $bb_cfg['ratio_to_null']));
|
||
}
|
||
|
||
$ratio_nulled_sql = !IS_ADMIN ? ', ratio_nulled = 1' : '';
|
||
DB()->query("UPDATE " . BB_BT_USERS . " SET u_up_total = 0, u_down_total = 0, u_up_release = 0, u_up_bonus = 0 $ratio_nulled_sql WHERE user_id = " . $user_id);
|
||
CACHE('bb_cache')->rm('btu_' . $user_id);
|
||
$this->ajax_die($lang['BT_NULL_RATIO_SUCCESS']);
|
||
break;
|
||
|
||
case 'releaser_stats':
|
||
$user_id = (int)$this->request['user_id'];
|
||
|
||
$sql = "
|
||
SELECT COUNT(tor.poster_id) as total_releases, SUM(tor.size) as total_size, SUM(tor.complete_count) as total_complete, SUM(ad.download_count) as total_dl_count
|
||
FROM " . BB_BT_TORRENTS . " tor
|
||
LEFT JOIN " . BB_USERS . " u ON(u.user_id = tor.poster_id)
|
||
LEFT JOIN " . BB_ATTACHMENTS_DESC . " ad ON(ad.attach_id = tor.attach_id)
|
||
LEFT JOIN " . BB_BT_USERS . " ut ON(ut.user_id = tor.poster_id)
|
||
WHERE u.user_id = $user_id
|
||
GROUP BY tor.poster_id
|
||
LIMIT 1
|
||
";
|
||
|
||
$total_releases_size = $total_releases = $total_releases_completed = $total_releases_downloaded = 0;
|
||
if ($row = DB()->fetch_row($sql)) {
|
||
$total_releases = $row['total_releases'];
|
||
$total_releases_size = $row['total_size'];
|
||
$total_releases_downloaded = $row['total_dl_count'];
|
||
$total_releases_completed = $row['total_complete'];
|
||
}
|
||
|
||
$html = '[
|
||
' . $lang['RELEASES'] . ': <span class="seed bold">' . $total_releases . '</span> |
|
||
' . $lang['RELEASER_STAT_SIZE'] . ' <span class="seed bold">' . humn_size($total_releases_size) . '</span> |
|
||
' . $lang['DOWNLOADED'] . ': <span title="' . $lang['COMPLETED'] . ': ' . declension((int)$total_releases_completed, 'times') . '" class="seed bold">' . declension((int)$total_releases_downloaded, 'times') . '</span> ]';
|
||
break;
|
||
|
||
case 'get_traf_stats':
|
||
if (!RATIO_ENABLED) {
|
||
$this->ajax_die($lang['MODULE_OFF']);
|
||
}
|
||
|
||
$user_id = (int)$this->request['user_id'];
|
||
$btu = get_bt_userdata($user_id);
|
||
$profiledata = get_userdata($user_id);
|
||
|
||
$speed_up = ($btu['speed_up']) ? humn_size($btu['speed_up']) . '/s' : '0 KB/s';
|
||
$speed_down = ($btu['speed_down']) ? humn_size($btu['speed_down']) . '/s' : '0 KB/s';
|
||
$user_ratio = ($btu['u_down_total'] > MIN_DL_FOR_RATIO) ? '<b class="gen">' . get_bt_ratio($btu) . '</b>' : $lang['IT_WILL_BE_DOWN'] . ' <b>' . humn_size(MIN_DL_FOR_RATIO) . '</b>';
|
||
|
||
$html = '
|
||
<tr class="row3">
|
||
<th style="padding: 0;"></th>
|
||
<th>' . $lang['DOWNLOADED'] . '</th>
|
||
<th>' . $lang['UPLOADED'] . '</th>
|
||
<th>' . $lang['RELEASED'] . '</th>
|
||
<th>' . $lang['BONUS'] . '</th>';
|
||
$html .= $bb_cfg['seed_bonus_enabled'] ? '<th>' . $lang['SEED_BONUS'] . '</th>' : '';
|
||
$html .= '</tr>
|
||
<tr class="row1">
|
||
<td>' . $lang['TOTAL_TRAF'] . '</td>
|
||
<td id="u_down_total"><span class="editable bold leechmed">' . humn_size($btu['u_down_total']) . '</span></td>
|
||
<td id="u_up_total"><span class="editable bold seedmed">' . humn_size($btu['u_up_total']) . '</span></td>
|
||
<td id="u_up_release"><span class="editable bold seedmed">' . humn_size($btu['u_up_release']) . '</span></td>
|
||
<td id="u_up_bonus"><span class="editable bold seedmed">' . humn_size($btu['u_up_bonus']) . '</span></td>';
|
||
$html .= $bb_cfg['seed_bonus_enabled'] ? '<td id="user_points"><span class="editable bold points">' . $profiledata['user_points'] . '</b></td>' : '';
|
||
$html .= '</tr>
|
||
<tr class="row5">
|
||
<td colspan="1">' . $lang['MAX_SPEED'] . '</td>
|
||
<td colspan="2">' . $lang['DL_DL_SPEED'] . ': ' . $speed_down . '</span></td>
|
||
<td colspan="2">' . $lang['DL_UL_SPEED'] . ': ' . $speed_up . '</span></td>';
|
||
$html .= $bb_cfg['seed_bonus_enabled'] ? '<td colspan="1"></td>' : '';
|
||
$html .= '</tr>';
|
||
|
||
$this->response['user_ratio'] = '
|
||
<th><a href="' . $bb_cfg['ratio_url_help'] . '" class="bold">' . $lang['USER_RATIO'] . '</a>:</th>
|
||
<td>' . $user_ratio . '</td>
|
||
';
|
||
break;
|
||
|
||
default:
|
||
$this->ajax_die('Invalid mode: ' . $mode);
|
||
}
|
||
|
||
$this->response['html'] = $html;
|
||
$this->response['mode'] = $mode;
|