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

org.springframework.boot.autoconfigure.amqp.RabbitProperties Maven / Gradle / Ivy

There is a newer version: 3.2.5
Show newest version
/*
 * Copyright 2012-2016 the original author or authors.
 *
 * 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.springframework.boot.autoconfigure.amqp;

import java.util.ArrayList;
import java.util.List;

import org.springframework.amqp.core.AcknowledgeMode;
import org.springframework.amqp.rabbit.connection.CachingConnectionFactory.CacheMode;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.NestedConfigurationProperty;
import org.springframework.util.CollectionUtils;
import org.springframework.util.StringUtils;

/**
 * Configuration properties for Rabbit.
 *
 * @author Greg Turnquist
 * @author Dave Syer
 * @author Stephane Nicoll
 * @author Andy Wilkinson
 * @author Josh Thornhill
 * @author Gary Russell
 */
@ConfigurationProperties(prefix = "spring.rabbitmq")
public class RabbitProperties {

	/**
	 * RabbitMQ host.
	 */
	private String host = "localhost";

	/**
	 * RabbitMQ port.
	 */
	private int port = 5672;

	/**
	 * Login user to authenticate to the broker.
	 */
	private String username;

	/**
	 * Login to authenticate against the broker.
	 */
	private String password;

	/**
	 * SSL configuration.
	 */
	private final Ssl ssl = new Ssl();

	/**
	 * Virtual host to use when connecting to the broker.
	 */
	private String virtualHost;

	/**
	 * Comma-separated list of addresses to which the client should connect.
	 */
	private String addresses;

	/**
	 * Requested heartbeat timeout, in seconds; zero for none.
	 */
	private Integer requestedHeartbeat;

	/**
	 * Enable publisher confirms.
	 */
	private boolean publisherConfirms;

	/**
	 * Enable publisher returns.
	 */
	private boolean publisherReturns;

	/**
	 * Connection timeout, in milliseconds; zero for infinite.
	 */
	private Integer connectionTimeout;

	/**
	 * Cache configuration.
	 */
	private final Cache cache = new Cache();

	/**
	 * Listener container configuration.
	 */
	private final Listener listener = new Listener();

	private final Template template = new Template();

