fix: 90b3675bd5
All checks were successful
continuous-integration/drone/push Build is passing

This commit is contained in:
Baoshuo Ren 2022-10-03 09:11:43 +08:00
parent 90b3675bd5
commit ef774d2e97
Signed by: baoshuo
GPG Key ID: 00CB9680AB29F51A
4 changed files with 14 additions and 12 deletions

View File

@ -2,6 +2,8 @@
requirePHPLib('form'); requirePHPLib('form');
requirePHPLib('judger'); requirePHPLib('judger');
$REQUIRE_LIB['bootstrap5'] = '';
if (!Auth::check()) { if (!Auth::check()) {
become403Page(UOJLocale::get('need login')); become403Page(UOJLocale::get('need login'));
} }
@ -18,11 +20,13 @@
$solution_viewable = hasViewSolutionPermission($problem_extra_config['view_solution_type'], $myUser, $problem); $solution_viewable = hasViewSolutionPermission($problem_extra_config['view_solution_type'], $myUser, $problem);
$solution_submittable = hasViewSolutionPermission($problem_extra_config['submit_solution_type'], $myUser, $problem); $solution_submittable = hasViewSolutionPermission($problem_extra_config['submit_solution_type'], $myUser, $problem);
if (!$solution_viewable || isRegisteredRunningContestProblem($myUser, $problem)) { if (!$solution_viewable) {
become403Page(); become403Page();
} }
$REQUIRE_LIB['bootstrap5'] = ''; if (!hasProblemPermission($myUser, $problem) && isRegisteredRunningContestProblem($myUser, $problem)) {
become403Page();
}
function removeSolutionForm($blog_id) { function removeSolutionForm($blog_id) {
$res_form = new UOJForm("remove_solution_{$blog_id}"); $res_form = new UOJForm("remove_solution_{$blog_id}");

View File

@ -21,10 +21,6 @@
if (!isNormalUser($myUser)) { if (!isNormalUser($myUser)) {
become403Page(); become403Page();
} }
if (isRegisteredRunningContestProblem($myUser, $problem)) {
become403Page();
}
} }
function scoreDistributionData() { function scoreDistributionData() {

View File

@ -30,7 +30,7 @@
} }
} }
if (!isSubmissionVisibleToUser($submission, $problem, $myUser) || isRegisteredRunningContestProblem($myUser, $problem)) { if (!isSubmissionVisibleToUser($submission, $problem, $myUser)) {
become403Page(); become403Page();
} }

View File

@ -221,12 +221,14 @@ function isHackVisibleToUser($hack, $problem, $user) {
function isSubmissionFullVisibleToUser($submission, $contest, $problem, $user) { function isSubmissionFullVisibleToUser($submission, $contest, $problem, $user) {
if (isSuperUser($user)) { if (isSuperUser($user)) {
return true; return true;
} elseif ($submission['submitter'] == $user['username']) {
return true;
} elseif (isRegisteredRunningContestProblem($user, $problem)) {
return false;
} elseif (!$contest) { } elseif (!$contest) {
return true; return true;
} elseif ($contest['cur_progress'] > CONTEST_IN_PROGRESS) { } elseif ($contest['cur_progress'] > CONTEST_IN_PROGRESS) {
return true; return true;
} elseif ($submission['submitter'] == $user['username']) {
return true;
} else { } else {
return hasProblemPermission($user, $problem); return hasProblemPermission($user, $problem);
} }
@ -250,7 +252,7 @@ function isRegisteredRunningContestProblem($user, $problem) {
while (list($contest_id) = DB::fetch($result, MYSQLI_NUM)) { while (list($contest_id) = DB::fetch($result, MYSQLI_NUM)) {
$contest = queryContest($contest_id); $contest = queryContest($contest_id);
genMoreContestInfo($contest); genMoreContestInfo($contest);
if (CONTEST_NOT_STARTED < $contest['cur_progress'] && $contest['cur_progress'] <= CONTEST_IN_PROGRESS if ($contest['cur_progress'] == CONTEST_IN_PROGRESS
&& hasRegistered($user, $contest) && hasRegistered($user, $contest)
&& !hasContestPermission($user, $contest) && !hasContestPermission($user, $contest)
&& queryContestProblemRank($contest, $problem)) { && queryContestProblemRank($contest, $problem)) {