diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ScreenProctoringGroupDAO.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ScreenProctoringGroupDAO.java index 49f48fb67..faec1af59 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ScreenProctoringGroupDAO.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ScreenProctoringGroupDAO.java @@ -79,4 +79,6 @@ public interface ScreenProctoringGroupDAO { Result> deleteGroups(Long examId); void updateGroupSize(String groupUUID, Integer activeCount, Integer totalCount); + + void resetAllForExam(Long examId); } diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/ScreenProctoringGroupDAOImpl.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/ScreenProctoringGroupDAOImpl.java index 4a2e53343..c8cb838f1 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/ScreenProctoringGroupDAOImpl.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/ScreenProctoringGroupDAOImpl.java @@ -243,7 +243,8 @@ public void updateGroupSize( try { - UpdateDSL.updateWithMapper( + UpdateDSL + .updateWithMapper( this.screenProctoringGroopRecordMapper::update, ScreenProctoringGroopRecordDynamicSqlSupport.screenProctoringGroopRecord) .set(ScreenProctoringGroopRecordDynamicSqlSupport.size) @@ -259,6 +260,26 @@ public void updateGroupSize( } + @Override + @Transactional + public void resetAllForExam(final Long examId) { + try { + + UpdateDSL + .updateWithMapper( + this.screenProctoringGroopRecordMapper::update, + ScreenProctoringGroopRecordDynamicSqlSupport.screenProctoringGroopRecord) + .set(ScreenProctoringGroopRecordDynamicSqlSupport.size) + .equalTo(0) + .where(ScreenProctoringGroopRecordDynamicSqlSupport.examId, isEqualTo(examId)) + .build() + .execute(); + + } catch (final Exception e) { + log.warn("Failed to reset SPS groups size: {}", e.getMessage()); + } + } + private ScreenProctoringGroup toDomainModel(final ScreenProctoringGroopRecord record) { return new ScreenProctoringGroup( record.getId(), diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/proctoring/ScreenProctoringServiceImpl.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/proctoring/ScreenProctoringServiceImpl.java index bd7812cd9..33a73d5bd 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/proctoring/ScreenProctoringServiceImpl.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/proctoring/ScreenProctoringServiceImpl.java @@ -318,6 +318,7 @@ public void notifyExamFinished(final ExamFinishedEvent event) { if (event.exam.status != Exam.ExamStatus.UP_COMING) { this.screenProctoringAPIBinding.deactivateScreenProctoring(event.exam); + this.screenProctoringGroupDAO.resetAllForExam(event.exam.id); } }