	private List
parsedAddresses; public String getHost() { return this.host; } /** * Returns the host from the first address, or the configured host if no addresses * have been set. * @return the host * @see #setAddresses(String) * @see #getHost() */ public String determineHost() { if (CollectionUtils.isEmpty(this.parsedAddresses)) { return getHost(); } return this.parsedAddresses.get(0).host; } public void setHost(String host) { this.host = host; } public int getPort() { return this.port; } /** * Returns the port from the first address, or the configured port if no addresses * have been set. * @return the port * @see #setAddresses(String) * @see #getPort() */ public int determinePort() { if (CollectionUtils.isEmpty(this.parsedAddresses)) { return getPort(); } Address address = this.parsedAddresses.get(0); return address.port; } public void setPort(int port) { this.port = port; } public String getAddresses() { return this.addresses; } /** * Returns the comma-separated addresses or a single address ({@code host:port}) * created from the configured host and port if no addresses have been set. * @return the addresses */ public String determineAddresses() { if (CollectionUtils.isEmpty(this.parsedAddresses)) { return this.host + ":" + this.port; } List addressStrings = new ArrayList(); for (Address parsedAddress : this.parsedAddresses) { addressStrings.add(parsedAddress.host + ":" + parsedAddress.port); } return StringUtils.collectionToCommaDelimitedString(addressStrings); } public void setAddresses(String addresses) { this.addresses = addresses; this.parsedAddresses = parseAddresses(addresses); } private List
parseAddresses(String addresses) { List
parsedAddresses = new ArrayList
(); for (String address : StringUtils.commaDelimitedListToStringArray(addresses)) { parsedAddresses.add(new Address(address)); } return parsedAddresses; } public String getUsername() { return this.username; } /** * If addresses have been set and the first address has a username it is returned. * Otherwise returns the result of calling {@code getUsername()}. * @return the username * @see #setAddresses(String) * @see #getUsername() */ public String determineUsername() { if (CollectionUtils.isEmpty(this.parsedAddresses)) { return this.username; } Address address = this.parsedAddresses.get(0); return address.username == null ? this.username : address.username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return this.password; } /** * If addresses have been set and the first address has a password it is returned. * Otherwise returns the result of calling {@code getPassword()}. * @return the password or {@code null} * @see #setAddresses(String) * @see #getPassword() */ public String determinePassword() { if (CollectionUtils.isEmpty(this.parsedAddresses)) { return getPassword(); } Address address = this.parsedAddresses.get(0); return address.password == null ? getPassword() : address.password; } public void setPassword(String password) { this.password = password; } public Ssl getSsl() { return this.ssl; } public String getVirtualHost() { return this.virtualHost; } /** * If addresses have been set and the first address has a virtual host it is returned. * Otherwise returns the result of calling {@code getVirtualHost()}. * @return the password or {@code null} * @see #setAddresses(String) * @see #getVirtualHost() */ public String determineVirtualHost() { if (CollectionUtils.isEmpty(this.parsedAddresses)) { return getVirtualHost(); } Address address = this.parsedAddresses.get(0); return address.virtualHost == null ? getVirtualHost() : address.virtualHost; } public void setVirtualHost(String virtualHost) { this.virtualHost = ("".equals(virtualHost) ? "/" : virtualHost); } public Integer getRequestedHeartbeat() { return this.requestedHeartbeat; } public void setRequestedHeartbeat(Integer requestedHeartbeat) { this.requestedHeartbeat = requestedHeartbeat; } public boolean isPublisherConfirms() { return this.publisherConfirms; } public void setPublisherConfirms(boolean publisherConfirms) { this.publisherConfirms = publisherConfirms; } public boolean isPublisherReturns() { return this.publisherReturns; } public void setPublisherReturns(boolean publisherReturns) { this.publisherReturns = publisherReturns; } public Integer getConnectionTimeout() { return this.connectionTimeout; } public void setConnectionTimeout(Integer connectionTimeout) { this.connectionTimeout = connectionTimeout; } public Cache getCache() { return this.cache; } public Listener getListener() { return this.listener; } public Template getTemplate() { return this.template; } public static class Ssl { /** * Enable SSL support. */ private boolean enabled; /** * Path to the key store that holds the SSL certificate. */ private String keyStore; /** * Password used to access the key store. */ private String keyStorePassword; /** * Trust store that holds SSL certificates. */ private String trustStore; /** * Password used to access the trust store. */ private String trustStorePassword; /** * SSL algorithm to use (e.g. TLSv1.1). Default is set automatically by the rabbit * client library. */ private String algorithm; public boolean isEnabled() { return this.enabled; } public void setEnabled(boolean enabled) { this.enabled = enabled; } public String getKeyStore() { return this.keyStore; } public void setKeyStore(String keyStore) { this.keyStore = keyStore; } public String getKeyStorePassword() { return this.keyStorePassword; } public void setKeyStorePassword(String keyStorePassword) { this.keyStorePassword = keyStorePassword; } public String getTrustStore() { return this.trustStore; } public void setTrustStore(String trustStore) { this.trustStore = trustStore; } public String getTrustStorePassword() { return this.trustStorePassword; } public void setTrustStorePassword(String trustStorePassword) { this.trustStorePassword = trustStorePassword; } public String getAlgorithm() { return this.algorithm; } public void setAlgorithm(String sslAlgorithm) { this.algorithm = sslAlgorithm; } } public static class Cache { private final Channel channel = new Channel(); private final Connection connection = new Connection(); public Channel getChannel() { return this.channel; } public Connection getConnection() { return this.connection; } public static class Channel { /** * Number of channels to retain in the cache. When "check-timeout" > 0, max * channels per connection. */ private Integer size; /** * Number of milliseconds to wait to obtain a channel if the cache size has * been reached. If 0, always create a new channel. */ private Long checkoutTimeout; public Integer getSize() { return this.size; } public void setSize(Integer size) { this.size = size; } public Long getCheckoutTimeout() { return this.checkoutTimeout; } public void setCheckoutTimeout(Long checkoutTimeout) { this.checkoutTimeout = checkoutTimeout; } } public static class Connection { /** * Connection factory cache mode. */ private CacheMode mode = CacheMode.CHANNEL; /** * Number of connections to cache. Only applies when mode is CONNECTION. */ private Integer size; public CacheMode getMode() { return this.mode; } public void setMode(CacheMode mode) { this.mode = mode; } public Integer getSize() { return this.size; } public void setSize(Integer size) { this.size = size; } } } public static class Listener { /** * Start the container automatically on startup. */ private boolean autoStartup = true; /** * Acknowledge mode of container. */ private AcknowledgeMode acknowledgeMode; /** * Minimum number of consumers. */ private Integer concurrency; /** * Maximum number of consumers. */ private Integer maxConcurrency; /** * Number of messages to be handled in a single request. It should be greater than * or equal to the transaction size (if used). */ private Integer prefetch; /** * Number of messages to be processed in a transaction. For best results it should * be less than or equal to the prefetch count. */ private Integer transactionSize; /** * Whether rejected deliveries are requeued by default; default true. */ private Boolean defaultRequeueRejected; /** * Optional properties for a retry interceptor. */ @NestedConfigurationProperty private final ListenerRetry retry = new ListenerRetry(); public boolean isAutoStartup() { return this.autoStartup; } public void setAutoStartup(boolean autoStartup) { this.autoStartup = autoStartup; } public AcknowledgeMode getAcknowledgeMode() { return this.acknowledgeMode; } public void setAcknowledgeMode(AcknowledgeMode acknowledgeMode) { this.acknowledgeMode = acknowledgeMode; } public Integer getConcurrency() { return this.concurrency; } public void setConcurrency(Integer concurrency) { this.concurrency = concurrency; } public Integer getMaxConcurrency() { return this.maxConcurrency; } public void setMaxConcurrency(Integer maxConcurrency) { this.maxConcurrency = maxConcurrency; } public Integer getPrefetch() { return this.prefetch; } public void setPrefetch(Integer prefetch) { this.prefetch = prefetch; } public Integer getTransactionSize() { return this.transactionSize; } public void setTransactionSize(Integer transactionSize) { this.transactionSize = transactionSize; } public Boolean getDefaultRequeueRejected() { return this.defaultRequeueRejected; } public void setDefaultRequeueRejected(Boolean defaultRequeueRejected) { this.defaultRequeueRejected = defaultRequeueRejected; } public ListenerRetry getRetry() { return this.retry; } } public static class Template { @NestedConfigurationProperty private final Retry retry = new Retry(); /** * Enable mandatory messages. If a mandatory message cannot be routed to a queue * by the server, it will return an unroutable message with a Return method. */ private Boolean mandatory; /** * Timeout for receive() operations. */ private Long receiveTimeout; /** * Timeout for sendAndReceive() operations. */ private Long replyTimeout; public Retry getRetry() { return this.retry; } public Boolean getMandatory() { return this.mandatory; } public void setMandatory(Boolean mandatory) { this.mandatory = mandatory; } public Long getReceiveTimeout() { return this.receiveTimeout; } public void setReceiveTimeout(Long receiveTimeout) { this.receiveTimeout = receiveTimeout; } public Long getReplyTimeout() { return this.replyTimeout; } public void setReplyTimeout(Long replyTimeout) { this.replyTimeout = replyTimeout; } } public static class Retry { /** * Whether or not publishing retries are enabled. */ private boolean enabled; /** * Maximum number of attempts to publish or deliver a message. */ private int maxAttempts = 3; /** * Interval between the first and second attempt to publish or deliver a message. */ private long initialInterval = 1000L; /** * A multiplier to apply to the previous retry interval. */ private double multiplier = 1.0; /** * Maximum interval between attempts. */ private long maxInterval = 10000L; public boolean isEnabled() { return this.enabled; } public void setEnabled(boolean enabled) { this.enabled = enabled; } public int getMaxAttempts() { return this.maxAttempts; } public void setMaxAttempts(int maxAttempts) { this.maxAttempts = maxAttempts; } public long getInitialInterval() { return this.initialInterval; } public void setInitialInterval(long initialInterval) { this.initialInterval = initialInterval; } public double getMultiplier() { return this.multiplier; } public void setMultiplier(double multiplier) { this.multiplier = multiplier; } public long getMaxInterval() { return this.maxInterval; } public void setMaxInterval(long maxInterval) { this.maxInterval = maxInterval; } } public static class ListenerRetry extends Retry { /** * Whether or not retries are stateless or stateful. */ private boolean stateless = true; public boolean isStateless() { return this.stateless; } public void setStateless(boolean stateless) { this.stateless = stateless; } } private static final class Address { private static final String PREFIX_AMQP = "amqp://"; private static final int DEFAULT_PORT = 5672; private String host; private int port; private String username; private String password; private String virtualHost; private Address(String input) { input = input.trim(); input = trimPrefix(input); input = parseUsernameAndPassword(input); input = parseVirtualHost(input); parseHostAndPort(input); } private String trimPrefix(String input) { if (input.startsWith(PREFIX_AMQP)) { input = input.substring(PREFIX_AMQP.length()); } return input; } private String parseUsernameAndPassword(String input) { if (input.contains("@")) { String[] split = StringUtils.split(input, "@"); String creds = split[0]; input = split[1]; split = StringUtils.split(creds, ":"); this.username = split[0]; if (split.length > 0) { this.password = split[1]; } } return input; } private String parseVirtualHost(String input) { int hostIndex = input.indexOf("/"); if (hostIndex >= 0 && hostIndex < input.length()) { this.virtualHost = input.substring(hostIndex + 1); if (this.virtualHost.length() == 0) { this.virtualHost = "/"; } input = input.substring(0, hostIndex); } return input; } private void parseHostAndPort(String input) { int portIndex = input.indexOf(':'); if (portIndex == -1) { this.host = input; this.port = DEFAULT_PORT; } else { this.host = input.substring(0, portIndex); this.port = Integer.valueOf(input.substring(portIndex + 1)); } } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy