Рейтинг:0

Ограничить доступ к определенному узлу по роли

флаг jp

Я работаю над проектом Drupal 9. Мне нужно ограничить доступ к узлу с идентификатором 1083 для роли «делегата». Для этого я использовал hook_node_access_records() и крючок_node_grants ():

/**
 * Реализует hook_node_access_records().
 */
функция wtotfaf_user_node_access_records (NodeInterface $ узел) {
  $гранты = [];
  если ($node->id() == 1083) {
    $ гранты [] = [
      'realm' => 'delegate_view_activity_tracker',
      // Название области зависит от вас.
      'гид' => 12,
      'грант_просмотр' => 1,
      'грант_обновление' => 0,
      'грант_удалить' => 0,
    ];
    $ гранты [] = [
      'область' => 'administrator_view_activity_tracker',
      // Название области зависит от вас.
      'гид' => 11,
      'грант_просмотр' => 1,
      'грант_обновление' => 1,
      'грант_удалить' => 1,
    ];
    $ гранты [] = [
      'область' => 'editor_view_activity_tracker',
      // Название области зависит от вас.
      'гид' => 13,
      'грант_просмотр' => 1,
      'грант_обновление' => 1,
      'грант_удалить' => 1,
    ];
  }
  возврат $грантов;
}

/**
 * Реализует hook_node_grants().
 */
функция wtotfaf_user_node_grants($account, $op) {
  $гранты = [];
  $roles = $account->getRoles();
  если (in_array('администратор', $роли)) {
    $grants['administrator_view_activity_tracker'] = [11];
  }
  elseif (in_array('делегат', $роли)) {
    $grants['delegate_view_activity_tracker'] = [12];
  }
  elseif (in_array('редактор', $роли)) {
    $grants['editor_view_activity_tracker'] = [13];
  }
  возврат $грантов;
}

В бд у меня так: введите описание изображения здесь

Узел с id 251 недоступен для других ролей после моих изменений. Что не так с кодом? Как я могу ограничить доступ для роли пользователя «делегата» только для идентификатора узла 1083?

Kevin avatar
флаг in
Вместо этого вы должны использовать один из различных модулей контроля доступа.
флаг in
Похоже, вы хотите https://www.drupal.org/project/nodeaccess
Asatur Vardanyan avatar
флаг jp
Большое спасибо за предложения. Я исправил это с помощью грантов. Я забыл восстановить разрешения.
jbarrio avatar
флаг cn
Я лично полагаюсь на hook_node_access(), который предоставит вам сущность, операцию и интерфейс учетной записи. Исходя из этого, я бы сделал свой возврат и вызвал бы cachePerPermissions(), чтобы убедиться, что это ничего не замедляет.

Ответить или комментировать

Большинство людей не понимают, что склонность к познанию нового открывает путь к обучению и улучшает межличностные связи. В исследованиях Элисон, например, хотя люди могли точно вспомнить, сколько вопросов было задано в их разговорах, они не чувствовали интуитивно связи между вопросами и симпатиями. В четырех исследованиях, в которых участники сами участвовали в разговорах или читали стенограммы чужих разговоров, люди, как правило, не осознавали, что задаваемый вопрос повлияет — или повлиял — на уровень дружбы между собеседниками.