function processInput($fieldValues, $expectedValues) { global $eppnRealm; $skv = array(); foreach ($expectedValues as $db => $field) { switch ($db) { case "cn": $hookfile = SimpleSAML_Module::getModuleDir('selfregister') . '/hooks/hook_attributes.php'; include_once $hookfile; $skv[$db] = get_cn_hook($fieldValues); break; case "userPassword": $skv[$db] = sspmod_selfregister_Util::validatePassword($fieldValues); break; // case "eduPersonPrincipalName": // $skv[$db] = $fieldValues['uid'].'@'.$eppnRealm; // break; // case "eduPersonPrincipalName": // $skv[$db] = $fieldValues['uid'].'@'.$eppnRealm; // break; case "mail": if (array_key_exists('token', $_POST)) { global $tokenLifetime; $tg = new SimpleSAML_Auth_TimeLimitedToken($tokenLifetime); $email = $_POST['emailconfirmed']; $tg->addVerificationData($email); $token = $_POST['token']; if (!$tg->validate_token($token)) { throw new sspmod_selfregister_Error_UserException('invalid_token'); } $skv[$db] = $email; } break; default: $skv[$db] = $fieldValues[$field]; } } return $skv; }
// Add or update user object $listValidate = array('pw1', 'pw2'); $validator = new sspmod_selfregister_Registration_Validation($formFields, $listValidate); $email = filter_input(INPUT_POST, 'emailconfirmed', FILTER_VALIDATE_EMAIL); if (!$email) { throw new SimpleSAML_Error_Exception('E-mail parameter in request is lost'); } $tg = new SimpleSAML_Auth_TimeLimitedToken($tokenLifetime); $tg->addVerificationData($email); $token = $_REQUEST['token']; if (!$tg->validate_token($token)) { throw new sspmod_selfregister_Error_UserException('invalid_token'); } $userValues = $store->findAndGetUser('mail', $email); $validValues = $validator->validateInput(); $newPw = sspmod_selfregister_Util::validatePassword($validValues); $store->changeUserPassword($userValues[$store->userIdAttr], $newPw); $html = new SimpleSAML_XHTML_Template($config, 'selfregister:lostPassword_complete.tpl.php', 'selfregister:selfregister'); $html->show(); } catch (sspmod_selfregister_Error_UserException $e) { // Some user error detected $formGen = new sspmod_selfregister_XHTML_Form($formFields, 'lostPassword.php'); $showFields = array('pw1', 'pw2'); $formGen->fieldsToShow($showFields); $hidden = array(); $hidden['emailconfirmed'] = $_REQUEST['emailconfirmed']; $hidden['token'] = $_REQUEST['token']; $formGen->addHiddenData($hidden); $formGen->setValues(array($store->userIdAttr => $_REQUEST[$store->userIdAttr])); $formGen->setSubmitter('submit_change'); $formHtml = $formGen->genFormHtml();