io.micronaut.data.model.Sort Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of micronaut-data-model Show documentation
Show all versions of micronaut-data-model Show documentation
Data Repository Support for Micronaut
/*
* Copyright 2017-2020 original authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.micronaut.data.model;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonProperty;
import io.micronaut.context.annotation.DefaultImplementation;
import io.micronaut.core.annotation.Creator;
import io.micronaut.core.annotation.NonNull;
import io.micronaut.core.annotation.Nullable;
import io.micronaut.core.util.ArgumentUtils;
import io.micronaut.core.util.ArrayUtils;
import io.micronaut.core.util.CollectionUtils;
import io.micronaut.serde.annotation.Serdeable;
import java.util.Arrays;
import java.util.List;
import java.util.Objects;
/**
* An interface for objects that can be sorted. Sorted instances are immutable and all mutating operations on this interface return a new instance.
*
* @author graemerocher
* @since 1.0
*/
@JsonIgnoreProperties(ignoreUnknown = true)
@Serdeable
@DefaultImplementation(DefaultSort.class)
public interface Sort {
/**
* Constant for unsorted.
*/
Sort UNSORTED = new DefaultSort();
/**
* @return Is sorting applied
*/
@JsonIgnore
boolean isSorted();
/**
* Orders by the specified property name (defaults to ascending).
*
* @param propertyName The property name to order by
* @return A new sort with the order applied
*/
@NonNull
Sort order(@NonNull String propertyName);
/**
* Adds an order object.
*
* @param order The order object
* @return A new sort with the order applied
*/
@NonNull Sort order(@NonNull Sort.Order order);
/**
* Adds an orders.
*
* @param orders The orders
* @return A new sort with the order applied
* @since 4.10
*/
@NonNull
default Sort orders(@NonNull List orders) {
for (Order order : orders) {
order(order);
}
return this;
}
/**
* Orders by the specified property name and direction.
*
* @param propertyName The property name to order by
* @param direction Either "asc" for ascending or "desc" for descending
*
* @return A new sort with the order applied
*/
@NonNull Sort order(@NonNull String propertyName, @NonNull Sort.Order.Direction direction);
/**
* @return The order definitions for this sort.
*/
@NonNull List getOrderBy();
/**
* @return Default unsorted sort instance.
*/
static Sort unsorted() {
return UNSORTED;
}
/**
* Create a sort from the given list of orders.
*
* @param orderList The order list
* @return The sort
*/
@JsonCreator
static @NonNull Sort of(
@JsonProperty("orderBy") @Nullable List orderList) {
if (CollectionUtils.isEmpty(orderList)) {
return UNSORTED;
}
return new DefaultSort(orderList);
}
/**
* Creates a sort from an array orders.
* @param orders The orders
* @return The orders
*/
static @NonNull Sort of(Order... orders) {
if (ArrayUtils.isEmpty(orders)) {
return UNSORTED;
} else {
return new DefaultSort(Arrays.asList(orders));
}
}
/**
* The ordering of results.
*/
@Serdeable
class Order {
private final String property;
private final Direction direction;
private final boolean ignoreCase;
/**
* Constructs an order for the given property in ascending order.
* @param property The property
*/
public Order(@NonNull String property) {
this(property, Direction.ASC, false);
}
/**
* Constructs an order for the given property with the given direction.
* @param property The property
* @param direction The direction
* @param ignoreCase Whether to ignore case
*/
@JsonCreator
@Creator
public Order(
@JsonProperty("property") @NonNull String property,
@JsonProperty("direction") @NonNull Direction direction,
@JsonProperty("ignoreCase") boolean ignoreCase) {
ArgumentUtils.requireNonNull("direction", direction);
ArgumentUtils.requireNonNull("property", property);
this.direction = direction;
this.property = property;
this.ignoreCase = ignoreCase;
}
/**
* @return Whether to ignore case when sorting
*/
public boolean isIgnoreCase() {
return ignoreCase;
}
/**
* @return The direction order by
*/
public Direction getDirection() {
return direction;
}
/**
* @return The property name to order by
*/
public String getProperty() {
return property;
}
/**
* Create an order that is reversed to current.
*
* @return A new instance of order that is reversed.
*/
public Order reverse() {
return new Order(
property,
direction == Direction.ASC ? Direction.DESC : Direction.ASC,
ignoreCase
);
}
/**
* Creates a new order for the given property in descending order.
*
* @param property The property
* @return The order instance
*/
public static Order desc(String property) {
return new Order(property, Direction.DESC, false);
}
/**
* Creates a new order for the given property in ascending order.
*
* @param property The property
* @return The order instance
*/
public static Order asc(String property) {
return new Order(property, Direction.ASC, false);
}
/**
* Creates a new order for the given property in descending order.
*
* @param property The property
* @param ignoreCase Whether to ignore case
* @return The order instance
*/
public static Order desc(String property, boolean ignoreCase) {
return new Order(property, Direction.DESC, ignoreCase);
}
/**
* Creates a new order for the given property in ascending order.
*
* @param property The property
* @param ignoreCase Whether to ignore case
* @return The order instance
*/
public static Order asc(String property, boolean ignoreCase) {
return new Order(property, Direction.ASC, ignoreCase);
}
/**
* @return Is the order ascending
*/
public boolean isAscending() {
return getDirection() == Direction.ASC;
}
/**
* Represents the direction of the ordering.
*/
public enum Direction {
ASC, DESC
}
@Override
public String toString() {
return "SORT{" + property
+ (direction == Direction.ASC ? ", ASC" : ", DESC")
+ (ignoreCase ? ", ignoreCase" : "")
+ ")";
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
Order order = (Order) o;
return ignoreCase == order.ignoreCase &&
property.equals(order.property) &&
direction == order.direction;
}
@Override
public int hashCode() {
return Objects.hash(property, direction, ignoreCase);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy