• Модуль: tasks
  • Путь к файлу: ~/bitrix/modules/tasks/lib/access/rule/taskeditrule.php
  • Класс: BitrixTasksAccessRuleTaskEditRule
  • Вызов: TaskEditRule::execute
public function execute(AccessibleItem $task = null, $params = null): bool
{
	if (!$task)
	{
		$this->controller->addError(static::class, 'Incorrect task');
		return false;
	}

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

	if (
		$task->getGroupId()
		&& Loader::includeModule("socialnetwork")
		&& BitrixSocialnetworkInternalsRegistryFeaturePermRegistry::getInstance()->get(
			$task->getGroupId(),
			'tasks',
			'edit_tasks',
			$this->user->getUserId()
		)
	)
	{
		return true;
	}

	if (
		!$task->isClosed()
		&& $task->isMember($this->user->getUserId(), RoleDictionary::ROLE_DIRECTOR)
	)
	{
		return true;
	}

	if (
		$task->isClosed()
		&& $task->isMember($this->user->getUserId(), RoleDictionary::ROLE_DIRECTOR)
		&& $this->user->getPermission(PermissionDictionary::TASK_CLOSED_DIRECTOR_EDIT)
	)
	{
		return true;
	}

	if (
		$task->isMember($this->user->getUserId(), RoleDictionary::ROLE_RESPONSIBLE)
		&& $this->user->getPermission(PermissionDictionary::TASK_RESPONSE_EDIT)
		&& !$task->isClosed()
	)
	{
		return true;
	}

	// can edit subordinate's task
	if (
		array_intersect($task->getMembers(RoleDictionary::ROLE_DIRECTOR), $this->user->getAllSubordinates())
	)
	{
		return true;
	}

	$isInDepartment = $task->isInDepartment($this->user->getUserId(), false, [RoleDictionary::ROLE_RESPONSIBLE, RoleDictionary::ROLE_DIRECTOR, RoleDictionary::ROLE_ACCOMPLICE]);

	if (
		$this->user->getPermission(PermissionDictionary::TASK_DEPARTMENT_EDIT)
		&& $isInDepartment
		&& !$task->isClosed()
	)
	{
		return true;
	}

	if (
		$this->user->getPermission(PermissionDictionary::TASK_CLOSED_DEPARTMENT_EDIT)
		&& $isInDepartment
		&& $task->isClosed()
	)
	{
		return true;
	}

	if (
		$this->user->getPermission(PermissionDictionary::TASK_NON_DEPARTMENT_EDIT)
		&& !$isInDepartment
		&& !$task->isClosed()
	)
	{
		return true;
	}

	if (
		$this->user->getPermission(PermissionDictionary::TASK_CLOSED_NON_DEPARTMENT_EDIT)
		&& !$isInDepartment
		&& $task->isClosed()
	)
	{
		return true;
	}

	$this->controller->addError(static::class, 'Access to edit task denied');
	return false;
}