users)) { $users = array_map('strtolower', StringHelper::trimSplit($section->users)); if (in_array($username, $users)) { return true; } } if (! empty($section->groups)) { $groups = array_map('strtolower', StringHelper::trimSplit($section->groups)); foreach ($userGroups as $userGroup) { if (in_array(strtolower($userGroup), $groups)) { return true; } } } return false; } /** * Get user permissions and restrictions * * @param User $user */ public function applyRoles(User $user) { $permissions = array(); $restrictions = array(); $username = $user->getUsername(); try { $roles = Config::app('roles'); } catch (NotReadableError $e) { Logger::error( 'Can\'t get permissions and restrictions for user \'%s\'. An exception was thrown:', $username, $e ); return; } $userGroups = $user->getGroups(); foreach ($roles as $role) { if ($this->match($username, $userGroups, $role)) { $permissions = array_merge( $permissions, array_diff(StringHelper::trimSplit($role->permissions), $permissions) ); $restrictionsFromRole = $role->toArray(); unset($restrictionsFromRole['users']); unset($restrictionsFromRole['groups']); unset($restrictionsFromRole['permissions']); foreach ($restrictionsFromRole as $name => $restriction) { if (! isset($restrictions[$name])) { $restrictions[$name] = array(); } $restrictions[$name][] = $restriction; } } } $user->setPermissions($permissions); $user->setRestrictions($restrictions); // $user->setRoles($roles); } }