arch-8.x-1.x-dev/modules/product/src/Plugin/views/filter/Access.php
modules/product/src/Plugin/views/filter/Access.php
<?php
namespace Drupal\arch_product\Plugin\views\filter;
use Drupal\Core\Database\Query\Condition;
use Drupal\Core\Form\FormStateInterface;
use Drupal\views\Plugin\views\filter\FilterPluginBase;
/**
* Filter by product_access records.
*
* @ingroup views_filter_handlers
*
* @ViewsFilter("product_access")
*/
class Access extends FilterPluginBase {
/**
* {@inheritdoc}
*/
public function adminSummary() {}
/**
* {@inheritdoc}
*/
protected function operatorForm(&$form, FormStateInterface $form_state) {}
/**
* {@inheritdoc}
*/
public function canExpose() {
return FALSE;
}
/**
* See _product_access_where_sql() for a non-views query based implementation.
*/
public function query() {
$account = $this->view->getUser();
if (!$account->hasPermission('bypass product access')) {
$table = $this->ensureMyTable();
$grants = new Condition('OR');
foreach (arch_product_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.product_grants:view';
return $contexts;
}
}
