コード例 #1
0
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;
}
コード例 #2
0
     // 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();