pl.allegro.tech.hermes.consumers.consumer.oauth.OAuthConsumerAuthorizationHandler Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hermes-consumers Show documentation
Show all versions of hermes-consumers Show documentation
Fast and reliable message broker built on top of Kafka.
package pl.allegro.tech.hermes.consumers.consumer.oauth;
import com.google.common.util.concurrent.RateLimiter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import pl.allegro.tech.hermes.api.OAuthProvider;
import pl.allegro.tech.hermes.api.Subscription;
import pl.allegro.tech.hermes.api.SubscriptionName;
import pl.allegro.tech.hermes.common.config.ConfigFactory;
import pl.allegro.tech.hermes.common.config.Configs;
import pl.allegro.tech.hermes.consumers.consumer.ConsumerAuthorizationHandler;
import pl.allegro.tech.hermes.consumers.consumer.Message;
import pl.allegro.tech.hermes.consumers.consumer.sender.MessageSendingResult;
import javax.inject.Inject;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.concurrent.ConcurrentHashMap;
import java.util.stream.Collectors;
public class OAuthConsumerAuthorizationHandler implements ConsumerAuthorizationHandler, OAuthProviderCacheListener {
private static final Logger logger = LoggerFactory.getLogger(OAuthConsumerAuthorizationHandler.class);
private final OAuthSubscriptionHandlerFactory handlerFactory;
private final Map handlers = new ConcurrentHashMap<>();
private final RateLimiter missingHandlersCreationRateLimiter;
@Inject
public OAuthConsumerAuthorizationHandler(OAuthSubscriptionHandlerFactory handlerFactory,
ConfigFactory configFactory,
OAuthProvidersNotifyingCache oAuthProvidersCache) {
this.handlerFactory = handlerFactory;
long rateLimiterDelayMs = configFactory.getLongProperty(Configs.OAUTH_MISSING_SUBSCRIPTION_HANDLERS_CREATION_DELAY);
this.missingHandlersCreationRateLimiter = RateLimiter.create(1000.0 / rateLimiterDelayMs);
oAuthProvidersCache.setListener(this);
}
@Override
public void createSubscriptionHandler(SubscriptionName subscriptionName) {
handlerFactory.create(subscriptionName).ifPresent(handler -> {
logger.info("OAuth handler for subscription {} created", subscriptionName);
handlers.put(subscriptionName, handler);
handler.initialize();
});
}
@Override
public void removeSubscriptionHandler(SubscriptionName subscriptionName) {
if (handlers.remove(subscriptionName) != null) {
logger.info("OAuth handler for subscription {} removed", subscriptionName);
}
}
@Override
public void updateSubscription(SubscriptionName subscriptionName) {
removeSubscriptionHandler(subscriptionName);
createSubscriptionHandler(subscriptionName);
}
@Override
public void oAuthProviderUpdate(OAuthProvider oAuthProvider) {
logger.info("Updated OAuth provider {}", oAuthProvider.getName());
List subscriptions = handlers.entrySet().stream()
.filter(entry -> entry.getValue().getProviderName().equals(oAuthProvider.getName()))
.map(Map.Entry::getKey)
.collect(Collectors.toList());
subscriptions.stream().forEach(this::updateSubscription);
}
@Override
public void handleSuccess(Message message, Subscription subscription, MessageSendingResult result) {
if (shouldHandle(subscription)) {
getSubscriptionHandler(subscription.getQualifiedName()).ifPresent(OAuthSubscriptionHandler::handleSuccess);
}
}
@Override
public void handleFailed(Message message, Subscription subscription, MessageSendingResult result) {
if (shouldHandle(subscription)) {
getSubscriptionHandler(subscription.getQualifiedName()).ifPresent(h -> h.handleFailed(subscription, result));
}
}
@Override
public void handleDiscarded(Message message, Subscription subscription, MessageSendingResult result) {
}
private boolean shouldHandle(Subscription subscription) {
return subscription.hasOAuthPolicy();
}
private Optional getSubscriptionHandler(SubscriptionName subscriptionName) {
if (handlers.containsKey(subscriptionName)) {
return Optional.of(handlers.get(subscriptionName));
}
return tryCreatingMissingHandler(subscriptionName);
}
private Optional tryCreatingMissingHandler(SubscriptionName subscriptionName) {
if (missingHandlersCreationRateLimiter.tryAcquire()) {
createSubscriptionHandler(subscriptionName);
return Optional.ofNullable(handlers.get(subscriptionName));
}
return Optional.empty();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy