fixed filter
This commit is contained in:
parent
bf8b30e061
commit
3744e10406
5 changed files with 127 additions and 35 deletions
2
Jenkinsfile
vendored
2
Jenkinsfile
vendored
|
@ -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"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)) {
|
||||||
|
|
||||||
|
final Collection<ClientConnectionData> allConnections = getAllData(filterMap)
|
||||||
|
.getOrThrow();
|
||||||
|
|
||||||
|
return this.paginationService.buildPageFromList(
|
||||||
|
pageNumber,
|
||||||
|
pageSize,
|
||||||
|
sort,
|
||||||
|
allConnections,
|
||||||
|
pageFunction(filterMap, sort));
|
||||||
|
} else {
|
||||||
|
|
||||||
|
return this.paginationService.getPage(
|
||||||
pageNumber,
|
pageNumber,
|
||||||
pageSize,
|
pageSize,
|
||||||
sort,
|
sort,
|
||||||
getSQLTableOfEntity().name(),
|
getSQLTableOfEntity().name(),
|
||||||
() -> getAllData(filterMap))
|
() -> getAllData(filterMap))
|
||||||
.getOrThrow();
|
.getOrThrow();
|
||||||
|
}
|
||||||
return page;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@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;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue