1
0
mirror of https://github.com/wbbaddons/Tims-Chat.git synced 2025-01-09 00:20:08 +00:00

Merge branch 'master' of github.com:wbbaddons/Tims-Chat

This commit is contained in:
Tim Düsterhus 2013-01-09 17:42:14 +01:00
commit 9a5f3043ba
6 changed files with 15 additions and 29 deletions

View File

@ -63,7 +63,7 @@ public function save() {
$this->title = 'wcf.chat.room.title'.$this->roomObj->roomID; $this->title = 'wcf.chat.room.title'.$this->roomObj->roomID;
if (I18nHandler::getInstance()->isPlainValue('title')) { if (I18nHandler::getInstance()->isPlainValue('title')) {
I18nHandler::getInstance()->remove($this->title, \wcf\util\ChatUtil::getPackageID()); I18nHandler::getInstance()->remove($this->title);
$this->title = I18nHandler::getInstance()->getValue('title'); $this->title = I18nHandler::getInstance()->getValue('title');
} }
else { else {
@ -72,7 +72,7 @@ public function save() {
$this->topic = 'wcf.chat.room.topic'.$this->roomObj->roomID; $this->topic = 'wcf.chat.room.topic'.$this->roomObj->roomID;
if (I18nHandler::getInstance()->isPlainValue('topic')) { if (I18nHandler::getInstance()->isPlainValue('topic')) {
I18nHandler::getInstance()->remove($this->topic, \wcf\util\ChatUtil::getPackageID()); I18nHandler::getInstance()->remove($this->topic);
$this->topic = I18nHandler::getInstance()->getValue('topic'); $this->topic = I18nHandler::getInstance()->getValue('topic');
} }
else { else {

View File

@ -110,10 +110,9 @@ public function countUsers() {
wcf".WCF_N."_user_storage wcf".WCF_N."_user_storage
WHERE WHERE
field = ? field = ?
AND packageID = ?
AND fieldValue = ?"; AND fieldValue = ?";
$stmt = WCF::getDB()->prepareStatement($sql); $stmt = WCF::getDB()->prepareStatement($sql);
$stmt->execute(array('roomID', \wcf\util\ChatUtil::getPackageID(), $this->roomID)); $stmt->execute(array('roomID', $this->roomID));
return $stmt->fetchColumn(); return $stmt->fetchColumn();
} }
@ -158,18 +157,15 @@ public function getTitle() {
* @return array<\wcf\data\user\User> * @return array<\wcf\data\user\User>
*/ */
public function getUsers() { public function getUsers() {
$packageID = \wcf\util\ChatUtil::getPackageID();
$sql = "SELECT $sql = "SELECT
userID userID
FROM FROM
wcf".WCF_N."_user_storage wcf".WCF_N."_user_storage
WHERE WHERE
field = ? field = ?
AND packageID = ?
AND fieldValue = ?"; AND fieldValue = ?";
$stmt = WCF::getDB()->prepareStatement($sql); $stmt = WCF::getDB()->prepareStatement($sql);
$stmt->execute(array('roomID', $packageID, $this->roomID)); $stmt->execute(array('roomID', $this->roomID));
$userIDs = array(); $userIDs = array();
while ($userIDs[] = $stmt->fetchColumn()); while ($userIDs[] = $stmt->fetchColumn());
@ -185,14 +181,13 @@ public function getUsers() {
ON ( ON (
u.userID = st.userID u.userID = st.userID
AND st.field = ? AND st.field = ?
AND st.packageID = ?
) )
WHERE WHERE
u.userID IN (".rtrim(str_repeat('?,', count($userIDs)), ',').") u.userID IN (".rtrim(str_repeat('?,', count($userIDs)), ',').")
ORDER BY ORDER BY
u.username ASC"; u.username ASC";
$stmt = WCF::getDB()->prepareStatement($sql); $stmt = WCF::getDB()->prepareStatement($sql);
array_unshift($userIDs, 'away', $packageID); array_unshift($userIDs, 'away');
$stmt->execute($userIDs); $stmt->execute($userIDs);
return $stmt->fetchObjects('\wcf\data\user\User'); return $stmt->fetchObjects('\wcf\data\user\User');

View File

@ -65,12 +65,11 @@ public function prune() {
FROM FROM
wcf".WCF_N."_user_storage wcf".WCF_N."_user_storage
WHERE WHERE
packageID = ?
AND field = ? AND field = ?
AND fieldValue IS NOT NULL AND fieldValue IS NOT NULL
)"; )";
$stmt = \wcf\system\WCF::getDB()->prepareStatement($sql); $stmt = \wcf\system\WCF::getDB()->prepareStatement($sql);
$stmt->execute(array(0, \wcf\util\ChatUtil::getPackageID(), 'roomID')); $stmt->execute(array(0, 'roomID'));
$objectIDs = array(); $objectIDs = array();
while ($objectIDs[] = $stmt->fetchColumn()); while ($objectIDs[] = $stmt->fetchColumn());

View File

@ -22,12 +22,10 @@ class ChatRoomEditor extends \wcf\data\DatabaseObjectEditor implements \wcf\data
* @see \wcf\data\DatabaseObjectEditor::deleteAll() * @see \wcf\data\DatabaseObjectEditor::deleteAll()
*/ */
public static function deleteAll(array $objectIDs = array()) { public static function deleteAll(array $objectIDs = array()) {
$packageID = \wcf\util\ChatUtil::getPackageID();
WCF::getDB()->beginTransaction(); WCF::getDB()->beginTransaction();
foreach ($objectIDs as $objectID) { foreach ($objectIDs as $objectID) {
\wcf\system\language\I18nHandler::getInstance()->remove('wcf.chat.room.title'.$objectID, $packageID); \wcf\system\language\I18nHandler::getInstance()->remove('wcf.chat.room.title'.$objectID);
\wcf\system\language\I18nHandler::getInstance()->remove('wcf.chat.room.topic'.$objectID, $packageID); \wcf\system\language\I18nHandler::getInstance()->remove('wcf.chat.room.topic'.$objectID);
} }
$sql = "SELECT $sql = "SELECT

View File

@ -21,9 +21,8 @@ class ChatSuspensionEditor extends \wcf\data\DatabaseObjectEditor implements \wc
* Clears the suspension cache. * Clears the suspension cache.
*/ */
public static function resetCache() { public static function resetCache() {
$packageID = \wcf\util\ChatUtil::getPackageID();
$ush = \wcf\system\user\storage\UserStorageHandler::getInstance(); $ush = \wcf\system\user\storage\UserStorageHandler::getInstance();
$ush->resetAll('suspensions', $packageID); $ush->resetAll('suspensions');
} }
} }

View File

@ -50,7 +50,6 @@ final class ChatUtil {
* @return array * @return array
*/ */
public static function getDiedUsers() { public static function getDiedUsers() {
$packageID = self::getPackageID();
if (self::nodePushRunning()) { if (self::nodePushRunning()) {
$time = TIME_NOW - 120; $time = TIME_NOW - 120;
} }
@ -66,17 +65,15 @@ public static function getDiedUsers() {
wcf".WCF_N."_user_storage a wcf".WCF_N."_user_storage a
ON a.userID = r.userID ON a.userID = r.userID
AND a.field = ? AND a.field = ?
AND a.packageID = ?
WHERE WHERE
r.field = ? r.field = ?
AND r.packageID = ?
AND r.fieldValue IS NOT NULL AND r.fieldValue IS NOT NULL
AND ( AND (
a.fieldValue < ? a.fieldValue < ?
OR a.fieldValue IS NULL OR a.fieldValue IS NULL
)"; )";
$stmt = WCF::getDB()->prepareStatement($sql); $stmt = WCF::getDB()->prepareStatement($sql);
$stmt->execute(array('lastActivity', $packageID, 'roomID', $packageID, $time - 30)); $stmt->execute(array('lastActivity', 'roomID', $time - 30));
$users = array(); $users = array();
while ($users[] = $stmt->fetchArray()); while ($users[] = $stmt->fetchArray());
@ -152,11 +149,10 @@ public static function nodePushRunning() {
public static function readUserData($field, \wcf\data\user\User $user = null) { public static function readUserData($field, \wcf\data\user\User $user = null) {
if ($user === null) $user = WCF::getUser(); if ($user === null) $user = WCF::getUser();
$ush = UserStorageHandler::getInstance(); $ush = UserStorageHandler::getInstance();
$packageID = self::getPackageID();
// load storage // load storage
$ush->loadStorage(array($user->userID), $packageID); $ush->loadStorage(array($user->userID));
$data = $ush->getStorage(array($user->userID), $field, $packageID); $data = $ush->getStorage(array($user->userID), $field);
if ($data[$user->userID] === null) { if ($data[$user->userID] === null) {
switch ($field) { switch ($field) {
@ -254,10 +250,9 @@ public static function timeModifier($time) {
public static function writeUserData(array $data, \wcf\data\user\User $user = null) { public static function writeUserData(array $data, \wcf\data\user\User $user = null) {
if ($user === null) $user = WCF::getUser(); if ($user === null) $user = WCF::getUser();
$ush = UserStorageHandler::getInstance(); $ush = UserStorageHandler::getInstance();
$packageID = self::getPackageID();
foreach ($data as $key => $value) { foreach ($data as $key => $value) {
$ush->update($user->userID, $key, (isset(static::$serialize[$key])) ? serialize($value) : $value, $packageID); $ush->update($user->userID, $key, (isset(static::$serialize[$key])) ? serialize($value) : $value);
} }
} }