SEBSERV-133 institution
This commit is contained in:
parent
53f4d8363a
commit
ebcbc134af
5 changed files with 51 additions and 19 deletions
|
@ -81,7 +81,6 @@ import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.institution.GetIn
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.lmssetup.GetLmsSetupNames;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.lmssetup.GetLmsSetupNames;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.cert.GetCertificateNames;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.cert.GetCertificateNames;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.examconfig.GetExamConfigNodeNames;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.examconfig.GetExamConfigNodeNames;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.examconfig.GetExamConfigNodes;
|
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.examconfig.GetViews;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.examconfig.GetViews;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.GetUserAccountNames;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.GetUserAccountNames;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.auth.CurrentUser;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.auth.CurrentUser;
|
||||||
|
@ -748,7 +747,7 @@ public class ResourceService {
|
||||||
|
|
||||||
public List<Tuple<String>> getExamConfigTemplateResourcesSelection(final boolean withEmpty) {
|
public List<Tuple<String>> getExamConfigTemplateResourcesSelection(final boolean withEmpty) {
|
||||||
final UserInfo userInfo = this.currentUser.get();
|
final UserInfo userInfo = this.currentUser.get();
|
||||||
final List<Tuple<String>> collect = this.restService.getBuilder(GetExamConfigNodes.class)
|
final List<Tuple<String>> collect = this.restService.getBuilder(GetExamConfigNodeNames.class)
|
||||||
.withQueryParam(Entity.FILTER_ATTR_INSTITUTION, String.valueOf(userInfo.getInstitutionId()))
|
.withQueryParam(Entity.FILTER_ATTR_INSTITUTION, String.valueOf(userInfo.getInstitutionId()))
|
||||||
.withQueryParam(ConfigurationNode.FILTER_ATTR_TYPE, ConfigurationType.TEMPLATE.name())
|
.withQueryParam(ConfigurationNode.FILTER_ATTR_TYPE, ConfigurationType.TEMPLATE.name())
|
||||||
.call()
|
.call()
|
||||||
|
|
|
@ -258,13 +258,13 @@ public class BulkActionServiceImpl implements BulkActionService {
|
||||||
this.supporter.get(EntityType.CERTIFICATE),
|
this.supporter.get(EntityType.CERTIFICATE),
|
||||||
this.supporter.get(EntityType.BATCH_ACTION),
|
this.supporter.get(EntityType.BATCH_ACTION),
|
||||||
this.supporter.get(EntityType.USER),
|
this.supporter.get(EntityType.USER),
|
||||||
this.supporter.get(EntityType.EXAM_TEMPLATE),
|
|
||||||
this.supporter.get(EntityType.EXAM),
|
this.supporter.get(EntityType.EXAM),
|
||||||
this.supporter.get(EntityType.INDICATOR),
|
this.supporter.get(EntityType.INDICATOR),
|
||||||
this.supporter.get(EntityType.SEB_CLIENT_CONFIGURATION),
|
this.supporter.get(EntityType.SEB_CLIENT_CONFIGURATION),
|
||||||
this.supporter.get(EntityType.EXAM_CONFIGURATION_MAP),
|
|
||||||
this.supporter.get(EntityType.CLIENT_CONNECTION),
|
this.supporter.get(EntityType.CLIENT_CONNECTION),
|
||||||
this.supporter.get(EntityType.CONFIGURATION_NODE));
|
this.supporter.get(EntityType.CONFIGURATION_NODE),
|
||||||
|
this.supporter.get(EntityType.EXAM_CONFIGURATION_MAP),
|
||||||
|
this.supporter.get(EntityType.EXAM_TEMPLATE));
|
||||||
case USER:
|
case USER:
|
||||||
return Arrays.asList(
|
return Arrays.asList(
|
||||||
this.supporter.get(EntityType.EXAM),
|
this.supporter.get(EntityType.EXAM),
|
||||||
|
|
|
@ -254,6 +254,8 @@ public class ConfigurationNodeDAOImpl implements ConfigurationNodeDAO {
|
||||||
.build()
|
.build()
|
||||||
.execute();
|
.execute();
|
||||||
|
|
||||||
|
if (!configurationIds.isEmpty()) {
|
||||||
|
|
||||||
// delete all ConfigurationValue's that belongs to the Configuration's to delete
|
// delete all ConfigurationValue's that belongs to the Configuration's to delete
|
||||||
this.configurationValueRecordMapper.deleteByExample()
|
this.configurationValueRecordMapper.deleteByExample()
|
||||||
.where(ConfigurationValueRecordDynamicSqlSupport.configurationId, isIn(configurationIds))
|
.where(ConfigurationValueRecordDynamicSqlSupport.configurationId, isIn(configurationIds))
|
||||||
|
@ -265,6 +267,7 @@ public class ConfigurationNodeDAOImpl implements ConfigurationNodeDAO {
|
||||||
.where(ConfigurationRecordDynamicSqlSupport.id, isIn(configurationIds))
|
.where(ConfigurationRecordDynamicSqlSupport.id, isIn(configurationIds))
|
||||||
.build()
|
.build()
|
||||||
.execute();
|
.execute();
|
||||||
|
}
|
||||||
|
|
||||||
// and finally delete the requested ConfigurationNode's
|
// and finally delete the requested ConfigurationNode's
|
||||||
this.configurationNodeRecordMapper.deleteByExample()
|
this.configurationNodeRecordMapper.deleteByExample()
|
||||||
|
|
|
@ -385,6 +385,11 @@ public class ExamTemplateDAOImpl implements ExamTemplateDAO {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Set<EntityDependency> getDependencies(final BulkAction bulkAction) {
|
public Set<EntityDependency> getDependencies(final BulkAction bulkAction) {
|
||||||
|
// all of institution
|
||||||
|
if (bulkAction.sourceType == EntityType.INSTITUTION) {
|
||||||
|
return getDependencies(bulkAction, this::allIdsOfInstitution);
|
||||||
|
}
|
||||||
|
|
||||||
return Collections.emptySet();
|
return Collections.emptySet();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -553,4 +558,19 @@ public class ExamTemplateDAOImpl implements ExamTemplateDAO {
|
||||||
.orElse(-1L) + 1;
|
.orElse(-1L) + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Result<Collection<EntityDependency>> allIdsOfInstitution(final EntityKey institutionKey) {
|
||||||
|
return Result.tryCatch(() -> this.examTemplateRecordMapper.selectByExample()
|
||||||
|
.where(ExamTemplateRecordDynamicSqlSupport.institutionId,
|
||||||
|
isEqualTo(Long.valueOf(institutionKey.modelId)))
|
||||||
|
.build()
|
||||||
|
.execute()
|
||||||
|
.stream()
|
||||||
|
.map(rec -> new EntityDependency(
|
||||||
|
institutionKey,
|
||||||
|
new EntityKey(rec.getId(), EntityType.EXAM_TEMPLATE),
|
||||||
|
rec.getName(),
|
||||||
|
rec.getDescription()))
|
||||||
|
.collect(Collectors.toList()));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -142,7 +142,7 @@ public class SEBClientConnectionServiceImpl implements SEBClientConnectionServic
|
||||||
}
|
}
|
||||||
|
|
||||||
if (examId != null) {
|
if (examId != null) {
|
||||||
checkExamIntegrity(examId);
|
checkExamIntegrity(examId, institutionId);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create ClientConnection in status CONNECTION_REQUESTED for further processing
|
// Create ClientConnection in status CONNECTION_REQUESTED for further processing
|
||||||
|
@ -226,7 +226,7 @@ public class SEBClientConnectionServiceImpl implements SEBClientConnectionServic
|
||||||
}
|
}
|
||||||
|
|
||||||
if (examId != null) {
|
if (examId != null) {
|
||||||
checkExamIntegrity(examId);
|
checkExamIntegrity(examId, institutionId);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (log.isDebugEnabled()) {
|
if (log.isDebugEnabled()) {
|
||||||
|
@ -412,7 +412,7 @@ public class SEBClientConnectionServiceImpl implements SEBClientConnectionServic
|
||||||
.getOrThrow();
|
.getOrThrow();
|
||||||
|
|
||||||
// check exam integrity for established connection
|
// check exam integrity for established connection
|
||||||
checkExamIntegrity(establishedClientConnection.examId);
|
checkExamIntegrity(establishedClientConnection.examId, institutionId);
|
||||||
|
|
||||||
// initialize distributed indicator value caches if possible and needed
|
// initialize distributed indicator value caches if possible and needed
|
||||||
if (examId != null && this.isDistributedSetup) {
|
if (examId != null && this.isDistributedSetup) {
|
||||||
|
@ -828,7 +828,7 @@ public class SEBClientConnectionServiceImpl implements SEBClientConnectionServic
|
||||||
return clientConnection;
|
return clientConnection;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkExamIntegrity(final Long examId) {
|
private void checkExamIntegrity(final Long examId, final Long institutionId) {
|
||||||
if (this.isDistributedSetup) {
|
if (this.isDistributedSetup) {
|
||||||
// if the cached Exam is not up to date anymore, we have to update the cache first
|
// if the cached Exam is not up to date anymore, we have to update the cache first
|
||||||
final Result<Exam> updateExamCache = this.examSessionService.updateExamCache(examId);
|
final Result<Exam> updateExamCache = this.examSessionService.updateExamCache(examId);
|
||||||
|
@ -844,6 +844,16 @@ public class SEBClientConnectionServiceImpl implements SEBClientConnectionServic
|
||||||
"Exam is currently on update and locked for new SEB Client connections");
|
"Exam is currently on update and locked for new SEB Client connections");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// check Exam is within the correct institution
|
||||||
|
if (this.examSessionService.getRunningExam(examId)
|
||||||
|
.map(e -> !e.institutionId.equals(institutionId))
|
||||||
|
.onError(error -> log.error("Failed to get running exam: ", error))
|
||||||
|
.getOr(true)) {
|
||||||
|
|
||||||
|
throw new APIConstraintViolationException(
|
||||||
|
"Exam institution mismatch. The requested exam is not within the expected institution");
|
||||||
|
}
|
||||||
|
|
||||||
// check Exam has a default SEB Exam configuration attached
|
// check Exam has a default SEB Exam configuration attached
|
||||||
if (!this.examSessionService.hasDefaultConfigurationAttached(examId)) {
|
if (!this.examSessionService.hasDefaultConfigurationAttached(examId)) {
|
||||||
throw new APIConstraintViolationException(
|
throw new APIConstraintViolationException(
|
||||||
|
|
Loading…
Reference in a new issue