X-Git-Url: https://git.mxchange.org/?p=shipsimu.git;a=blobdiff_plain;f=application%2Fship-simu%2Fmain%2Fregistration%2Fclass_ShipSimuRegistration.php;h=a4a0b355425e6ed9b1a792b709139031e4f261d0;hp=dd5ef73d611210d964ac2573b9e053b4b979d5f8;hb=d527a312ec4b2983fc0ecda2179ce335c1a5a1f9;hpb=36dfbfe39c864c7a426573df03c8ab59ff968737 diff --git a/application/ship-simu/main/registration/class_ShipSimuRegistration.php b/application/ship-simu/main/registration/class_ShipSimuRegistration.php index dd5ef73..a4a0b35 100644 --- a/application/ship-simu/main/registration/class_ShipSimuRegistration.php +++ b/application/ship-simu/main/registration/class_ShipSimuRegistration.php @@ -4,7 +4,7 @@ * * @author Roland Haeder * @version 0.0.0 - * @copyright Copyright(c) 2007, 2008 Roland Haeder, this is free software + * @copyright Copyright (c) 2007, 2008 Roland Haeder, this is free software * @license GNU GPL 3.0 or any newer version * @link http://www.ship-simu.org * @@ -23,7 +23,31 @@ */ class ShipSimuRegistration extends BaseRegistration { /** - * Private constructor + * Hashed password + */ + private $hashedPassword = ""; + + /** + * Elements for criteria + */ + private $criteriaElements = array( + 'username', + 'pass_hash', + 'email' => 'email1', + 'surname', + 'family', + 'street', + 'zip', + 'city', + 'icq', + 'jabber', + 'yahoo', + 'aol', + 'msn' + ); + + /** + * Protected constructor * * @return void */ @@ -35,7 +59,7 @@ class ShipSimuRegistration extends BaseRegistration { $this->setObjectDescription("Ship-Simu registration class"); // Create unique ID number - $this->createUniqueID(); + $this->generateUniqueId(); } /** @@ -47,19 +71,35 @@ class ShipSimuRegistration extends BaseRegistration { // Get a new instance $registrationInstance = new ShipSimuRegistration(); + // Initialize the filter chains + $registrationInstance->initFilterChains(); + // And return it return $registrationInstance; } /** - * Encrypt the given request key or throws an exception if the key was not + * Encrypt the given request key or throw an exception if the key was not * found in the request * * @param $requestKey Key in request class * @return void */ public function encryptPassword ($requestKey) { - $this->partialStub(sprintf("requestKey=%s", $requestKey)); + // Check if the password is found in the request + if ($this->getRequestInstance()->isRequestElementSet($requestKey)) { + // So encrypt the password and store it for later usage in + // the request: + + // 1.: Get the plain password + $plainPassword = $this->getRequestInstance()->getRequestElement($requestKey); + + // 2. Get a crypto helper and hash the password + $this->hashedPassword = ObjectFactory::createObjectByConfiguredName('crypto_class')->hashString($plainPassword); + + // 3. Store the hash back in the request + $this->getRequestInstance()->setRequestElement('pass_hash', $this->hashedPassword); + } } /** @@ -69,7 +109,8 @@ class ShipSimuRegistration extends BaseRegistration { * @return void */ public function doPreRegistration () { - $this->partialStub(); + // First run all pre filters + $this->executePreFilters(); } /** @@ -79,7 +120,11 @@ class ShipSimuRegistration extends BaseRegistration { * @return void */ public function registerNewUser () { - $this->partialStub(); + // Get a user database wrapper + $wrapperInstance = ObjectFactory::createObjectByConfiguredName('user_db_wrapper_class'); + + // Use this instance to insert the whole registration instance + $wrapperInstance->insertRegistrationObject($this); } /** @@ -88,7 +133,8 @@ class ShipSimuRegistration extends BaseRegistration { * @return void */ public function doPostRegistration () { - $this->partialStub(); + // First run all post filters + $this->executePostFilters(); } /** @@ -99,7 +145,49 @@ class ShipSimuRegistration extends BaseRegistration { * @return void */ public function doPostAction () { - $this->partialStub(); + // Get an action instance from our factory + $actionInstance = ObjectFactory::createObjectByConfiguredName('post_registration_class'); + + // Execute the action + $actionInstance->execute($this->getRequestInstance(), $this->getResponseInstance()); + } + + /** + * Adds registration elements to a given dataset instance + * + * @param $criteriaInstance An instance of a storeable criteria + * @return void + */ + public function addElementsToDataSet (StoreableCriteria $criteriaInstance) { + // Default is user account! + $configEntry = 'user_status_unconfirmed'; + + // Add a lot elements to the dataset criteria + foreach ($this->criteriaElements as $alias=>$element) { + // Do we have an alias? + if (is_string($alias)) { + // Yes, so use it + $criteriaInstance->addCriteria($alias, $this->getRequestInstance()->getRequestElement($element)); + } else { + // No, default entry + $criteriaInstance->addCriteria($element, $this->getRequestInstance()->getRequestElement($element)); + } + + // Is this a guest account? + if ((($element == "username") || ($alias == "username")) && ($this->getRequestInstance()->getRequestElement($element) == $this->getConfigInstance()->readConfig('guest_login_user'))) { + // Yes, then set the config entry to guest status + $configEntry = 'user_status_guest'; + } // END - if + } // END - foreach + + // Mark the username as unique key + $criteriaInstance->setUniqueKey('username'); + + // Add account status as configured + $criteriaInstance->addConfiguredCriteria('user_status', $configEntry); + + // Include registration timestamp + $criteriaInstance->addCriteria('registered', date("Y-m-d H:i:s", time())); } }