From cd1fb8e3fd6f32371d4bc7e1b9040f2c92ddea1e Mon Sep 17 00:00:00 2001 From: MCJ Vasseur <14887731+vmcj@users.noreply.github.com> Date: Sun, 3 Sep 2023 10:08:43 +0200 Subject: [PATCH] cherry-pick: Add option to hide nonloggedin/nonsubmitted teams on the scoreboard (#2134) * Add option to hide nonloggedin/nonsubmitted teams on the scoreboard Done as a config option for the following 2 cases: - Normally you want a team which has logged on on the scoreboard - In case of the autologin tool of GEHACK/Nicky the user would also login without interaction of the actual team * Allow API logon as the submit client uses it Alternative would be to UNION over teams which submitted and teams which did a GUI logon but that is more expensive. --- etc/db-config.yaml | 9 +++++++++ webapp/src/Service/ScoreboardService.php | 13 +++++++++++++ .../Unit/Integration/ScoreboardIntegrationTest.php | 11 ++++++----- 3 files changed, 28 insertions(+), 5 deletions(-) diff --git a/etc/db-config.yaml b/etc/db-config.yaml index ed70e302ad..c1333251e6 100644 --- a/etc/db-config.yaml +++ b/etc/db-config.yaml @@ -259,6 +259,15 @@ default_value: true public: true description: Show submission and problem statistics on the team and public pages. + - name: show_teams_on_scoreboard + type: int + default_value: 0 + public: true + description: Show teams on the scoreboard? + options: + 0: Always + 1: After login + 2: After first submission - category: Authentication description: Options related to authentication. items: diff --git a/webapp/src/Service/ScoreboardService.php b/webapp/src/Service/ScoreboardService.php index 9d0a4da2d7..6d419f783c 100644 --- a/webapp/src/Service/ScoreboardService.php +++ b/webapp/src/Service/ScoreboardService.php @@ -39,6 +39,10 @@ */ class ScoreboardService { + final public const SHOW_TEAM_ALWAYS = 0; + final public const SHOW_TEAM_AFTER_LOGIN = 1; + final public const SHOW_TEAM_AFTER_SUBMIT = 2; + protected EntityManagerInterface $em; protected DOMJudgeService $dj; protected ConfigurationService $config; @@ -932,8 +936,17 @@ protected function getTeams(Contest $contest, bool $jury = false, Filter $filter ->setParameter('cid', $contest->getCid()); } + $show_filter = $this->config->get('show_teams_on_scoreboard'); if (!$jury) { $queryBuilder->andWhere('tc.visible = 1'); + if ($show_filter === self::SHOW_TEAM_AFTER_LOGIN) { + $queryBuilder + ->join('t.users', 'u', Join::WITH, 'u.last_login IS NOT NULL OR u.last_api_login IS NOT NULL'); + } elseif ($show_filter === self::SHOW_TEAM_AFTER_SUBMIT) { + $queryBuilder + ->join('t.submissions', 's', Join::WITH, 's.contest = :cid') + ->setParameter('cid', $contest->getCid()); + } } if ($filter) { diff --git a/webapp/tests/Unit/Integration/ScoreboardIntegrationTest.php b/webapp/tests/Unit/Integration/ScoreboardIntegrationTest.php index f6fd73f5ec..a756a8cb5b 100644 --- a/webapp/tests/Unit/Integration/ScoreboardIntegrationTest.php +++ b/webapp/tests/Unit/Integration/ScoreboardIntegrationTest.php @@ -88,11 +88,12 @@ protected function setUp(): void // Default configuration values: $this->configValues = [ - 'verification_required' => false, - 'compile_penalty' => false, - 'penalty_time' => 20, - 'score_in_seconds' => false, - 'data_source' => 0, + 'verification_required' => false, + 'compile_penalty' => false, + 'penalty_time' => 20, + 'score_in_seconds' => false, + 'data_source' => 0, + 'show_teams_on_scoreboard' => 0, ]; $this->config = $this->createMock(ConfigurationService::class);