<?php
use Drupal\node\Plugin\Core\Entity\Node;
function node_access_test_node_grants($account, $op) {
$grants = array();
$grants['node_access_test_author'] = array(
$account->uid,
);
if ($op == 'view' && user_access('node test view', $account)) {
$grants['node_access_test'] = array(
8888,
8889,
);
}
$no_access_uid = state()
->get('node_access_test.no_access_uid') ?: 0;
if ($op == 'view' && $account->uid == $no_access_uid) {
$grants['node_access_all'] = array(
0,
);
}
return $grants;
}
function node_access_test_node_access_records(Node $node) {
$grants = array();
if (!state()
->get('node_access_test.private') || $node->private) {
$grants[] = array(
'realm' => 'node_access_test',
'gid' => 8888,
'grant_view' => 1,
'grant_update' => 0,
'grant_delete' => 0,
'priority' => 0,
);
$grants[] = array(
'realm' => 'node_access_test',
'gid' => 8889,
'grant_view' => 1,
'grant_update' => 0,
'grant_delete' => 0,
'priority' => 0,
);
$grants[] = array(
'realm' => 'node_access_test_author',
'gid' => $node->uid,
'grant_view' => 1,
'grant_update' => 1,
'grant_delete' => 1,
'priority' => 0,
);
}
return $grants;
}
function node_access_test_permission() {
return array(
'node test view' => array(
'title' => 'View content',
),
);
}
function node_access_test_menu() {
$items = array();
$items['node_access_test_page'] = array(
'title' => 'Node access test',
'page callback' => 'node_access_test_page',
'access arguments' => array(
'access content',
),
'type' => MENU_SUGGESTED_ITEM,
);
$items['node_access_entity_test_page'] = array(
'title' => 'Node access test',
'page callback' => 'node_access_entity_test_page',
'access arguments' => array(
'access content',
),
'type' => MENU_SUGGESTED_ITEM,
);
return $items;
}
function node_access_test_page() {
$output = '';
try {
$query = db_select('node', 'mytab')
->fields('mytab');
$query
->addTag('node_access');
$result = $query
->execute()
->fetchAll();
if (count($result)) {
$output .= '<p>Yes, ' . count($result) . ' nodes</p>';
$output .= '<ul>';
foreach ($result as $item) {
$output .= '<li>' . $item->nid . '</li>';
}
$output .= '</ul>';
}
else {
$output .= '<p>No nodes</p>';
}
$output .= '<p>' . (string) $query . '</p>';
} catch (Exception $e) {
$output = '<p>Exception</p>';
$output .= '<p>' . $e
->getMessage() . '</p>';
}
return $output;
}
function node_access_entity_test_page() {
$output = '';
try {
$result = entity_query('node')
->condition('body.value', 'A', 'STARTS_WITH')
->execute();
if (!empty($result)) {
$output .= '<p>Yes, ' . count($result) . ' nodes</p>';
$output .= '<ul>';
foreach ($result as $nid) {
$output .= '<li>' . $nid . '</li>';
}
$output .= '</ul>';
}
else {
$output .= '<p>No nodes</p>';
}
} catch (Exception $e) {
$output = '<p>Exception</p>';
$output .= '<p>' . $e
->getMessage() . '</p>';
}
return $output;
}
function node_access_test_form_node_form_alter(&$form, $form_state) {
if (state()
->get('node_access_test.private')) {
$node = $form_state['controller']
->getEntity($form_state);
$form['private'] = array(
'#type' => 'checkbox',
'#title' => t('Private'),
'#description' => t('Check here if this content should be set private and only shown to privileged users.'),
'#default_value' => isset($node->private) ? $node->private : FALSE,
);
}
}
function node_access_test_node_load($nodes, $types) {
$result = db_query('SELECT nid, private FROM {node_access_test} WHERE nid IN(:nids)', array(
':nids' => array_keys($nodes),
));
foreach ($result as $record) {
$nodes[$record->nid]->private = $record->private;
}
}
function node_access_test_node_predelete(Node $node) {
db_delete('node_access_test')
->condition('nid', $node->nid)
->execute();
}
function node_access_test_node_insert(Node $node) {
_node_access_test_node_write($node);
}
function node_access_test_node_update(Node $node) {
_node_access_test_node_write($node);
}
function _node_access_test_node_write(Node $node) {
if (isset($node->private)) {
db_merge('node_access_test')
->key(array(
'nid' => $node->nid,
))
->fields(array(
'private' => (int) $node->private,
))
->execute();
}
}
function node_access_test_node_access($node, $op, $account, $langcode) {
if (variable_get('node_access_test_secret_catalan', 0) && $langcode == 'ca') {
return NODE_ACCESS_DENY;
}
return NODE_ACCESS_IGNORE;
}