%PDF- %PDF- 403WebShell
403Webshell
Server IP : 37.220.80.31  /  Your IP : 3.145.82.191
Web Server : Apache/2.4.52 (Ubuntu)
System : Linux 3051455-guretool.twc1.net 5.15.0-107-generic #117-Ubuntu SMP Fri Apr 26 12:26:49 UTC 2024 x86_64
User : www-root ( 1010)
PHP Version : 7.4.33
Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,
MySQL : OFF  |  cURL : ON  |  WGET : OFF  |  Perl : OFF  |  Python : OFF  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /var/www/www-root/data/www/dev.artlot24.ru/bitrix/modules/sender/lib/security/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /var/www/www-root/data/www/dev.artlot24.ru/bitrix/modules/sender/lib/security/user.php
<?php
/**
 * Bitrix Framework
 * @package bitrix
 * @subpackage sender
 * @copyright 2001-2012 Bitrix
 */
namespace Bitrix\Sender\Security;

use Bitrix\Main\Config\Option;
use Bitrix\Main\Localization\Loc;
use Bitrix\Main\UserTable;

use Bitrix\Sender\Integration;

Loc::loadMessages(__FILE__);

/**
 * Class User
 * @package Bitrix\Sender\Security
 */
class User
{
	/** @var integer|null $id User ID. */
	protected $id = null;

	/** @var \CAllUser $object User object. */
	protected $object;

	/** @var Access $access Access. */
	protected $access;

	/** @var static $instanceCurrentUser Instance. */
	protected static $instanceCurrentUser;

	/** @var static $instance Instance. */
	protected static $instance;

	/**
	 * Get current user.
	 *
	 * @return static
	 */
	public static function current()
	{
		if (!static::$instanceCurrentUser)
		{
			static::$instanceCurrentUser = new static();
		}

		return static::$instanceCurrentUser;
	}

	/**
	 * Get user by ID.
	 *
	 * @param integer $id ID.
	 * @return static
	 */
	public static function get($id)
	{
		if (!static::$instance || static::$instance->getId() != $id)
		{
			static::$instance = new static($id);
		}

		return static::$instance;
	}

	/**
	 * User constructor.
	 *
	 * @param integer|null $id ID.
	 */
	public function __construct($id = null)
	{
		$this->id = $id;
	}

	/**
	 * Get current user ID.
	 *
	 * @return integer|null
	 */
	public function getId()
	{
		if ($this->isCurrent())
		{
			return $this->getObject()->getID();
		}

		return $this->id;
	}

	/**
	 * Return true if current user is admin.
	 *
	 * @return bool
	 */
	public function isAdmin()
	{
		if ($this->isCurrent())
		{
			return $this->getObject()->isAdmin();
		}

		return in_array(1, UserTable::getUserGroupIds($this->id));
	}

	/**
	 * Return true if current user has access to one or more module pages.
	 *
	 * @return bool
	 */
	public function hasAccess()
	{
		return $this->getAccess()->canViewAnything();
	}

	/**
	 * Return access instance.
	 *
	 * @return Access
	 * @throws \Bitrix\Main\ArgumentException
	 */
	public function getAccess()
	{
		if (!$this->access)
		{
			$this->access = Access::getInstance($this);
		}

		return $this->access;
	}

	/**
	 * Return true if current user can view module pages.
	 *
	 * @return bool
	 */
	public function canView()
	{
		if (!$this->isModuleAccessibleOnPortal())
		{
			return false;
		}

		if ($this->isBroadAccess())
		{
			return true;
		}

		if ($this->isPortalAdmin())
		{
			return true;
		}

		if (is_object($GLOBALS['APPLICATION']) && $GLOBALS['APPLICATION']->getGroupRight('sender') !== "D")
		{
			return true;
		}

		return false;
	}

	private function isBroadAccess()
	{
		if (!Integration\Bitrix24\Service::isPortal())
		{
			return false;
		}

		return !Role\Manager::canUse();
	}

	private function isModuleAccessibleOnPortal()
	{
		if (!Integration\Bitrix24\Service::isCloud())
		{
			return true;
		}

		return Option::get('sender', '~is_accessible_on_portal', 'Y') === 'Y';
	}

	/**
	 * Return true if current user can edit on module pages.
	 *
	 * @return bool
	 */
	public function canEdit()
	{
		if (!$this->isModuleAccessibleOnPortal())
		{
			return false;
		}

		if ($this->isBroadAccess())
		{
			return true;
		}

		if ($this->isPortalAdmin())
		{
			return true;
		}

		if (is_object($GLOBALS['APPLICATION']) && $GLOBALS['APPLICATION']->getGroupRight('sender') === "W")
		{
			return true;
		}

		return false;
	}

	/**
	 * Return true if current user is portal admin.
	 *
	 * @return bool
	 */
	public function isPortalAdmin()
	{
		if (!Integration\Bitrix24\Service::isPortal() && !Integration\Bitrix24\Service::isCloud())
		{
			return $this->isAdmin();
		}

		return $this->getObject()->canDoOperation('bitrix24_config', $this->id);
	}

	/**
	 * Return true if user accepted agreement.
	 *
	 * @return bool
	 */
	public function isAgreementAccepted()
	{
		if (!Integration\Bitrix24\Service::isCloud())
		{
			return true;
		}

		return Agreement::isAcceptedByUser($this->getId());
	}

	/**
	 * Return true if current user can edit php.
	 *
	 * @return bool
	 */
	public function canEditPhp()
	{
		if (Integration\Bitrix24\Service::isCloud())
		{
			return false;
		}

		return $this->getObject()->canDoOperation('edit_php', $this->id);
	}

	/**
	 * Return true if current user can use LPA.
	 *
	 * @return bool
	 */
	public function canUseLpa()
	{
		if (Integration\Bitrix24\Service::isCloud())
		{
			return false;
		}

		return $this->getObject()->canDoOperation('lpa_template_edit', $this->id);
	}

	/**
	 * Get USER object.
	 *
	 * @return \CAllUser|null
	 */
	public function getObject()
	{
		if ($this->object)
		{
			return $this->object;
		}

		if ($this->isCurrent())
		{
			$this->object = (is_object($GLOBALS['USER']) && ($GLOBALS['USER'] instanceof \CAllUser)) ? $GLOBALS['USER'] : null;
		}

		if (!$this->object)
		{
			$this->object = new \CUser();
		}

		return $this->object;
	}

	private function isCurrent()
	{
		return !$this->id;
	}
}

Youez - 2016 - github.com/yon3zu
LinuXploit