All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.rabbitmq.client.impl.CredentialsRefreshService Maven / Gradle / Ivy

Go to download

The RabbitMQ Java client library allows Java applications to interface with RabbitMQ.

The newest version!
// Copyright (c) 2019-2023 Broadcom. All Rights Reserved. The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries.
//
// This software, the RabbitMQ Java client library, is triple-licensed under the
// Mozilla Public License 2.0 ("MPL"), the GNU General Public License version 2
// ("GPL") and the Apache License version 2 ("ASL"). For the MPL, please see
// LICENSE-MPL-RabbitMQ. For the GPL, please see LICENSE-GPL2.  For the ASL,
// please see LICENSE-APACHE2.
//
// This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND,
// either express or implied. See the LICENSE file for specific language governing
// rights and limitations of this software.
//
// If you have any questions regarding licensing, please contact us at
// [email protected].

package com.rabbitmq.client.impl;

import java.time.Duration;
import java.util.concurrent.Callable;

/**
 * Provider interface to refresh credentials when appropriate
 * and perform an operation once the credentials have been
 * renewed. In the context of RabbitMQ, the operation consists
 * in calling the update.secret AMQP extension
 * to provide new valid credentials before the current ones
 * expire.
 * 

* New connections are registered and implementations must perform * credentials renewal when appropriate. Implementations * must call a registered callback once credentials are renewed. * * @see CredentialsProvider * @see DefaultCredentialsRefreshService */ public interface CredentialsRefreshService { /** * Register a new entity that needs credentials renewal. *

* The registered callback must return true if the action was * performed correctly, throw an exception if something goes wrong, * and return false if it became stale and wants to be unregistered. *

* Implementations are free to automatically unregister an entity whose * callback has failed a given number of times. * * @param credentialsProvider the credentials provider * @param refreshAction the action to perform after credentials renewal * @return a tracking ID for the registration */ String register(CredentialsProvider credentialsProvider, Callable refreshAction); /** * Unregister the entity with the given registration ID. *

* Its state is cleaned up and its registered callback will not be * called again. * * @param credentialsProvider the credentials provider * @param registrationId the registration ID */ void unregister(CredentialsProvider credentialsProvider, String registrationId); /** * Provide a hint about whether credentials should be renewed now or not before attempting to connect. *

* This can avoid a connection to use almost expired credentials if this connection * is created just before credentials are refreshed in the background, but does not * benefit from the refresh. * * @param timeBeforeExpiration * @return true if credentials should be renewed, false otherwise */ boolean isApproachingExpiration(Duration timeBeforeExpiration); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy