Your IP : 216.73.216.86


Current Path : /var/www/homesaver/www/bitrix/modules/rest/lib/Tools/Diagnostics/
Upload File :
Current File : /var/www/homesaver/www/bitrix/modules/rest/lib/Tools/Diagnostics/RestServerProcessLogger.php

<?php

namespace Bitrix\Rest\Tools\Diagnostics;

use Bitrix\Main;
use Bitrix\Rest\LogTable;
use Exception;

final class RestServerProcessLogger
{
	private ?int $requestLogId;

	public function __construct(private readonly \CRestServer $restServer)
	{
	}

	public function logRequest(): void
	{
		if (!is_null($this->restServer))
		{
			$request = Main\Context::getCurrent()?->getRequest();
			$logger = LoggerManager::getInstance()->getLogger();
			$logger?->info('Start', [
				'CLIENT_ID' => $this->restServer->getClientId(),
				'PASSWORD_ID' => $this->restServer->getPasswordId(),
				'SCOPE' => $this->restServer->getScope(),
				'METHOD' => $this->restServer->getMethod(),
				'REQUEST_METHOD' => $request->getRequestMethod(),
				'REQUEST_URI' => $request->getRequestUri(),
				'REQUEST_AUTH' => $this->restServer->getAuth(),
				'REQUEST_DATA' => $this->restServer->getQuery(),
			]);
			$this->requestLogId = $logger instanceof DataBaseLogger ? $logger->getLogId() : null;
		}
	}

	/**
	 * @throws Exception
	 */
	public function logResponse(mixed $responseData): bool
	{
		if (is_null($this->requestLogId))
		{
			return false;
		}

		LogTable::filterResponseData($responseData);
		$this->restServer->sendHeaders();
		$fields = [
			'RESPONSE_STATUS' => \CHTTP::GetLastStatus(),
			'RESPONSE_DATA' => $responseData,
			'MESSAGE' => 'Successful response',
		];

		return LogTable::update($this->requestLogId, $fields)->isSuccess();
	}
}