Annotation Interface Router
A method annotated with @Router may accept a parameter of type
Message
or of the expected
Message payload's type. Any type conversion supported by
SimpleTypeConverter
will be applied to
the Message payload if necessary. Header values can also be passed as
Message parameters by using the
@Header
parameter annotation.
Return values from the annotated method may be either a Collection or Array
whose elements are either
channels
or
Strings. In the latter case, the endpoint hosting this router will attempt
to resolve each channel name with the Channel Registry or with
channelMappings()
, if provided.
- Author:
- Mark Fisher, Artem Bilan
-
Optional Element Summary
Modifier and TypeOptional ElementDescriptionSpecify whether sequence number and size headers should be added to each Message.TheSmartLifecycle
autoStartup
option.String[]
The 'key=value' pairs to represent channelMapping entries.Specify the channel to which this router will send messages for which destination channels are not resolved andresolutionRequired()
is false.If set totrue
, failures to send to a message channel will be ignored.Specify the channel from which this router will consume messages.Specify aSmartLifecycle
phase
option.Poller[]
Specify a prefix to be added to each channel name prior to resolution.Specify whether channel names must always be successfully resolved to existing channel instances.Specify the maximum amount of time in milliseconds to wait when sending a replyMessage
to theoutputChannel
.Specify a suffix to be added to each channel name prior to resolution.
-
Element Details
-
inputChannel
String inputChannelSpecify the channel from which this router will consume messages. If the channel does not exist, aDirectChannel
with this name will be registered in the application context.- Returns:
- The channel name.
- Default:
- ""
-
defaultOutputChannel
String defaultOutputChannelSpecify the channel to which this router will send messages for which destination channels are not resolved andresolutionRequired()
is false.- Returns:
- The channel name.
- Default:
- ""
-
channelMappings
String[] channelMappingsThe 'key=value' pairs to represent channelMapping entries.- Returns:
- the channelMappings.
- See Also:
- Default:
- {}
-
prefix
String prefixSpecify a prefix to be added to each channel name prior to resolution.- Returns:
- the prefix.
- Default:
- ""
-
suffix
String suffixSpecify a suffix to be added to each channel name prior to resolution.- Returns:
- the suffix.
- Default:
- ""
-
resolutionRequired
String resolutionRequiredSpecify whether channel names must always be successfully resolved to existing channel instances.If set to
true
(default), aMessagingException
will be raised in case the channel cannot be resolved. Setting this attribute tofalse
, will cause any unresolvable channels to be ignored. Can be specified as 'property placeholder', e.g.${spring.integration.resolutionRequired}
.- Returns:
- the resolution required flag.
- Default:
- ""
-
applySequence
String applySequenceSpecify whether sequence number and size headers should be added to each Message. Defaults tofalse
. Can be specified as 'property placeholder', e.g.${spring.integration.applySequence}
.- Returns:
- the apply sequence flag.
- Default:
- ""
-
ignoreSendFailures
String ignoreSendFailuresIf set totrue
, failures to send to a message channel will be ignored. If set tofalse
(default), aMessageDeliveryException
will be thrown instead, and if the router resolves more than one channel, any subsequent channels will not receive the message. Please be aware that when using direct channels (single threaded), send-failures can be caused by exceptions thrown by components much further down-stream. Can be specified as 'property placeholder', e.g.${spring.integration.ignoreSendFailures}
.- Returns:
- the ignore send failures flag.
- Default:
- ""
-
sendTimeout
String sendTimeoutSpecify the maximum amount of time in milliseconds to wait when sending a replyMessage
to theoutputChannel
. Defaults to-1
- blocking indefinitely. It is applied only if the output channel has some 'sending' limitations, e.g.QueueChannel
with fixed a 'capacity'. In this case aMessageDeliveryException
is thrown. The 'sendTimeout' is ignored in case ofAbstractSubscribableChannel
implementations. Can be specified as 'property placeholder', e.g.${spring.integration.sendTimeout}
.- Returns:
- The timeout for sending results to the reply target (in milliseconds)
- Default:
- ""
-
autoStartup
String autoStartupTheSmartLifecycle
autoStartup
option. Can be specified as 'property placeholder', e.g.${foo.autoStartup}
. Defaults totrue
.- Returns:
- the auto startup
boolean
flag.
- Default:
- ""
-
phase
String phaseSpecify aSmartLifecycle
phase
option. DefaultsInteger.MAX_VALUE / 2
forPollingConsumer
andInteger.MIN_VALUE
forEventDrivenConsumer
. Can be specified as 'property placeholder', e.g.${foo.phase}
.- Returns:
- the
SmartLifecycle
phase.
- Default:
- ""
-
poller
Poller[] poller- Returns:
- the
Poller
options for a polled endpoint (PollerMetadata
). This attribute is anarray
just to allow an empty default (no poller). Mutually exclusive withreactive()
.
- Default:
- {}
-
reactive
Reactive reactive- Default:
- @org.springframework.integration.annotation.Reactive("\n\t\t\n\t\t\n\ue000\ue001\ue002\n\t\t\t\t\n")
-