SEBSERV-417 do not deactivate teacher account (might be used by others)

This commit is contained in:
anhefti 2024-06-18 10:57:41 +02:00
parent 27c5cff6f5
commit bf7204660d
3 changed files with 2 additions and 33 deletions

View file

@ -17,7 +17,7 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.lms.FullLmsIntegrationServi
/** Service used to maintain Teacher Ad-Hoc Accounts */ /** Service used to maintain Teacher Ad-Hoc Accounts */
public interface TeacherAccountService { public interface TeacherAccountService {
String AD_HOC_TEACHER_ID_PREFIX = "AD_HOC_TEACHER_"; String AD_HOC_TEACHER_ID_PREFIX = "TEACHER_ACCOUNT_";
/** Creates an Ad-Hoc Teacher account for a given existing Exam. /** Creates an Ad-Hoc Teacher account for a given existing Exam.
* *
@ -52,16 +52,6 @@ public interface TeacherAccountService {
*/ */
String getTeacherAccountIdentifier(String lmsId, String userId); String getTeacherAccountIdentifier(String lmsId, String userId);
/** Deactivates a certain ad-hoc Teacher account
* Usually called when an exam is deleted. Checks if Teacher account for exam
* is not used by other active exams and if so, deactivates unused ad-hoc accounts
*
* @param exam The Exam for witch to deactivate all applied ad-hoc Teacher accounts
* if they are not used anymore.
* @return Result refer to the given exam or to an error when happened
*/
Result<Exam> deactivateTeacherAccountsForExam(Exam exam);
/** Get a One Time Access JWT Token for auto-login for a specific ad-hoc Teacher account. /** Get a One Time Access JWT Token for auto-login for a specific ad-hoc Teacher account.
* *
* @param exam The involved Exam instance * @param exam The involved Exam instance

View file

@ -127,20 +127,6 @@ public class TeacherAccountServiceImpl implements TeacherAccountService {
}); });
} }
@Override
public Result<Exam> deactivateTeacherAccountsForExam(final Exam exam) {
return Result.tryCatch(() -> {
exam.supporter.stream()
.map(userUUID -> userDAO.byModelId(userUUID).getOr(null))
.filter(user -> user != null && user.roles.contains(UserRole.TEACHER.name()))
.filter( user -> user.roles.size() == 1)
.forEach( user -> userDAO.setActive(user, false));
return exam;
});
}
@Override @Override
public Result<String> getOneTimeTokenForTeacherAccount( public Result<String> getOneTimeTokenForTeacherAccount(
final Exam exam, final Exam exam,

View file

@ -53,7 +53,6 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.sebconfig.ConnectionConfigu
import ch.ethz.seb.sebserver.webservice.servicelayer.session.ScreenProctoringService; import ch.ethz.seb.sebserver.webservice.servicelayer.session.ScreenProctoringService;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.joda.time.DateTime;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value; import org.springframework.beans.factory.annotation.Value;
@ -159,7 +158,6 @@ public class FullLmsIntegrationServiceImpl implements FullLmsIntegrationService
@Override @Override
public void notifyExamDeletion(final ExamDeletionEvent event) { public void notifyExamDeletion(final ExamDeletionEvent event) {
event.ids.forEach( examId -> this.examDAO.byPK(examId) event.ids.forEach( examId -> this.examDAO.byPK(examId)
.flatMap(this.teacherAccountServiceImpl::deactivateTeacherAccountsForExam)
.map(exam -> applyExamData(exam, true)) .map(exam -> applyExamData(exam, true))
.onError(error -> log.warn("Failed delete teacher accounts for exam: {}", examId)) .onError(error -> log.warn("Failed delete teacher accounts for exam: {}", examId))
); );
@ -187,12 +185,7 @@ public class FullLmsIntegrationServiceImpl implements FullLmsIntegrationService
// remove all active exam data for involved exams before deactivate them // remove all active exam data for involved exams before deactivate them
this.examDAO this.examDAO
.allActiveForLMSSetup(Arrays.asList(lmsSetup.id)) .allActiveForLMSSetup(Arrays.asList(lmsSetup.id))
.getOrThrow() .getOrThrow();
.forEach( exam -> {
this.teacherAccountServiceImpl.deactivateTeacherAccountsForExam(exam)
.map(e -> applyExamData(e, true))
.onError(error -> log.warn("Failed delete teacher accounts for exam: {}", exam.name));
});
// delete full integration on Moodle side due to deactivation // delete full integration on Moodle side due to deactivation
this.deleteFullLmsIntegration(lmsSetup.id) this.deleteFullLmsIntegration(lmsSetup.id)
.getOrThrow(); .getOrThrow();