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