org.redisson.ElementsSubscribeService Maven / Gradle / Ivy
/**
* Copyright (c) 2013-2024 Nikita Koksharov
*
* 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.redisson;
import org.redisson.connection.ServiceManager;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.Map;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.CompletionStage;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.TimeUnit;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.function.Supplier;
/**
* @author Nikita Koksharov
*/
public class ElementsSubscribeService {
private static final Logger log = LoggerFactory.getLogger(ElementsSubscribeService.class);
private final Map> subscribeListeners = new ConcurrentHashMap<>();
private final ServiceManager serviceManager;
public ElementsSubscribeService(ServiceManager serviceManager) {
this.serviceManager = serviceManager;
}
public int subscribeOnElements(Supplier> func, Function> consumer) {
int id = System.identityHashCode(consumer);
CompletableFuture> currentFuture = subscribeListeners.putIfAbsent(id, CompletableFuture.completedFuture(null));
if (currentFuture != null) {
throw new IllegalArgumentException("Consumer object with listener id " + id + " already registered");
}
resubscribe(func, consumer);
return id;
}
@Deprecated
public int subscribeOnElements(Supplier> func, Consumer consumer) {
int id = System.identityHashCode(consumer);
CompletableFuture> currentFuture = subscribeListeners.putIfAbsent(id, CompletableFuture.completedFuture(null));
if (currentFuture != null) {
throw new IllegalArgumentException("Consumer object with listener id " + id + " already registered");
}
resubscribe(func, consumer);
return id;
}
public void unsubscribe(int listenerId) {
CompletableFuture> f = subscribeListeners.remove(listenerId);
if (f != null) {
f.cancel(false);
}
}
@Deprecated
private void resubscribe(Supplier> func, Consumer consumer) {
int listenerId = System.identityHashCode(consumer);
CompletionStage f = (CompletionStage) subscribeListeners.computeIfPresent(listenerId, (k, v) -> {
return func.get().toCompletableFuture();
});
if (f == null) {
return;
}
f.whenComplete((r, e) -> {
if (e != null) {
if (e.getCause() instanceof RedissonShutdownException) {
return;
}
serviceManager.newTimeout(t -> {
resubscribe(func, consumer);
}, 1, TimeUnit.SECONDS);
return;
}
consumer.accept(r);
resubscribe(func, consumer);
});
}
private void resubscribe(Supplier> func, Function> consumer) {
int listenerId = System.identityHashCode(consumer);
CompletionStage f = (CompletionStage) subscribeListeners.computeIfPresent(listenerId, (k, v) -> {
return func.get().toCompletableFuture();
});
if (f == null) {
return;
}
f.thenCompose(consumer).whenComplete((r, ex) -> {
if (ex != null) {
if (ex.getCause() instanceof RedissonShutdownException) {
return;
}
log.error(ex.getMessage(), ex);
serviceManager.newTimeout(t -> {
resubscribe(func, consumer);
}, 1, TimeUnit.SECONDS);
return;
}
resubscribe(func, consumer);
});
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy