mirror of
https://github.com/wbbaddons/Tims-Chat.git
synced 2024-12-23 21:50:09 +00:00
53 lines
1.4 KiB
PHP
53 lines
1.4 KiB
PHP
|
<?php
|
||
|
namespace wcf\data\chat\suspension;
|
||
|
use \wcf\system\WCF;
|
||
|
|
||
|
/**
|
||
|
* Represents a chat suspension.
|
||
|
*
|
||
|
* @author Tim Düsterhus
|
||
|
* @copyright 2010-2012 Tim Düsterhus
|
||
|
* @license Creative Commons Attribution-NonCommercial-ShareAlike <http://creativecommons.org/licenses/by-nc-sa/3.0/legalcode>
|
||
|
* @package be.bastelstu.wcf.chat
|
||
|
* @subpackage data.chat.suspension
|
||
|
*/
|
||
|
class ChatSuspension extends \wcf\data\DatabaseObject {
|
||
|
/**
|
||
|
* @see \wcf\data\DatabaseObject::$databaseTableName
|
||
|
*/
|
||
|
protected static $databaseTableName = 'chat_suspension';
|
||
|
|
||
|
/**
|
||
|
* @see \wcf\data\DatabaseObject::$databaseTableIndexName
|
||
|
*/
|
||
|
protected static $databaseTableIndexName = 'suspensionID';
|
||
|
|
||
|
const TYPE_MUTE = 1;
|
||
|
const TYPE_BAN = 2;
|
||
|
|
||
|
public static function getSuspensionsForUser(\wcf\data\user\User $user = null) {
|
||
|
if ($user === null) $user = WCF::getUser();
|
||
|
$suspensions = \wcf\util\ChatUtil::readUserData('suspensions', $user);
|
||
|
if ($suspensions === null) {
|
||
|
$sql = "SELECT
|
||
|
*
|
||
|
FROM
|
||
|
wcf".WCF_N."_chat_suspension
|
||
|
WHERE
|
||
|
userID = ?
|
||
|
AND time > ?";
|
||
|
$stmt = WCF::getDB()->prepareStatement($sql);
|
||
|
$stmt->execute(array($user->userID, TIME_NOW));
|
||
|
|
||
|
$suspensions = array();
|
||
|
while ($row = $stmt->fetchArray()) {
|
||
|
$suspensions[$row['roomID']][$row['type']] = $row;
|
||
|
}
|
||
|
|
||
|
\wcf\util\ChatUtil::writeUserData(array('suspensions' => $suspensions), $user);
|
||
|
}
|
||
|
|
||
|
return $suspensions;
|
||
|
}
|
||
|
}
|