SEBSERV-240 finished
This commit is contained in:
parent
085ec45fb1
commit
1c48526fce
2 changed files with 24 additions and 54 deletions
|
@ -16,6 +16,7 @@ import org.springframework.beans.factory.annotation.Value;
|
||||||
import org.springframework.context.annotation.Lazy;
|
import org.springframework.context.annotation.Lazy;
|
||||||
import org.springframework.stereotype.Component;
|
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.api.API;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.Domain;
|
import ch.ethz.seb.sebserver.gbl.model.Domain;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
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) {
|
if (indicator.type == IndicatorType.LAST_PING || indicator.type == IndicatorType.NONE) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
tableBuilder.withColumn(new ColumnDefinition<>(
|
tableBuilder.withColumn(new ColumnDefinition<ClientConnectionData>(
|
||||||
indicator.name,
|
ClientConnectionData.ATTR_INDICATOR_VALUE + Constants.UNDERLINE + indicator.id,
|
||||||
new LocTextKey(indicator.name),
|
new LocTextKey(indicator.name),
|
||||||
cc -> cc.getIndicatorDisplayValue(indicator)));
|
cc -> cc.getIndicatorDisplayValue(indicator))
|
||||||
|
.sortable());
|
||||||
});
|
});
|
||||||
|
|
||||||
final EntityTable<ClientConnectionData> table = tableBuilder.compose(pageContext.copyOf(content));
|
final EntityTable<ClientConnectionData> table = tableBuilder.compose(pageContext.copyOf(content));
|
||||||
|
|
|
@ -30,6 +30,7 @@ import org.springframework.web.bind.annotation.RequestMethod;
|
||||||
import org.springframework.web.bind.annotation.RequestParam;
|
import org.springframework.web.bind.annotation.RequestParam;
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
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;
|
||||||
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;
|
||||||
|
@ -82,34 +83,6 @@ public class ClientConnectionController extends ReadonlyEntityController<ClientC
|
||||||
this.sebClientConnectionService = sebClientConnectionService;
|
this.sebClientConnectionService = sebClientConnectionService;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** The generic endpoint to get a Page of domain-entities of a specific type.
|
|
||||||
* </p>
|
|
||||||
* GET /{api}/{domain-entity-name}
|
|
||||||
* </p>
|
|
||||||
* 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
|
|
||||||
* </p>
|
|
||||||
* 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.
|
|
||||||
* </p>
|
|
||||||
* 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
|
@Override
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
method = RequestMethod.GET,
|
method = RequestMethod.GET,
|
||||||
|
@ -299,12 +272,8 @@ public class ClientConnectionController extends ReadonlyEntityController<ClientC
|
||||||
}
|
}
|
||||||
|
|
||||||
private Predicate<ClientConnectionData> getClientConnectionDataFilter(final FilterMap filterMap) {
|
private Predicate<ClientConnectionData> getClientConnectionDataFilter(final FilterMap filterMap) {
|
||||||
final String infoFilter = filterMap.getString(ClientConnection.FILTER_ATTR_INFO);
|
final Predicate<ClientConnection> clientConnectionFilter = getClientConnectionFilter(filterMap);
|
||||||
Predicate<ClientConnectionData> filter = Utils.truePredicate();
|
return ccd -> clientConnectionFilter.test(ccd.clientConnection);
|
||||||
if (StringUtils.isNotBlank(infoFilter)) {
|
|
||||||
filter = c -> c.clientConnection.getInfo() == null || c.clientConnection.getInfo().contains(infoFilter);
|
|
||||||
}
|
|
||||||
return filter;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final class ClientConnectionComparator implements Comparator<ClientConnection> {
|
private static final class ClientConnectionComparator implements Comparator<ClientConnection> {
|
||||||
|
@ -338,30 +307,29 @@ public class ClientConnectionController extends ReadonlyEntityController<ClientC
|
||||||
|
|
||||||
private static final class ClientConnectionDataComparator implements Comparator<ClientConnectionData> {
|
private static final class ClientConnectionDataComparator implements Comparator<ClientConnectionData> {
|
||||||
|
|
||||||
final String sortColumn;
|
final ClientConnectionComparator clientConnectionComparator;
|
||||||
final boolean descending;
|
|
||||||
|
|
||||||
ClientConnectionDataComparator(final String sort) {
|
ClientConnectionDataComparator(final String sort) {
|
||||||
this.sortColumn = PageSortOrder.decode(sort);
|
this.clientConnectionComparator = new ClientConnectionComparator(sort);
|
||||||
this.descending = PageSortOrder.getSortOrder(sort) == PageSortOrder.DESCENDING;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int compare(final ClientConnectionData cc1, final ClientConnectionData cc2) {
|
public int compare(final ClientConnectionData cc1, final ClientConnectionData cc2) {
|
||||||
int result = 0;
|
if (this.clientConnectionComparator.sortColumn.startsWith(ClientConnectionData.ATTR_INDICATOR_VALUE)) {
|
||||||
if (Domain.CLIENT_CONNECTION.ATTR_EXAM_USER_SESSION_ID.equals(this.sortColumn)) {
|
try {
|
||||||
result = cc1.clientConnection.userSessionId
|
final Long iValuePK = Long.valueOf(StringUtils.split(
|
||||||
.compareTo(cc2.clientConnection.userSessionId);
|
this.clientConnectionComparator.sortColumn,
|
||||||
} else if (ClientConnection.ATTR_INFO.equals(this.sortColumn)) {
|
Constants.UNDERLINE)[1]);
|
||||||
result = cc1.clientConnection.getInfo().compareTo(cc2.clientConnection.getInfo());
|
final Double indicatorValue1 = cc1.getIndicatorValue(iValuePK);
|
||||||
} else if (Domain.CLIENT_CONNECTION.ATTR_STATUS.equals(this.sortColumn)) {
|
final Double indicatorValue2 = cc2.getIndicatorValue(iValuePK);
|
||||||
result = cc1.clientConnection.getStatus()
|
final int result = indicatorValue1.compareTo(indicatorValue2);
|
||||||
.compareTo(cc2.clientConnection.getStatus());
|
return (this.clientConnectionComparator.descending) ? -result : result;
|
||||||
} else {
|
} catch (final Exception e) {
|
||||||
result = cc1.clientConnection.userSessionId
|
this.clientConnectionComparator.compare(cc1.clientConnection, cc2.clientConnection);
|
||||||
.compareTo(cc2.clientConnection.userSessionId);
|
|
||||||
}
|
}
|
||||||
return (this.descending) ? -result : result;
|
}
|
||||||
|
|
||||||
|
return this.clientConnectionComparator.compare(cc1.clientConnection, cc2.clientConnection);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue