SEBSERV-308 finished up refactoring of LMS connection handling
This commit is contained in:
parent
dad44d9b4d
commit
adac7a044c
8 changed files with 37 additions and 15 deletions
|
@ -276,8 +276,6 @@ public class ExamList implements TemplateComposer {
|
||||||
item.setData(RWT.CUSTOM_VARIANT, CustomVariant.WARNING.key);
|
item.setData(RWT.CUSTOM_VARIANT, CustomVariant.WARNING.key);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
item.setGrayed(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Function<Exam, String> examLmsSetupNameFunction(final ResourceService resourceService) {
|
private static Function<Exam, String> examLmsSetupNameFunction(final ResourceService resourceService) {
|
||||||
|
|
|
@ -198,11 +198,11 @@ public interface ExamDAO extends ActivatableEntityDAO<Exam, Exam>, BulkActionSup
|
||||||
key = "#examId")
|
key = "#examId")
|
||||||
Result<QuizData> updateQuizData(Long examId, QuizData quizData, String updateId);
|
Result<QuizData> updateQuizData(Long examId, QuizData quizData, String updateId);
|
||||||
|
|
||||||
/** This is used by the internal update process to mark exams for which the LMS related data is
|
/** This is used by the internal update process to mark exams for which the LMS related data availability
|
||||||
* not currently available and the local data might be out-dated
|
|
||||||
*
|
*
|
||||||
* @param externalQuizId The exams external UUID or quiz id of the exam to mark
|
* @param externalQuizId The exams external UUID or quiz id of the exam to mark
|
||||||
|
* @param available The LMS availability flag to set
|
||||||
* @param updateId The update identifier given by the update task */
|
* @param updateId The update identifier given by the update task */
|
||||||
void markLMSNotAvailable(final String externalQuizId, final String updateId);
|
void markLMSAvailability(final String externalQuizId, final boolean available, final String updateId);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -177,12 +177,16 @@ public class ExamDAOImpl implements ExamDAO {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void markLMSNotAvailable(final String externalQuizId, final String updateId) {
|
public void markLMSAvailability(final String externalQuizId, final boolean available, final String updateId) {
|
||||||
|
|
||||||
|
if (!available) {
|
||||||
log.info("Mark exam quiz data not available form LMS: {}", externalQuizId);
|
log.info("Mark exam quiz data not available form LMS: {}", externalQuizId);
|
||||||
|
} else {
|
||||||
|
log.info("Mark exam quiz data back again form LMS: {}", externalQuizId);
|
||||||
|
}
|
||||||
|
|
||||||
this.examRecordDAO.idByExternalQuizId(externalQuizId)
|
this.examRecordDAO.idByExternalQuizId(externalQuizId)
|
||||||
.map(examId -> this.examRecordDAO.updateLmsNotAvailable(examId, updateId))
|
.flatMap(examId -> this.examRecordDAO.updateLmsNotAvailable(examId, available, updateId))
|
||||||
.onError(error -> log.error("Failed to mark LMS not available: {}", externalQuizId, error));
|
.onError(error -> log.error("Failed to mark LMS not available: {}", externalQuizId, error));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -283,7 +283,7 @@ public class ExamRecordDAO {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Transactional
|
@Transactional
|
||||||
public Result<ExamRecord> updateLmsNotAvailable(final Long examId, final String updateId) {
|
public Result<ExamRecord> updateLmsNotAvailable(final Long examId, final boolean available, final String updateId) {
|
||||||
return Result.tryCatch(() -> {
|
return Result.tryCatch(() -> {
|
||||||
|
|
||||||
// check internal persistent write-lock
|
// check internal persistent write-lock
|
||||||
|
@ -300,7 +300,7 @@ public class ExamRecordDAO {
|
||||||
null, null,
|
null, null,
|
||||||
Utils.getMillisecondsNow(),
|
Utils.getMillisecondsNow(),
|
||||||
null, null, null,
|
null, null, null,
|
||||||
BooleanUtils.toIntegerObject(false));
|
BooleanUtils.toIntegerObject(available));
|
||||||
|
|
||||||
this.examRecordMapper.updateByPrimaryKeySelective(examRecord);
|
this.examRecordMapper.updateByPrimaryKeySelective(examRecord);
|
||||||
return this.examRecordMapper.selectByPrimaryKey(examId);
|
return this.examRecordMapper.selectByPrimaryKey(examId);
|
||||||
|
|
|
@ -166,6 +166,7 @@ public class MockCourseAccessAPI implements CourseAccessAPI {
|
||||||
public Result<QuizData> getQuiz(final String id) {
|
public Result<QuizData> getQuiz(final String id) {
|
||||||
return Result.of(this.mockups
|
return Result.of(this.mockups
|
||||||
.stream()
|
.stream()
|
||||||
|
.map(this::getExternalAddressAlias)
|
||||||
.filter(q -> id.equals(q.id))
|
.filter(q -> id.equals(q.id))
|
||||||
.findFirst()
|
.findFirst()
|
||||||
.get());
|
.get());
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
|
|
||||||
package ch.ethz.seb.sebserver.webservice.servicelayer.session.impl;
|
package ch.ethz.seb.sebserver.webservice.servicelayer.session.impl;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
@ -85,9 +86,14 @@ class ExamUpdateHandler {
|
||||||
final Set<String> failedOrMissing = new HashSet<>(exams.keySet());
|
final Set<String> failedOrMissing = new HashSet<>(exams.keySet());
|
||||||
final String updateId = this.createUpdateId();
|
final String updateId = this.createUpdateId();
|
||||||
|
|
||||||
this.lmsAPIService.getLmsAPITemplate(lmsSetupId)
|
this.lmsAPIService
|
||||||
|
.getLmsAPITemplate(lmsSetupId)
|
||||||
.flatMap(template -> template.getQuizzes(new HashSet<>(exams.keySet())))
|
.flatMap(template -> template.getQuizzes(new HashSet<>(exams.keySet())))
|
||||||
.getOrThrow()
|
.onError(error -> log.warn(
|
||||||
|
"Failed to get quizzes form LMS Setup: {} cause: {}",
|
||||||
|
lmsSetupId,
|
||||||
|
error.getMessage()))
|
||||||
|
.getOr(Collections.emptyList())
|
||||||
.stream()
|
.stream()
|
||||||
.forEach(quiz -> {
|
.forEach(quiz -> {
|
||||||
|
|
||||||
|
@ -102,11 +108,17 @@ class ExamUpdateHandler {
|
||||||
log.error("Failed to update quiz data for exam: {}", quiz,
|
log.error("Failed to update quiz data for exam: {}", quiz,
|
||||||
updateQuizData.getError());
|
updateQuizData.getError());
|
||||||
} else {
|
} else {
|
||||||
|
if (!exam.lmsAvailable) {
|
||||||
|
this.examDAO.markLMSAvailability(quiz.id, true, updateId);
|
||||||
|
}
|
||||||
failedOrMissing.remove(quiz.id);
|
failedOrMissing.remove(quiz.id);
|
||||||
log.info("Updated quiz data for exam: {}", updateQuizData.get());
|
log.info("Updated quiz data for exam: {}", updateQuizData.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
if (!exam.lmsAvailable) {
|
||||||
|
this.examDAO.markLMSAvailability(quiz.id, true, updateId);
|
||||||
|
}
|
||||||
failedOrMissing.remove(quiz.id);
|
failedOrMissing.remove(quiz.id);
|
||||||
}
|
}
|
||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
|
@ -214,6 +226,7 @@ class ExamUpdateHandler {
|
||||||
final String updateId) {
|
final String updateId) {
|
||||||
|
|
||||||
return Result.tryCatch(() -> {
|
return Result.tryCatch(() -> {
|
||||||
|
final Exam exam = exams.get(quizId);
|
||||||
final LmsAPITemplate lmsTemplate = this.lmsAPIService
|
final LmsAPITemplate lmsTemplate = this.lmsAPIService
|
||||||
.getLmsAPITemplate(lmsSetupId)
|
.getLmsAPITemplate(lmsSetupId)
|
||||||
.getOrThrow();
|
.getOrThrow();
|
||||||
|
@ -230,7 +243,6 @@ class ExamUpdateHandler {
|
||||||
|
|
||||||
log.info("Try to recover quiz data for Moodle quiz with internal identifier: {}", quizId);
|
log.info("Try to recover quiz data for Moodle quiz with internal identifier: {}", quizId);
|
||||||
|
|
||||||
final Exam exam = exams.get(quizId);
|
|
||||||
if (exam != null && exam.name != null) {
|
if (exam != null && exam.name != null) {
|
||||||
|
|
||||||
log.debug("Found formerName quiz name: {}", exam.name);
|
log.debug("Found formerName quiz name: {}", exam.name);
|
||||||
|
@ -270,7 +282,9 @@ class ExamUpdateHandler {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.examDAO.markLMSNotAvailable(quizId, updateId);
|
if (exam.lmsAvailable) {
|
||||||
|
this.examDAO.markLMSAvailability(quizId, false, updateId);
|
||||||
|
}
|
||||||
throw new RuntimeException("Not Available");
|
throw new RuntimeException("Not Available");
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,5 +34,5 @@ ALTER TABLE `exam`
|
||||||
ADD COLUMN IF NOT EXISTS `quiz_name` VARCHAR(255) NULL AFTER `last_modified`,
|
ADD COLUMN IF NOT EXISTS `quiz_name` VARCHAR(255) NULL AFTER `last_modified`,
|
||||||
ADD COLUMN IF NOT EXISTS `quiz_start_time` DATETIME NULL AFTER `quiz_name`,
|
ADD COLUMN IF NOT EXISTS `quiz_start_time` DATETIME NULL AFTER `quiz_name`,
|
||||||
ADD COLUMN IF NOT EXISTS `quiz_end_time` DATETIME NULL AFTER `quiz_start_time`,
|
ADD COLUMN IF NOT EXISTS `quiz_end_time` DATETIME NULL AFTER `quiz_start_time`,
|
||||||
ADD COLUMN IF NOT EXISTS `lms_available` INT(1) NULL AFTER `quiz_end_time`,
|
ADD COLUMN IF NOT EXISTS `lms_available` INT(1) NULL AFTER `quiz_end_time`
|
||||||
;
|
;
|
|
@ -909,6 +909,11 @@ TableItem:linesvisible:even {
|
||||||
color: inherit;
|
color: inherit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TableItem:linesvisible:even.disabled {
|
||||||
|
background-color: #ffffff;
|
||||||
|
color: #aaaaaa;
|
||||||
|
}
|
||||||
|
|
||||||
Table-RowOverlay {
|
Table-RowOverlay {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
color: inherit;
|
color: inherit;
|
||||||
|
|
Loading…
Reference in a new issue