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/components/bitrix/rest.authorize/

Upload File :
current_dir [ Writeable] document_root [ Writeable]

 

Command :


[ Back ]     

Current File : /home/bitrix/ext_www/rospirotorg.ru/bitrix/components/bitrix/rest.authorize/component.php
<?php
if(!defined("B_PROLOG_INCLUDED") || B_PROLOG_INCLUDED !== true)
{
	die();
}

/**
 * Bitrix vars
 *
 * @var array $arParams
 * @var array $arResult
 * @var CBitrixComponent $this
 * @global CMain $APPLICATION
 * @global CUser $USER
 */

use Bitrix\Main\Loader;

if(!Loader::includeModule('rest'))
{
	return;
}

if (isset($_GET['oauth_proxy_params']) && Loader::includeModule('socialservices'))
{
	CSocServUtil::checkOAuthProxyParams();
}

$request = \Bitrix\Main\Context::getCurrent()->getRequest();

$clientId = $request['client_id'] ?? $_GET['client_id'];
if(!$clientId)
{
	ShowError(\Bitrix\Main\Localization\Loc::getMessage('REST_APP_NOT_FOUND'));
	return;
}

if($USER->IsAuthorized())
{
	if (isset($request['state']) || isset($_GET['state']))
	{
		$state = $request['state'] ?? $_GET['state'];
	}
	else
	{
		$state = '';
	}

	$authResult = \Bitrix\Rest\Application::getAuthProvider()->authorizeClient($clientId, $USER->GetID(), $state);

	if($authResult['error'])
	{
		ShowError($authResult['error'].': '.$authResult['error_description']);
	}
	elseif($authResult['redirect_uri'])
	{
		$redirectUri = $authResult['redirect_uri'];

		unset($authResult['redirect_uri']);

		$fragment = '';
		if(array_key_exists('fragment', $authResult))
		{
			$fragment = $authResult['fragment'];
			unset($authResult['fragment']);
		}

		$authResult['server_domain'] = $authResult['domain'];
		$authResult['domain'] = $request->getHttpHost();

		$redirectUri .= (mb_strpos($redirectUri, '?') !== false) ? '&' : '?';
		$redirectUri .= http_build_query($authResult);

		if($fragment <> '')
		{
			$redirectUri .= '#'.$fragment;
		}

		LocalRedirect($redirectUri, true);
	}
	else
	{
		$arResult['OAUTH_PARAMS'] = $authResult;
		$this->includeComponentTemplate();
	}
}
else
{
	if(isset($clientId))
	{
		$appInfo = \Bitrix\Rest\AppTable::getByClientId($clientId);
		if($appInfo && $appInfo['ACTIVE'] === \Bitrix\Rest\AppTable::ACTIVE)
		{
			$APPLICATION->AuthForm(\Bitrix\Main\Localization\Loc::getMessage('REST_NEED_AUTHORIZE_A', array(
				'#APP_ID#' => $appInfo['CODE']
			)));
			return;
		}
	}

	ShowError(\Bitrix\Main\Localization\Loc::getMessage('REST_APP_NOT_FOUND'));
}

Youez - 2016 - github.com/yon3zu
LinuXploit