Access.php

Same filename in other branches
  1. 9 core/modules/node/src/Plugin/views/filter/Access.php
  2. 10 core/modules/node/src/Plugin/views/filter/Access.php
  3. 11.x core/modules/node/src/Plugin/views/filter/Access.php

Namespace

Drupal\node\Plugin\views\filter

File

core/modules/node/src/Plugin/views/filter/Access.php

View source
<?php

namespace Drupal\node\Plugin\views\filter;

use Drupal\Core\Database\Query\Condition;
use Drupal\Core\Form\FormStateInterface;
use Drupal\views\Plugin\views\filter\FilterPluginBase;

/**
 * Filter by node_access records.
 *
 * @ingroup views_filter_handlers
 *
 * @ViewsFilter("node_access")
 */
class Access extends FilterPluginBase {
    public function adminSummary() {
    }
    protected function operatorForm(&$form, FormStateInterface $form_state) {
    }
    public function canExpose() {
        return FALSE;
    }
    
    /**
     * See _node_access_where_sql() for a non-views query based implementation.
     */
    public function query() {
        $account = $this->view
            ->getUser();
        if (!$account->hasPermission('bypass node access')) {
            $table = $this->ensureMyTable();
            $grants = new Condition('OR');
            foreach (node_access_grants('view', $account) as $realm => $gids) {
                foreach ($gids as $gid) {
                    $grants->condition((new Condition('AND'))->condition($table . '.gid', $gid)
                        ->condition($table . '.realm', $realm));
                }
            }
            $this->query
                ->addWhere('AND', $grants);
            $this->query
                ->addWhere('AND', $table . '.grant_view', 1, '>=');
        }
    }
    
    /**
     * {@inheritdoc}
     */
    public function getCacheContexts() {
        $contexts = parent::getCacheContexts();
        $contexts[] = 'user.node_grants:view';
        return $contexts;
    }

}

Classes

Title Deprecated Summary
Access Filter by node_access records.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.