first import
This commit is contained in:
		| @@ -0,0 +1,78 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * @file | ||||
|  * Hook provided by the Devel Node Access module. | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * @addtogroup hooks | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Explain your records in the {node_access} table. | ||||
|  * | ||||
|  * In order to help developers and administrators understand the forces | ||||
|  * that control access to any given node, the DNA module provides the | ||||
|  * Devel Node Access block, which lists all the grant records in the | ||||
|  * {node_access} table for that node. | ||||
|  * | ||||
|  * However, every Node Access module is free in how it defines and uses the | ||||
|  * 'realm' and 'gid' fields in its records in the {node_access} table, and | ||||
|  * it's often difficult to interpret them. This hook passes each record | ||||
|  * that DNA wants to display, and the owning module is expected to return | ||||
|  * an explanation of that record. | ||||
|  * | ||||
|  * The explanation should not be localized (not be passed through t()), so | ||||
|  * that administrators seeking help can present English explanations. | ||||
|  * | ||||
|  * @param $row | ||||
|  *   The record from the {node_access} table, as object. The member fields are: | ||||
|  *   nid, gid, realm, grant_view, grant_update, grant_delete. | ||||
|  * | ||||
|  * @return | ||||
|  *   A string with a (short!) explanation of the given {node_access} row, | ||||
|  *   to be displayed in DNA's 'Devel Node Access' block. It will be displayed | ||||
|  *   as HTML; any variable parts must already be sanitized. | ||||
|  * | ||||
|  * @see hook_node_access_records() | ||||
|  * @see devel_node_access_node_access_explain() | ||||
|  * | ||||
|  * @ingroup node_access | ||||
|  */ | ||||
| function hook_node_access_explain($row) { | ||||
|   if ($row->realm == 'mymodule_myrealm') { | ||||
|     if ($row->grant_view) { | ||||
|       $role = user_role_load($row->gid); | ||||
|       return 'Role ' . drupal_placeholder($role->name) . ' may view this node.'; | ||||
|     } | ||||
|     else { | ||||
|       return 'No access.'; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Acknowledge ownership of 'alien' grant records. | ||||
|  * | ||||
|  * Some node access modules store grant records directly into the {node_access} | ||||
|  * table rather than returning them through hook_node_access_records(). This | ||||
|  * practice is not recommended and DNA will flag all such records as 'alien'. | ||||
|  * | ||||
|  * If this is unavoidable, a module can confess to being the owner of these | ||||
|  * grant records, so that DNA can properly attribute them. | ||||
|  * | ||||
|  * @see hook_node_access_records() | ||||
|  * | ||||
|  * @ingroup node_access | ||||
|  */ | ||||
| function hook_node_access_acknowledge($grant) { | ||||
|   if ($grant['realm'] == 'mymodule_all' && $grant['nid'] == 0) { | ||||
|     return TRUE; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @} End of "addtogroup hooks". | ||||
|  */ | ||||
		Reference in New Issue
	
	Block a user
	 Bachir Soussi Chiadmi
					Bachir Soussi Chiadmi