setUsername($username); if ($firstname !== null) { $this->setFirstname($firstname); } if ($lastname !== null) { $this->setLastname($lastname); } if ($email !== null) { $this->setEmail($email); } } /** * Setter for preferences * * @param Preferences $preferences */ public function setPreferences(Preferences $preferences) { $this->preferences = $preferences; } /** * Getter for preferences * * @return Preferences */ public function getPreferences() { if ($this->preferences === null) { $this->preferences = new Preferences(); } return $this->preferences; } /** * Return all groups this user belongs to * * @return array */ public function getGroups() { return $this->groups; } /** * Set the groups this user belongs to * * @param array $groups */ public function setGroups(array $groups) { $this->groups = $groups; } /** * Return true if the user is a member of this group * * @param string $group * * @return boolean */ public function isMemberOf($group) { return in_array($group, $this->groups); } /** * Get the user's permissions * * @return array */ public function getPermissions() { return $this->permissions; } /** * Set the user's permissions * * @param array $permissions * * @return $this */ public function setPermissions(array $permissions) { if (! empty($permissions)) { natcasesort($permissions); $this->permissions = array_combine($permissions, $permissions); } return $this; } /** * Return restriction information for this user * * @param string $name * * @return array */ public function getRestrictions($name) { if (array_key_exists($name, $this->restrictions)) { return $this->restrictions[$name]; } return array(); } /** * Settter for restrictions * * @param array $restrictions */ public function setRestrictions(array $restrictions) { $this->restrictions = $restrictions; } /** * Getter for username * * @return string */ public function getUsername() { return $this->username; } /** * Setter for username * * @param string $name */ public function setUsername($name) { $this->username = $name; } /** * Getter for firstname * * @return string */ public function getFirstname() { return $this->firstname; } /** * Setter for firstname * * @param string $name */ public function setFirstname($name) { $this->firstname = $name; } /** * Getter for lastname * * @return string */ public function getLastname() { return $this->lastname; } /** * Setter for lastname * * @param string $name */ public function setLastname($name) { $this->lastname = $name; } /** * Getter for email * * @return string */ public function getEmail() { return $this->email; } /** * Setter for mail * * @param string $mail * * @throws InvalidArgumentException When an invalid mail is provided */ public function setEmail($mail) { if (filter_var($mail, FILTER_VALIDATE_EMAIL)) { $this->email = $mail; } else { throw new InvalidArgumentException("Invalid mail given for user $this->username: $mail"); } } /** * Setter for domain * * @param string $domain */ public function setDomain($domain) { $this->domain = $domain; } /** * Getter for domain * * @return string */ public function getDomain() { return $this->domain; } /** * Set additional information about user * * @param string $key * @param string $value */ public function setAdditional($key, $value) { $this->additionalInformation[$key] = $value; } /** * Getter for additional information * * @param string $key * @return mixed|null */ public function getAdditional($key) { if (isset($this->additionalInformation[$key])) { return $this->additionalInformation[$key]; } return null; } /** * Retrieve the user's timezone * * If the user did not set a timezone, the default timezone set via config.ini is returned * * @return DateTimeZone */ public function getTimeZone() { $tz = $this->preferences->get('timezone'); if ($tz === null) { $tz = date_default_timezone_get(); } return new DateTimeZone($tz); } /** * Set additional external user information * * @param string $username * @param string $field */ public function setExternalUserInformation($username, $field) { $this->externalUserInformation = array($username, $field); } /** * Get additional external user information * * @return array */ public function getExternalUserInformation() { return $this->externalUserInformation; } /** * Return true if user has external user information set * * @return bool */ public function isExternalUser() { return ! empty($this->externalUserInformation); } /** * Get whether the user is authenticated using a HTTP authentication mechanism * * @return bool */ public function getIsHttpUser() { return $this->isHttpUser; } /** * Set whether the user is authenticated using a HTTP authentication mechanism * * @param bool $isHttpUser * * @return $this */ public function setIsHttpUser($isHttpUser = true) { $this->isHttpUser = (bool) $isHttpUser; return $this; } /** * Whether the user has a given permission * * @param string $requiredPermission * * @return bool */ public function can($requiredPermission) { if (isset($this->permissions['*']) || isset($this->permissions[$requiredPermission])) { return true; } $requiredWildcard = strpos($requiredPermission, '*'); foreach ($this->permissions as $grantedPermission) { if ($requiredWildcard !== false) { if (($grantedWildcard = strpos($grantedPermission, '*')) !== false) { $wildcard = min($requiredWildcard, $grantedWildcard); } else { $wildcard = $requiredWildcard; } } else { $wildcard = strpos($grantedPermission, '*'); } if ($wildcard !== false) { if (substr($requiredPermission, 0, $wildcard) === substr($grantedPermission, 0, $wildcard)) { return true; } } elseif ($requiredPermission === $grantedPermission) { return true; } } return false; } /** * Load and return this user's navigation configuration * * @return Config */ public function loadNavigationConfig() { return Config::fromIni( Config::resolvePath('preferences') . DIRECTORY_SEPARATOR . $this->getUsername() . DIRECTORY_SEPARATOR . 'navigation.ini' ); } /** * Load and return this user's configured navigation of the given type * * @param string $type * * @return Navigation */ public function getNavigation($type) { $config = $this->loadNavigationConfig(); $config->getConfigObject()->setKeyColumn('name'); if ($type === 'dashboard-pane') { $panes = array(); foreach ($config->select()->where('type', 'dashlet') as $dashletName => $dashletConfig) { // TODO: Throw ConfigurationError if pane or url is missing $panes[$dashletConfig->pane][$dashletName] = $dashletConfig->url; } $navigation = new Navigation(); foreach ($panes as $paneName => $dashlets) { $navigation->addItem( $paneName, array( 'type' => 'dashboard-pane', 'dashlets' => $dashlets ) ); } } else { $navigation = Navigation::fromConfig($config->select()->where('type', $type)); } return $navigation; } }