code cleanup

This commit is contained in:
anhefti 2022-01-25 10:04:20 +01:00
parent e19e7aeb2a
commit ecc5398147
21 changed files with 391 additions and 166 deletions

View file

@ -13,6 +13,7 @@ import static org.mybatis.dynamic.sql.SqlBuilder.*;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.HashSet; import java.util.HashSet;
import java.util.List; import java.util.List;
import java.util.Set; import java.util.Set;
@ -212,14 +213,20 @@ public class BatchActionDAOImpl implements BatchActionDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<BatchAction>> allOf(final Set<Long> pks) { public Result<Collection<BatchAction>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.batchActionRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.batchActionRecordMapper.selectByExample()
.where(BatchActionRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(BatchActionRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(this::toDomainModel) .map(this::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override
@ -293,6 +300,10 @@ public class BatchActionDAOImpl implements BatchActionDAO {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids.isEmpty()) {
return Collections.emptyList();
}
this.batchActionRecordMapper.deleteByExample() this.batchActionRecordMapper.deleteByExample()
.where(BatchActionRecordDynamicSqlSupport.id, isIn(ids)) .where(BatchActionRecordDynamicSqlSupport.id, isIn(ids))
.build() .build()

View file

@ -141,7 +141,7 @@ public class ClientConnectionDAOImpl implements ClientConnectionDAO {
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<ClientConnection>> allOf(final Set<Long> pks) { public Result<Collection<ClientConnection>> allOf(final Set<Long> pks) {
if (pks == null || pks.isEmpty()) { if (pks == null || pks.isEmpty()) {
return Result.ofRuntimeError("Null or empty set reference"); return Result.of(Collections.emptyList());
} }
return Result.tryCatch(() -> this.clientConnectionRecordMapper.selectByExample() return Result.tryCatch(() -> this.clientConnectionRecordMapper.selectByExample()
.where(ClientConnectionRecordDynamicSqlSupport.id, SqlBuilder.isIn(new ArrayList<>(pks))) .where(ClientConnectionRecordDynamicSqlSupport.id, SqlBuilder.isIn(new ArrayList<>(pks)))

View file

@ -13,6 +13,7 @@ import static org.mybatis.dynamic.sql.SqlBuilder.*;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Set; import java.util.Set;
import java.util.function.Predicate; import java.util.function.Predicate;
@ -186,14 +187,21 @@ public class ClientEventDAOImpl implements ClientEventDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<ClientEvent>> allOf(final Set<Long> pks) { public Result<Collection<ClientEvent>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.clientEventRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.clientEventRecordMapper.selectByExample()
.where(ClientEventRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(ClientEventRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(ClientEventDAOImpl::toDomainModel) .map(ClientEventDAOImpl::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override
@ -378,6 +386,10 @@ public class ClientEventDAOImpl implements ClientEventDAO {
public Result<Collection<EntityKey>> delete(final Set<EntityKey> all) { public Result<Collection<EntityKey>> delete(final Set<EntityKey> all) {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
if (all == null || all.isEmpty()) {
return Collections.emptyList();
}
final List<Long> pks = all final List<Long> pks = all
.stream() .stream()
.map(EntityKey::getModelId) .map(EntityKey::getModelId)
@ -402,12 +414,20 @@ public class ClientEventDAOImpl implements ClientEventDAO {
public Result<Collection<EntityKey>> deleteClientNotification(final Set<EntityKey> keys) { public Result<Collection<EntityKey>> deleteClientNotification(final Set<EntityKey> keys) {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
if (keys == null || keys.isEmpty()) {
return Collections.emptyList();
}
final List<Long> pks = keys final List<Long> pks = keys
.stream() .stream()
.map(EntityKey::getModelId) .map(EntityKey::getModelId)
.map(Long::parseLong) .map(Long::parseLong)
.collect(Collectors.toList()); .collect(Collectors.toList());
if (log.isDebugEnabled()) {
log.debug("Going to delete all client notifications: {}", pks);
}
this.clientNotificationRecordMapper this.clientNotificationRecordMapper
.deleteByExample() .deleteByExample()
.where(ClientNotificationRecordDynamicSqlSupport.id, isIn(pks)) .where(ClientNotificationRecordDynamicSqlSupport.id, isIn(pks))

View file

@ -12,6 +12,7 @@ import static org.mybatis.dynamic.sql.SqlBuilder.isIn;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Set; import java.util.Set;
import java.util.function.Predicate; import java.util.function.Predicate;
@ -75,14 +76,21 @@ public class ConfigurationAttributeDAOImpl implements ConfigurationAttributeDAO
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<ConfigurationAttribute>> allOf(final Set<Long> pks) { public Result<Collection<ConfigurationAttribute>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.configurationAttributeRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.configurationAttributeRecordMapper.selectByExample()
.where(ConfigurationAttributeRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(ConfigurationAttributeRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(ConfigurationAttributeDAOImpl::toDomainModel) .map(ConfigurationAttributeDAOImpl::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override
@ -191,6 +199,10 @@ public class ConfigurationAttributeDAOImpl implements ConfigurationAttributeDAO
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
final List<EntityKey> result = new ArrayList<>(); final List<EntityKey> result = new ArrayList<>();
if (ids == null || ids.isEmpty()) {
return result;
}
// if this is a complex attribute that has children, delete the children first // if this is a complex attribute that has children, delete the children first
final List<ConfigurationAttributeRecord> children = final List<ConfigurationAttributeRecord> children =
this.configurationAttributeRecordMapper.selectByExample() this.configurationAttributeRecordMapper.selectByExample()

View file

@ -552,6 +552,7 @@ class ConfigurationDAOBatchService {
.collect(Collectors.toList()); .collect(Collectors.toList());
// first delete all old values of this table // first delete all old values of this table
if (!columnAttributeIds.isEmpty()) {
this.batchConfigurationValueRecordMapper.deleteByExample() this.batchConfigurationValueRecordMapper.deleteByExample()
.where( .where(
ConfigurationValueRecordDynamicSqlSupport.configurationId, ConfigurationValueRecordDynamicSqlSupport.configurationId,
@ -561,6 +562,7 @@ class ConfigurationDAOBatchService {
SqlBuilder.isIn(columnAttributeIds)) SqlBuilder.isIn(columnAttributeIds))
.build() .build()
.execute(); .execute();
}
// then add the new values // then add the new values
for (final TableValue tableValue : value.values) { for (final TableValue tableValue : value.values) {

View file

@ -8,6 +8,22 @@
package ch.ethz.seb.sebserver.webservice.servicelayer.dao.impl; package ch.ethz.seb.sebserver.webservice.servicelayer.dao.impl;
import static org.mybatis.dynamic.sql.SqlBuilder.*;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Set;
import java.util.function.Predicate;
import java.util.stream.Collectors;
import org.apache.commons.lang3.BooleanUtils;
import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
import ch.ethz.seb.sebserver.gbl.api.EntityType; import ch.ethz.seb.sebserver.gbl.api.EntityType;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.Configuration; import ch.ethz.seb.sebserver.gbl.model.sebconfig.Configuration;
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile; import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
@ -23,20 +39,6 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.dao.DAOLoggingSupport;
import ch.ethz.seb.sebserver.webservice.servicelayer.dao.FilterMap; import ch.ethz.seb.sebserver.webservice.servicelayer.dao.FilterMap;
import ch.ethz.seb.sebserver.webservice.servicelayer.dao.ResourceNotFoundException; import ch.ethz.seb.sebserver.webservice.servicelayer.dao.ResourceNotFoundException;
import ch.ethz.seb.sebserver.webservice.servicelayer.dao.TransactionHandler; import ch.ethz.seb.sebserver.webservice.servicelayer.dao.TransactionHandler;
import org.apache.commons.lang3.BooleanUtils;
import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Set;
import java.util.function.Predicate;
import java.util.stream.Collectors;
import static org.mybatis.dynamic.sql.SqlBuilder.*;
@Lazy @Lazy
@Component @Component
@ -72,14 +74,21 @@ public class ConfigurationDAOImpl implements ConfigurationDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<Configuration>> allOf(final Set<Long> pks) { public Result<Collection<Configuration>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.configurationRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.configurationRecordMapper.selectByExample()
.where(ConfigurationRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(ConfigurationRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(ConfigurationDAOImpl::toDomainModel) .map(ConfigurationDAOImpl::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override

View file

@ -91,14 +91,21 @@ public class ConfigurationNodeDAOImpl implements ConfigurationNodeDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<ConfigurationNode>> allOf(final Set<Long> pks) { public Result<Collection<ConfigurationNode>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.configurationNodeRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.configurationNodeRecordMapper.selectByExample()
.where(ConfigurationNodeRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(ConfigurationNodeRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(ConfigurationNodeDAOImpl::toDomainModel) .map(ConfigurationNodeDAOImpl::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override
@ -225,6 +232,10 @@ public class ConfigurationNodeDAOImpl implements ConfigurationNodeDAO {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
// find all configurations for this configuration node // find all configurations for this configuration node
final List<Long> configurationIds = this.configurationRecordMapper.selectIdsByExample() final List<Long> configurationIds = this.configurationRecordMapper.selectIdsByExample()
.where(ConfigurationRecordDynamicSqlSupport.configurationNodeId, isIn(ids)) .where(ConfigurationRecordDynamicSqlSupport.configurationNodeId, isIn(ids))

View file

@ -11,7 +11,17 @@ package ch.ethz.seb.sebserver.webservice.servicelayer.dao.impl;
import static org.mybatis.dynamic.sql.SqlBuilder.isEqualTo; import static org.mybatis.dynamic.sql.SqlBuilder.isEqualTo;
import static org.mybatis.dynamic.sql.SqlBuilder.isIn; import static org.mybatis.dynamic.sql.SqlBuilder.isIn;
import java.util.*; import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Optional;
import java.util.Set;
import java.util.function.Function; import java.util.function.Function;
import java.util.function.Predicate; import java.util.function.Predicate;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@ -115,14 +125,21 @@ public class ConfigurationValueDAOImpl implements ConfigurationValueDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<ConfigurationValue>> allOf(final Set<Long> pks) { public Result<Collection<ConfigurationValue>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.configurationValueRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.configurationValueRecordMapper.selectByExample()
.where(ConfigurationValueRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(ConfigurationValueRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(ConfigurationValueDAOImpl::toDomainModel) .map(ConfigurationValueDAOImpl::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override
@ -248,6 +265,9 @@ public class ConfigurationValueDAOImpl implements ConfigurationValueDAO {
.flatMap(this::getAttributeMapping) .flatMap(this::getAttributeMapping)
.map(attributeMapping -> { .map(attributeMapping -> {
// get all values of the table // get all values of the table
final ArrayList<Long> attrs = (attributeMapping != null && !attributeMapping.isEmpty())
? new ArrayList<>(attributeMapping.keySet())
: null;
final List<TableValue> values = this.configurationValueRecordMapper.selectByExample() final List<TableValue> values = this.configurationValueRecordMapper.selectByExample()
.where( .where(
ConfigurationValueRecordDynamicSqlSupport.institutionId, ConfigurationValueRecordDynamicSqlSupport.institutionId,
@ -257,7 +277,7 @@ public class ConfigurationValueDAOImpl implements ConfigurationValueDAO {
isEqualTo(configurationId)) isEqualTo(configurationId))
.and( .and(
ConfigurationValueRecordDynamicSqlSupport.configurationAttributeId, ConfigurationValueRecordDynamicSqlSupport.configurationAttributeId,
SqlBuilder.isIn(new ArrayList<>(attributeMapping.keySet()))) SqlBuilder.isInWhenPresent(attrs))
.build() .build()
.execute() .execute()
.stream() .stream()
@ -362,7 +382,9 @@ public class ConfigurationValueDAOImpl implements ConfigurationValueDAO {
final Set<EntityKey> tableValues = new HashSet<>(); final Set<EntityKey> tableValues = new HashSet<>();
if (attributeMapping != null && !attributeMapping.isEmpty()) { if (attributeMapping != null && !attributeMapping.isEmpty()) {
final ArrayList<Long> attrs = (attributeMapping != null && !attributeMapping.isEmpty())
? new ArrayList<>(attributeMapping.keySet())
: null;
tableValues.addAll(this.configurationValueRecordMapper.selectByExample() tableValues.addAll(this.configurationValueRecordMapper.selectByExample()
.where( .where(
ConfigurationValueRecordDynamicSqlSupport.institutionId, ConfigurationValueRecordDynamicSqlSupport.institutionId,
@ -372,7 +394,7 @@ public class ConfigurationValueDAOImpl implements ConfigurationValueDAO {
isEqualTo(configurationId)) isEqualTo(configurationId))
.and( .and(
ConfigurationValueRecordDynamicSqlSupport.configurationAttributeId, ConfigurationValueRecordDynamicSqlSupport.configurationAttributeId,
SqlBuilder.isIn(new ArrayList<>(attributeMapping.keySet()))) SqlBuilder.isInWhenPresent(attrs))
.build() .build()
.execute() .execute()
.stream() .stream()

View file

@ -98,14 +98,21 @@ public class ExamConfigurationMapDAOImpl implements ExamConfigurationMapDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<ExamConfigurationMap>> allOf(final Set<Long> pks) { public Result<Collection<ExamConfigurationMap>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.examConfigurationMapRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.examConfigurationMapRecordMapper.selectByExample()
.where(ExamConfigurationMapRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(ExamConfigurationMapRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(this::toDomainModel) .map(this::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override
@ -268,6 +275,9 @@ public class ExamConfigurationMapDAOImpl implements ExamConfigurationMapDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
// get all involved configurations // get all involved configurations
final List<Long> configIds = this.examConfigurationMapRecordMapper.selectByExample() final List<Long> configIds = this.examConfigurationMapRecordMapper.selectByExample()

View file

@ -217,6 +217,10 @@ public class ExamDAOImpl implements ExamDAO {
final Result<Collection<EntityKey>> tryCatch = Result.tryCatch(() -> { final Result<Collection<EntityKey>> tryCatch = Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
final ExamRecord examRecord = new ExamRecord(null, null, null, null, null, final ExamRecord examRecord = new ExamRecord(null, null, null, null, null,
null, null, null, null, null, null, null, null, BooleanUtils.toInteger(active), null, null, null, null, null, null, null, null, null, BooleanUtils.toInteger(active), null,
Utils.getMillisecondsNow()); Utils.getMillisecondsNow());
@ -484,6 +488,9 @@ public class ExamDAOImpl implements ExamDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
// notify exam deletion listener about following deletion, to cleanup stuff before deletion // notify exam deletion listener about following deletion, to cleanup stuff before deletion
this.applicationEventPublisher.publishEvent(new ExamDeletionEvent(ids)); this.applicationEventPublisher.publishEvent(new ExamDeletionEvent(ids));

View file

@ -12,6 +12,7 @@ import static org.mybatis.dynamic.sql.SqlBuilder.*;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Set; import java.util.Set;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@ -330,10 +331,17 @@ public class ExamRecordDAO {
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<ExamRecord>> allOf(final Set<Long> pks) { public Result<Collection<ExamRecord>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.examRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.examRecordMapper.selectByExample()
.where(ExamRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(ExamRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute()); .execute();
});
} }
} }

View file

@ -117,14 +117,21 @@ public class ExamTemplateDAOImpl implements ExamTemplateDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<ExamTemplate>> allOf(final Set<Long> pks) { public Result<Collection<ExamTemplate>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.examTemplateRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.examTemplateRecordMapper.selectByExample()
.where(IndicatorRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(IndicatorRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(this::toDomainModel) .map(this::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override
@ -247,6 +254,9 @@ public class ExamTemplateDAOImpl implements ExamTemplateDAO {
log.info("Delete exam templates: {}", all); log.info("Delete exam templates: {}", all);
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
ids.stream() ids.stream()
.forEach(id -> { .forEach(id -> {

View file

@ -105,14 +105,21 @@ public class IndicatorDAOImpl implements IndicatorDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<Indicator>> allOf(final Set<Long> pks) { public Result<Collection<Indicator>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.indicatorRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.indicatorRecordMapper.selectByExample()
.where(IndicatorRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(IndicatorRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(this::toDomainModel) .map(this::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override
@ -193,6 +200,9 @@ public class IndicatorDAOImpl implements IndicatorDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
// first delete all thresholds of indicators // first delete all thresholds of indicators
this.thresholdRecordMapper.deleteByExample() this.thresholdRecordMapper.deleteByExample()

View file

@ -170,6 +170,10 @@ public class InstitutionDAOImpl implements InstitutionDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
final InstitutionRecord institutionRecord = new InstitutionRecord( final InstitutionRecord institutionRecord = new InstitutionRecord(
null, null, null, null, BooleanUtils.toInteger(active), null); null, null, null, null, BooleanUtils.toInteger(active), null);
@ -204,6 +208,9 @@ public class InstitutionDAOImpl implements InstitutionDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
this.institutionRecordMapper.deleteByExample() this.institutionRecordMapper.deleteByExample()
.where(InstitutionRecordDynamicSqlSupport.id, isIn(ids)) .where(InstitutionRecordDynamicSqlSupport.id, isIn(ids))
@ -226,14 +233,21 @@ public class InstitutionDAOImpl implements InstitutionDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<Institution>> allOf(final Set<Long> pks) { public Result<Collection<Institution>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.institutionRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.institutionRecordMapper.selectByExample()
.where(InstitutionRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(InstitutionRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(InstitutionDAOImpl::toDomainModel) .map(InstitutionDAOImpl::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
private Result<InstitutionRecord> recordById(final Long id) { private Result<InstitutionRecord> recordById(final Long id) {

View file

@ -241,6 +241,10 @@ public class LmsSetupDAOImpl implements LmsSetupDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
final LmsSetupRecord lmsSetupRecord = new LmsSetupRecord( final LmsSetupRecord lmsSetupRecord = new LmsSetupRecord(
null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null,
System.currentTimeMillis(), System.currentTimeMillis(),
@ -277,6 +281,9 @@ public class LmsSetupDAOImpl implements LmsSetupDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
this.lmsSetupRecordMapper.deleteByExample() this.lmsSetupRecordMapper.deleteByExample()
.where(LmsSetupRecordDynamicSqlSupport.id, isIn(ids)) .where(LmsSetupRecordDynamicSqlSupport.id, isIn(ids))
@ -303,14 +310,21 @@ public class LmsSetupDAOImpl implements LmsSetupDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<LmsSetup>> allOf(final Set<Long> pks) { public Result<Collection<LmsSetup>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.lmsSetupRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.lmsSetupRecordMapper.selectByExample()
.where(LmsSetupRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(LmsSetupRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(this::toDomainModel) .map(this::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override

View file

@ -13,6 +13,7 @@ import static org.mybatis.dynamic.sql.SqlBuilder.isIn;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
@ -68,14 +69,21 @@ public class OrientationDAOImpl implements OrientationDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<Orientation>> allOf(final Set<Long> pks) { public Result<Collection<Orientation>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.orientationRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.orientationRecordMapper.selectByExample()
.where(OrientationRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(OrientationRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(OrientationDAOImpl::toDomainModel) .map(OrientationDAOImpl::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override
@ -227,6 +235,9 @@ public class OrientationDAOImpl implements OrientationDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
this.orientationRecordMapper.deleteByExample() this.orientationRecordMapper.deleteByExample()
.where(OrientationRecordDynamicSqlSupport.id, isIn(ids)) .where(OrientationRecordDynamicSqlSupport.id, isIn(ids))

View file

@ -196,6 +196,10 @@ public class SEBClientConfigDAOImpl implements SEBClientConfigDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
final SebClientConfigRecord record = new SebClientConfigRecord( final SebClientConfigRecord record = new SebClientConfigRecord(
null, null, null, null, null, null, null, null, null, null, null, null, null, null,
BooleanUtils.toIntegerObject(active)); BooleanUtils.toIntegerObject(active));
@ -278,6 +282,9 @@ public class SEBClientConfigDAOImpl implements SEBClientConfigDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
this.sebClientConfigRecordMapper.deleteByExample() this.sebClientConfigRecordMapper.deleteByExample()
.where(SebClientConfigRecordDynamicSqlSupport.id, isIn(ids)) .where(SebClientConfigRecordDynamicSqlSupport.id, isIn(ids))
@ -293,14 +300,21 @@ public class SEBClientConfigDAOImpl implements SEBClientConfigDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<SEBClientConfig>> allOf(final Set<Long> pks) { public Result<Collection<SEBClientConfig>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.sebClientConfigRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.sebClientConfigRecordMapper.selectByExample()
.where(SebClientConfigRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(SebClientConfigRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(this::toDomainModel) .map(this::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override

View file

@ -324,6 +324,9 @@ public class UserActivityLogDAOImpl implements UserActivityLogDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
this.userLogRecordMapper.deleteByExample() this.userLogRecordMapper.deleteByExample()
.where(UserActivityLogRecordDynamicSqlSupport.id, isIn(ids)) .where(UserActivityLogRecordDynamicSqlSupport.id, isIn(ids))
@ -438,12 +441,19 @@ public class UserActivityLogDAOImpl implements UserActivityLogDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<UserActivityLog>> allOf(final Set<Long> pks) { public Result<Collection<UserActivityLog>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.toDomainModel( return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.toDomainModel(
this.userService.getCurrentUser().institutionId(), this.userService.getCurrentUser().institutionId(),
this.userLogRecordMapper.selectByExample() this.userLogRecordMapper.selectByExample()
.where(UserActivityLogRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(UserActivityLogRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute())); .execute());
});
} }
@Override @Override

View file

@ -324,6 +324,10 @@ public class UserDAOImpl implements UserDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
final UserRecord userRecord = new UserRecord( final UserRecord userRecord = new UserRecord(
null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null, null,
BooleanUtils.toIntegerObject(active)); BooleanUtils.toIntegerObject(active));
@ -363,6 +367,9 @@ public class UserDAOImpl implements UserDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
// get all user records for later processing // get all user records for later processing
final List<UserRecord> users = this.userRecordMapper.selectByExample() final List<UserRecord> users = this.userRecordMapper.selectByExample()
@ -413,14 +420,21 @@ public class UserDAOImpl implements UserDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<UserInfo>> allOf(final Set<Long> pks) { public Result<Collection<UserInfo>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.userRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.userRecordMapper.selectByExample()
.where(InstitutionRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(InstitutionRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(this::toDomainModel) .map(this::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override
@ -429,6 +443,11 @@ public class UserDAOImpl implements UserDAO {
return UserDAO.super.extractPKsFromKeys(keys); return UserDAO.super.extractPKsFromKeys(keys);
} else { } else {
try { try {
if (keys == null || keys.isEmpty()) {
return Collections.emptySet();
}
final List<String> uuids = keys.stream() final List<String> uuids = keys.stream()
.map(key -> key.modelId) .map(key -> key.modelId)
.collect(Collectors.toList()); .collect(Collectors.toList());

View file

@ -12,6 +12,7 @@ import static org.mybatis.dynamic.sql.SqlBuilder.isIn;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
@ -65,14 +66,21 @@ public class ViewDAOImpl implements ViewDAO {
@Override @Override
@Transactional(readOnly = true) @Transactional(readOnly = true)
public Result<Collection<View>> allOf(final Set<Long> pks) { public Result<Collection<View>> allOf(final Set<Long> pks) {
return Result.tryCatch(() -> this.viewRecordMapper.selectByExample() return Result.tryCatch(() -> {
if (pks == null || pks.isEmpty()) {
return Collections.emptyList();
}
return this.viewRecordMapper.selectByExample()
.where(ViewRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks))) .where(ViewRecordDynamicSqlSupport.id, isIn(new ArrayList<>(pks)))
.build() .build()
.execute() .execute()
.stream() .stream()
.map(ViewDAOImpl::toDomainModel) .map(ViewDAOImpl::toDomainModel)
.flatMap(DAOLoggingSupport::logAndSkipOnError) .flatMap(DAOLoggingSupport::logAndSkipOnError)
.collect(Collectors.toList())); .collect(Collectors.toList());
});
} }
@Override @Override
@ -212,6 +220,9 @@ public class ViewDAOImpl implements ViewDAO {
return Result.tryCatch(() -> { return Result.tryCatch(() -> {
final List<Long> ids = extractListOfPKs(all); final List<Long> ids = extractListOfPKs(all);
if (ids == null || ids.isEmpty()) {
return Collections.emptyList();
}
this.viewRecordMapper.deleteByExample() this.viewRecordMapper.deleteByExample()
.where(ViewRecordDynamicSqlSupport.id, isIn(ids)) .where(ViewRecordDynamicSqlSupport.id, isIn(ids))

View file

@ -282,7 +282,7 @@ sebserver.useraccount.delete.form.deleteExams.tooltip=This includes all Exams wh
sebserver.useraccount.delete.form.action.delete=Delete sebserver.useraccount.delete.form.action.delete=Delete
sebserver.useraccount.delete.form.action.report=Show Report sebserver.useraccount.delete.form.action.report=Show Report
sebserver.useraccount.delete.confirm.title=Deletion Successful sebserver.useraccount.delete.confirm.title=Deletion Successful
sebserver.useraccount.delete.confirm.message=The User Account ({0}) was successfully deleted.<br/>Also the following number dependencies where successfully deleted: {1}.<br/><br/>And there where {2} errors. sebserver.useraccount.delete.confirm.message=The User Account ({0}) was successfully deleted.<br/>Also the following number of dependencies where successfully deleted: {1}.<br/><br/>And there where {2} errors.
sebserver.useraccount.delete.confirm.message.noDeps=The User Account ({0}) was successfully deleted. sebserver.useraccount.delete.confirm.message.noDeps=The User Account ({0}) was successfully deleted.
################################ ################################
# LMS Setup # LMS Setup