2011-12-13 22:35:11 +01:00
|
|
|
<?php
|
2013-01-19 20:36:40 +01:00
|
|
|
namespace chat\data\message;
|
2011-12-13 22:35:11 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Executes message related actions.
|
|
|
|
*
|
|
|
|
* @author Tim Düsterhus
|
2013-01-19 20:36:40 +01:00
|
|
|
* @copyright 2010-2013 Tim Düsterhus
|
2011-12-13 22:35:11 +01:00
|
|
|
* @license Creative Commons Attribution-NonCommercial-ShareAlike <http://creativecommons.org/licenses/by-nc-sa/3.0/legalcode>
|
2013-01-19 20:36:40 +01:00
|
|
|
* @package be.bastelstu.chat
|
|
|
|
* @subpackage chat.message
|
2011-12-13 22:35:11 +01:00
|
|
|
*/
|
2013-01-19 20:36:40 +01:00
|
|
|
class MessageAction extends \wcf\data\AbstractDatabaseObjectAction {
|
2011-12-13 22:35:11 +01:00
|
|
|
/**
|
2012-02-26 17:55:44 +01:00
|
|
|
* @see \wcf\data\AbstractDatabaseObjectAction::$className
|
2011-12-13 22:35:11 +01:00
|
|
|
*/
|
2013-01-19 20:36:40 +01:00
|
|
|
protected $className = '\chat\data\message\MessageEditor';
|
2012-05-19 20:33:25 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes old messages.
|
|
|
|
*
|
|
|
|
* @return integer Number of deleted messages.
|
|
|
|
*/
|
|
|
|
public function prune() {
|
|
|
|
$sql = "SELECT
|
|
|
|
".call_user_func(array($this->className, 'getDatabaseTableIndexName'))."
|
|
|
|
FROM
|
|
|
|
".call_user_func(array($this->className, 'getDatabaseTableName'))."
|
|
|
|
WHERE
|
|
|
|
time < ?";
|
|
|
|
$stmt = \wcf\system\WCF::getDB()->prepareStatement($sql);
|
|
|
|
$stmt->execute(array(TIME_NOW - CHAT_LOG_ARCHIVETIME));
|
|
|
|
$objectIDs = array();
|
|
|
|
while ($objectIDs[] = $stmt->fetchColumn());
|
|
|
|
|
|
|
|
return call_user_func(array($this->className, 'deleteAll'), $objectIDs);
|
|
|
|
}
|
2011-12-13 22:35:11 +01:00
|
|
|
}
|