drupaldrupal-6drupal-navigation

How do I limit access to menu by role in Drupal?


I'm building a Drupal site, and have added two custom menus to give two different groups of management links (some people will see one menu or the other, some will see both, and anonymous/low-level users will see neither).

The problem is, at the moment, all users can see the menus (but the menu items are not visible).

I'm trying to create a simple permissions module - and have created the administration forms which specify which menus are viewable by which role.

But I can't find a hook which lets me override the visibility of a particular menu - only the items.

So, how do I limit access to menu by role in Drupal now that I have a list of permissions in the database?

--

I have looked at Menu per Role and Menu Access. Unfortunately, these work at the item level and not on the menus directly.


Solution

  • I've come up with a solution - instead of using the auto-generated menu blocks for display, I've created a single block and put the following code in my module:

    function amh_menu_block($op = 'list', $delta = 0, $edit = array())
    {
        if ($op == 'list') {
            $blocks[0] = array(
                'info' => t('AMH Menu block'),
                'weight' => 0,
                'status' => 1,
                'region' => 'left',
            );
    
            return $blocks;
        } elseif ($op == 'view') {
            switch($delta) {
                case 0:
                    $block = array(
                        'subject' => '',
                        'content' => _amh_menu_display(),
                    );
    
                    break;
            }
    
            return $block;
        }
    }
    
    function _amh_menu_display()
    {
        global $user;
    
        $content = '';
    
        if ($user->uid != 0) {
            $result = db_query('SELECT * FROM {amh_menu_permission} p LEFT JOIN {menu_custom} m ON p.menu_name = m.menu_name LEFT JOIN {users_roles} u ON p.rid = u.rid WHERE u.uid = %d OR p.rid = 2', $user->uid);
        } else {
            $result = db_query('SELECT * FROM {amh_menu_permission} p LEFT JOIN {menu_custom} m ON p.menu_name = m.menu_name WHERE p.rid = 1');
        }
        $menus = array();
        while ($m = db_fetch_object($result)) {
            $menu = menu_tree($m->menu_name);
    
            if ($menu) {
                $content .= "\r\n<h2>" . $m->title . "<h2>\r\n";
                $content .= theme_menu_tree($menu);
            }
        }
    
        return $content;
    }
    

    This seems to work fine.