X-Git-Url: https://git.mxchange.org/?p=shipsimu.git;a=blobdiff_plain;f=application%2Fship-simu%2Fmain%2Fregistration%2Fclass_ShipSimuRegistration.php;h=1ad97313716eb84008af5695ac96c2f0939e7c10;hp=a6639c5688f00013960e4a98054fc32b9c279b7c;hb=abb8bf6be9f5238f8a4552707bcb190f0dbf0b7a;hpb=7f126edad9d95a1bf63bb828fd7e0b54bfa3aa74 diff --git a/application/ship-simu/main/registration/class_ShipSimuRegistration.php b/application/ship-simu/main/registration/class_ShipSimuRegistration.php index a6639c5..1ad9731 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 * @@ -28,19 +28,32 @@ class ShipSimuRegistration extends BaseRegistration { private $hashedPassword = ""; /** - * Private constructor + * 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 */ protected function __construct () { // Call parent constructor parent::__construct(__CLASS__); - - // Set part description - $this->setObjectDescription("Ship-Simu registration class"); - - // Create unique ID number - $this->createUniqueID(); } /** @@ -52,6 +65,9 @@ class ShipSimuRegistration extends BaseRegistration { // Get a new instance $registrationInstance = new ShipSimuRegistration(); + // Initialize the filter chains + $registrationInstance->initFilterChains(); + // And return it return $registrationInstance; } @@ -68,10 +84,13 @@ class ShipSimuRegistration extends BaseRegistration { 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_heler')->hashPassword($plainPassword); + $this->hashedPassword = ObjectFactory::createObjectByConfiguredName('crypto_class')->hashString($plainPassword); + // 3. Store the hash back in the request $this->getRequestInstance()->setRequestElement('pass_hash', $this->hashedPassword); } @@ -84,7 +103,8 @@ class ShipSimuRegistration extends BaseRegistration { * @return void */ public function doPreRegistration () { - $this->partialStub(); + // First run all pre filters + $this->executePreFilters(); } /** @@ -94,7 +114,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); } /** @@ -103,7 +127,8 @@ class ShipSimuRegistration extends BaseRegistration { * @return void */ public function doPostRegistration () { - $this->partialStub(); + // First run all post filters + $this->executePostFilters(); } /** @@ -114,7 +139,55 @@ 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 unconfirmed! + $configEntry = 'user_status_unconfirmed'; + + // Is the confirmation process entirely disabled? + if ($this->getConfigInstance()->readConfig('confirm_email_enabled') === "N") { + // No confirmation of email needed + $configEntry = 'user_status_confirmed'; + } // END - if + + // 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(UserDatabaseWrapper::DB_COLUMN_USERNAME); + + // Add account status as configured + $criteriaInstance->addConfiguredCriteria(UserDatabaseWrapper::DB_COLUMN_USER_STATUS, $configEntry); + + // Include registration timestamp + $criteriaInstance->addCriteria("registered", date("Y-m-d H:i:s", time())); } }