1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- <?php
- /**
- * @file
- * Describe hooks provided by the publishcontent module.
- */
- /**
- * Allow other modules the ability to modify access to the publish controls.
- *
- * Modules may implement this hook if they want to have a say in whether or not
- * a given user has access to perform publish action on a node.
- *
- * @param node $node
- * A node object being checked
- * @param user $account
- * The user wanting to publish the node.
- *
- * @return bool|NULL
- * PUBLISHCONTENT_ACCESS_ALLOW - if the account can publish the node
- * PUBLISHCONTENT_ACCESS_DENY - if the user definetley can not publish
- * PUBLISHCONTENT_ACCESS_IGNORE - This module wan't change the outcome.
- * It is typically better to return IGNORE than DENY. If no module returns
- * ALLOW then the account will be denied publish access. If one module
- * returns DENY then the user will denied even if another module returns
- * ALLOW.
- */
- function hook_publishcontent_publish_access($node, $account) {
- $access = !$node->status &&
- (user_access('administer nodes')
- || user_access('publish any content')
- || (user_access('publish own content') && $account->uid == $node->uid)
- || (user_access('publish editable content') && node_access('update', $node))
- || (user_access('publish own ' . check_plain($node->type) . ' content', $account) && $account->uid == $node->uid)
- || user_access('publish any ' . check_plain($node->type) . ' content')
- || (user_access('publish editable ' . check_plain($node->type) . ' content') && node_access('update', $node))
- );
- if ($access) {
- // The user can publish the node according to this hook.
- // If another hook denys access they will be denied.
- return PUBLISHCONTENT_ACCESS_ALLOW;
- }
- // This function does not believe they can publish but is
- // not explicitly denying access to publish. If no other hooks
- // allow it then the user will be denied.
- return PUBLISHCONTENT_ACCESS_IGNORE;
- }
- /**
- * Allow other modules the ability to modify access to the unpublish controls.
- *
- * Modules may implement this hook if they want to have a say in whether or not
- * a given user has access to perform unpublish action on a node.
- *
- * @param node $node
- * A node object being checked
- * @param user $account
- * The user wanting to unpublish the node.
- *
- * @return bool|NULL
- * PUBLISHCONTENT_ACCESS_ALLOW - if the user can unpublish the node.
- * PUBLISHCONTENT_ACCESS_DENY - if the user definetley cannot unpublish.
- * PUBLISHCONTENT_ACCESS_IGNORE - This module wan't change the outcome.
- * It is typically better to return IGNORE than DENY. If no module returns
- * ALLOW then the user will be denied access. If one module returns
- * DENY then the user will denied even if another module returns
- * ALLOW.
- */
- function hook_publishcontent_unpublish_access($node, $account) {
- $access = $node->status &&
- (user_access('administer nodes')
- || user_access('unpublish any content')
- || (user_access('unpublish own content') && $user->uid == $node->uid)
- || (user_access('unpublish editable content') && node_access('update', $node))
- || (user_access('unpublish own ' . check_plain($node->type) . ' content', $user) && $user->uid == $node->uid)
- || user_access('unpublish any ' . check_plain($node->type) . ' content')
- || (user_access('unpublish editable ' . check_plain($node->type) . ' content') && node_access('update', $node))
- );
- if ($access) {
- // The user is allowed to unpublish the node according to this hook.
- // If another hook denys access they will be denied.
- return PUBLISHCONTENT_ACCESS_ALLOW;
- }
- // This function does not believe they can publish but is
- // not explicitly denying access to publish. If no other hooks
- // allow it then the user will be denied.
- return PUBLISHCONTENT_ACCESS_IGNORE;
- }
|