SEBSERV-366

This commit is contained in:
anhefti 2022-12-21 16:52:45 +01:00
parent 729dd23577
commit b9962a2609
5 changed files with 64 additions and 36 deletions

View file

@ -136,6 +136,8 @@ public class ExamForm implements TemplateComposer {
new LocTextKey("sebserver.exam.consistency.no-lms-connection"); new LocTextKey("sebserver.exam.consistency.no-lms-connection");
private final static LocTextKey CONSISTENCY_MESSAGEINVALID_ID_REFERENCE = private final static LocTextKey CONSISTENCY_MESSAGEINVALID_ID_REFERENCE =
new LocTextKey("sebserver.exam.consistency.invalid-lms-id"); new LocTextKey("sebserver.exam.consistency.invalid-lms-id");
private final static LocTextKey CONSISTENCY_MESSAGE_SEB_RESTRICTION_MISMATCH =
new LocTextKey("sebserver.exam.consistencyseb-restriction-mismatch");
private final static LocTextKey AUTO_GEN_CONFIG_ERROR_TITLE = private final static LocTextKey AUTO_GEN_CONFIG_ERROR_TITLE =
new LocTextKey("sebserver.exam.autogen.error.config.title"); new LocTextKey("sebserver.exam.autogen.error.config.title");
@ -220,30 +222,6 @@ public class ExamForm implements TemplateComposer {
// new PageContext with actual EntityKey // new PageContext with actual EntityKey
final PageContext formContext = pageContext.withEntityKey(exam.getEntityKey()); final PageContext formContext = pageContext.withEntityKey(exam.getEntityKey());
// check exam consistency and inform the user if needed
Collection<APIMessage> warnings = null;
if (readonly) {
warnings = this.restService.getBuilder(CheckExamConsistency.class)
.withURIVariable(API.PARAM_MODEL_ID, entityKey.modelId)
.call()
.getOr(Collections.emptyList());
if (warnings != null && !warnings.isEmpty()) {
showConsistencyChecks(warnings, formContext.getParent());
}
}
// the default page layout with title
final LocTextKey titleKey = importFromQuizData
? EXAM_FORM_TITLE_IMPORT_KEY
: EXAM_FORM_TITLE_KEY;
final Composite content = this.widgetFactory.defaultPageLayout(
formContext.getParent(),
titleKey);
if (warnings != null && !warnings.isEmpty()) {
final GridData gridData = (GridData) content.getLayoutData();
gridData.verticalIndent = 10;
}
final BooleanSupplier isNew = () -> importFromQuizData; final BooleanSupplier isNew = () -> importFromQuizData;
final BooleanSupplier isNotNew = () -> !isNew.getAsBoolean(); final BooleanSupplier isNotNew = () -> !isNew.getAsBoolean();
final EntityGrantCheck entityGrantCheck = currentUser.entityGrantCheck(exam); final EntityGrantCheck entityGrantCheck = currentUser.entityGrantCheck(exam);
@ -262,6 +240,32 @@ public class ExamForm implements TemplateComposer {
.call() .call()
.onError(e -> log.error("Unexpected error while trying to verify seb restriction settings: ", e)) .onError(e -> log.error("Unexpected error while trying to verify seb restriction settings: ", e))
.getOr(false); .getOr(false);
final boolean sebRestrictionMismatch = isRestricted != exam.sebRestriction;
// check exam consistency and inform the user if needed
Collection<APIMessage> warnings = null;
if (readonly) {
warnings = this.restService.getBuilder(CheckExamConsistency.class)
.withURIVariable(API.PARAM_MODEL_ID, entityKey.modelId)
.call()
.getOr(Collections.emptyList());
if (sebRestrictionMismatch || (warnings != null && !warnings.isEmpty())) {
showConsistencyChecks(warnings, sebRestrictionMismatch, formContext.getParent());
}
}
// the default page layout with title
final LocTextKey titleKey = importFromQuizData
? EXAM_FORM_TITLE_IMPORT_KEY
: EXAM_FORM_TITLE_KEY;
final Composite content = this.widgetFactory.defaultPageLayout(
formContext.getParent(),
titleKey);
if ((warnings != null && !warnings.isEmpty()) || sebRestrictionMismatch) {
final GridData gridData = (GridData) content.getLayoutData();
gridData.verticalIndent = 10;
}
// The Exam form // The Exam form
final FormHandle<Exam> formHandle = this.pageService.formBuilder( final FormHandle<Exam> formHandle = this.pageService.formBuilder(
@ -637,10 +641,10 @@ public class ExamForm implements TemplateComposer {
return !lmsSetupTestResult.hasError(ErrorType.QUIZ_RESTRICTION_API_REQUEST); return !lmsSetupTestResult.hasError(ErrorType.QUIZ_RESTRICTION_API_REQUEST);
} }
private void showConsistencyChecks(final Collection<APIMessage> result, final Composite parent) { private void showConsistencyChecks(
if (result == null || result.isEmpty()) { final Collection<APIMessage> result,
return; final boolean sebRestrictionMismatch,
} final Composite parent) {
final Composite warningPanel = this.widgetFactory.createWarningPanel(parent); final Composite warningPanel = this.widgetFactory.createWarningPanel(parent);
this.widgetFactory.labelLocalized( this.widgetFactory.labelLocalized(
@ -656,6 +660,21 @@ public class ExamForm implements TemplateComposer {
warningPanel, warningPanel,
CustomVariant.MESSAGE, CustomVariant.MESSAGE,
message)); message));
if (sebRestrictionMismatch) {
this.widgetFactory.labelLocalized(
warningPanel,
CustomVariant.MESSAGE,
CONSISTENCY_MESSAGE_SEB_RESTRICTION_MISMATCH);
}
}
private void showSEBRestrictionMismatchMessage(final Composite parent) {
final Composite warningPanel = this.widgetFactory.createWarningPanel(parent);
this.widgetFactory.labelLocalized(
warningPanel,
CustomVariant.MESSAGE,
CONSISTENCY_MESSAGE_SEB_RESTRICTION_MISMATCH);
} }
private Result<Exam> getExistingExam(final PageContext pageContext) { private Result<Exam> getExistingExam(final PageContext pageContext) {

View file

@ -372,14 +372,11 @@ public class LmsAPITemplateAdapter implements LmsAPITemplate {
log.debug("Get course restriction: {} for LMSSetup: {}", exam.externalId, lmsSetup()); log.debug("Get course restriction: {} for LMSSetup: {}", exam.externalId, lmsSetup());
} }
System.out.println("******************* getSEBClientRestriction");
return this.restrictionRequest.protectedRun(() -> this.sebRestrictionAPI return this.restrictionRequest.protectedRun(() -> this.sebRestrictionAPI
.getSEBClientRestriction(exam) .getSEBClientRestriction(exam)
.onError(error -> { .onError(error -> log.error("Failed to get SEB restrictions: {}", error.getMessage()))
if (error instanceof NoSEBRestrictionException) {
return;
}
log.error("Failed to get SEB restrictions: {}", error.getMessage());
})
.getOrThrow()); .getOrThrow());
} }

View file

@ -244,6 +244,7 @@ public class SEBRestrictionServiceImpl implements SEBRestrictionService {
exam, exam,
sebRestrictionData)) sebRestrictionData))
.map(data -> exam) .map(data -> exam)
.onError(error -> this.examDAO.setSEBRestriction(exam.id, false))
.getOrThrow(); .getOrThrow();
}) })
.getOrThrow(); .getOrThrow();

