mirror of
https://github.com/slawkens/myaac.git
synced 2025-10-23 22:05:02 +02:00

* wip * wip * wip * wip * wip * fix: reusing pdo connection from pot * wip * wip * wip * wip * move files In future, all classes will be in src/ folder * Replace namespace name, for future * Remove duplicated exception * Fix towns from db * Fix spells page * Add default FAQ question + FAQ model * feat: reset colors in menus * Add confirm + save button at the top (menus) * Do not insert duplicated FAQ on install * Refactor install menus * Fix changelogs showing * Fix menu update, only with specified template name * Fix account create -> missing compat * Fix bans_per_page * banned_by is player_id. type = 2 is namelock in tfs 0.3 * Add getPlayerNameById, fix getPlayerNameByAccount * Change link name * Order by lastlogin * fix: query optimize * wip * wip * wip * wip * wip * wip * wip * Refactor notepad.php, class was useless * This is showing error, if the updated rows = 0 * Fix success & error class (bootstrap) * Uncomment require migrate.php * Some distro have owner_id * Update Player.php --------- Co-authored-by: slawkens <slawkens@gmail.com>
139 lines
3.0 KiB
PHP
139 lines
3.0 KiB
PHP
<?php
|
|
/**
|
|
* Bans
|
|
*
|
|
* @package MyAAC
|
|
* @author Gesior <jerzyskalski@wp.pl>
|
|
* @author Slawkens <slawkens@gmail.com>
|
|
* @copyright 2019 MyAAC
|
|
* @link https://my-aac.org
|
|
*/
|
|
defined('MYAAC') or die('Direct access not allowed!');
|
|
$title = 'Bans list';
|
|
|
|
$configBansPerPage = setting('core.bans_per_page');
|
|
$_page = $_GET['page'] ?? 1;
|
|
|
|
if(!is_numeric($_page) || $_page < 1 || $_page > PHP_INT_MAX) {
|
|
$_page = 1;
|
|
}
|
|
|
|
$offset = ($_page - 1) * $configBansPerPage;
|
|
|
|
/**
|
|
* @var OTS_DB_MySQL $db
|
|
*/
|
|
$configBans = [];
|
|
$configBans['hasType'] = false;
|
|
$configBans['hasReason'] = false;
|
|
|
|
$limit = 'LIMIT ' . ($configBansPerPage + 1) . (isset($offset) ? ' OFFSET ' . $offset : '');
|
|
if ($db->hasTable('account_bans')) {
|
|
$bansQuery = $db->query('SELECT * FROM `account_bans` ORDER BY `banned_at` DESC ' . $limit);
|
|
}
|
|
else if ($db->hasTable('bans') && $db->hasColumn('bans', 'active')
|
|
&& $db->hasColumn('bans', 'type') && $db->hasColumn('bans', 'reason')) {
|
|
$bansQuery = $db->query('SELECT * FROM `bans` WHERE `active` = 1 ORDER BY `added` DESC ' . $limit);
|
|
$configBans['hasType'] = true;
|
|
$configBans['hasReason'] = true;
|
|
}
|
|
else {
|
|
echo 'Bans list is not supported in your distribution.';
|
|
return;
|
|
}
|
|
|
|
if(!$bansQuery->rowCount())
|
|
{
|
|
echo 'There are no banishments yet.';
|
|
return;
|
|
}
|
|
|
|
$nextPage = false;
|
|
$i = 0;
|
|
$bans = $bansQuery->fetchAll(PDO::FETCH_ASSOC);
|
|
|
|
foreach ($bans as $id => &$ban)
|
|
{
|
|
if(++$i > $configBansPerPage)
|
|
{
|
|
unset($bans[$id]);
|
|
$nextPage = true;
|
|
break;
|
|
}
|
|
|
|
$ban['i'] = $i;
|
|
if ($db->hasColumn('bans', 'value')) {
|
|
$accountId = $ban['value'];
|
|
}
|
|
else {
|
|
// TFS 1.x
|
|
$accountId = $ban['account_id'];
|
|
}
|
|
|
|
$playerName = 'Unknown';
|
|
if ($configBans['hasType']) {
|
|
$ban['type'] = getBanType($ban['type']);
|
|
|
|
if ($ban['type'] == 2) { // namelock
|
|
$playerName = getPlayerNameById($accountId);
|
|
}
|
|
else {
|
|
$playerName = getPlayerNameByAccount($accountId);
|
|
}
|
|
}
|
|
else {
|
|
$playerName = getPlayerNameByAccount($accountId);
|
|
}
|
|
|
|
$ban['player'] = getPlayerLink($playerName);
|
|
|
|
$expiresColumn = 'expires_at';
|
|
if ($db->hasColumn('bans', 'expires')) {
|
|
$expiresColumn = 'expires';
|
|
}
|
|
|
|
if ((int)$ban[$expiresColumn] === -1) {
|
|
$ban['expires'] = 'Never';
|
|
}
|
|
else {
|
|
$ban['expires'] = date('H:i:s', $ban[$expiresColumn]) . '<br/>' . date('d.M.Y', $ban[$expiresColumn]);
|
|
}
|
|
|
|
if ($configBans['hasReason']) {
|
|
$ban['reason'] = getBanReason($ban['reason']);
|
|
}
|
|
else {
|
|
$ban['comment'] = $ban['reason'];
|
|
}
|
|
|
|
$addedBy = '';
|
|
if ($db->hasColumn('bans', 'admin_id')) {
|
|
if ((int)$ban['admin_id'] === 0) {
|
|
$addedBy = 'Autoban';
|
|
}
|
|
else {
|
|
$addedBy = getPlayerLink(getPlayerNameByAccount($ban['admin_id']));
|
|
}
|
|
}
|
|
else {
|
|
$addedBy = getPlayerLink(getPlayerNameById($ban['banned_by']));
|
|
}
|
|
|
|
if ($db->hasColumn('bans', 'added')) {
|
|
$addedTime = $ban['added'];
|
|
}
|
|
else {
|
|
$addedTime = $ban['banned_at'];
|
|
}
|
|
|
|
$ban['addedTime'] = date('H:i:s', $addedTime) . '<br/>' . date('d.M.Y', $addedTime);
|
|
$ban['addedBy'] = $addedBy;
|
|
}
|
|
|
|
$twig->display('bans.html.twig', [
|
|
'bans' => $bans,
|
|
'configBans' => $configBans,
|
|
'page' => $_page,
|
|
'nextPage' => $nextPage,
|
|
]);
|