org.infinispan.query.clustered.commandworkers.CQCreateLazyQuery Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of infinispan-embedded-query
Show all versions of infinispan-embedded-query
Infinispan Embedded Query All-in-One module
package org.infinispan.query.clustered.commandworkers;
import org.apache.lucene.search.TopDocs;
import org.hibernate.search.engine.spi.SearchFactoryImplementor;
import org.hibernate.search.query.engine.spi.DocumentExtractor;
import org.infinispan.query.clustered.QueryBox;
import org.infinispan.query.clustered.QueryResponse;
/**
* CQCreateLazyQuery.
*
* Creates a DocumentExtractor and register it on the node QueryBox.
*
* @author Israel Lacerra
* @since 5.1
*/
public class CQCreateLazyQuery extends ClusteredQueryCommandWorker {
@Override
public QueryResponse perform() {
query.afterDeserialise((SearchFactoryImplementor) getSearchFactory());
DocumentExtractor extractor = query.queryDocumentExtractor();
int resultSize = query.queryResultSize();
QueryBox box = getQueryBox();
// registering...
box.put(lazyQueryId, extractor);
// returning the QueryResponse
TopDocs topDocs = extractor.getTopDocs();
QueryResponse queryResponse = new QueryResponse(topDocs, box.getMyId(), resultSize);
queryResponse.setAddress(cache.getAdvancedCache().getRpcManager().getAddress());
return queryResponse;
}
}