2018-08-16 22:30:59 +00:00
|
|
|
<?php
|
2022-03-04 17:10:24 +00:00
|
|
|
|
2018-08-16 22:30:59 +00:00
|
|
|
/*
|
2022-03-04 17:10:24 +00:00
|
|
|
* Copyright (c) 2010-2022 Tim Düsterhus.
|
2018-08-16 22:30:59 +00:00
|
|
|
*
|
|
|
|
* Use of this software is governed by the Business Source License
|
|
|
|
* included in the LICENSE file.
|
|
|
|
*
|
2022-03-04 16:52:33 +00:00
|
|
|
* Change Date: 2026-03-04
|
2018-08-16 22:30:59 +00:00
|
|
|
*
|
|
|
|
* 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;
|
|
|
|
|
2022-03-04 17:10:24 +00:00
|
|
|
use chat\data\message\MessageAction;
|
|
|
|
use chat\data\user\UserAction as ChatUserAction;
|
|
|
|
use wcf\system\event\listener\IParameterizedEventListener;
|
|
|
|
use wcf\system\WCF;
|
2018-08-16 22:30:59 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Vaporizes unneeded data.
|
|
|
|
*/
|
2022-03-04 17:43:24 +00:00
|
|
|
final class HourlyCleanUpCronjobExecuteChatCleanUpListener implements IParameterizedEventListener
|
2022-03-04 17:10:24 +00:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @inheritDoc
|
|
|
|
*/
|
|
|
|
public function execute($eventObj, $className, $eventName, array &$parameters)
|
|
|
|
{
|
|
|
|
(new MessageAction([ ], 'prune'))->executeAction();
|
|
|
|
(new ChatUserAction([ ], 'clearDeadSessions'))->executeAction();
|
2018-08-16 22:30:59 +00:00
|
|
|
|
2022-03-04 17:10:24 +00:00
|
|
|
$sql = "UPDATE chat1_room_to_user
|
|
|
|
SET active = ?
|
|
|
|
WHERE (roomID, userID) NOT IN (
|
|
|
|
SELECT roomID, userID
|
|
|
|
FROM chat1_session
|
|
|
|
)
|
|
|
|
AND active = ?";
|
|
|
|
$statement = WCF::getDB()->prepare($sql);
|
|
|
|
$statement->execute([ 0, 1 ]);
|
|
|
|
if ($statement->getAffectedRows()) {
|
|
|
|
\wcf\functions\exception\logThrowable(new \Exception('Unreachable'));
|
|
|
|
}
|
|
|
|
}
|
2018-08-16 22:30:59 +00:00
|
|
|
}
|