Example #1
0
 /**
  * Get User Access Config Object
  *
  * @param int $user_id
  * @param array $force_roles
  * @return object
  */
 public static function getUserAccessConfig($user_id, $force_roles = FALSE)
 {
     if ($force_roles || !($config = mvb_Model_Cache::getCacheData('user', $user_id))) {
         $config = new mvb_Model_UserConfig($user_id);
         if (!$config->getID()) {
             //user is logged in
             $config = new mvb_Model_RoleConfig('_visitor');
         } else {
             if (is_array($force_roles)) {
                 $role_list = $force_roles;
             } else {
                 $role_list = $config->getUser()->getRoles();
             }
             //get first role and use as base
             //TODO - probably implement multirole support
             $r_config = mvb_Model_API::getRoleAccessConfig(array_shift($role_list));
             if (!count($config->getMenu())) {
                 $config->setMenu($r_config->getMenu());
             }
             if (!count($config->getMetaboxes())) {
                 $config->setMetaboxes($r_config->getMetaboxes());
             }
             if (!count($config->getMenuOrder())) {
                 $config->setMenuOrder($r_config->getMenuOrder());
             }
             if (!count($config->getCapabilities())) {
                 $config->setCapabilities($r_config->getCapabilities());
             }
             //merge restrictions
             $role_restrs = $r_config->getRestrictions();
             if (count($role_restrs)) {
                 if (isset($role_restrs['post'])) {
                     foreach ($role_restrs['post'] as $id => $data) {
                         if (!$config->hasRestriction('post', $id)) {
                             $config->addRestriction('post', $id, $data);
                         }
                     }
                 }
                 if (isset($role_restrs['taxonomy'])) {
                     foreach ($role_restrs['taxonomy'] as $id => $data) {
                         if (!$config->hasRestriction('taxonomy', $id)) {
                             $config->addRestriction('taxonomy', $id, $data);
                         }
                     }
                 }
             }
             if (!$force_roles) {
                 mvb_Model_Cache::saveCacheData('user', $user_id, $config);
             }
         }
     }
     return $config;
 }
 /**
  * Get User Access Config Object
  * 
  * @param int $user_id
  * @param array $force_roles
  * @return object
  */
 public static function getUserAccessConfig($user_id, $force_roles = FALSE)
 {
     $config = new mvb_Model_UserConfig($user_id);
     if (!$config->getID()) {
         //user is logged in
         $config = new mvb_Model_RoleConfig('_visitor');
     } else {
         if (is_array($force_roles)) {
             $role_list = $force_roles;
         } else {
             $role_list = $config->getUser()->getRoles();
         }
         $m_config = mvb_Model_API::getRoleAccessConfig(array_shift($role_list));
         foreach ($role_list as $role) {
             mvb_merge_configs($m_config, mvb_Model_API::getRoleAccessConfig($role));
         }
         mvb_merge_configs($config, $m_config);
     }
     return $config;
 }