mirror of
https://github.com/renbaoshuo/S2OJ.git
synced 2024-11-10 13:08:41 +00:00
195 lines
7.2 KiB
PHP
195 lines
7.2 KiB
PHP
|
<?php
|
|||
|
if (!Auth::check()) {
|
|||
|
redirectToLogin();
|
|||
|
}
|
|||
|
function handlePost() {
|
|||
|
global $myUser;
|
|||
|
if (!isset($_POST['old_password']))
|
|||
|
{
|
|||
|
return '无效表单';
|
|||
|
}
|
|||
|
$old_password = $_POST['old_password'];
|
|||
|
if (!validatePassword($old_password) || !checkPassword($myUser, $old_password))
|
|||
|
{
|
|||
|
return "失败:密码错误。";
|
|||
|
}
|
|||
|
if ($_POST['ptag'])
|
|||
|
{
|
|||
|
$password = $_POST['password'];
|
|||
|
if (!validatePassword($password))
|
|||
|
{
|
|||
|
return "失败:无效密码。";
|
|||
|
}
|
|||
|
$password = getPasswordToStore($password, $myUser['username']);
|
|||
|
DB::update("update user_info set password = '$password' where username = '{$myUser['username']}'");
|
|||
|
}
|
|||
|
|
|||
|
$email = $_POST['email'];
|
|||
|
if (!validateEmail($email))
|
|||
|
{
|
|||
|
return "失败:无效电子邮箱。";
|
|||
|
}
|
|||
|
$esc_email = mysql_real_escape_string($email);
|
|||
|
DB::update("update user_info set email = '$esc_email' where username = '{$myUser['username']}'");
|
|||
|
|
|||
|
if ($_POST['Qtag'])
|
|||
|
{
|
|||
|
$qq = $_POST['qq'];
|
|||
|
if (!validateQQ($qq))
|
|||
|
{
|
|||
|
return "失败:无效QQ。";
|
|||
|
}
|
|||
|
$esc_qq = mysql_real_escape_string($qq);
|
|||
|
DB::update("update user_info set qq = '$esc_qq' where username = '{$myUser['username']}'");
|
|||
|
}
|
|||
|
else
|
|||
|
DB::update("update user_info set QQ = NULL where username = '{$myUser['username']}'");
|
|||
|
if ($_POST['sex'] == "U" || $_POST['sex'] == 'M' || $_POST['sex'] == 'F')
|
|||
|
{
|
|||
|
$sex = $_POST['sex'];
|
|||
|
$esc_sex = mysql_real_escape_string($sex);
|
|||
|
DB::update("update user_info set sex = '$esc_sex' where username = '{$myUser['username']}'");
|
|||
|
}
|
|||
|
|
|||
|
if (validateMotto($_POST['motto'])) {
|
|||
|
$esc_motto = DB::escape($_POST['motto']);
|
|||
|
DB::update("update user_info set motto = '$esc_motto' where username = '{$myUser['username']}'");
|
|||
|
}
|
|||
|
|
|||
|
return "ok";
|
|||
|
}
|
|||
|
if (isset($_POST['change'])) {
|
|||
|
die(handlePost());
|
|||
|
}
|
|||
|
?>
|
|||
|
<?php
|
|||
|
$REQUIRE_LIB['dialog'] = '';
|
|||
|
$REQUIRE_LIB['md5'] = '';
|
|||
|
?>
|
|||
|
<?php echoUOJPageHeader(UOJLocale::get('modify my profile')) ?>
|
|||
|
<h2 class="page-header"><?= UOJLocale::get('modify my profile') ?></h2>
|
|||
|
<form id="form-update" class="form-horizontal">
|
|||
|
<h4><?= UOJLocale::get('please enter your password for authorization') ?></h4>
|
|||
|
<div id="div-old_password" class="form-group">
|
|||
|
<label for="input-old_password" class="col-sm-2 control-label"><?= UOJLocale::get('password') ?></label>
|
|||
|
<div class="col-sm-3">
|
|||
|
<input type="password" class="form-control" name="old_password" id="input-old_password" placeholder="<?= UOJLocale::get('enter your password') ?>" maxlength="20" />
|
|||
|
<span class="help-block" id="help-old_password"></span>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<h4><?= UOJLocale::get('please enter your new profile') ?></h4>
|
|||
|
<div id="div-password" class="form-group">
|
|||
|
<label for="input-password" class="col-sm-2 control-label"><?= UOJLocale::get('new password') ?></label>
|
|||
|
<div class="col-sm-3">
|
|||
|
<input type="password" class="form-control" id="input-password" name="password" placeholder="<?= UOJLocale::get('enter your new password') ?>" maxlength="20" />
|
|||
|
<input type="password" class="form-control top-buffer-sm" id="input-confirm_password" placeholder="<?= UOJLocale::get('re-enter your new password') ?>" maxlength="20" />
|
|||
|
<span class="help-block" id="help-password"><?= UOJLocale::get('leave it blank if you do not want to change the password') ?></span>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div id="div-email" class="form-group">
|
|||
|
<label for="input-email" class="col-sm-2 control-label"><?= UOJLocale::get('email') ?></label>
|
|||
|
<div class="col-sm-3">
|
|||
|
<input type="email" class="form-control" name="email" id="input-email" value="<?=$myUser['email']?>" placeholder="<?= UOJLocale::get('enter your email') ?>" maxlength="50" />
|
|||
|
<span class="help-block" id="help-email"></span>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div id="div-qq" class="form-group">
|
|||
|
<label for="input-qq" class="col-sm-2 control-label"><?= UOJLocale::get('QQ') ?></label>
|
|||
|
<div class="col-sm-3">
|
|||
|
<input type="text" class="form-control" name="qq" id="input-qq" value="<?= $myUser['qq'] != 0 ? $myUser['qq'] : '' ?>" placeholder="<?= UOJLocale::get('enter your QQ') ?>" maxlength="50" />
|
|||
|
<span class="help-block" id="help-qq"></span>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div id="div-sex" class="form-group">
|
|||
|
<label for="input-sex" class="col-sm-2 control-label"><?= UOJLocale::get('sex') ?></label>
|
|||
|
<div class="col-sm-3">
|
|||
|
<select class="form-control" id="input-sex" name="sex">
|
|||
|
<option value="U"<?= Auth::user()['sex'] == 'U' ? ' selected="selected"' : ''?>><?= UOJLocale::get('refuse to answer') ?></option>
|
|||
|
<option value="M"<?= Auth::user()['sex'] == 'M' ? ' selected="selected"' : ''?>><?= UOJLocale::get('male') ?></option>
|
|||
|
<option value="F"<?= Auth::user()['sex'] == 'F' ? ' selected="selected"' : ''?>><?= UOJLocale::get('female') ?></option>
|
|||
|
</select>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div id="div-motto" class="form-group">
|
|||
|
<label for="input-motto" class="col-sm-2 control-label"><?= UOJLocale::get('motto') ?></label>
|
|||
|
<div class="col-sm-3">
|
|||
|
<textarea class="form-control" id="input-motto" name="motto"><?=HTML::escape($myUser['motto'])?></textarea>
|
|||
|
<span class="help-block" id="help-motto"></span>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="form-group">
|
|||
|
<div class="col-sm-offset-2 col-sm-3">
|
|||
|
<p class="form-control-static"><strong><?= UOJLocale::get('change avatar help') ?></strong></p>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="form-group">
|
|||
|
<div class="col-sm-offset-2 col-sm-3">
|
|||
|
<button type="submit" id="button-submit" class="btn btn-default"><?= UOJLocale::get('submit') ?></button>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</form>
|
|||
|
|
|||
|
<script type="text/javascript">
|
|||
|
function validateUpdatePost() {
|
|||
|
var ok = true;
|
|||
|
ok &= getFormErrorAndShowHelp('email', validateEmail);
|
|||
|
ok &= getFormErrorAndShowHelp('old_password', validatePassword);
|
|||
|
|
|||
|
if ($('#input-password').val().length > 0)
|
|||
|
ok &= getFormErrorAndShowHelp('password', validateSettingPassword);
|
|||
|
if ($('#input-qq').val().length > 0)
|
|||
|
ok &= getFormErrorAndShowHelp('qq', validateQQ);
|
|||
|
ok &= getFormErrorAndShowHelp('motto', validateMotto);
|
|||
|
return ok;
|
|||
|
}
|
|||
|
function submitUpdatePost() {
|
|||
|
if (!validateUpdatePost())
|
|||
|
return;
|
|||
|
$.post('/user/modify-profile', {
|
|||
|
change : '',
|
|||
|
etag : $('#input-email').val().length,
|
|||
|
ptag : $('#input-password').val().length,
|
|||
|
Qtag : $('#input-qq').val().length,
|
|||
|
email : $('#input-email').val(),
|
|||
|
password : md5($('#input-password').val(), "<?= getPasswordClientSalt() ?>"),
|
|||
|
old_password : md5($('#input-old_password').val(), "<?= getPasswordClientSalt() ?>"),
|
|||
|
qq : $('#input-qq').val(),
|
|||
|
sex : $('#input-sex').val(),
|
|||
|
motto : $('#input-motto').val()
|
|||
|
}, function(msg) {
|
|||
|
if (msg == 'ok') {
|
|||
|
BootstrapDialog.show({
|
|||
|
title : '修改成功',
|
|||
|
message : '用户信息修改成功',
|
|||
|
type : BootstrapDialog.TYPE_SUCCESS,
|
|||
|
buttons : [{
|
|||
|
label: '好的',
|
|||
|
action: function(dialog) {
|
|||
|
dialog.close();
|
|||
|
}
|
|||
|
}],
|
|||
|
onhidden : function(dialog) {
|
|||
|
window.location.href = '/user/profile/<?=$myUser['username']?>';
|
|||
|
}
|
|||
|
});
|
|||
|
} else {
|
|||
|
BootstrapDialog.show({
|
|||
|
title : '修改失败',
|
|||
|
message : msg,
|
|||
|
type : BootstrapDialog.TYPE_DANGER,
|
|||
|
buttons: [{
|
|||
|
label: '好的',
|
|||
|
action: function(dialog) {
|
|||
|
dialog.close();
|
|||
|
}
|
|||
|
}],
|
|||
|
});
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
$(document).ready(function(){$('#form-update').submit(function(e) {submitUpdatePost();e.preventDefault();});
|
|||
|
});
|
|||
|
</script>
|
|||
|
<?php echoUOJPageFooter() ?>
|
|||
|
|