View file

@ -30,7 +30,16 @@ public class MockSEBRestrictionAPI implements SEBRestrictionAPI {
@Override @Override
public Result<SEBRestriction> getSEBClientRestriction(final Exam exam) { public Result<SEBRestriction> getSEBClientRestriction(final Exam exam) {
log.info("Apply SEB Client restriction for Exam: {}", exam); log.info("Get SEB Client restriction for Exam: {}", exam);
// if (BooleanUtils.toBoolean(exam.sebRestriction)) {
// return Result.of(new SEBRestriction(
// exam.id,
// Stream.of("configKey").collect(Collectors.toList()),
// Collections.emptyList(),
// Collections.emptyMap()));
// } else {
// return Result.ofError(new NoSEBRestrictionException());
// }
return Result.ofError(new NoSEBRestrictionException()); return Result.ofError(new NoSEBRestrictionException());
} }
@ -40,6 +49,7 @@ public class MockSEBRestrictionAPI implements SEBRestrictionAPI {
final SEBRestriction sebRestrictionData) { final SEBRestriction sebRestrictionData) {
log.info("Apply SEB Client restriction: {}", sebRestrictionData); log.info("Apply SEB Client restriction: {}", sebRestrictionData);
//return Result.ofError(new NoSEBRestrictionException());
return Result.of(sebRestrictionData); return Result.of(sebRestrictionData);
} }

View file

@ -509,9 +509,10 @@ sebserver.exam.consistency.title=Note: This exam is already running but has some
sebserver.exam.consistency.missing-supporter= - There are no Exam Supporter defined for this exam. Use 'Edit Exam' on the right to add an Exam Supporter. sebserver.exam.consistency.missing-supporter= - There are no Exam Supporter defined for this exam. Use 'Edit Exam' on the right to add an Exam Supporter.
sebserver.exam.consistency.missing-indicator= - There is no indicator defined for this exam. Use 'Add Indicator" on the right to add an indicator. sebserver.exam.consistency.missing-indicator= - There is no indicator defined for this exam. Use 'Add Indicator" on the right to add an indicator.
sebserver.exam.consistency.missing-config= - There is no configuration defined for this exam. Use 'Add Configuration' to attach one. sebserver.exam.consistency.missing-config= - There is no configuration defined for this exam. Use 'Add Configuration' to attach one.
sebserver.exam.consistency.missing-seb-restriction= - There is currently no SEB restriction applied on the LMS side. Use 'Enable SEB Restriction' on the right to activate auto-restriction.<br/> Or if this is not possible consider doing it manually on the LMS. sebserver.exam.consistency.missing-seb-restriction= - There is currently no SEB restriction applied on the LMS side. Use 'Apply SEB Lock' on the right to activate auto-restriction.<br/> Or if this is not possible consider doing it manually on the LMS.
sebserver.exam.consistency.no-lms-connection= - Failed to connect to the LMS Setup of this exam yet.<br/>Please check the LMS connection within the LMS Setup. sebserver.exam.consistency.no-lms-connection= - Failed to connect to the LMS Setup of this exam yet.<br/>Please check the LMS connection within the LMS Setup.
sebserver.exam.consistency.invalid-lms-id= - The referencing course identifier seems to be invalid.<br/>Please check if the course for this exam still exists on the LMS and the course identifier has not changed. sebserver.exam.consistency.invalid-lms-id= - The referencing course identifier seems to be invalid.<br/>Please check if the course for this exam still exists on the LMS and the course identifier has not changed.
sebserver.exam.consistencyseb-restriction-mismatch= - There seems to be a mismatch in the SEB restriction for this exam. SEB Server has different state then the one of the LMS.<br/>&nbsp;&nbsp;&nbsp;&nbsp;The cause of this might lie in a connection errors with the LMS.<br/>&nbsp;&nbsp;&nbsp;&nbsp;However SEB Server is not able to verify the exact status of the SEB restriction on the LMS for this exam.
sebserver.exam.confirm.remove-config=This exam is current running. The remove of the attached configuration will led to an invalid state<br/>where connecting SEB clients cannot download the configuration for the exam.<br/><br/>Are you sure to remove the configuration? sebserver.exam.confirm.remove-config=This exam is current running. The remove of the attached configuration will led to an invalid state<br/>where connecting SEB clients cannot download the configuration for the exam.<br/><br/>Are you sure to remove the configuration?
sebserver.exam.autogen.error.config.title=Exam Import Setup Failure sebserver.exam.autogen.error.config.title=Exam Import Setup Failure
sebserver.exam.autogen.error.config.text=There was an unexpected error while setting up the imported exam.<br/> Please note that the exam has successfully been imported and can be modified but one or more additional auto-setup(s) failed:<br/>{0} sebserver.exam.autogen.error.config.text=There was an unexpected error while setting up the imported exam.<br/> Please note that the exam has successfully been imported and can be modified but one or more additional auto-setup(s) failed:<br/>{0}