function views_handler_filter_node_access::query

3.x views_handler_filter_node_access.inc views_handler_filter_node_access::query()
2.x views_handler_filter_node_access.inc views_handler_filter_node_access::query()

See _node_access_where_sql() for a non-views query based implementation.

Overrides views_handler_filter::query

File

modules/node/views_handler_filter_node_access.inc, line 15

Class

views_handler_filter_node_access
Filter by node_access records.

Code

function query() {
  if (!user_access('administer nodes')) {
    $table = $this->ensure_my_table();
    $grants = array();
    foreach (node_access_grants('view') as $realm => $gids) {
      foreach ($gids as $gid) {
        $grants[] = "($table.gid = $gid AND $table.realm = '$realm')";
      }
    }
    $grants_sql = '';
    if (count($grants)) {
      $grants_sql = implode(' OR ', $grants);
    }
    $this->query->add_where('AND', $grants_sql);
    $this->query->add_where('AND', "$table.grant_view >= 1");
  }
}