diff options
-rw-r--r-- | modules-available/exams/inc/exams.inc.php | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/modules-available/exams/inc/exams.inc.php b/modules-available/exams/inc/exams.inc.php index dfc38273..da4dec85 100644 --- a/modules-available/exams/inc/exams.inc.php +++ b/modules-available/exams/inc/exams.inc.php @@ -12,10 +12,14 @@ class Exams if (!is_array($locationIds)) { $locationIds = array($locationIds); } - $l = str_repeat(',?', count($locationIds)); + if (empty($locationIds)) { + $locationIds[] = 0; + } $res = Database::queryFirst("SELECT lectureid, autologin FROM exams" . " INNER JOIN exams_x_location USING (examid)" - . " WHERE UNIX_TIMESTAMP() BETWEEN starttime AND endtime AND locationid IN (0$l) LIMIT 1", $locationIds); + . " WHERE UNIX_TIMESTAMP() BETWEEN starttime AND endtime AND (locationid IN (:lids) OR locationid IS NULL) LIMIT 1", [ + 'lids' => array_values($locationIds), + ]); if ($res !== false) { $lectureId = $res['lectureid']; $autoLogin = $res['autologin']; |