fixed filter

This commit is contained in:
anhefti 2022-03-28 16:37:13 +02:00
parent bf8b30e061
commit 3744e10406
5 changed files with 127 additions and 35 deletions

2
Jenkinsfile vendored
View file

@ -23,7 +23,7 @@ pipeline {
stage('Reporting') { stage('Reporting') {
steps { steps {
withMaven(maven: 'Maven', options: [findbugsPublisher(disabled: true)]) { withMaven(maven: 'Maven', options: [findbugsPublisher(disabled: true)]) {
sh "mvn --batch-mode -V -U -e pmd:pmd pmd:cpd findbugs:findbugs spotbugs:spotbugs" sh "mvn --batch-mode -V -U -e -P let_reporting pmd:pmd pmd:cpd findbugs:findbugs spotbugs:spotbugs"
} }
} }
} }

View file

@ -129,20 +129,23 @@ public class FinishedExam implements TemplateComposer {
Domain.CLIENT_CONNECTION.ATTR_EXAM_USER_SESSION_ID, Domain.CLIENT_CONNECTION.ATTR_EXAM_USER_SESSION_ID,
TABLE_COLUMN_NAME, TABLE_COLUMN_NAME,
c -> c.clientConnection.getUserSessionId()) c -> c.clientConnection.getUserSessionId())
.withFilter(this.nameFilter)) .withFilter(this.nameFilter)
.sortable())
.withColumn(new ColumnDefinition<ClientConnectionData>( .withColumn(new ColumnDefinition<ClientConnectionData>(
ClientConnection.ATTR_INFO, ClientConnection.ATTR_INFO,
TABLE_COLUMN_INFO, TABLE_COLUMN_INFO,
c -> c.clientConnection.getInfo()) c -> c.clientConnection.getInfo())
.withFilter(this.infoFilter)) .withFilter(this.infoFilter)
.sortable())
.withColumn(new ColumnDefinition<ClientConnectionData>( .withColumn(new ColumnDefinition<ClientConnectionData>(
Domain.CLIENT_CONNECTION.ATTR_STATUS, Domain.CLIENT_CONNECTION.ATTR_STATUS,
TABLE_COLUMN_STATUS, TABLE_COLUMN_STATUS,
row -> this.pageService.getResourceService() row -> this.pageService.getResourceService()
.localizedClientConnectionStatusName(row.clientConnection.getStatus())) .localizedClientConnectionStatusName(row.clientConnection.getStatus()))
.withFilter(this.statusFilter)) .withFilter(this.statusFilter)
.sortable())
.withDefaultAction(t -> actionBuilder .withDefaultAction(t -> actionBuilder
.newAction(ActionDefinition.VIEW_FINISHED_EXAM_CLIENT_CONNECTION) .newAction(ActionDefinition.VIEW_FINISHED_EXAM_CLIENT_CONNECTION)

View file

@ -108,16 +108,17 @@ public interface PaginationService {
* @param pageSize the size of a page * @param pageSize the size of a page
* @param sort the page sort flag * @param sort the page sort flag
* @param all list of all entities, unsorted * @param all list of all entities, unsorted
* @param sorter a sorter function that sorts the list for specific type of entries * @param pageFunction a function that filter and sorts the list for specific type of entries
* @return current page of objects from the sorted list of entities */ * @return current page of objects from the sorted list of entities */
default <T> Page<T> buildPageFromList( default <T> Page<T> buildPageFromList(
final Integer pageNumber, final Integer pageNumber,
final Integer pageSize, final Integer pageSize,
final String sort, final String sort,
final Collection<T> all, final Collection<T> all,
final Function<Collection<T>, List<T>> sorter) { final Function<Collection<T>, List<T>> pageFunction) {
final List<T> sorted = pageFunction.apply(all);
final List<T> sorted = sorter.apply(all);
final int _pageNumber = getPageNumber(pageNumber); final int _pageNumber = getPageNumber(pageNumber);
final int _pageSize = getPageSize(pageSize); final int _pageSize = getPageSize(pageSize);
final int start = (_pageNumber - 1) * _pageSize; final int start = (_pageNumber - 1) * _pageSize;
@ -125,7 +126,10 @@ public interface PaginationService {
if (sorted.size() < end) { if (sorted.size() < end) {
end = sorted.size(); end = sorted.size();
} }
final int numberOfPages = sorted.size() / _pageSize; int numberOfPages = sorted.size() / _pageSize;
if (sorted.size() % _pageSize > 0) {
numberOfPages++;
}
return new Page<>( return new Page<>(
(numberOfPages > 0) ? numberOfPages : 1, (numberOfPages > 0) ? numberOfPages : 1,

View file

@ -9,6 +9,7 @@
package ch.ethz.seb.sebserver.webservice.servicelayer.dao; package ch.ethz.seb.sebserver.webservice.servicelayer.dao;
import java.util.Arrays; import java.util.Arrays;
import java.util.Set;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.joda.time.DateTime; import org.joda.time.DateTime;
@ -333,4 +334,11 @@ public class FilterMap extends POSTMapper {
} }
} }
public boolean containsAny(final Set<String> extFilter) {
return extFilter.stream()
.filter(this.params::containsKey)
.findFirst()
.isPresent();
}
} }

View file

@ -8,8 +8,14 @@
package ch.ethz.seb.sebserver.webservice.weblayer.api; package ch.ethz.seb.sebserver.webservice.weblayer.api;
import java.util.Arrays;
import java.util.Collection; import java.util.Collection;
import java.util.Comparator;
import java.util.HashSet;
import java.util.List; import java.util.List;
import java.util.Set;
import java.util.function.Function;
import java.util.function.Predicate;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
@ -27,13 +33,16 @@ import org.springframework.web.bind.annotation.RestController;
import ch.ethz.seb.sebserver.gbl.api.API; import ch.ethz.seb.sebserver.gbl.api.API;
import ch.ethz.seb.sebserver.gbl.api.API.BulkActionType; import ch.ethz.seb.sebserver.gbl.api.API.BulkActionType;
import ch.ethz.seb.sebserver.gbl.api.EntityType; import ch.ethz.seb.sebserver.gbl.api.EntityType;
import ch.ethz.seb.sebserver.gbl.model.Domain;
import ch.ethz.seb.sebserver.gbl.model.EntityDependency; import ch.ethz.seb.sebserver.gbl.model.EntityDependency;
import ch.ethz.seb.sebserver.gbl.model.Page; import ch.ethz.seb.sebserver.gbl.model.Page;
import ch.ethz.seb.sebserver.gbl.model.PageSortOrder;
import ch.ethz.seb.sebserver.gbl.model.session.ClientConnection; import ch.ethz.seb.sebserver.gbl.model.session.ClientConnection;
import ch.ethz.seb.sebserver.gbl.model.session.ClientConnectionData; import ch.ethz.seb.sebserver.gbl.model.session.ClientConnectionData;
import ch.ethz.seb.sebserver.gbl.model.user.UserRole; import ch.ethz.seb.sebserver.gbl.model.user.UserRole;
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile; import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
import ch.ethz.seb.sebserver.gbl.util.Result; import ch.ethz.seb.sebserver.gbl.util.Result;
import ch.ethz.seb.sebserver.gbl.util.Utils;
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ClientConnectionRecordDynamicSqlSupport; import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ClientConnectionRecordDynamicSqlSupport;
import ch.ethz.seb.sebserver.webservice.servicelayer.PaginationService; import ch.ethz.seb.sebserver.webservice.servicelayer.PaginationService;
import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.AuthorizationService; import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.AuthorizationService;
@ -52,6 +61,8 @@ public class ClientConnectionController extends ReadonlyEntityController<ClientC
private final SEBClientConnectionService sebClientConnectionService; private final SEBClientConnectionService sebClientConnectionService;
private static final Set<String> EXT_FILTER = new HashSet<>(Arrays.asList(ClientConnection.FILTER_ATTR_INFO));
protected ClientConnectionController( protected ClientConnectionController(
final AuthorizationService authorization, final AuthorizationService authorization,
final BulkActionService bulkActionService, final BulkActionService bulkActionService,
@ -93,15 +104,27 @@ public class ClientConnectionController extends ReadonlyEntityController<ClientC
final FilterMap filterMap = new FilterMap(allRequestParams, request.getQueryString()); final FilterMap filterMap = new FilterMap(allRequestParams, request.getQueryString());
populateFilterMap(filterMap, institutionId, sort); populateFilterMap(filterMap, institutionId, sort);
final Page<ClientConnectionData> page = this.paginationService.getPage( if (StringUtils.isNotBlank(sort) || filterMap.containsAny(EXT_FILTER)) {
pageNumber,
pageSize,
sort,
getSQLTableOfEntity().name(),
() -> getAllData(filterMap))
.getOrThrow();
return page; final Collection<ClientConnectionData> allConnections = getAllData(filterMap)
.getOrThrow();
return this.paginationService.buildPageFromList(
pageNumber,
pageSize,
sort,
allConnections,
pageFunction(filterMap, sort));
} else {
return this.paginationService.getPage(
pageNumber,
pageSize,
sort,
getSQLTableOfEntity().name(),
() -> getAllData(filterMap))
.getOrThrow();
}
} }
@RequestMapping( @RequestMapping(
@ -115,25 +138,17 @@ public class ClientConnectionController extends ReadonlyEntityController<ClientC
.getOrThrow(); .getOrThrow();
} }
private Result<Collection<ClientConnectionData>> getAllData(final FilterMap filterMap) { // @Override
return getAll(filterMap) // protected Result<Collection<ClientConnection>> getAll(final FilterMap filterMap) {
.map(connection -> connection.stream() // final String infoFilter = filterMap.getString(ClientConnection.FILTER_ATTR_INFO);
.map(this.sebClientConnectionService::getIndicatorValues) // if (StringUtils.isNotBlank(infoFilter)) {
.flatMap(Result::onErrorLogAndSkip) // return super.getAll(filterMap)
.collect(Collectors.toList())); // .map(all -> all.stream().filter(c -> c.getInfo() == null || c.getInfo().contains(infoFilter))
} // .collect(Collectors.toList()));
// }
@Override //
protected Result<Collection<ClientConnection>> getAll(final FilterMap filterMap) { // return super.getAll(filterMap);
final String infoFilter = filterMap.getString(ClientConnection.FILTER_ATTR_INFO); // }
if (StringUtils.isNotBlank(infoFilter)) {
return super.getAll(filterMap)
.map(all -> all.stream().filter(c -> c.getInfo() == null || c.getInfo().contains(infoFilter))
.collect(Collectors.toList()));
}
return super.getAll(filterMap);
}
@Override @Override
public Collection<EntityDependency> getDependencies( public Collection<EntityDependency> getDependencies(
@ -174,4 +189,66 @@ public class ClientConnectionController extends ReadonlyEntityController<ClientC
UserRole.EXAM_ADMIN, UserRole.EXAM_ADMIN,
UserRole.EXAM_SUPPORTER); UserRole.EXAM_SUPPORTER);
} }
private Result<Collection<ClientConnectionData>> getAllData(final FilterMap filterMap) {
return getAll(filterMap)
.map(connections -> connections.stream()
.map(this.sebClientConnectionService::getIndicatorValues)
.flatMap(Result::onErrorLogAndSkip)
.collect(Collectors.toList()));
}
private Function<Collection<ClientConnectionData>, List<ClientConnectionData>> pageFunction(
final FilterMap filterMap,
final String sort) {
return connections -> {
final List<ClientConnectionData> filtered = connections.stream()
.filter(getFilter(filterMap))
.collect(Collectors.toList());
if (StringUtils.isNotBlank(sort)) {
filtered.sort(new ClientConnectionDataComparator(sort));
}
return filtered;
};
}
private Predicate<ClientConnectionData> getFilter(final FilterMap filterMap) {
final String infoFilter = filterMap.getString(ClientConnection.FILTER_ATTR_INFO);
Predicate<ClientConnectionData> filter = Utils.truePredicate();
if (StringUtils.isNotBlank(infoFilter)) {
filter = c -> c.clientConnection.getInfo() == null || c.clientConnection.getInfo().contains(infoFilter);
}
return filter;
}
private static final class ClientConnectionDataComparator implements Comparator<ClientConnectionData> {
final String sortColumn;
final boolean descending;
ClientConnectionDataComparator(final String sort) {
this.sortColumn = PageSortOrder.decode(sort);
this.descending = PageSortOrder.getSortOrder(sort) == PageSortOrder.DESCENDING;
}
@Override
public int compare(final ClientConnectionData cc1, final ClientConnectionData cc2) {
int result = 0;
if (Domain.CLIENT_CONNECTION.ATTR_EXAM_USER_SESSION_ID.equals(this.sortColumn)) {
result = cc1.clientConnection.userSessionId
.compareTo(cc2.clientConnection.userSessionId);
} else if (ClientConnection.ATTR_INFO.equals(this.sortColumn)) {
result = cc1.clientConnection.getInfo().compareTo(cc2.clientConnection.getInfo());
} else if (Domain.CLIENT_CONNECTION.ATTR_STATUS.equals(this.sortColumn)) {
result = cc1.clientConnection.getStatus()
.compareTo(cc2.clientConnection.getStatus());
} else {
result = cc1.clientConnection.userSessionId
.compareTo(cc2.clientConnection.userSessionId);
}
return (this.descending) ? -result : result;
}
}
} }