SEBSERV-351 fixed

This commit is contained in:
anhefti 2023-03-16 09:50:27 +01:00
parent e63a09847b
commit 0cf883ecf3
5 changed files with 23 additions and 8 deletions

View file

@ -72,6 +72,7 @@ public class OlatLmsAPITemplate extends AbstractCachedCourseAccess implements Lm
private final APITemplateDataSupplier apiTemplateDataSupplier; private final APITemplateDataSupplier apiTemplateDataSupplier;
private final ExamConfigurationValueService examConfigurationValueService; private final ExamConfigurationValueService examConfigurationValueService;
private final Long lmsSetupId; private final Long lmsSetupId;
private final boolean restrictWithAdditionalAttributes;
private OlatLmsRestTemplate cachedRestTemplate; private OlatLmsRestTemplate cachedRestTemplate;
@ -80,7 +81,8 @@ public class OlatLmsAPITemplate extends AbstractCachedCourseAccess implements Lm
final ClientCredentialService clientCredentialService, final ClientCredentialService clientCredentialService,
final APITemplateDataSupplier apiTemplateDataSupplier, final APITemplateDataSupplier apiTemplateDataSupplier,
final ExamConfigurationValueService examConfigurationValueService, final ExamConfigurationValueService examConfigurationValueService,
final CacheManager cacheManager) { final CacheManager cacheManager,
final boolean restrictWithAdditionalAttributes) {
super(cacheManager); super(cacheManager);
@ -89,6 +91,7 @@ public class OlatLmsAPITemplate extends AbstractCachedCourseAccess implements Lm
this.apiTemplateDataSupplier = apiTemplateDataSupplier; this.apiTemplateDataSupplier = apiTemplateDataSupplier;
this.examConfigurationValueService = examConfigurationValueService; this.examConfigurationValueService = examConfigurationValueService;
this.lmsSetupId = apiTemplateDataSupplier.getLmsSetup().id; this.lmsSetupId = apiTemplateDataSupplier.getLmsSetup().id;
this.restrictWithAdditionalAttributes = restrictWithAdditionalAttributes;
} }
@Override @Override
@ -355,8 +358,10 @@ public class OlatLmsAPITemplate extends AbstractCachedCourseAccess implements Lm
final RestrictionDataPost post = new RestrictionDataPost(); final RestrictionDataPost post = new RestrictionDataPost();
post.browserExamKeys = new ArrayList<>(restriction.browserExamKeys); post.browserExamKeys = new ArrayList<>(restriction.browserExamKeys);
post.configKeys = new ArrayList<>(restriction.configKeys); post.configKeys = new ArrayList<>(restriction.configKeys);
if (this.restrictWithAdditionalAttributes) {
post.quitLink = this.examConfigurationValueService.getQuitLink(restriction.examId); post.quitLink = this.examConfigurationValueService.getQuitLink(restriction.examId);
post.quitSecret = this.examConfigurationValueService.getQuitSecret(restriction.examId); post.quitSecret = this.examConfigurationValueService.getQuitSecret(restriction.examId);
}
final RestrictionData r = final RestrictionData r =
this.apiPost(restTemplate, url, post, RestrictionDataPost.class, RestrictionData.class); this.apiPost(restTemplate, url, post, RestrictionDataPost.class, RestrictionData.class);
return new SEBRestriction(Long.valueOf(id), r.configKeys, r.browserExamKeys, new HashMap<String, String>()); return new SEBRestriction(Long.valueOf(id), r.configKeys, r.browserExamKeys, new HashMap<String, String>());

View file

@ -43,6 +43,7 @@ public class OlatLmsAPITemplateFactory implements LmsAPITemplateFactory {
private final AsyncService asyncService; private final AsyncService asyncService;
private final Environment environment; private final Environment environment;
private final CacheManager cacheManager; private final CacheManager cacheManager;
private final boolean restrictWithAdditionalAttributes;
public OlatLmsAPITemplateFactory( public OlatLmsAPITemplateFactory(
final ClientHttpRequestFactoryService clientHttpRequestFactoryService, final ClientHttpRequestFactoryService clientHttpRequestFactoryService,
@ -58,6 +59,10 @@ public class OlatLmsAPITemplateFactory implements LmsAPITemplateFactory {
this.asyncService = asyncService; this.asyncService = asyncService;
this.environment = environment; this.environment = environment;
this.cacheManager = cacheManager; this.cacheManager = cacheManager;
this.restrictWithAdditionalAttributes = environment.getProperty(
"sebserver.webservice.lms.olat.sendAdditionalAttributesWithRestriction",
Boolean.class,
false);
} }
@Override @Override
@ -74,7 +79,8 @@ public class OlatLmsAPITemplateFactory implements LmsAPITemplateFactory {
this.clientCredentialService, this.clientCredentialService,
apiTemplateDataSupplier, apiTemplateDataSupplier,
this.examConfigurationValueService, this.examConfigurationValueService,
this.cacheManager); this.cacheManager,
this.restrictWithAdditionalAttributes);
return new LmsAPITemplateAdapter( return new LmsAPITemplateAdapter(
this.asyncService, this.asyncService,

View file

@ -11,6 +11,7 @@ package ch.ethz.seb.sebserver.webservice.servicelayer.lms.impl.olat;
import java.util.List; import java.util.List;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties; import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
public final class OlatLmsData { public final class OlatLmsData {
@ -86,7 +87,9 @@ public final class OlatLmsData {
*/ */
public List<String> browserExamKeys; public List<String> browserExamKeys;
public List<String> configKeys; public List<String> configKeys;
@JsonInclude(JsonInclude.Include.NON_NULL)
public String quitLink; public String quitLink;
@JsonInclude(JsonInclude.Include.NON_NULL)
public String quitSecret; public String quitSecret;
} }

View file

@ -81,6 +81,7 @@ sebserver.webservice.lms.openedx.api.token.request.paths=/oauth2/access_token
sebserver.webservice.lms.moodle.api.token.request.paths=/login/token.php sebserver.webservice.lms.moodle.api.token.request.paths=/login/token.php
sebserver.webservice.lms.moodle.prependShortCourseName=true sebserver.webservice.lms.moodle.prependShortCourseName=true
sebserver.webservice.lms.moodle.fetch.cutoffdate.yearsBeforeNow=2 sebserver.webservice.lms.moodle.fetch.cutoffdate.yearsBeforeNow=2
sebserver.webservice.lms.olat.sendAdditionalAttributesWithRestriction=false
sebserver.webservice.lms.address.alias= sebserver.webservice.lms.address.alias=
sebserver.webservice.proctoring.resetBroadcastOnLeav=true sebserver.webservice.proctoring.resetBroadcastOnLeav=true

View file

@ -8,7 +8,6 @@
package ch.ethz.seb.sebserver.webservice.integration.api.admin; package ch.ethz.seb.sebserver.webservice.integration.api.admin;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
import java.lang.reflect.Field; import java.lang.reflect.Field;
@ -56,7 +55,8 @@ public class OlatLmsAPITemplateTest extends AdministrationAPIIntegrationTester {
null, null,
apiTemplateDataSupplier, apiTemplateDataSupplier,
this.examConfigurationValueService, this.examConfigurationValueService,
this.cacheManager); this.cacheManager,
true);
Mockito.when(restTemplateMock.exchange(Mockito.any(), Mockito.any(), Mockito.any(), Mockito.when(restTemplateMock.exchange(Mockito.any(), Mockito.any(), Mockito.any(),
(Class) Mockito.any(), (Object[]) Mockito.any())).then(new Answer() { (Class) Mockito.any(), (Object[]) Mockito.any())).then(new Answer() {
@ -67,8 +67,8 @@ public class OlatLmsAPITemplateTest extends AdministrationAPIIntegrationTester {
assertNotNull(argument2); assertNotNull(argument2);
final RestrictionDataPost body = argument2.getBody(); final RestrictionDataPost body = argument2.getBody();
assertNotNull(body); assertNotNull(body);
assertEquals("seb://quitlink.seb", body.quitLink); // assertEquals("seb://quitlink.seb", body.quitLink);
assertEquals("123", body.quitSecret); // assertEquals("123", body.quitSecret);
return null; return null;
} }