Compare commits

..

2 Commits

Author SHA1 Message Date
0804bcb14b
feat: display ip from http_x_forwarded_for
All checks were successful
continuous-integration/drone/push Build is passing
2022-09-21 14:39:09 +08:00
8754b60958
feat: force set user participated 2022-09-21 14:34:16 +08:00

View File

@ -113,6 +113,40 @@
updateContestPlayerNum($contest); updateContestPlayerNum($contest);
}; };
$remove_user_from_contest_form->runAtServer(); $remove_user_from_contest_form->runAtServer();
$force_set_user_participated_form = new UOJForm('force_set_user_participated');
$force_set_user_participated_form->addInput('force_set_username', 'text', '用户名', '',
function ($x) {
global $contest;
if (!validateUsername($x)) {
return '用户名不合法';
}
$user = queryUser($x);
if (!$user) {
return '用户不存在';
}
if (!hasRegistered($user, $contest)) {
return '该用户未报名';
}
return '';
},
null
);
$force_set_user_participated_form->submit_button_config['align'] = 'compressed';
$force_set_user_participated_form->submit_button_config['text'] = '强制参赛';
$force_set_user_participated_form->submit_button_config['class_str'] = 'mt-2 btn btn-warning';
$force_set_user_participated_form->handle = function() {
global $contest;
$username = $_POST['force_set_username'];
DB::query("update contests_registrants set has_participated = 1 where username = '{$username}' and contest_id = {$contest['id']}");
updateContestPlayerNum($contest);
};
$force_set_user_participated_form->runAtServer();
} }
$has_contest_permission = hasContestPermission($myUser, $contest); $has_contest_permission = hasContestPermission($myUser, $contest);
@ -153,12 +187,16 @@
<?php <?php
if ($show_ip) { if ($show_ip) {
$header_row = '<tr><th>#</th><th>'.UOJLocale::get('username').'</th><th>remote_addr</th></tr>'; $header_row = '<tr><th>#</th><th>'.UOJLocale::get('username').'</th><th>remote_addr</th><th>http_x_forwarded_for</th><th>是否参赛</th></tr>';
$ip_owner = array(); $ip_owner = array();
$forwarded_ip_owner = array();
$has_participated = array();
foreach (DB::selectAll("select * from contests_registrants where contest_id = {$contest['id']} order by username desc") as $reg) { foreach (DB::selectAll("select * from contests_registrants where contest_id = {$contest['id']} order by username desc") as $reg) {
$user = queryUser($reg['username']); $user = queryUser($reg['username']);
$ip_owner[$user['remote_addr']] = $reg['username']; $ip_owner[$user['remote_addr']] = $reg['username'];
$forwarded_ip_owner[$user['http_x_forwarded_for']] = $reg['username'];
$has_participated[$reg['username']] = $reg['has_participated'];
} }
} else { } else {
$header_row = '<tr><th>#</th><th>'.UOJLocale::get('username').'</th></tr>'; $header_row = '<tr><th>#</th><th>'.UOJLocale::get('username').'</th></tr>';
@ -168,14 +206,14 @@
$header_row, $header_row,
function($contest, $num) { function($contest, $num) {
global $myUser; global $myUser;
global $show_ip, $ip_owner; global $show_ip, $ip_owner, $has_participated;
$user = queryUser($contest['username']); $user = queryUser($contest['username']);
$user_link = getUserLink($contest['username']); $user_link = getUserLink($contest['username']);
if (!$show_ip) { if (!$show_ip) {
echo '<tr>'; echo '<tr>';
} else { } else {
if ($ip_owner[$user['remote_addr']] != $user['username']) { if ($ip_owner[$user['remote_addr']] != $user['username'] || $forwarded_ip_owner[$user['http_x_forwarded_for']] != $user['username']) {
echo '<tr class="danger">'; echo '<tr class="danger">';
} else { } else {
echo '<tr>'; echo '<tr>';
@ -185,13 +223,18 @@
echo '<td>'.$user_link.'</td>'; echo '<td>'.$user_link.'</td>';
if ($show_ip) { if ($show_ip) {
echo '<td>'.$user['remote_addr'].'</td>'; echo '<td>'.$user['remote_addr'].'</td>';
echo '<td>'.$user['http_x_forwarded_for'].'</td>';
echo '<td>'.($has_participated[$user['username']] ? 'Yes' : 'No').'</td>';
} }
echo '</tr>'; echo '</tr>';
}, },
array('page_len' => 100, array('page_len' => 100,
'get_row_index' => '', 'get_row_index' => '',
'print_after_table' => function() { 'print_after_table' => function() {
global $add_new_contestant_form, $add_group_to_contest_form, $remove_user_from_contest_form; global $add_new_contestant_form,
$add_group_to_contest_form,
$remove_user_from_contest_form,
$force_set_user_participated_form;
if (isset($add_new_contestant_form)) { if (isset($add_new_contestant_form)) {
$add_new_contestant_form->printHTML(); $add_new_contestant_form->printHTML();
@ -202,6 +245,9 @@
if (isset($remove_user_from_contest_form)) { if (isset($remove_user_from_contest_form)) {
$remove_user_from_contest_form->printHTML(); $remove_user_from_contest_form->printHTML();
} }
if (isset($force_set_user_participated_form)) {
$force_set_user_participated_form->printHTML();
}
} }
) )
); );