= $MinClass || G::$LoggedUser['EffectiveClass'] >= $MinClass) ) ? true : false; } /** * Gets the permissions associated with a certain permissionid * * @param int $PermissionID the kind of permissions to fetch * @return array permissions */ public static function get_permissions($PermissionID) { $Permission = G::$Cache->get_value('perm_'.$PermissionID); if (empty($Permission)) { $QueryID = G::$DB->get_query_id(); G::$DB->query(" SELECT p.Level AS Class, p.Values as Permissions, p.Secondary, p.PermittedForums FROM permissions AS p WHERE ID='$PermissionID'"); $Permission = G::$DB->next_record(MYSQLI_ASSOC, array('Permissions')); G::$DB->set_query_id($QueryID); $Permission['Permissions'] = unserialize($Permission['Permissions']); G::$Cache->cache_value('perm_'.$PermissionID, $Permission, 2592000); } return $Permission; } /** * Get a user's permissions. * * @param $UserID * @param array|false $CustomPermissions * Pass in the user's custom permissions if you already have them. * Leave false if you don't have their permissions, the function will fetch them. * @return array Mapping of PermissionName=>bool/int */ public static function get_permissions_for_user($UserID, $CustomPermissions = false) { $UserInfo = Users::user_info($UserID); // Fetch custom permissions if they weren't passed in. if ($CustomPermissions === false) { $QueryID = G::$DB->get_query_id(); G::$DB->query(' SELECT um.CustomPermissions FROM users_main AS um WHERE um.ID = '.((int)$UserID)); list($CustomPermissions) = G::$DB->next_record(MYSQLI_NUM, false); G::$DB->set_query_id($QueryID); } if (!empty($CustomPermissions) && !is_array($CustomPermissions)) { $CustomPermissions = unserialize($CustomPermissions); } $Permissions = self::get_permissions($UserInfo['PermissionID']); // Manage 'special' inherited permissions $BonusPerms = array(); $BonusCollages = 0; foreach ($UserInfo['ExtraClasses'] as $PermID => $Value) { $ClassPerms = self::get_permissions($PermID); $BonusCollages += $ClassPerms['Permissions']['MaxCollages']; unset($ClassPerms['Permissions']['MaxCollages']); $BonusPerms = array_merge($BonusPerms, $ClassPerms['Permissions']); } if (empty($CustomPermissions)) { $CustomPermissions = array(); } // This is legacy donor cruft if ($UserInfo['Donor']) { $DonorPerms = self::get_permissions(DONOR); } else { $DonorPerms = array('Permissions' => array()); } $MaxCollages = $Permissions['Permissions']['MaxCollages'] + $BonusCollages; if (isset($CustomPermissions['MaxCollages'])) { $MaxCollages += $CustomPermissions['MaxCollages']; } $Permissions['MaxCollages'] = $MaxCollages; //Combine the permissions return array_merge( $Permissions['Permissions'], $BonusPerms, $CustomPermissions, $DonorPerms['Permissions']); } } ?>