| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230 | 
							- <?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.
 
-  */
 
- /**
 
-  * 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);
 
-   }
 
-   if ($op == 'view' && $account->uid == variable_get('node_test_node_access_all_uid', 0)) {
 
-     $grants['node_access_all'] = array(0);
 
-   }
 
-   return $grants;
 
- }
 
- /**
 
-  * Implements hook_node_access_records().
 
-  */
 
- function node_access_test_node_access_records($node) {
 
-   $grants = array();
 
-   // For NodeAccessBaseTableTestCase, only set records for private nodes.
 
-   if (!variable_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 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 for 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.
 
-  */
 
- 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 for 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 {
 
-     $query = new EntityFieldQuery;
 
-     $result = $query->fieldCondition('body', 'value', 'A', 'STARTS_WITH')->execute();
 
-     if (!empty($result['node'])) {
 
-       $output .= '<p>Yes, ' . count($result['node']) . ' nodes</p>';
 
-       $output .= '<ul>';
 
-       foreach ($result['node'] as $nid => $v) {
 
-         $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 (variable_get('node_access_test_private')) {
 
-     $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($form['#node']->private) ? $form['#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_delete().
 
-  */
 
- function node_access_test_node_delete($node) {
 
-   db_delete('node_access_test')->condition('nid', $node->nid)->execute();
 
- }
 
- /**
 
-  * Implements hook_node_insert().
 
-  */
 
- function node_access_test_node_insert($node) {
 
-   _node_access_test_node_write($node);
 
- }
 
- /**
 
-  * Implements hook_node_update().
 
-  */
 
- function node_access_test_node_update($node) {
 
-   _node_access_test_node_write($node);
 
- }
 
- /**
 
-  * Helper for node insert/update.
 
-  */
 
- function _node_access_test_node_write($node) {
 
-   if (isset($node->private)) {
 
-     db_merge('node_access_test')
 
-       ->key(array('nid' => $node->nid))
 
-       ->fields(array('private' => (int) $node->private))
 
-       ->execute();
 
-   }
 
- }
 
 
  |