Your IP : 172.70.178.32


Current Path : /var/www/element/data/www/revenuestory.ru/bitrix/modules/rest/lib/event/
Upload File :
Current File : /var/www/element/data/www/revenuestory.ru/bitrix/modules/rest/lib/event/callback.php

<?php
namespace Bitrix\Rest\Event;

use Bitrix\Rest\AppTable;
use Bitrix\Rest\EventTable;
use Bitrix\Rest\Tools\Diagnostics\LoggerManager;

/**
 * Class Callback
 *
 * Callback for Bitrix events transferred to REST events
 *
 * @package Bitrix\Rest
 **/
class Callback
{
	/**
	 * Handler for all PHP events transferred to REST.
	 *
	 * @param string $name Event name.
	 * @param array $arguments Event arguments.
	 *
	 * @throws \Bitrix\Main\ArgumentException
	 * @throws \Bitrix\Main\SystemException
	 */
	public static function __callStatic($name, $arguments)
	{
		$logger = LoggerManager::getInstance()->getLogger();
		$event = Sender::parseEventName($name);
		if ($logger)
		{
			$logger->debug(
				"\n{delimiter}\n"
				. "{date} - {host}\n{delimiter}\n"
				. "Event {eventName} starts. \n{delimiter}\n"
				. "{arguments}",
				[
					'eventName' => $event['EVENT'],
					'arguments' => $arguments,
				]
			);
		}

		$provider = new \CRestProvider();
		$description = $provider->getDescription();

		foreach($description as $scope => $scopeMethods)
		{
			if(
				array_key_exists(\CRestUtil::EVENTS, $scopeMethods)
				&& is_array($scopeMethods[\CRestUtil::EVENTS])
			)
			{
				foreach($scopeMethods[\CRestUtil::EVENTS] as $key => $restEvent)
				{
					if($restEvent[0] == $event['MODULE_ID'] && toUpper($restEvent[1]) == $event['EVENT'])
					{
						$event['EVENT_REST'] = array(
							'EVENT' => $key,
							'HANDLER' => $restEvent[2],
							'ADDITIONAL' => array(),
						);

						if(isset($restEvent[3]) && is_array($restEvent[3]))
						{
							$event['EVENT_REST']['ADDITIONAL'] = $restEvent[3];
						}

						break;
					}
				}
			}

			if(array_key_exists('EVENT_REST', $event))
			{
				break;
			}
		}

		$handlerFound = false;
		$appHoldExceptId = 0;
		if (!empty($arguments[1]['REST_EVENT_HOLD_EXCEPT_APP']))
		{
			$app = AppTable::getByClientId($arguments[1]['REST_EVENT_HOLD_EXCEPT_APP']);
			if ($app['ID'] > 0)
			{
				$appHoldExceptId = $app['ID'];
			}
		}

		if(array_key_exists('EVENT_REST', $event))
		{
			$filter = [
				'=EVENT_NAME' => mb_strtoupper($event['EVENT_REST']['EVENT']),
			];
			if ($appHoldExceptId > 0)
			{
				$filter['=APP_ID'] = $appHoldExceptId;
			}

			$dbRes = EventTable::getList(
				[
					'filter' => $filter,
					'select' => [
						'*',
						'APP_CODE' => 'REST_APP.CLIENT_ID',
						'APP_ACTIVE' => 'REST_APP.ACTIVE',
						'APP_INSTALLED' => 'REST_APP.INSTALLED',
					],
				]
			);

			$dataProcessed = !is_array($event['EVENT_REST']['HANDLER']) || !is_callable($event['EVENT_REST']['HANDLER']);
			$call = array();
			while ($handler = $dbRes->fetch())
			{
				if (!empty($handler['APP_CODE']))
				{
					if (
						$handler['APP_ACTIVE'] !== AppTable::ACTIVE
						|| $handler['APP_INSTALLED'] !== AppTable::INSTALLED
					)
					{
						if ($logger)
						{
							$logger->error(
								"\n{delimiter}\n"
								. "{date} - {host}\n{delimiter}\n"
								. "Event {eventName} skipped because inactive app: \n"
								. "{handler}",
								[
									'eventName' => $event['EVENT'],
									'handler' => $handler,
								]
							);
						}

						continue;
					}

					$appStatus = AppTable::getAppStatusInfo($handler['APP_CODE'], '');
					if ($appStatus['PAYMENT_EXPIRED'] === 'Y')
					{
						if ($logger)
						{
							$logger->error(
								"\n{delimiter}\n"
								. "{date} - {host}\n{delimiter}\n"
								. "Event {eventName} skipped because PAYMENT_EXPIRED: \n"
								. "{appStatus}",
								[
									'eventName' => $event['EVENT'],
									'appStatus' => $appStatus,
								]
							);
						}

						continue;
					}
				}

				$handlerArguments = $arguments;
				$handlerFound = true;

				if(!$dataProcessed)
				{
					try
					{
						$handlerArguments = call_user_func_array($event['EVENT_REST']['HANDLER'], array($handlerArguments, $handler));
						$call[] = array($handler, $handlerArguments, $event['EVENT_REST']['ADDITIONAL']);
					}
					catch(\Exception $e)
					{
						if ($logger)
						{
							$logger->error(
								"\n{delimiter}\n"
								. "{date} - {host}\n{delimiter}\n"
								. "Event {eventName} exception: \n"
								. "{errorCode}: {errorMessage}",
								[
									'eventName' => $event['EVENT'],
									'errorCode' => $e->getCode(),
									'errorMessage' => $e->getMessage(),
								]
							);
						}
					}
				}
				else
				{
					$call[] = array($handler, $handlerArguments, $event['EVENT_REST']['ADDITIONAL']);
				}
			}

			if(count($call) > 0)
			{
				Sender::call($call);
			}
		}

		if(!$handlerFound)
		{
			Sender::unbind($event['MODULE_ID'], $event['EVENT']);
		}
	}
}