[ 'name' => ' 个人资料', 'url' => "/user/{$user['username']}/edit/profile", ], 'password' => [ 'name' => ' 修改密码', 'url' => "/user/{$user['username']}/edit/password", ], 'privilege' => [ 'name' => ' 特权', 'url' => "/user/{$user['username']}/edit/privilege", ] ]; if (!isset($tabs_info[$cur_tab])) { become404Page(); } if ($cur_tab == 'profile') { $update_profile_form = new UOJBs4Form('update_profile'); $username = UOJLocale::get('username'); $avatar = UOJLocale::get('avatar'); $update_profile_form->appendHTML(<< $username 用户名不能被修改。 EOD); if (isSuperUser(Auth::user())) { $update_profile_form->addVInput( 'realname', 'text', UOJLocale::get('user::real name'), $user['realname'], function ($realname, &$vdata) { $vdata['realname'] = $realname; return ''; }, null ); } else { $real_name = UOJLocale::get('user::real name'); $update_profile_form->appendHTML(<< $real_name 只有管理员才能修改用户的真实姓名。 EOD); } if (isTmpUser($user)) { if (isSuperUser(Auth::user())) { $update_profile_form->addVInput( 'expiration_time', 'text', UOJLocale::get('user::expiration time'), $user['expiration_time'], function ($str, &$vdata) { try { $vdata['expiration_time'] = new DateTime($str); } catch (Exception $e) { return '无效时间格式'; } return ''; }, null ); } else { $expiration_time = UOJLocale::get('user::expiration time'); $update_profile_form->appendHTML(<< $expiration_time 只有管理员才能修改用户的账号过期时间。 EOD); } } $update_profile_form->addVCheckboxes('avatar_source', [ 'gravatar' => 'Gravatar', 'qq' => 'QQ', ], UOJLocale::get('user::avatar source'), $extra['avatar_source'] ?: 'gravatar'); $change_avatar_help = UOJLocale::get('change avatar help'); $update_profile_form->appendHTML(<< $change_avatar_help EOD); $update_profile_form->addVInput( 'email', 'email', UOJLocale::get('email'), $user['email'] ?: '', function ($email, &$vdata) { if ($email && !validateEmail($email)) { return 'Email 格式不合法。'; } $vdata['email'] = $email; return ''; }, null ); $update_profile_form->addVInput( 'qq', 'text', UOJLocale::get('QQ'), $user['qq'] == 0 ? '' : $user['qq'], function ($qq, &$vdata) { if ($qq && !validateQQ($qq)) { return 'QQ 格式不合法。'; } $vdata['qq'] = $qq; return ''; }, null ); $update_profile_form->addVInput( 'github', 'text', 'GitHub', $extra['social']['github'] ?: '', function ($github, &$vdata) { if ($github && !validateGitHubUsername($github)) { return 'GitHub 用户名不合法。'; } $vdata['github'] = $github; return ''; }, null ); if (isSuperUser(Auth::user())) { $update_profile_form->addVInput( 'school', 'text', UOJLocale::get('school'), $user['school'] ?: '', function ($school, &$vdata) { $vdata['school'] = $school; return ''; }, null ); } else { $school = UOJLocale::get('school'); $update_profile_form->appendHTML(<< $school 只有管理员才能修改用户所属学校。 EOD); } $update_profile_form->addVCheckboxes('sex', [ 'U' => UOJLocale::get('refuse to answer'), 'M' => UOJLocale::get('male'), 'F' => UOJLocale::get('female'), ], UOJLocale::get('sex'), $user['sex']); $update_profile_form->addVInput( 'motto', 'text', UOJLocale::get('motto'), $user['motto'] ?: '', function ($motto, &$vdata) { if (!validateMotto($motto)) { return '格言格式不合法'; } $vdata['motto'] = $motto; return ''; }, null ); $update_profile_form->addVInput( 'codeforces', 'text', UOJLocale::get('codeforces handle'), $extra['social']['codeforces'] ?: '', function ($codeforces, &$vdata) { if ($codeforces && !validateUsername($codeforces)) { return 'Codeforces 用户名格式不合法。'; } $vdata['codeforces'] = $codeforces; return ''; }, null ); $update_profile_form->addVInput( 'website', 'text', UOJLocale::get('user::website'), $extra['social']['website'] ?: '', function ($url, &$vdata) { if ($url && !validateURL($url)) { return '链接格式不合法。'; } $vdata['website'] = $url; return ''; }, null ); if ($user['usergroup'] == 'B') { $update_profile_form->appendHTML(<< 用户名颜色 被封禁的用户无法修改用户名颜色。 EOD); } else if ($user['usergroup'] == 'T') { $update_profile_form->appendHTML(<< 用户名颜色 临时用户无法修改用户名颜色。 EOD); } else { $additional_colors = []; if (isSuperUser($user)) { $additional_colors['#9d3dcf'] = '紫色 - #9d3dcf'; $additional_colors['#fe4c61'] = '红色 - #fe4c61'; } $update_profile_form->addVSelect('username_color', $additional_colors + [ '#0d6efd' => '蓝色 - #0d6efd', '#2da44e' => '绿色 - #2da44e', '#f48fb1' => '粉色 - #f48fb1', ], '用户名颜色', '#0d6efd'); } $update_profile_form->handle = function (&$vdata) use ($user) { $data = [ 'email' => $vdata['email'], 'qq' => $vdata['qq'], 'sex' => $_POST['sex'], 'motto' => $vdata['motto'], ]; if (isSuperUser(Auth::user())) { $data['realname'] = $vdata['realname']; $data['school'] = $vdata['school']; if (isTmpUser($user)) { $data['expiration_time'] = $vdata['expiration_time']->format(UOJTime::FORMAT); } } DB::update([ "update user_info", "set", $data, "where", ["username" => $user['username']] ]); DB::update([ "update user_info", "set", [ 'extra' => DB::json_set( 'extra', '$.avatar_source', $_POST['avatar_source'], '$.social.github', $vdata['github'], '$.social.codeforces', $vdata['codeforces'], '$.social.website', $vdata['website'], '$.username_color', $_POST['username_color'] ), ], "where", ["username" => $user['username']] ]); dieWithJsonData(['status' => 'success']); }; $update_profile_form->submit_button_config['class_str'] = 'btn btn-secondary mt-3'; $update_profile_form->submit_button_config['text'] = '更新'; $update_profile_form->setAjaxSubmit(<<runAtServer(); } elseif ($cur_tab == 'password') { if (isset($_POST['submit-change_password']) && $_POST['submit-change_password'] == 'change_password') { $old_password = $_POST['current_password']; $new_password = $_POST['new_password']; if (!validatePassword($old_password) || !checkPassword($user, $old_password)) { dieWithJsonData(['status' => 'error', 'message' => '旧密码错误']); } if (!validatePassword($new_password)) { dieWithJsonData(['status' => 'error', 'message' => '新密码不合法']); } if ($old_password == $new_password) { dieWithJsonData(['status' => 'error', 'message' => '新密码不能与旧密码相同']); } DB::update([ "update user_info", "set", [ 'password' => getPasswordToStore($new_password, $user['username']), ], "where", ["username" => $user['username']] ]); dieWithJsonData(['status' => 'success', 'message' => '密码修改成功']); } } elseif ($cur_tab == 'privilege') { $users_default_permissions = UOJContext::getMeta('users_default_permissions'); $type_text = UOJLocale::get('user::normal user'); if ($user['usergroup'] == 'S') { $type_text = UOJLocale::get('user::super user'); } elseif ($user['usergroup'] == 'T') { $type_text = UOJLocale::get('user::tmp user'); } elseif ($user['usergroup'] == 'B') { $type_text = UOJLocale::get('user::banned user'); } $disabled = !isSuperUser(Auth::user()); $update_user_permissions_form = new UOJForm('update_user_permissions'); if ($disabled) { $update_user_permissions_form->config['no_submit'] = true; } $update_user_permissions_form->appendHTML(HTML::tag('span', [], UOJLocale::get('user::user group'))); $update_user_permissions_form->appendHTML(HTML::tag('span', ['class' => 'd-inline-block ms-3'], $type_text)); $update_user_permissions_form->addSelect('user_type', [ 'label' => '账号类型', 'options' => [ 'student' => '学生', 'teacher' => '老师', 'system' => '系统', ], 'div_class' => 'my-3 row gy-2 gx-3 align-items-center', 'label_class' => 'form-label col-auto', 'select_class' => 'form-select w-auto col-auto', ]); $update_user_permissions_form->appendHTML(HTML::tag('h3', ['class' => 'h5 mt-3'], '题目')); $update_user_permissions_form->addCheckbox('problems__view', [ 'checked' => $extra['permissions']['problems']['view'], 'label' => '查看题目', 'role' => 'switch', 'help' => '', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('problems__download_testdata', [ 'checked' => $extra['permissions']['problems']['download_testdata'], 'label' => '下载测试数据', 'role' => 'switch', 'help' => '请谨慎开启此权限,以防数据泄露。', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('problems__create', [ 'checked' => $extra['permissions']['problems']['create'], 'label' => '新建题目', 'role' => 'switch', 'help' => '', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('problems__manage', [ 'checked' => $extra['permissions']['problems']['manage'], 'label' => '管理题目', 'role' => 'switch', 'help' => '若用户不具有「新建题目」权限,则只能对现有题目进行管理。', 'disabled' => $disabled, ]); $update_user_permissions_form->appendHTML(HTML::tag('h3', ['class' => 'h5 mt-3'], '比赛')); $update_user_permissions_form->addCheckbox('contests__view', [ 'checked' => $extra['permissions']['contests']['view'], 'label' => '查看比赛', 'role' => 'switch', 'help' => '若用户不具有此权限,则只显示已报名过的比赛列表及详情。', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('contests__register', [ 'checked' => $extra['permissions']['contests']['register'], 'label' => '报名比赛', 'role' => 'switch', 'help' => '', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('contests__create', [ 'checked' => $extra['permissions']['contests']['create'], 'label' => '新建比赛', 'role' => 'switch', 'help' => '', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('contests__start_final_test', [ 'checked' => $extra['permissions']['contests']['start_final_test'], 'label' => '开始比赛最终测试', 'role' => 'switch', 'help' => '拥有此权限的用户可以代为开始比赛最终测试。', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('contests__manage', [ 'checked' => $extra['permissions']['contests']['manage'], 'label' => '管理比赛', 'role' => 'switch', 'help' => '若用户不具有「新建比赛」权限,则只能对现有比赛进行管理。', 'disabled' => $disabled, ]); $update_user_permissions_form->appendHTML(HTML::tag('h3', ['class' => 'h5 mt-3'], '题单')); $update_user_permissions_form->addCheckbox('lists__view', [ 'checked' => $extra['permissions']['lists']['view'], 'label' => '查看题单', 'role' => 'switch', 'help' => '', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('lists__create', [ 'checked' => $extra['permissions']['lists']['create'], 'label' => '新建题单', 'role' => 'switch', 'help' => '', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('lists__manage', [ 'checked' => $extra['permissions']['lists']['manage'], 'label' => '管理题单', 'role' => 'switch', 'help' => '若用户不具有「新建题单」权限,则只能对现有题单进行管理。', 'disabled' => $disabled, ]); $update_user_permissions_form->appendHTML(HTML::tag('h3', ['class' => 'h5 mt-3'], '小组')); $update_user_permissions_form->addCheckbox('groups__view', [ 'checked' => $extra['permissions']['groups']['view'], 'label' => '查看小组', 'role' => 'switch', 'help' => '', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('groups__create', [ 'checked' => $extra['permissions']['groups']['create'], 'label' => '新建小组', 'role' => 'switch', 'help' => '', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('groups__manage', [ 'checked' => $extra['permissions']['groups']['manage'], 'label' => '管理小组', 'role' => 'switch', 'help' => '若用户不具有「新建小组」权限,则只能对现有小组进行管理。', 'disabled' => $disabled, ]); $update_user_permissions_form->appendHTML(HTML::tag('h3', ['class' => 'h5 mt-3'], '博客')); $update_user_permissions_form->addCheckbox('blogs__view', [ 'checked' => $extra['permissions']['blogs']['view'], 'label' => '查看博客', 'role' => 'switch', 'help' => '', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('blogs__create', [ 'checked' => $extra['permissions']['blogs']['create'], 'label' => '新建博客', 'role' => 'switch', 'help' => '', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('blogs__manage', [ 'checked' => $extra['permissions']['blogs']['manage'], 'label' => '管理博客', 'role' => 'switch', 'help' => '若用户不具有「新建博客」权限,则只能对现有博客进行管理。', 'disabled' => $disabled, ]); $update_user_permissions_form->appendHTML(HTML::tag('h3', ['class' => 'h5 mt-3'], '用户')); $update_user_permissions_form->addCheckbox('users__view', [ 'checked' => $extra['permissions']['users']['view'], 'label' => '查看用户', 'role' => 'switch', 'help' => '若用户不具有此权限,则不能查看他人的个人资料。', 'disabled' => $disabled, ]); $update_user_permissions_form->addCheckbox('users__upload_image', [ 'checked' => $extra['permissions']['users']['upload_image'], 'label' => '上传图片', 'role' => 'switch', 'help' => '若用户不具有此权限,则不能使用图床功能。', 'disabled' => $disabled, ]); $update_user_permissions_form->setAjaxSubmit(<<handle = function () use ($user, $extra, $users_default_permissions) { $new_permissions = [ '_placeholder' => '', 'problems' => [ '_placeholder' => '', // 'view' => isset($_POST['problems__view']), // 'download_testdata' => isset($_POST['problems__download_testdata']), // 'create' => isset($_POST['problems__create']), // 'manage' => isset($_POST['problems__manage']), ], 'contests' => [ '_placeholder' => '', // 'view' => isset($_POST['contests__view']), // 'register' => isset($_POST['contests__register']), // 'create' => isset($_POST['contests__create']), // 'start_final_test' => isset($_POST['contests__start_final_test']), // 'manage' => isset($_POST['contests__manage']), ], 'lists' => [ '_placeholder' => '', // 'view' => isset($_POST['lists__view']), // 'create' => isset($_POST['lists__create']), // 'manage' => isset($_POST['lists__manage']), ], 'groups' => [ '_placeholder' => '', // 'view' => isset($_POST['groups__view']), // 'create' => isset($_POST['groups__create']), // 'manage' => isset($_POST['groups__manage']), ], 'blogs' => [ '_placeholder' => '', // 'view' => isset($_POST['blogs__view']), // 'create' => isset($_POST['blogs__create']), // 'manage' => isset($_POST['blogs__manage']), ], 'users' => [ '_placeholder' => '', ] ]; if (isset($_POST['problems__view']) && !$users_default_permissions['problems']['view']) { $new_permissions['problems']['view'] = true; } elseif (!isset($_POST['problems__view']) && $users_default_permissions['problems']['view']) { $new_permissions['problems']['view'] = false; } if (isset($_POST['problems__download_testdata']) && !$users_default_permissions['problems']['download_testdata']) { $new_permissions['problems']['download_testdata'] = true; } elseif (!isset($_POST['problems__download_testdata']) && $users_default_permissions['problems']['download_testdata']) { $new_permissions['problems']['download_testdata'] = false; } if (isset($_POST['problems__create']) && !$users_default_permissions['problems']['create']) { $new_permissions['problems']['create'] = true; } elseif (!isset($_POST['problems__create']) && $users_default_permissions['problems']['create']) { $new_permissions['problems']['create'] = false; } if (isset($_POST['problems__manage']) && !$users_default_permissions['problems']['manage']) { $new_permissions['problems']['manage'] = true; } elseif (!isset($_POST['problems__manage']) && $users_default_permissions['problems']['manage']) { $new_permissions['problems']['manage'] = false; } if (isset($_POST['contests__view']) && !$users_default_permissions['contests']['view']) { $new_permissions['contests']['view'] = true; } elseif (!isset($_POST['contests__view']) && $users_default_permissions['contests']['view']) { $new_permissions['contests']['view'] = false; } if (isset($_POST['contests__register']) && !$users_default_permissions['contests']['register']) { $new_permissions['contests']['register'] = true; } elseif (!isset($_POST['contests__register']) && $users_default_permissions['contests']['register']) { $new_permissions['contests']['register'] = false; } if (isset($_POST['contests__create']) && !$users_default_permissions['contests']['create']) { $new_permissions['contests']['create'] = true; } elseif (!isset($_POST['contests__create']) && $users_default_permissions['contests']['create']) { $new_permissions['contests']['create'] = false; } if (isset($_POST['contests__start_final_test']) && !$users_default_permissions['contests']['start_final_test']) { $new_permissions['contests']['start_final_test'] = true; } elseif (!isset($_POST['contests__start_final_test']) && $users_default_permissions['contests']['start_final_test']) { $new_permissions['contests']['start_final_test'] = false; } if (isset($_POST['contests__manage']) && !$users_default_permissions['contests']['manage']) { $new_permissions['contests']['manage'] = true; } elseif (!isset($_POST['contests__manage']) && $users_default_permissions['contests']['manage']) { $new_permissions['contests']['manage'] = false; } if (isset($_POST['lists__view']) && !$users_default_permissions['lists']['view']) { $new_permissions['lists']['view'] = true; } elseif (!isset($_POST['lists__view']) && $users_default_permissions['lists']['view']) { $new_permissions['lists']['view'] = false; } if (isset($_POST['lists__create']) && !$users_default_permissions['lists']['create']) { $new_permissions['lists']['create'] = true; } elseif (!isset($_POST['lists__create']) && $users_default_permissions['lists']['create']) { $new_permissions['lists']['create'] = false; } if (isset($_POST['lists__manage']) && !$users_default_permissions['lists']['manage']) { $new_permissions['lists']['manage'] = true; } elseif (!isset($_POST['lists__manage']) && $users_default_permissions['lists']['manage']) { $new_permissions['lists']['manage'] = false; } if (isset($_POST['groups__view']) && !$users_default_permissions['groups']['view']) { $new_permissions['groups']['view'] = true; } elseif (!isset($_POST['groups__view']) && $users_default_permissions['groups']['view']) { $new_permissions['groups']['view'] = false; } if (isset($_POST['groups__create']) && !$users_default_permissions['groups']['create']) { $new_permissions['groups']['create'] = true; } elseif (!isset($_POST['groups__create']) && $users_default_permissions['groups']['create']) { $new_permissions['groups']['create'] = false; } if (isset($_POST['groups__manage']) && !$users_default_permissions['groups']['manage']) { $new_permissions['groups']['manage'] = true; } elseif (!isset($_POST['groups__manage']) && $users_default_permissions['groups']['manage']) { $new_permissions['groups']['manage'] = false; } if (isset($_POST['blogs__view']) && !$users_default_permissions['blogs']['view']) { $new_permissions['blogs']['view'] = true; } elseif (!isset($_POST['blogs__view']) && $users_default_permissions['blogs']['view']) { $new_permissions['blogs']['view'] = false; } if (isset($_POST['blogs__create']) && !$users_default_permissions['blogs']['create']) { $new_permissions['blogs']['create'] = true; } elseif (!isset($_POST['blogs__create']) && $users_default_permissions['blogs']['create']) { $new_permissions['blogs']['create'] = false; } if (isset($_POST['blogs__manage']) && !$users_default_permissions['blogs']['manage']) { $new_permissions['blogs']['manage'] = true; } elseif (!isset($_POST['blogs__manage']) && $users_default_permissions['blogs']['manage']) { $new_permissions['blogs']['manage'] = false; } if (isset($_POST['users__view']) && !$users_default_permissions['users']['view']) { $new_permissions['users']['view'] = true; } elseif (!isset($_POST['users__view']) && $users_default_permissions['users']['view']) { $new_permissions['users']['view'] = false; } if (isset($_POST['users__upload_image']) && !$users_default_permissions['users']['upload_image']) { $new_permissions['users']['upload_image'] = true; } elseif (!isset($_POST['users__upload_image']) && $users_default_permissions['users']['upload_image']) { $new_permissions['users']['upload_image'] = false; } $extra['permissions'] = $new_permissions; DB::update([ "update user_info", "set", [ "usertype" => $_POST['user_type'], "extra" => json_encode($extra), ], "where", [ "username" => $user['username'], ], ]); dieWithJsonData(['status' => 'success', 'message' => '']); }; $update_user_permissions_form->runAtServer(); } $pageTitle = $user['username'] == Auth::id() ? UOJLocale::get('modify my profile') : UOJLocale::get('modify his profile', $user['username']) ?> = $pageTitle ?> = HTML::navListGroup($tabs_info, $cur_tab) ?> "> 返回 您正在使用管理特权查看并编辑其它用户的资料。 printHTML() ?> = UOJLocale::get('current password') ?> = UOJLocale::get('new password') ?> = UOJLocale::get('confirm new password') ?> 如需重置其他用户的密码,请前往 系统管理 页面操作。 更新 关于各项权限的详细解释,请查看 权限管理 文档。 printHTML() ?>
关于各项权限的详细解释,请查看 权限管理 文档。