File size: 4.93Kb
<?
include_once 'sys/inc/start.php';
include_once 'sys/inc/compress.php';
include_once 'sys/inc/sess.php';
include_once 'sys/inc/home.php';
include_once 'sys/inc/settings.php';
include_once 'sys/inc/db_connect.php';
include_once 'sys/inc/ipua.php';
include_once 'sys/inc/fnc.php';
include_once 'sys/inc/shif.php';
$show_all=true;
include_once 'sys/inc/user.php';
only_unreg();
$set['title']='Восстановление пароля';
include_once 'sys/inc/thead.php';
title();
if (isset($_POST['nick']) && isset($_POST['mail']) && $_POST['nick']!=NULL && $_POST['mail']!=NULL){
if (mysql_result(mysql_query("SELECT COUNT(*) FROM `user` WHERE `nick` = '".my_esc($_POST['nick'])."'"), 0)==0){
$err = "Пользователь с таким логином не зарегистрирован";
}
elseif (mysql_result(mysql_query("SELECT COUNT(*) FROM `user` WHERE `nick` = '".my_esc($_POST['nick'])."' AND `ank_mail` = '".my_esc($_POST['mail'])."'"), 0)==0)
{
$err ='Неверный адрес E-mail или информация о E-mail отсутствует';
}else{
$q = mysql_query("SELECT * FROM `user` WHERE `nick` = '".my_esc($_POST['nick'])."' LIMIT 1");
$user2 = mysql_fetch_assoc($q);
$new_sess=substr(md5(passgen()), 0, 20);
$subject = "Восстановление пароля";
$regmail = "Здравствуйте $user2[nick]<br />
Вы активировали восстановление пароля<br />
Для установки нового пароля перейдите по ссылке:<br />
<a href='http://$_SERVER[HTTP_HOST]/pass.php?id=$user2[id]&set_new=$new_sess'>http://$_SERVER[HTTP_HOST]/pass.php?id=$user2[id]&set_new=$new_sess</a><br />
Данная ссылка действительна до первой авторизации под своим логином ($user2[nick])<br />
С уважением, администрация сайта<br />";
$adds="From: \"password@$_SERVER[HTTP_HOST]\" <password@$_SERVER[HTTP_HOST]>\n";
$adds .= "Content-Type: text/html; charset=utf-8\n";
mail($user2['ank_mail'],'=?utf-8?B?'.base64_encode($subject).'?=',$regmail,$adds);
mysql_query("UPDATE `user` SET `sess` = '$new_sess' WHERE `id` = '$user2[id]' LIMIT 1");
msg("Ссылка для установки нового пароля отправлена на e-mail \"$user2[ank_mail]\"");
}
}
if (isset($_GET['id']) && isset($_GET['set_new']) && strlen($_GET['set_new'])==20 &&
mysql_result(mysql_query("SELECT COUNT(*) FROM `user` WHERE `id` = '".intval($_GET['id'])."' AND `sess` = '".my_esc($_GET['set_new'])."'"), 0)==1)
{
$q = mysql_query("SELECT * FROM `user` WHERE `id` = '".intval($_GET['id'])."' LIMIT 1");
$user2 = mysql_fetch_assoc($q);
if (isset($_POST['pass1']) && isset($_POST['pass2'])){
if ($_POST['pass1']==$_POST['pass2']){
if (strlen2($_POST['pass1'])<6)$err='По соображениям безопасности новый пароль не может быть короче 6-ти символов';
if (strlen2($_POST['pass1'])>32)$err='Длина пароля превышает 32 символа';
}
else $err='Новый пароль не совпадает с подтверждением';
if (!isset($err)){
setcookie('id_user', $user2['id'], time()+60*60*24*365);
mysql_query("UPDATE `user` SET `pass` = '".shif($_POST['pass1'])."' WHERE `id` = '$user2[id]' LIMIT 1");
setcookie('pass', cookie_encrypt($_POST['pass1'],$user2['id']), time()+60*60*24*365);
msg('Пароль успешно изменен');
}
}
err();
aut();
echo '<div class="menu">';
echo "<form action='/pass.php?id=$user2[id]&set_new=".esc($_GET['set_new'],1)."&$passgen' method=\"post\">\n";
echo '<div class="input_f">
<div class="input_b">
<div class="input_l" style="padding: 10px 25px 10px 25px;">Логин</div>
</div>
<input class="input_t" type="text" value="'.$user2[nick].'" disabled="disabled" maxlength="32">
</div>
<div class="input_f">
<div class="input_b">
<div class="input_l" style="padding: 10px 25px 10px 25px;">Пароль</div>
</div>
<input class="input_t" type="text" name="pass1" value="'.$user2[nick].'" maxlength="32">
</div>
<div class="input_f">
<div class="input_b">
<div class="input_l" style="padding: 10px 25px 10px 25px;">Повторите</div>
</div>
<input class="input_t" type="text" name="pass2" value="'.$user2[nick].'" maxlength="32">
</div>
<input type="submit" name="save" value="Сохранить">
</form>';
}else{
err();
aut();
echo '<div class="menu">';
echo "<form action=\"?$passgen\" method=\"post\">\n";
echo '<div class="input_f">
<div class="input_b">
<div class="input_l" style="padding: 10px 25px 10px 25px;">Логин</div>
</div>
<input class="input_t" type="text" name="nick" maxlength="32">
</div>
<div class="input_f">
<div class="input_b">
<div class="input_l" style="padding: 10px 26px 10px 26px;">Email</div>
</div>
<input class="input_t" type="text" name="mail" maxlength="32">
</div>
<input type="submit" value="Продолжить">
</form>';
}
include_once 'sys/inc/tfoot.php';
?>