Agaric Design Collective

AND/OR logic error in Userreference Access function

By Benjamin Melançon
on 14 Dec
0 comments

Description

OK, the problem is definitely in this function. I'll get back to it in a little bit, but it may make enough sense for you to correct where an OR isn't doing what I think it should. I'm dyslexic and I swear that's why I can't do a damn thing with ANDs and ORs.

<pre>
function userreference_access_node_grants($account, $op) {
  $grants = array();
  switch ($op) {
    case 'view':
      if (variable_get('userreference_access_na_view', TRUE) || user_access('view all userreference access content')) {
        $grants['userreference_access'] = array(1);
      }
      else {
        $grants['userreference_access_nodes'] = userreference_access_nids($account, TRUE);
      }
      break;
    case 'update':  // aka edit
      if (user_access('edit all userreference access content')) {
        $grants['userreference_access'] = array(1);
      }
      else {
        $grants['userreference_access_nodes'] = userreference_access_nids($account, TRUE);
      }
      break;
    case 'delete':
      if (user_access('delete all userreference access content')) {
        $grants['userreference_access'] = array(1);
      }
      elseif (variable_get('userreference_access_na_dlet', FALSE)) {
        $grants['userreference_access_nodes'] = userreference_access_nids($account);       
      }
      break;
  }
  return $grants;
}
</pre>

 

Post new comment
The content of this field is kept private and will not be shown publicly.
  • Allowed HTML tags: <a> <em> <strong> <cite> <code> <ul> <ol> <li> <dl> <dt> <dd> <blockquote> <h1> <h2> <h3> <h4> <h5> <h6> <small> <pre> <strike> <sub> <sup> <kbd> <s>
  • Lines and paragraphs break automatically.
  • Web page addresses and e-mail addresses turn into links automatically.
  • You may post code using <code>...</code> (generic) or <?php ... ?> (highlighted PHP) tags.

More information about formatting options

CAPTCHA
This question is for testing whether you are a human visitor and to prevent automated spam submissions.
Image CAPTCHA
Copy the characters (respecting upper/lower case) from the image.