1
0
mirror of https://github.com/wbbaddons/Tims-Chat.git synced 2025-01-22 02:00:40 +00:00
Tims-Chat/file/lib/acp/page/ChatSuspensionListPage.class.php

184 lines
6.3 KiB
PHP
Raw Normal View History

2013-06-04 22:54:11 +02:00
<?php
namespace chat\acp\page;
use \wcf\system\WCF;
/**
* Lists chat suspensions.
*
* @author Maximilian Mader
2014-02-27 23:05:09 +01:00
* @copyright 2010-2014 Tim Düsterhus
2013-06-04 22:54:11 +02:00
* @license Creative Commons Attribution-NonCommercial-ShareAlike <http://creativecommons.org/licenses/by-nc-sa/3.0/legalcode>
* @package be.bastelstu.chat
* @subpackage acp.page
*/
2013-06-06 16:46:27 +02:00
class ChatSuspensionListPage extends \wcf\page\SortablePage {
2013-06-04 22:54:11 +02:00
/**
* @see \wcf\page\AbstractPage::$activeMenuItem
*/
public $activeMenuItem = 'chat.acp.menu.link.suspension.list';
/**
* @see \wcf\page\AbstractPage::$neededPermissions
*/
2013-06-22 17:57:33 +02:00
public $neededPermissions = array('admin.chat.canManageSuspensions');
2013-06-04 22:54:11 +02:00
/**
2013-06-06 16:56:13 +02:00
* @see \wcf\page\SortablePage::$defaultSortField
*/
2013-06-06 16:46:27 +02:00
public $defaultSortField = 'expires';
2013-06-04 22:54:11 +02:00
/**
2013-06-06 16:56:13 +02:00
* @see \wcf\page\SortablePage::$validSortFields
*/
public $validSortFields = array('suspensionID', 'userID', 'username', 'roomID', 'type', 'expires', 'issuer', 'time', 'reason');
2013-06-04 22:54:11 +02:00
/**
2013-06-06 16:56:13 +02:00
* @see \wcf\page\MultipleLinkPage::$objectListClassName
*/
2013-06-04 22:54:11 +02:00
public $objectListClassName = 'chat\data\suspension\SuspensionList';
/**
2013-06-06 16:46:27 +02:00
* type filter
*
* @var integer
*/
2013-06-15 15:33:30 +02:00
public $filterSuspensionType = null;
2013-06-06 16:46:27 +02:00
/**
* user filter
*
* @var integer
*/
public $filterUserID = null;
2013-06-15 15:33:30 +02:00
/*
* username
*
* @var String
*/
public $filterUsername = null;
2013-06-12 22:49:25 +02:00
/**
* issuer filter
*
* @var integer
*/
public $filterIssuerUserID = null;
2013-06-15 15:33:30 +02:00
/*
* issuer username
*
* @var String
*/
public $filterIssuerUsername = null;
2013-06-06 16:46:27 +02:00
/**
* room filter
*
* @var integer
*/
public $filterRoomID = null;
2013-06-22 14:40:54 +02:00
/**
* display revoked suspensions
*
* @var integer
*/
public $displayRevoked = 0;
2013-06-06 16:46:27 +02:00
/**
* @see \wcf\page\IPage::readParameters()
*/
public function readParameters() {
parent::readParameters();
// get usernames
2013-06-15 15:33:30 +02:00
if (isset($_REQUEST['username']) && !empty($_REQUEST['username'])) $this->filterUsername = \wcf\util\StringUtil::trim($_REQUEST['username']);
if (isset($_REQUEST['issuerUsername']) && !empty($_REQUEST['issuerUsername'])) $this->filterIssuerUsername = \wcf\util\StringUtil::trim($_REQUEST['issuerUsername']);
// get user IDs by username
2013-06-15 15:33:30 +02:00
if ($this->filterUsername != null) $this->filterUserID = \wcf\data\user\UserProfile::getUserProfileByUsername($this->filterUsername)->userID;
if ($this->filterIssuerUsername != null) $this->filterIssuerUserID = \wcf\data\user\UserProfile::getUserProfileByUsername($this->filterIssuerUsername)->userID;
// get user IDs by request if no username was sent
if ($this->filterUserID === null && isset($_REQUEST['userID']) && !empty($_REQUEST['userID'])) $this->filterUserID = intval($_REQUEST['userID']);
2013-06-15 15:33:30 +02:00
if ($this->filterIssuerUserID === null && isset($_REQUEST['issuerUserID']) && !empty($_REQUEST['issuerUserID'])) $this->filterIssuerUserID = intval($_REQUEST['issuerUserID']);
// get usernames by ID if no usernames were sent
if ($this->filterUsername === null) $this->filterUsername = \wcf\data\user\UserProfile::getUserProfile($this->filterUserID);
if ($this->filterIssuerUsername === null) $this->filterIssuerUsername = \wcf\data\user\UserProfile::getUserProfile($this->filterIssuerUserID);
// get room IDs by request
if (isset($_REQUEST['roomID']) && $_REQUEST['roomID'] != -1) {
$this->filterRoomID = intval($_REQUEST['roomID']);
$room = \chat\data\room\RoomCache::getInstance()->getRoom($this->filterRoomID);
if (!$room) throw new \wcf\system\exception\IllegalLinkException();
if (!$room->permanent) throw new \wcf\system\exception\PermissionDeniedException();
}
2013-06-15 15:33:30 +02:00
if (isset($_REQUEST['suspensionType']) && !empty($_REQUEST['suspensionType'])) $this->filterSuspensionType = intval($_REQUEST['suspensionType']);
2013-06-22 14:40:54 +02:00
// display revoked
if (isset($_REQUEST['displayRevoked'])) $this->displayRevoked = intval($_REQUEST['displayRevoked']);
2013-06-15 15:33:30 +02:00
}
/**
* @see wcf\page\IPage::assignVariables()
*/
public function assignVariables() {
parent::assignVariables();
$rooms = \chat\data\room\RoomCache::getInstance()->getRooms();
foreach ($rooms as $id => $room) {
if (!$room->permanent) unset($rooms[$id]);
}
2013-06-15 15:33:30 +02:00
WCF::getTPL()->assign(array(
'availableRooms' => $rooms,
'roomID' => ($this->filterRoomID !== null) ? $this->filterRoomID : -1,
'username' => $this->filterUsername,
'issuerUsername' => $this->filterIssuerUsername,
'suspensionType' => $this->filterSuspensionType,
'userID' => $this->filterUserID,
2013-06-22 14:40:54 +02:00
'issuerUserID' => $this->filterIssuerUserID,
'displayRevoked' => $this->displayRevoked
2013-06-15 15:33:30 +02:00
));
2013-06-06 16:46:27 +02:00
}
/**
* @see \wcf\page\MultipleLinkPage::readObjects()
2013-06-04 22:54:11 +02:00
*/
protected function initObjectList() {
parent::initObjectList();
$this->objectList->sqlSelects .= "user_table_muted.username, user_table_issuer.username AS issuerUsername, user_table_revoker.username AS revokerUsername, room_table.title AS roomTitle";
2013-06-06 16:46:27 +02:00
$this->objectList->sqlJoins .= "
LEFT JOIN wcf".WCF_N."_user user_table_muted
ON suspension.userID = user_table_muted.userID
LEFT JOIN wcf".WCF_N."_user user_table_issuer
ON suspension.issuer = user_table_issuer.userID
LEFT JOIN wcf".WCF_N."_user user_table_revoker
ON suspension.revoker = user_table_revoker.userID";
2013-06-06 16:46:27 +02:00
$conditionJoins = " LEFT JOIN chat".WCF_N."_room room_table
ON suspension.roomID = room_table.roomID";
$this->objectList->sqlConditionJoins .= $conditionJoins;
$this->objectList->sqlJoins .= $conditionJoins;
2013-06-22 14:40:54 +02:00
if (!$this->displayRevoked) {
$this->objectList->getConditionBuilder()->add('expires > ?', array(TIME_NOW));
2013-06-22 14:40:54 +02:00
}
2013-06-06 21:51:25 +03:00
$this->objectList->getConditionBuilder()->add('(room_table.permanent = ? OR suspension.roomID IS NULL)', array(1));
2013-06-15 15:33:30 +02:00
if ($this->filterSuspensionType !== null) $this->objectList->getConditionBuilder()->add('suspension.type = ?', array($this->filterSuspensionType));
2013-06-06 16:46:27 +02:00
if ($this->filterUserID !== null) $this->objectList->getConditionBuilder()->add('suspension.userID = ?', array($this->filterUserID));
2013-06-12 22:49:25 +02:00
if ($this->filterIssuerUserID !== null) $this->objectList->getConditionBuilder()->add('suspension.issuer = ?', array($this->filterIssuerUserID));
2013-06-06 16:46:27 +02:00
if ($this->filterRoomID !== null) {
if ($this->filterRoomID === 0) {
$this->objectList->getConditionBuilder()->add('suspension.roomID IS NULL', array());
}
else {
$this->objectList->getConditionBuilder()->add('suspension.roomID = ?', array($this->filterRoomID));
}
}
2013-06-04 22:54:11 +02:00
}
}