S2OJ/web/app/controllers/reset_pw.php

153 lines
4.2 KiB
PHP
Raw Normal View History

2016-07-19 00:39:37 +08:00
<?php
2023-02-05 20:36:06 +08:00
requireLib('dialog');
requireLib('md5');
2023-01-15 20:01:37 +08:00
if (!isset($_GET['p'])) {
become404Page();
}
list($username, $check_code) = explode('.', base64url_decode($_GET['p']));
$user = UOJUser::query($username);
if (!$user) become404Page();
if (!isset($check_code) || strlen($check_code) != 32) become404Page();
$extra = UOJUser::getExtra($user);
if ($check_code !== $extra['reset_password_check_code']) {
become404Page();
}
if (UOJTime::str2time($extra['reset_password_time'])->add(new DateInterval('P3D')) < UOJTime::$time_now) {
becomeMsgPage('链接已过期');
}
function resetPassword() {
global $user;
if (!isset($_POST['newPW']) || !validatePassword($_POST['newPW'])) {
return '操作失败,无效密码';
2016-07-19 00:39:37 +08:00
}
2023-01-15 20:01:37 +08:00
$newPW = $_POST['newPW'];
$newPW = getPasswordToStore($newPW, $user['username']);
2023-05-02 18:28:59 +08:00
$oj_name = UOJConfig::$data['profile']['oj-name'];
$oj_name_short = UOJConfig::$data['profile']['oj-name-short'];
$name = $user['username'];
$remote_addr = UOJContext::remoteAddr();
$http_x_forwarded_for = UOJContext::httpXForwardedFor();
$user_agent = UOJContext::httpUserAgent();
if ($user['realname']) {
$name .= ' (' . $user['realname'] . ')';
}
sendEmail($user['username'], "密码被重置", <<<EOD
<p>您刚刚重置了您在 {$oj_name_short} 上账号的密码。如果这是您进行的操作,请忽略本邮件。如果您没有请求重置密码,请立即联系管理员进行处理。</p>
<ul>
<li>请求 IP: {$remote_addr}</li>
<li>转发源 IP: {$http_x_forwarded_for} </li>
<li>用户代理: {$user_agent}</li>
</ul>
EOD, 5);
2023-01-15 20:01:37 +08:00
DB::update([
"update user_info",
"set", [
"password" => $newPW,
2023-02-13 15:45:06 +08:00
"remember_token" => '',
2023-01-15 20:01:37 +08:00
"extra" => DB::json_remove('extra', '$.reset_password_check_code', '$.reset_password_time'),
],
"where", [
"username" => $user['username'],
],
]);
return 'ok';
}
if (isset($_POST['reset'])) {
die(resetPassword());
}
?>
2023-02-05 20:36:06 +08:00
<?php echoUOJPageHeader(UOJLocale::get('reset password')) ?>
<form id="form-reset" class="card mw-100 mx-auto" style="width:600px">
<div class="card-body">
<h1 class="card-title text-center mb-3">
<?= UOJLocale::get('reset password') ?>
</h1>
<div class="mb-1">
<label for="input-username" class="form-label"><?= UOJLocale::get('username') ?></label>
<input type="text" class="form-control" value="<?= $user['username'] ?>" disabled />
2016-07-19 00:39:37 +08:00
</div>
2023-02-05 20:36:06 +08:00
<div id="div-password" class="mb-1">
<label for="input-password" class="form-label">
<?= UOJLocale::get('new password') ?>
</label>
<input type="password" class="form-control" id="input-password" name="password" placeholder="<?= UOJLocale::get('enter your password') ?>" maxlength="20" />
<input type="password" class="form-control mt-2" id="input-confirm_password" placeholder="<?= UOJLocale::get('re-enter your password') ?>" maxlength="20" />
<span class="help-block invalid-feedback" id="help-password"></span>
</div>
<div class="text-center">
<button type="submit" id="button-submit" class="btn btn-primary">
<?= UOJLocale::get('submit') ?>
</button>
2023-01-15 20:01:37 +08:00
</div>
</div>
2016-07-19 00:39:37 +08:00
</form>
<script type="text/javascript">
2023-01-15 20:01:37 +08:00
function validateResetPwPost() {
var ok = true;
ok &= getFormErrorAndShowHelp('password', validateSettingPassword);
return ok;
}
2023-02-05 20:36:06 +08:00
2023-01-15 20:01:37 +08:00
$(document).ready(function() {
$('#form-reset').submit(function(e) {
if (!validateResetPwPost()) {
return false;
}
2023-02-05 20:36:06 +08:00
$.post(<?= json_encode(UOJContext::requestURI()) ?>, {
2023-01-15 20:01:37 +08:00
reset: '',
newPW: md5($('#input-password').val(), "<?= getPasswordClientSalt() ?>")
}, function(res) {
if (res == 'ok') {
BootstrapDialog.show({
title: '提示',
message: '密码更改成功',
type: BootstrapDialog.TYPE_SUCCESS,
buttons: [{
label: '好的',
action: function(dialog) {
dialog.close();
}
}],
onhidden: function(dialog) {
window.location.href = '/login';
2016-07-19 00:39:37 +08:00
}
2023-01-15 20:01:37 +08:00
});
} else {
BootstrapDialog.show({
title: '提示',
message: res,
type: BootstrapDialog.TYPE_DANGER,
buttons: [{
2016-07-19 00:39:37 +08:00
label: '好的',
action: function(dialog) {
dialog.close();
}
2023-01-15 20:01:37 +08:00
}]
});
}
});
return false;
2016-07-19 00:39:37 +08:00
});
});
</script>
2023-02-05 20:36:06 +08:00
2016-07-19 00:39:37 +08:00
<?php echoUOJPageFooter() ?>