123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- <?php
- /**
- * @file
- * Provide views runtime hooks for node.module.
- */
- use Drupal\user\RoleInterface;
- use Drupal\views\ViewExecutable;
- use Drupal\user\Entity\Role;
- /**
- * Implements hook_views_query_substitutions().
- */
- function node_views_query_substitutions(ViewExecutable $view) {
- $account = \Drupal::currentUser();
- return [
- '***ADMINISTER_NODES***' => intval($account->hasPermission('administer nodes')),
- '***VIEW_OWN_UNPUBLISHED_NODES***' => intval($account->hasPermission('view own unpublished content')),
- '***BYPASS_NODE_ACCESS***' => intval($account->hasPermission('bypass node access')),
- ];
- }
- /**
- * Implements hook_views_analyze().
- */
- function node_views_analyze(ViewExecutable $view) {
- $ret = [];
- // Check for something other than the default display:
- if ($view->storage->get('base_table') == 'node') {
- foreach ($view->displayHandlers as $display) {
- if (!$display->isDefaulted('access') || !$display->isDefaulted('filters')) {
- // check for no access control
- $access = $display->getOption('access');
- if (empty($access['type']) || $access['type'] == 'none') {
- $anonymous_role = Role::load(RoleInterface::ANONYMOUS_ID);
- $anonymous_has_access = $anonymous_role && $anonymous_role->hasPermission('access content');
- $authenticated_role = Role::load(RoleInterface::AUTHENTICATED_ID);
- $authenticated_has_access = $authenticated_role && $authenticated_role->hasPermission('access content');
- if (!$anonymous_has_access || !$authenticated_has_access) {
- $ret[] = Analyzer::formatMessage(t('Some roles lack permission to access content, but display %display has no access control.', ['%display' => $display->display['display_title']]), 'warning');
- }
- $filters = $display->getOption('filters');
- foreach ($filters as $filter) {
- if ($filter['table'] == 'node' && ($filter['field'] == 'status' || $filter['field'] == 'status_extra')) {
- continue 2;
- }
- }
- $ret[] = Analyzer::formatMessage(t('Display %display has no access control but does not contain a filter for published nodes.', ['%display' => $display->display['display_title']]), 'warning');
- }
- }
- }
- }
- foreach ($view->displayHandlers as $display) {
- if ($display->getPluginId() == 'page') {
- if ($display->getOption('path') == 'node/%') {
- $ret[] = Analyzer::formatMessage(t('Display %display has set node/% as path. This will not produce what you want. If you want to have multiple versions of the node view, use panels.', ['%display' => $display->display['display_title']]), 'warning');
- }
- }
- }
- return $ret;
- }
|