41 lines
1.3 KiB
PHP
41 lines
1.3 KiB
PHP
|
<?php
|
||
|
/*
|
||
|
* Copyright (c) 2010-2018 Tim Düsterhus.
|
||
|
*
|
||
|
* Use of this software is governed by the Business Source License
|
||
|
* included in the LICENSE file.
|
||
|
*
|
||
|
* Change Date: 2022-08-16
|
||
|
*
|
||
|
* On the date above, in accordance with the Business Source
|
||
|
* License, use of this software will be governed by version 2
|
||
|
* or later of the General Public License.
|
||
|
*/
|
||
|
|
||
|
namespace chat\system\event\listener;
|
||
|
|
||
|
use \wcf\system\WCF;
|
||
|
|
||
|
/**
|
||
|
* Vaporizes unneeded data.
|
||
|
*/
|
||
|
class HourlyCleanUpCronjobExecuteChatCleanUpListener implements \wcf\system\event\listener\IParameterizedEventListener {
|
||
|
/**
|
||
|
* @see \wcf\system\event\listener\IParameterizedEventListener::execute()
|
||
|
*/
|
||
|
public function execute($eventObj, $className, $eventName, array &$parameters) {
|
||
|
(new \chat\data\message\MessageAction([ ], 'prune'))->executeAction();
|
||
|
(new \chat\data\user\UserAction([], 'clearDeadSessions'))->executeAction();
|
||
|
|
||
|
$sql = "UPDATE chat".WCF_N."_room_to_user
|
||
|
SET active = ?
|
||
|
WHERE (roomID, userID) NOT IN (SELECT roomID, userID FROM chat".WCF_N."_session)
|
||
|
AND active = ?";
|
||
|
$statement = WCF::getDB()->prepareStatement($sql);
|
||
|
$statement->execute([ 0, 1 ]);
|
||
|
if ($statement->getAffectedRows()) {
|
||
|
\wcf\functions\exception\logThrowable(new \Exception('Unreachable'));
|
||
|
}
|
||
|
}
|
||
|
}
|