
org.infinispan.query.impl.massindex.IndexUpdater 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
The newest version!
package org.infinispan.query.impl.massindex;
import org.hibernate.search.backend.UpdateLuceneWork;
import org.hibernate.search.bridge.spi.ConversionContext;
import org.hibernate.search.bridge.util.impl.ContextualExceptionBridgeHelper;
import org.hibernate.search.engine.spi.DocumentBuilderIndexedEntity;
import org.hibernate.search.engine.spi.EntityIndexBinding;
import org.hibernate.search.spi.DefaultInstanceInitializer;
import org.hibernate.search.spi.IndexedTypeIdentifier;
import org.hibernate.search.spi.SearchIntegrator;
import org.hibernate.search.spi.impl.PojoIndexedTypeIdentifier;
import org.infinispan.Cache;
import org.infinispan.factories.ComponentRegistry;
import org.infinispan.query.backend.KeyTransformationHandler;
import org.infinispan.query.backend.QueryInterceptor;
import org.infinispan.query.impl.ComponentRegistryUtils;
import org.infinispan.query.logging.Log;
import org.infinispan.util.logging.LogFactory;
/**
* Handle batch updates to an index.
*
* @author gustavonalle
* @since 7.1
*/
public class IndexUpdater {
private static final Log LOG = LogFactory.getLog(IndexUpdater.class, Log.class);
private final SearchIntegrator searchIntegrator;
private final KeyTransformationHandler keyTransformationHandler;
private final ExtendedBatchBackend defaultBatchBackend;
public IndexUpdater(Cache, ?> cache) {
QueryInterceptor queryInterceptor = ComponentRegistryUtils.getQueryInterceptor(cache);
this.searchIntegrator = queryInterceptor.getSearchFactory();
this.keyTransformationHandler = queryInterceptor.getKeyTransformationHandler();
ComponentRegistry componentRegistry = SecurityActions.getCacheComponentRegistry(cache.getAdvancedCache());
DefaultMassIndexerProgressMonitor monitor = new DefaultMassIndexerProgressMonitor(componentRegistry.getTimeService());
this.defaultBatchBackend = new ExtendedBatchBackend(searchIntegrator, monitor);
}
public void flush(IndexedTypeIdentifier entity) {
LOG.flushingIndex(entity.getName());
defaultBatchBackend.flush(entity.asTypeSet());
}
public void purge(IndexedTypeIdentifier entity) {
LOG.purgingIndex(entity.getName());
defaultBatchBackend.purge(entity.asTypeSet());
}
public void waitForAsyncCompletion() {
defaultBatchBackend.awaitAsyncProcessingCompletion();
}
public void updateIndex(Object key, Object value) {
if (value != null) {
if (!Thread.currentThread().isInterrupted()) {
EntityIndexBinding entityIndexBinding = searchIntegrator.getIndexBindings().get(new PojoIndexedTypeIdentifier(value.getClass()));
if (entityIndexBinding == null) {
// it might be possible to receive not-indexes types
return;
}
ConversionContext conversionContext = new ContextualExceptionBridgeHelper();
DocumentBuilderIndexedEntity docBuilder = entityIndexBinding.getDocumentBuilder();
final String idInString = keyTransformationHandler.keyToString(key);
UpdateLuceneWork updateTask = docBuilder.createUpdateWork(
null,
docBuilder.getTypeIdentifier(),
value,
idInString,
idInString,
DefaultInstanceInitializer.DEFAULT_INITIALIZER,
conversionContext
);
try {
defaultBatchBackend.enqueueAsyncWork(updateTask);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy