/* * Copyright 2016 the original author or 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 * * http://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 org.springframework.data.gemfire.search.lucene; import java.util.List; import org.apache.geode.cache.lucene.LuceneQueryProvider; import org.springframework.data.domain.Page; /** * The {@link ProjectingLuceneOperations} interface defines a contract for implementing classes to execute * Lucene data access operations and mapping the results to entity domain {@link Class types}. * * @author John Blum * @see java.util.List * @see org.springframework.data.domain.Page * @see org.springframework.data.gemfire.search.lucene.LuceneOperations * @see org.apache.geode.cache.lucene.LuceneQueryProvider * @since 1.1.0 */ @SuppressWarnings("unused") public interface ProjectingLuceneOperations extends LuceneOperations { /** * Executes the given {@link String query} with the results projected as instances of * the {@link Class projectionType}. * * @param <T> {@link Class} type of the projection. * @param query Lucene {@link String query} to execute. * @param defaultField {@link String} specifying the default field used in Lucene queries when a field * is not explicitly defined in the Lucene query clause. * @param projectionType {@link Class} type of the individual elements in the query results. * @return a {@link List} of Lucene query results projected as instances of {@link Class projectionType}. * @see #query(String, String, int, Class) * @see java.util.List */ default <T> List<T> query(String query, String defaultField, Class<T> projectionType) { return query(query, defaultField, DEFAULT_RESULT_LIMIT, projectionType); } /** * Executes the given {@link String query} with the limited results projected as instances of * the {@link Class projectionType}. * * @param <T> {@link Class} type of the projection. * @param query Lucene {@link String query} to execute. * @param defaultField {@link String} specifying the default field used in Lucene queries when a field * is not explicitly defined in the Lucene query clause. * @param resultLimit limit on the number of query results to return. * @param projectionType {@link Class} type of the individual elements in the query results. * @return a {@link List} of Lucene query results projected as instances of {@link Class projectionType}. * @see #query(String, String, int, Class) * @see java.util.List */ <T> List<T> query(String query, String defaultField, int resultLimit, Class<T> projectionType); /** * Executes the given {@link String query} with the limited results projected as instances of * the {@link Class projectionType}. * * @param <T> {@link Class} type of the projection. * @param query Lucene {@link String query} to execute. * @param defaultField {@link String} specifying the default field used in Lucene queries when a field * is not explicitly defined in the Lucene query clause. * @param resultLimit limit on the number of query results to return. * @param pageSize number of results on a {@link Page}. * @param projectionType {@link Class} type of the individual elements in the query results. * @return the first {@link Page} of results returned from the Lucene query. * @see org.springframework.data.domain.Page */ <T> Page<T> query(String query, String defaultField, int resultLimit, int pageSize, Class<T> projectionType); /** * Executes the provided {@link String query} with the results projected as instances of * the {@link Class projectionType}. * * @param <T> {@link Class} type of the projection. * @param queryProvider {@link LuceneQueryProvider} providing the Lucene {@link String query} to execute. * @param projectionType {@link Class} type of the individual elements in the query results. * @return a {@link List} of Lucene query results projected as instances of {@link Class projectionType}. * @see org.apache.geode.cache.lucene.LuceneQueryProvider * @see #query(LuceneQueryProvider, int, Class) * @see java.util.List */ default <T> List<T> query(LuceneQueryProvider queryProvider, Class<T> projectionType) { return query(queryProvider, DEFAULT_RESULT_LIMIT, projectionType); } /** * Executes the provided {@link String query} with the limited results projected as instances of * the {@link Class projectionType}. * * @param <T> {@link Class} type of the projection. * @param queryProvider {@link LuceneQueryProvider} providing the Lucene {@link String query} to execute. * @param resultLimit limit on the number of query results to return. * @param projectionType {@link Class} type of the individual elements in the query results. * @return a {@link List} of Lucene query results projected as instances of {@link Class projectionType}. * @see org.apache.geode.cache.lucene.LuceneQueryProvider * @see java.util.List */ <T> List<T> query(LuceneQueryProvider queryProvider, int resultLimit, Class<T> projectionType); /** * Executes the provided {@link String query} with the limited results projected as instances of * the {@link Class projectionType}. * * @param <T> {@link Class} type of the projection. * @param queryProvider {@link LuceneQueryProvider} providing the Lucene {@link String query} to execute. * @param resultLimit limit on the number of query results to return. * @param pageSize number of results on a {@link Page}. * @param projectionType {@link Class} type of the individual elements in the query results. * @return the first {@link Page} of results returned from the Lucene query. * @see org.apache.geode.cache.lucene.LuceneQueryProvider * @see org.springframework.data.domain.Page */ <T> Page<T> query(LuceneQueryProvider queryProvider, int resultLimit, int pageSize, Class<T> projectionType); }