2011-11-27 12:21:58 +01:00
|
|
|
<?php
|
|
|
|
namespace wcf\data\chat\message;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Provides functions to edit chat messages.
|
|
|
|
*
|
|
|
|
* @author Tim Düsterhus
|
2012-01-28 17:50:33 +01:00
|
|
|
* @copyright 2010-2012 Tim Düsterhus
|
2011-11-27 12:21:58 +01:00
|
|
|
* @license Creative Commons Attribution-NonCommercial-ShareAlike <http://creativecommons.org/licenses/by-nc-sa/3.0/legalcode>
|
2012-03-12 17:18:15 +01:00
|
|
|
* @package be.bastelstu.wcf.chat
|
2011-11-27 12:21:58 +01:00
|
|
|
* @subpackage data.chat.message
|
|
|
|
*/
|
|
|
|
class ChatMessageEditor extends \wcf\data\DatabaseObjectEditor {
|
|
|
|
/**
|
2012-02-26 17:55:44 +01:00
|
|
|
* @see \wcf\data\DatabaseObjectDecorator::$baseClass
|
2011-11-27 12:21:58 +01:00
|
|
|
*/
|
|
|
|
protected static $baseClass = '\wcf\data\chat\message\ChatMessage';
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes old messages.
|
|
|
|
*
|
|
|
|
* @param integer $lifetime Delete messages older that this time.
|
|
|
|
* @return integer Number of deleted messages.
|
|
|
|
*/
|
2012-04-15 17:32:25 +02:00
|
|
|
public static function prune($lifetime = CHAT_LOG_ARCHIVETIME) {
|
2012-03-08 22:07:46 +01:00
|
|
|
$baseClass = self::$baseClass;
|
2011-12-10 17:20:57 +01:00
|
|
|
$sql = "SELECT
|
2012-03-08 22:07:46 +01:00
|
|
|
".$baseClass::getDatabaseTableIndexName()."
|
2011-11-27 12:21:58 +01:00
|
|
|
FROM
|
2012-03-08 22:07:46 +01:00
|
|
|
".$baseClass::getDatabaseTableName()."
|
2011-11-27 12:21:58 +01:00
|
|
|
WHERE
|
2012-03-08 22:07:46 +01:00
|
|
|
time < ?";
|
|
|
|
$stmt = \wcf\system\WCF::getDB()->prepareStatement($sql);
|
|
|
|
$stmt->execute(array(TIME_NOW - $lifetime));
|
2011-11-27 12:21:58 +01:00
|
|
|
$objectIDs = array();
|
2012-03-08 22:07:46 +01:00
|
|
|
while ($objectIDs[] = $stmt->fetchColumn());
|
|
|
|
|
|
|
|
return self::deleteAll($objectIDs);
|
2011-11-27 12:21:58 +01:00
|
|
|
}
|
|
|
|
}
|