diff --git a/src/main/java/ch/ethz/seb/sebserver/gui/content/monitoring/FinishedExam.java b/src/main/java/ch/ethz/seb/sebserver/gui/content/monitoring/FinishedExam.java index d25a1aae..9839d159 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gui/content/monitoring/FinishedExam.java +++ b/src/main/java/ch/ethz/seb/sebserver/gui/content/monitoring/FinishedExam.java @@ -16,6 +16,7 @@ import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Lazy; import org.springframework.stereotype.Component; +import ch.ethz.seb.sebserver.gbl.Constants; import ch.ethz.seb.sebserver.gbl.api.API; import ch.ethz.seb.sebserver.gbl.model.Domain; import ch.ethz.seb.sebserver.gbl.model.EntityKey; @@ -156,10 +157,11 @@ public class FinishedExam implements TemplateComposer { if (indicator.type == IndicatorType.LAST_PING || indicator.type == IndicatorType.NONE) { return; } - tableBuilder.withColumn(new ColumnDefinition<>( - indicator.name, + tableBuilder.withColumn(new ColumnDefinition( + ClientConnectionData.ATTR_INDICATOR_VALUE + Constants.UNDERLINE + indicator.id, new LocTextKey(indicator.name), - cc -> cc.getIndicatorDisplayValue(indicator))); + cc -> cc.getIndicatorDisplayValue(indicator)) + .sortable()); }); final EntityTable table = tableBuilder.compose(pageContext.copyOf(content)); diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/weblayer/api/ClientConnectionController.java b/src/main/java/ch/ethz/seb/sebserver/webservice/weblayer/api/ClientConnectionController.java index daef8596..bed39fc5 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/weblayer/api/ClientConnectionController.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/weblayer/api/ClientConnectionController.java @@ -30,6 +30,7 @@ import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; +import ch.ethz.seb.sebserver.gbl.Constants; import ch.ethz.seb.sebserver.gbl.api.API; import ch.ethz.seb.sebserver.gbl.api.API.BulkActionType; import ch.ethz.seb.sebserver.gbl.api.EntityType; @@ -82,34 +83,6 @@ public class ClientConnectionController extends ReadonlyEntityController - * GET /{api}/{domain-entity-name} - *

- * For example for the "exam" domain-entity - * GET /admin-api/v1/exam - * GET /admin-api/v1/exam?page_number=2&page_size=10&sort=-name - * GET /admin-api/v1/exam?name=seb&active=true - *

- * Sorting: the sort parameter to sort the list of entities before paging - * the sort parameter is the name of the entity-model attribute to sort with a leading '-' sign for - * descending sort order. Note that not all entity-model attribute are suited for sorting while the most - * are. - *

- * Filter: The filter attributes accepted by this API depend on the actual entity model (domain object) - * and are of the form [domain-attribute-name]=[filter-value]. E.g.: name=abc or type=EXAM. Usually - * filter attributes of text type are treated as SQL wildcard with %[text]% to filter all text containing - * a given text-snippet. - * - * @param institutionId The institution identifier of the request. - * Default is the institution identifier of the institution of the current user - * @param pageNumber the number of the page that is requested - * @param pageSize the size of the page that is requested - * @param sort the sort parameter to sort the list of entities before paging - * the sort parameter is the name of the entity-model attribute to sort with a leading '-' sign for - * descending sort order. - * @param allRequestParams a MultiValueMap of all request parameter that is used for filtering. - * @return Page of domain-model-entities of specified type */ @Override @RequestMapping( method = RequestMethod.GET, @@ -299,12 +272,8 @@ public class ClientConnectionController extends ReadonlyEntityController getClientConnectionDataFilter(final FilterMap filterMap) { - final String infoFilter = filterMap.getString(ClientConnection.FILTER_ATTR_INFO); - Predicate filter = Utils.truePredicate(); - if (StringUtils.isNotBlank(infoFilter)) { - filter = c -> c.clientConnection.getInfo() == null || c.clientConnection.getInfo().contains(infoFilter); - } - return filter; + final Predicate clientConnectionFilter = getClientConnectionFilter(filterMap); + return ccd -> clientConnectionFilter.test(ccd.clientConnection); } private static final class ClientConnectionComparator implements Comparator { @@ -338,30 +307,29 @@ public class ClientConnectionController extends ReadonlyEntityController { - final String sortColumn; - final boolean descending; + final ClientConnectionComparator clientConnectionComparator; ClientConnectionDataComparator(final String sort) { - this.sortColumn = PageSortOrder.decode(sort); - this.descending = PageSortOrder.getSortOrder(sort) == PageSortOrder.DESCENDING; + this.clientConnectionComparator = new ClientConnectionComparator(sort); } @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); + if (this.clientConnectionComparator.sortColumn.startsWith(ClientConnectionData.ATTR_INDICATOR_VALUE)) { + try { + final Long iValuePK = Long.valueOf(StringUtils.split( + this.clientConnectionComparator.sortColumn, + Constants.UNDERLINE)[1]); + final Double indicatorValue1 = cc1.getIndicatorValue(iValuePK); + final Double indicatorValue2 = cc2.getIndicatorValue(iValuePK); + final int result = indicatorValue1.compareTo(indicatorValue2); + return (this.clientConnectionComparator.descending) ? -result : result; + } catch (final Exception e) { + this.clientConnectionComparator.compare(cc1.clientConnection, cc2.clientConnection); + } } - return (this.descending) ? -result : result; + + return this.clientConnectionComparator.compare(cc1.clientConnection, cc2.clientConnection); } } }