org.bonitasoft.engine.persistence.QueryOptions Maven / Gradle / Ivy
The newest version!
/**
* Copyright (C) 2019 Bonitasoft S.A.
* Bonitasoft, 32 rue Gustave Eiffel - 38000 Grenoble
* This library is free software; you can redistribute it and/or modify it under the terms
* of the GNU Lesser General Public License as published by the Free Software Foundation
* version 2.1 of the License.
* This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU Lesser General Public License for more details.
* You should have received a copy of the GNU Lesser General Public License along with this
* program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
* Floor, Boston, MA 02110-1301, USA.
**/
package org.bonitasoft.engine.persistence;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/**
* @author Charles Souillard
* @author Matthieu Chaffotte
* @author Elias Ricken de Medeiros
*/
public class QueryOptions implements Serializable {
private static final long serialVersionUID = 8923754215920928153L;
private final int fromIndex;
private final int numberOfResults;
private final List filters;
private final SearchFields multipleFilter;
private final List orderByOptions;
public static final int UNLIMITED_NUMBER_OF_RESULTS = Integer.MAX_VALUE;
public static final QueryOptions ALL_RESULTS = new QueryOptions(0, UNLIMITED_NUMBER_OF_RESULTS);
public static final QueryOptions ONE_RESULT = new QueryOptions(0, 1);
public QueryOptions(final QueryOptions queryOptions) {
super();
fromIndex = queryOptions.getFromIndex();
numberOfResults = queryOptions.getNumberOfResults();
orderByOptions = queryOptions.getOrderByOptions();
filters = queryOptions.getFilters();
multipleFilter = queryOptions.getMultipleFilter();
}
/**
* Just for get number of elements on a table, or if the request is already ordered
*/
public QueryOptions(final int fromIndex, final int numberOfResults) {
super();
this.fromIndex = fromIndex;
this.numberOfResults = numberOfResults;
orderByOptions = Collections.emptyList();
filters = Collections.emptyList();
multipleFilter = null;
}
public QueryOptions(final int fromIndex, final int numberOfResults, final List orderByOptions) {
super();
this.fromIndex = fromIndex;
this.numberOfResults = numberOfResults;
this.orderByOptions = orderByOptions;
filters = Collections.emptyList();
multipleFilter = null;
}
public QueryOptions(final int fromIndex, final int numberOfResults, final List orderByOptions,
final List filters,
final SearchFields multipleFilter) {
super();
this.fromIndex = fromIndex;
this.numberOfResults = numberOfResults;
this.orderByOptions = orderByOptions;
this.filters = filters;
this.multipleFilter = multipleFilter;
}
/**
* Just for get number of elements on a table
*/
public QueryOptions(final List filters, final SearchFields multipleFilter) {
this(0, UNLIMITED_NUMBER_OF_RESULTS, Collections. emptyList(), filters, multipleFilter);
}
public QueryOptions(final int fromIndex, final int numberOfResults, final Class extends PersistentObject> clazz,
final String fieldName,
final OrderByType orderByType) {
super();
this.fromIndex = fromIndex;
this.numberOfResults = numberOfResults;
if (fieldName == null || orderByType == null) {
orderByOptions = Collections.emptyList();
} else {
orderByOptions = new ArrayList();
orderByOptions.add(new OrderByOption(clazz, fieldName, orderByType));
}
filters = Collections.emptyList();
multipleFilter = null;
}
@Deprecated
public QueryOptions(final List orderByOptions) {
super();
fromIndex = 0;
numberOfResults = UNLIMITED_NUMBER_OF_RESULTS;
this.orderByOptions = orderByOptions;
filters = Collections.emptyList();
multipleFilter = null;
}
@Deprecated
public QueryOptions(final Class extends PersistentObject> clazz, final String fieldName,
final OrderByType orderByType) {
super();
fromIndex = 0;
numberOfResults = UNLIMITED_NUMBER_OF_RESULTS;
orderByOptions = new ArrayList();
orderByOptions.add(new OrderByOption(clazz, fieldName, orderByType));
filters = Collections.emptyList();
multipleFilter = null;
}
public int getFromIndex() {
return fromIndex;
}
public int getNumberOfResults() {
return numberOfResults;
}
public List getFilters() {
return filters;
}
public SearchFields getMultipleFilter() {
return multipleFilter;
}
public List getOrderByOptions() {
return orderByOptions;
}
public boolean hasOrderByOptions() {
return orderByOptions != null && !orderByOptions.isEmpty();
}
/**
* Just for get number of elements on a table
*/
public static QueryOptions countQueryOptions() {
return ALL_RESULTS;
}
public static QueryOptions getNextPage(final QueryOptions queryOptions) {
return new QueryOptions(queryOptions.getFromIndex() + queryOptions.getNumberOfResults(),
queryOptions.getNumberOfResults(),
queryOptions.getOrderByOptions(), queryOptions.getFilters(), queryOptions.getMultipleFilter());
}
@Override
public String toString() {
return "QueryOptions [fromIndex=" + fromIndex + ", numberOfResults=" + numberOfResults + ", orderByOptions="
+ orderByOptions + "]";
}
public boolean hasAFilter() {
return filters != null && !filters.isEmpty() || multipleFilter != null;
}
@Override
public boolean equals(final Object o) {
if (this == o) {
return true;
}
if (!(o instanceof QueryOptions)) {
return false;
}
final QueryOptions that = (QueryOptions) o;
if (fromIndex != that.fromIndex) {
return false;
}
if (numberOfResults != that.numberOfResults) {
return false;
}
if (filters != null ? !filters.equals(that.filters) : that.filters != null) {
return false;
}
if (multipleFilter != null ? !multipleFilter.equals(that.multipleFilter) : that.multipleFilter != null) {
return false;
}
if (orderByOptions != null ? !orderByOptions.equals(that.orderByOptions) : that.orderByOptions != null) {
return false;
}
return true;
}
@Override
public int hashCode() {
int result = fromIndex;
result = 31 * result + numberOfResults;
result = 31 * result + (filters != null ? filters.hashCode() : 0);
result = 31 * result + (multipleFilter != null ? multipleFilter.hashCode() : 0);
result = 31 * result + (orderByOptions != null ? orderByOptions.hashCode() : 0);
return result;
}
}