open class MessageBrokerRegistry
A registry for configuring message broker options.
Author
Rossen Stoyanchev
Author
Sebastien Deleuze
Since
4.0
MessageBrokerRegistry(clientInboundChannel: SubscribableChannel, clientOutboundChannel: MessageChannel) |
open fun configureBrokerChannel(): ChannelRegistration
Customize the channel used to send messages from the application to the message broker. By default, messages from the application to the message broker are sent synchronously, which means application code sending a message will find out if the message cannot be sent through an exception. However, this can be changed if the broker channel is configured here with task executor properties. |
|
open fun enableSimpleBroker(vararg destinationPrefixes: String): SimpleBrokerRegistration
Enable a simple message broker and configure one or more prefixes to filter destinations targeting the broker (e.g. destinations prefixed with "/topic"). |
|
open fun enableStompBrokerRelay(vararg destinationPrefixes: String): StompBrokerRelayRegistration
Enable a STOMP broker relay and configure the destination prefixes supported by the message broker. Check the STOMP documentation of the message broker for supported destinations. |
|
open fun setApplicationDestinationPrefixes(vararg prefixes: String): MessageBrokerRegistry
Configure one or more prefixes to filter destinations targeting application annotated methods. For example destinations prefixed with "/app" may be processed by annotated methods while other destinations may target the message broker (e.g. "/topic", "/queue"). When messages are processed, the matching prefix is removed from the destination in order to form the lookup path. This means annotations should not contain the destination prefix. Prefixes that do not have a trailing slash will have one automatically appended. |
|
open fun setCacheLimit(cacheLimit: Int): MessageBrokerRegistry
Configure the cache limit to apply for registrations with the broker. This is currently only applied for the destination cache in the subscription registry. The default cache limit there is 1024. |
|
open fun setPathMatcher(pathMatcher: PathMatcher): MessageBrokerRegistry
Configure the PathMatcher to use to match the destinations of incoming messages to By default org.springframework.util.AntPathMatcher is configured. However applications may provide an Note that the configured PathMatcher is only used for matching the portion of the destination after the configured prefix. For example given application destination prefix "/app" and destination "/app/price.stock.**", the message might be mapped to a controller with "price" and "stock.**" as its type and method-level mappings respectively. When the simple broker is enabled, the PathMatcher configured here is also used to match message destinations when brokering messages. |
|
open fun setUserDestinationPrefix(destinationPrefix: String): MessageBrokerRegistry
Configure the prefix used to identify user destinations. User destinations provide the ability for a user to subscribe to queue names unique to their session as well as for others to send messages to those unique, user-specific queues. For example when a user attempts to subscribe to "/user/queue/position-updates", the destination may be translated to "/queue/position-updatesi9oqdfzo" yielding a unique queue name that does not collide with any other user attempting to do the same. Subsequently when messages are sent to "/user/{username}/queue/position-updates", the destination is translated to "/queue/position-updatesi9oqdfzo". The default prefix used to identify such destinations is "/user/". |