A dummy module implementing node access related hooks for testing purposes.
A dummy module implementing node access related hooks to test API interaction with the Node module. This module restricts view permission to those with a special 'node test view' permission.
<?php
/**
* @file
* A dummy module implementing node access related hooks for testing purposes.
*
* A dummy module implementing node access related hooks to test API interaction
* with the Node module. This module restricts view permission to those with
* a special 'node test view' permission.
*/
use Drupal\Core\Entity\EntityInterface;
/**
* Implements hook_node_grants().
*/
function node_access_test_node_grants($account, $op) {
$grants = array();
// First grant a grant to the author for own content.
$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 = Drupal::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;
}
/**
* Implements hook_node_access_records().
*/
function node_access_test_node_access_records(EntityInterface $node) {
$grants = array();
// For NodeAccessBaseTableTestCase, only set records for private nodes.
if (!Drupal::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,
);
// For the author realm, the GID is equivalent to a UID, which
// means there are many many groups of just 1 user.
$grants[] = array(
'realm' => 'node_access_test_author',
'gid' => $node->uid,
'grant_view' => 1,
'grant_update' => 1,
'grant_delete' => 1,
'priority' => 0,
);
}
return $grants;
}
/**
* Implements hook_permission().
*
* Sets up permissions for this module.
*/
function node_access_test_permission() {
return array(
'node test view' => array(
'title' => 'View content',
),
);
}
/**
* Implements hook_menu().
*
* Sets up a test page that lists nodes.
*/
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;
}
/**
* Page callback: Creates the node access test page.
*
* Page should say "No nodes" if there are no nodes, and "Yes, # nodes" (with
* the number filled in) if there were nodes the user could access. Also, the
* database query is shown, and a list of the node IDs, for debugging purposes.
* And if there is a query exception, the page says "Exception" and gives the
* error.
*
* @see node_access_test_menu()
*/
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;
}
/**
* Page callback: Creates the node access entity test page.
*
* Page should say "No nodes" if there are no nodes, and "Yes, # nodes" (with
* the number filled in) if there were nodes the user could access. Also, the
* database query is shown, and a list of the node IDs, for debugging purposes.
* And if there is a query exception, the page says "Exception" and gives the
* error.
*
* @see node_access_test_menu()
*/
function node_access_entity_test_page() {
$output = '';
try {
$result = Drupal::entityQuery('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;
}
/**
* Implements hook_form_BASE_FORM_ID_alter().
*/
function node_access_test_form_node_form_alter(&$form, $form_state) {
// Only show this checkbox for NodeAccessBaseTableTestCase.
if (Drupal::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,
);
}
}
/**
* Implements hook_node_load().
*/
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;
}
}
/**
* Implements hook_node_predelete().
*/
function node_access_test_node_predelete(EntityInterface $node) {
db_delete('node_access_test')
->condition('nid', $node->nid)
->execute();
}
/**
* Implements hook_node_insert().
*/
function node_access_test_node_insert(EntityInterface $node) {
_node_access_test_node_write($node);
}
/**
* Implements hook_nodeapi_update().
*/
function node_access_test_node_update(EntityInterface $node) {
_node_access_test_node_write($node);
}
/**
* Helper for node insert/update.
*/
function _node_access_test_node_write(EntityInterface $node) {
if (isset($node->private)) {
db_merge('node_access_test')
->key(array(
'nid' => $node->nid,
))
->fields(array(
'private' => (int) $node->private,
))
->execute();
}
}
/**
* Implements hook_node_access().
*/
function node_access_test_node_access($node, $op, $account, $langcode) {
$secret_catalan = Drupal::state()
->get('node_access_test_secret_catalan') ?: 0;
if ($secret_catalan && $langcode == 'ca') {
// Make all Catalan content secret.
return NODE_ACCESS_DENY;
}
return NODE_ACCESS_IGNORE;
}
Name | Description |
---|---|
node_access_entity_test_page | Page callback: Creates the node access entity test page. |
node_access_test_form_node_form_alter | Implements hook_form_BASE_FORM_ID_alter(). |
node_access_test_menu | Implements hook_menu(). |
node_access_test_node_access | Implements hook_node_access(). |
node_access_test_node_access_records | Implements hook_node_access_records(). |
node_access_test_node_grants | Implements hook_node_grants(). |
node_access_test_node_insert | Implements hook_node_insert(). |
node_access_test_node_load | Implements hook_node_load(). |
node_access_test_node_predelete | Implements hook_node_predelete(). |
node_access_test_node_update | Implements hook_nodeapi_update(). |
node_access_test_page | Page callback: Creates the node access test page. |
node_access_test_permission | Implements hook_permission(). |
_node_access_test_node_write | Helper for node insert/update. |