1
0
mirror of https://github.com/wbbaddons/Tims-Chat.git synced 2024-12-25 22:10:08 +00:00
Tims-Chat/file/lib/data/chat/room/ChatRoomEditor.class.php

97 lines
2.5 KiB
PHP
Raw Normal View History

2011-11-27 19:20:13 +00:00
<?php
namespace wcf\data\chat\room;
2012-02-04 20:57:39 +00:00
use \wcf\system\WCF;
2011-11-27 19:20:13 +00:00
/**
* Provides functions to edit chat rooms.
*
* @author Tim Düsterhus
2012-01-28 16:50:33 +00:00
* @copyright 2010-2012 Tim Düsterhus
2011-11-27 19:20:13 +00:00
* @license Creative Commons Attribution-NonCommercial-ShareAlike <http://creativecommons.org/licenses/by-nc-sa/3.0/legalcode>
* @package be.bastelstu.wcf.chat
2011-11-27 19:20:13 +00:00
* @subpackage data.chat.room
*/
class ChatRoomEditor extends \wcf\data\DatabaseObjectEditor implements \wcf\data\IEditableCachedObject {
2011-11-27 19:20:13 +00:00
/**
* @see \wcf\data\DatabaseObjectDecorator::$baseClass
2011-11-27 19:20:13 +00:00
*/
protected static $baseClass = '\wcf\data\chat\room\ChatRoom';
2012-02-04 20:57:39 +00:00
/**
* @see \wcf\data\DatabaseObjectEditor::deleteAll()
2012-02-04 20:57:39 +00:00
*/
public static function deleteAll(array $objectIDs = array()) {
$packageID = \wcf\util\ChatUtil::getPackageID();
2012-02-04 20:57:39 +00:00
WCF::getDB()->beginTransaction();
foreach ($objectIDs as $objectID) {
2012-02-05 17:29:16 +00:00
\wcf\system\language\I18nHandler::getInstance()->remove('wcf.chat.room.title'.$objectID, $packageID);
\wcf\system\language\I18nHandler::getInstance()->remove('wcf.chat.room.topic'.$objectID, $packageID);
2012-02-04 20:57:39 +00:00
}
$sql = "SELECT
position
FROM
wcf".WCF_N."_chat_room
WHERE
roomID = ?
FOR UPDATE";
$select = WCF::getDB()->prepareStatement($sql);
$sql = "UPDATE
wcf".WCF_N."_chat_room
SET
position = position - 1
WHERE
position > ?";
$update = WCF::getDB()->prepareStatement($sql);
foreach ($objectIDs as $objectID) {
$select->execute(array($objectID));
$update->execute(array($select->fetchColumn()));
}
// The transaction is being committed in parent::deleteAll()
// The beginTransaction() call in there is simply ignored.
return parent::deleteAll($objectIDs);
2012-02-04 20:57:39 +00:00
}
/**
* Deletes temporary rooms that are unused.
*
* @return integer Number of deleted rooms
*/
public static function prune() {
$sql = "SELECT
2012-04-15 16:00:59 +00:00
".static::getDatabaseTableIndexName()."
FROM
2012-04-15 16:00:59 +00:00
".static::getDatabaseTableName()."
WHERE
2012-04-15 16:00:59 +00:00
permanent = ?
AND roomID NOT IN (
SELECT
fieldValue AS roomID
FROM
wcf".WCF_N."_user_storage
WHERE
packageID = ?
2012-04-15 16:00:59 +00:00
AND field = ?
AND fieldValue IS NOT NULL
)";
$stmt = \wcf\system\WCF::getDB()->prepareStatement($sql);
$stmt->execute(array(0, \wcf\util\ChatUtil::getPackageID(), 'roomID'));
$objectIDs = array();
while ($objectIDs[] = $stmt->fetchColumn());
return self::deleteAll($objectIDs);
}
/**
* Clears the room cache.
*/
public static function resetCache() {
\wcf\system\cache\CacheHandler::getInstance()->clear(WCF_DIR.'cache', 'cache.chatrooms.php');
}
2011-11-27 19:20:13 +00:00
}