/**
* A generic class for handling users
*
- * @author Roland Haeder <webmaster@ship-simu.org>
+ * @author Roland Haeder <webmaster@shipsimu.org>
* @version 0.0.0
- * @copyright Copyright (c) 2007 - 2009 Roland Haeder, this is free software
+ * @copyright Copyright (c) 2007, 2008 Roland Haeder, 2009 - 2015 Core Developer Team
* @license GNU GPL 3.0 or any newer version
- * @link http://www.ship-simu.org
+ * @link http://www.shipsimu.org
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
-class Member extends BaseUser implements ManageableMember, Registerable, Updateable {
+class Member extends BaseUser implements ManageableMember, Registerable {
/**
* Protected constructor
*
* @param $userName Username we need a class instance for
* @return $userInstance An instance of this user class
* @throws UsernameMissingException If the username does not exist
+ * @throws UnexpectedGuestAccountException If the user status is 'guest'
*/
- public final static function createMemberByUsername ($userName) {
+ public static final function createMemberByUsername ($userName) {
// Get a new instance
$userInstance = new Member();
$userInstance->setUserName($userName);
// Check if username exists
- if ($userInstance->ifUsernameExists() === false) {
+ if ($userInstance->ifUsernameExists() === FALSE) {
// Throw an exception here
throw new UsernameMissingException(array($userInstance, $userName), self::EXCEPTION_USERNAME_NOT_FOUND);
- } // END - if
+ } elseif ($userInstance->isGuest()) === TRUE) {
+ // User should not be a guest here
+ throw new UnexpectedGuestAccountException(array($userInstance, $userName), self::EXCEPTION_USERNAME_NOT_FOUND);
+ }
// Return the instance
return $userInstance;
* @param $email Email address of the user
* @return $userInstance An instance of this user class
*/
- public final static function createMemberByEmail ($email) {
+ public static final function createMemberByEmail ($email) {
// Get a new instance
$userInstance = new Member();
* @return $userInstance An instance of this user class
* @todo Add more ways over creating user classes
*/
- public final static function createMemberByRequest (Requestable $requestInstance) {
+ public static final function createMemberByRequest (Requestable $requestInstance) {
// Determine if by email or username
if (!is_null($requestInstance->getRequestElement('username'))) {
// Username supplied
} else {
// Unsupported mode
$userInstance = new Member();
- $userInstance->partialStub("We need to add more ways of creating user classes here.");
- $userInstance->debugBackTrace();
+ $userInstance->debugBackTrace('More ways of creating user classes are needed here.');
exit();
}
// If there is no action use the default on
if (is_null($lastAction)) {
- $lastAction = $this->getConfigInstance()->readConfig('login_default_action');
+ $lastAction = $this->getConfigInstance()->getConfigEntry('login_default_action');
} // END - if
// Get a critieria instance
$updateInstance = ObjectFactory::createObjectByConfiguredName('update_criteria_class');
// And add our both entries
- $updateInstance->addCriteria("last_activity", date("Y-m-d H:i:s", time()));
- $updateInstance->addCriteria("last_action", $lastAction);
+ $updateInstance->addCriteria('last_activity', date('Y-m-d H:i:s', time()));
+ $updateInstance->addCriteria('last_action', $lastAction);
// Add the search criteria for searching for the right entry
$updateInstance->setSearchInstance($searchInstance);