org.infinispan.client.hotrod.HotRodMutinyCache Maven / Gradle / Ivy
The newest version!
package org.infinispan.client.hotrod;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.Flow;
import org.infinispan.api.Experimental;
import org.infinispan.api.async.AsyncCacheEntryProcessor;
import org.infinispan.api.common.CacheEntry;
import org.infinispan.api.common.CacheEntryVersion;
import org.infinispan.api.common.CacheOptions;
import org.infinispan.api.common.CacheWriteOptions;
import org.infinispan.api.common.MutableCacheEntry;
import org.infinispan.api.common.events.cache.CacheEntryEvent;
import org.infinispan.api.common.events.cache.CacheEntryEventType;
import org.infinispan.api.common.events.cache.CacheListenerOptions;
import org.infinispan.api.common.process.CacheEntryProcessorContext;
import org.infinispan.api.common.process.CacheEntryProcessorResult;
import org.infinispan.api.configuration.CacheConfiguration;
import org.infinispan.api.mutiny.MutinyCache;
import org.infinispan.api.mutiny.MutinyCacheEntryProcessor;
import org.infinispan.api.mutiny.MutinyContainer;
import org.infinispan.api.mutiny.MutinyQuery;
import org.infinispan.api.mutiny.MutinyStreamingCache;
import org.infinispan.client.hotrod.impl.InternalRemoteCache;
import io.smallrye.mutiny.Multi;
import io.smallrye.mutiny.Uni;
/**
* @since 14.0
**/
@Experimental
final class HotRodMutinyCache implements MutinyCache {
private final HotRod hotrod;
private final InternalRemoteCache remoteCache;
HotRodMutinyCache(HotRod hotrod, InternalRemoteCache remoteCache) {
this.hotrod = hotrod;
this.remoteCache = remoteCache;
}
@Override
public String name() {
return remoteCache.getName();
}
@Override
public Uni configuration() {
return Uni.createFrom().completionStage(remoteCache.configuration());
}
@Override
public MutinyContainer container() {
return hotrod.mutiny();
}
@Override
public Uni get(K key, CacheOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.get(key, options));
}
@Override
public Uni> getEntry(K key, CacheOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.getEntry(key, options));
}
@Override
public Uni> putIfAbsent(K key, V value, CacheWriteOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.putIfAbsent(key, value, options));
}
@Override
public Uni setIfAbsent(K key, V value, CacheWriteOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.setIfAbsent(key, value, options));
}
@Override
public Uni> put(K key, V value, CacheWriteOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.put(key, value, options));
}
@Override
public Uni set(K key, V value, CacheWriteOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.set(key, value, options));
}
@Override
public Uni remove(K key, CacheOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.remove(key, options));
}
@Override
public Uni> getAndRemove(K key, CacheOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.getAndRemove(key, options));
}
@Override
public Multi keys(CacheOptions options) {
return Multi.createFrom().publisher(remoteCache.keys(options));
}
@Override
public Multi> entries(CacheOptions options) {
return Multi.createFrom().publisher(remoteCache.entries(options));
}
@Override
public Multi> getAll(Set keys, CacheOptions options) {
return Multi.createFrom().publisher(remoteCache.getAll(keys, options));
}
@Override
public Multi> getAll(CacheOptions options, K[] keys) {
return Multi.createFrom().publisher(remoteCache.getAll(options, keys));
}
@Override
public Uni putAll(Multi> entries, CacheWriteOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.putAll(entries.convert().toPublisher(), options));
}
@Override
public Uni putAll(Map map, CacheWriteOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.putAll(map, options));
}
@Override
public Uni replace(K key, V value, CacheEntryVersion version, CacheWriteOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.replace(key, value, version, options));
}
@Override
public Uni> getOrReplaceEntry(K key, V value, CacheEntryVersion version, CacheWriteOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.getOrReplaceEntry(key, value, version, options));
}
@Override
public Multi removeAll(Set keys, CacheWriteOptions options) {
return Multi.createFrom().publisher(remoteCache.removeAll(keys, options));
}
@Override
public Multi removeAll(Multi keys, CacheWriteOptions options) {
return Multi.createFrom().publisher(remoteCache.removeAll(keys.convert().toPublisher(), options));
}
@Override
public Multi> getAndRemoveAll(Multi keys, CacheWriteOptions options) {
return Multi.createFrom().publisher(remoteCache.getAndRemoveAll(keys.convert().toPublisher(), options));
}
@Override
public Uni estimateSize(CacheOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.estimateSize(options));
}
@Override
public Uni clear(CacheOptions options) {
return Uni.createFrom().completionStage(() -> remoteCache.clear(options));
}
@Override
public MutinyQuery query(String query, CacheOptions options) {
return new HotRodMutinyQuery<>();
}
@Override
public Multi> listen(CacheListenerOptions options, CacheEntryEventType... types) {
return Multi.createFrom().publisher(remoteCache.listen(options, types));
}
@Override
public Multi> process(Set keys, MutinyCacheEntryProcessor processor, CacheOptions options) {
return Multi.createFrom().publisher(remoteCache.process(keys, new MutinyToAsyncCacheEntryProcessor<>(processor), options));
}
@Override
public MutinyStreamingCache streaming() {
return new HotRodMutinyStreamingCache<>();
}
private record MutinyToAsyncCacheEntryProcessor(MutinyCacheEntryProcessor processor) implements AsyncCacheEntryProcessor {
@Override
public Flow.Publisher> process(Flow.Publisher> entries, CacheEntryProcessorContext context) {
return processor.process(Multi.createFrom().publisher(entries), context).convert().toPublisher();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy