IMPROVED Forgot your password? CT#1754

skala
Alberto Torreblanca 14 years ago
commit abb63d4ed2
  1. 57
      main/auth/lostPassword.php

@ -45,10 +45,10 @@ if (isset ($_GET['reset']) && isset ($_GET['id'])) {
} else {
$form = new FormValidator('lost_password');
$form->addElement('text', 'user', get_lang('User'), array('size'=>'40'));
$form->addElement('text', 'email', get_lang('Email'), array('size'=>'40'));
$form->addElement('text', 'user', get_lang('LoginOrEmailAddress'), array('size'=>'40'));
//$form->addElement('text', 'email', get_lang('Email'), array('size'=>'40'));
$form->applyFilter('email','strtolower');
//$form->applyFilter('email','strtolower');
$form->addElement('style_submit_button', 'submit', get_lang('Send'),'class="save"');
// setting the rules
@ -57,39 +57,42 @@ if (isset ($_GET['reset']) && isset ($_GET['id'])) {
if ($form->validate()) {
$values = $form->exportValues();
$user = $values['user'];
$email = $values['email'];
if(strpos($values['user'],'@')){
$user = strtolower($values['user']);
$email = TRUE;
} else {
$user = strtolower($values['user']);
$email = FALSE;
}
$condition = '';
if (!empty($email)) {
$condition = " AND LOWER(email) = '".Database::escape_string($email)."' ";
}
if ($email) {
$condition = "LOWER(email) = '".Database::escape_string($user)."' ";
} else {
$condition = "LOWER(username) = '".Database::escape_string($user)."'";
}
$tbl_user = Database :: get_main_table(TABLE_MAIN_USER);
$query = " SELECT user_id AS uid, lastname AS lastName, firstname AS firstName,
username AS loginName, password, email, status AS status,
official_code, phone, picture_uri, creator_id
FROM ".$tbl_user."
WHERE ( username = '".Database::escape_string($user)."' $condition ) ";
$query = "SELECT user_id AS uid, lastname AS lastName, firstname AS firstName, ".
"username AS loginName, password, email, status AS status, ".
"official_code, phone, picture_uri, creator_id ".
"FROM ".$tbl_user." ".
"WHERE ( $condition ) ";
$result = Database::query($query);
$num_rows = Database::num_rows($result);
if ($result && $num_rows > 0) {
if ($num_rows > 1) {
$by_username = false; // more than one user
while ($data = Database::fetch_array($result)) {
$user[] = $data;
}
} else {
$by_username = true; // single user (valid user + email)
$user = Database::fetch_array($result);
}
if ($userPasswordCrypted != 'none') {
Login::handle_encrypted_password($user, $by_username);
} else {
Login::send_password_to_user($user, $by_username);
}
$by_username = true;
// $user = Database::fetch_array($result);
$users = Database::store_result($result);
foreach( $users as $user ) {
if ($userPasswordCrypted != 'none') {
Login::handle_encrypted_password($user, $by_username);
} else {
Login::send_password_to_user($user, $by_username);
}
}
} else {
Display::display_error_message(get_lang('NoUserAccountWithThisEmailAddress'));
}

Loading…
Cancel
Save