Class KinesisMessageHandler
java.lang.Object
org.springframework.integration.context.IntegrationObjectSupport
org.springframework.integration.handler.MessageHandlerSupport
org.springframework.integration.handler.AbstractMessageHandler
org.springframework.integration.handler.AbstractMessageProducingHandler
org.springframework.integration.aws.outbound.AbstractAwsMessageHandler<Void>
org.springframework.integration.aws.outbound.KinesisMessageHandler
- All Implemented Interfaces:
org.reactivestreams.Subscriber<org.springframework.messaging.Message<?>>
,org.springframework.beans.factory.Aware
,org.springframework.beans.factory.BeanFactoryAware
,org.springframework.beans.factory.BeanNameAware
,org.springframework.beans.factory.DisposableBean
,org.springframework.beans.factory.InitializingBean
,org.springframework.context.ApplicationContextAware
,org.springframework.core.Ordered
,org.springframework.integration.context.ExpressionCapable
,org.springframework.integration.context.Orderable
,org.springframework.integration.core.MessageProducer
,org.springframework.integration.handler.HeaderPropagationAware
,org.springframework.integration.IntegrationPattern
,org.springframework.integration.support.context.NamedComponent
,org.springframework.integration.support.management.IntegrationManagement
,org.springframework.integration.support.management.TrackableComponent
,org.springframework.messaging.MessageHandler
,reactor.core.CoreSubscriber<org.springframework.messaging.Message<?>>
The
AbstractMessageHandler
implementation for the Amazon Kinesis
putRecord(s)
.- Since:
- 1.1
- Author:
- Artem Bilan, Jacob Severson
- See Also:
-
KinesisAsyncClient.putRecord(PutRecordRequest)
KinesisAsyncClient.putRecords(PutRecordsRequest)
-
Nested Class Summary
Nested classes/interfaces inherited from interface org.springframework.integration.support.management.IntegrationManagement
org.springframework.integration.support.management.IntegrationManagement.ManagementOverrides
-
Field Summary
Fields inherited from class org.springframework.integration.aws.outbound.AbstractAwsMessageHandler
DEFAULT_SEND_TIMEOUT
Fields inherited from class org.springframework.integration.handler.AbstractMessageProducingHandler
messagingTemplate
Fields inherited from class org.springframework.integration.context.IntegrationObjectSupport
EXPRESSION_PARSER, logger
Fields inherited from interface org.springframework.integration.support.management.IntegrationManagement
METER_PREFIX, RECEIVE_COUNTER_NAME, SEND_TIMER_NAME
Fields inherited from interface org.springframework.core.Ordered
HIGHEST_PRECEDENCE, LOWEST_PRECEDENCE
-
Constructor Summary
ConstructorsConstructorDescriptionKinesisMessageHandler
(software.amazon.awssdk.services.kinesis.KinesisAsyncClient amazonKinesis) -
Method Summary
Modifier and TypeMethodDescriptionadditionalOnSuccessHeaders
(software.amazon.awssdk.awscore.AwsRequest request, software.amazon.awssdk.awscore.AwsResponse response) protected CompletableFuture<? extends software.amazon.awssdk.awscore.AwsResponse>
handleMessageToAws
(org.springframework.messaging.Message<?> message, software.amazon.awssdk.awscore.AwsRequest request) protected software.amazon.awssdk.awscore.AwsRequest
messageToAwsRequest
(org.springframework.messaging.Message<?> message) void
setConverter
(org.springframework.core.convert.converter.Converter<Object, byte[]> converter) Deprecated.void
setEmbeddedHeadersMapper
(org.springframework.integration.mapping.OutboundMessageMapper<byte[]> embeddedHeadersMapper) Specify aOutboundMessageMapper
for embedding message headers into the record data together with payload.void
setExplicitHashKey
(String explicitHashKey) void
setExplicitHashKeyExpression
(org.springframework.expression.Expression explicitHashKeyExpression) void
setExplicitHashKeyExpressionString
(String explicitHashKeyExpression) void
setHeaderMapper
(org.springframework.integration.mapping.HeaderMapper<Void> headerMapper) Unsupported operation.void
setMessageConverter
(org.springframework.messaging.converter.MessageConverter messageConverter) Configure aMessageConverter
for converting payload tobyte[]
for Kinesis record.void
setPartitionKey
(String partitionKey) void
setPartitionKeyExpression
(org.springframework.expression.Expression partitionKeyExpression) void
setPartitionKeyExpressionString
(String partitionKeyExpression) void
setSequenceNumberExpression
(org.springframework.expression.Expression sequenceNumberExpression) void
setSequenceNumberExpressionString
(String sequenceNumberExpression) void
void
setStreamExpression
(org.springframework.expression.Expression streamExpression) void
setStreamExpressionString
(String streamExpression) Methods inherited from class org.springframework.integration.aws.outbound.AbstractAwsMessageHandler
doSetHeaderMapper, getEvaluationContext, getHeaderMapper, getSendTimeoutExpression, handleMessageInternal, handleResponse, onInit, setSendTimeout, setSendTimeoutExpression, setSendTimeoutExpressionString, shouldCopyRequestHeaders
Methods inherited from class org.springframework.integration.handler.AbstractMessageProducingHandler
addNotPropagatedHeaders, createOutputMessage, getNotPropagatedHeaders, getOutputChannel, isAsync, messageBuilderForReply, produceOutput, resolveErrorChannel, sendErrorMessage, sendOutput, sendOutputs, setAsync, setNotPropagatedHeaders, setOutputChannel, setOutputChannelName, setupMessageProcessor, shouldSplitOutput, updateNotPropagatedHeaders
Methods inherited from class org.springframework.integration.handler.AbstractMessageHandler
handleMessage, onComplete, onError, onNext, onSubscribe, setObservationConvention
Methods inherited from class org.springframework.integration.handler.MessageHandlerSupport
buildSendTimer, destroy, getComponentType, getIntegrationPatternType, getManagedName, getManagedType, getMetricsCaptor, getObservationRegistry, getOrder, getOverrides, isLoggingEnabled, isObserved, registerMetricsCaptor, registerObservationRegistry, sendTimer, setLoggingEnabled, setManagedName, setManagedType, setOrder, setShouldTrack, shouldTrack
Methods inherited from class org.springframework.integration.context.IntegrationObjectSupport
afterPropertiesSet, extractTypeIfPossible, generateId, getApplicationContext, getApplicationContextId, getBeanDescription, getBeanFactory, getBeanName, getChannelResolver, getComponentName, getConversionService, getExpression, getIntegrationProperties, getIntegrationProperty, getMessageBuilderFactory, getTaskScheduler, isInitialized, setApplicationContext, setBeanFactory, setBeanName, setChannelResolver, setComponentName, setConversionService, setMessageBuilderFactory, setPrimaryExpression, setTaskScheduler, toString
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface reactor.core.CoreSubscriber
currentContext
Methods inherited from interface org.springframework.integration.support.management.IntegrationManagement
getThisAs
Methods inherited from interface org.springframework.integration.support.context.NamedComponent
getBeanName, getComponentName
-
Constructor Details
-
KinesisMessageHandler
public KinesisMessageHandler(software.amazon.awssdk.services.kinesis.KinesisAsyncClient amazonKinesis)
-
-
Method Details
-
setConverter
@Deprecated public void setConverter(org.springframework.core.convert.converter.Converter<Object, byte[]> converter) Deprecated.since 2.3 in favor ofsetMessageConverter(org.springframework.messaging.converter.MessageConverter)
Specify aConverter
to serializepayload
to thebyte[]
if that isn'tbyte[]
already.- Parameters:
converter
- theConverter
to use; cannot be null.
-
setMessageConverter
public void setMessageConverter(org.springframework.messaging.converter.MessageConverter messageConverter) Configure aMessageConverter
for converting payload tobyte[]
for Kinesis record.- Parameters:
messageConverter
- theMessageConverter
to use.- Since:
- 2.3
-
setStream
-
setStreamExpressionString
-
setStreamExpression
public void setStreamExpression(org.springframework.expression.Expression streamExpression) -
setPartitionKey
-
setPartitionKeyExpressionString
-
setPartitionKeyExpression
public void setPartitionKeyExpression(org.springframework.expression.Expression partitionKeyExpression) -
setExplicitHashKey
-
setExplicitHashKeyExpressionString
-
setExplicitHashKeyExpression
public void setExplicitHashKeyExpression(org.springframework.expression.Expression explicitHashKeyExpression) -
setSequenceNumberExpressionString
-
setSequenceNumberExpression
public void setSequenceNumberExpression(org.springframework.expression.Expression sequenceNumberExpression) -
setEmbeddedHeadersMapper
public void setEmbeddedHeadersMapper(org.springframework.integration.mapping.OutboundMessageMapper<byte[]> embeddedHeadersMapper) Specify aOutboundMessageMapper
for embedding message headers into the record data together with payload.- Parameters:
embeddedHeadersMapper
- theOutboundMessageMapper
to embed headers into the record data.- Since:
- 2.0
- See Also:
-
EmbeddedJsonHeadersMessageMapper
-
setHeaderMapper
public void setHeaderMapper(org.springframework.integration.mapping.HeaderMapper<Void> headerMapper) Unsupported operation. UsesetEmbeddedHeadersMapper(org.springframework.integration.mapping.OutboundMessageMapper<byte[]>)
instead.- Overrides:
setHeaderMapper
in classAbstractAwsMessageHandler<Void>
- Parameters:
headerMapper
- is not used.- See Also:
-
messageToAwsRequest
protected software.amazon.awssdk.awscore.AwsRequest messageToAwsRequest(org.springframework.messaging.Message<?> message) - Specified by:
messageToAwsRequest
in classAbstractAwsMessageHandler<Void>
-
handleMessageToAws
protected CompletableFuture<? extends software.amazon.awssdk.awscore.AwsResponse> handleMessageToAws(org.springframework.messaging.Message<?> message, software.amazon.awssdk.awscore.AwsRequest request) - Specified by:
handleMessageToAws
in classAbstractAwsMessageHandler<Void>
-
additionalOnSuccessHeaders
@Nullable protected Map<String,?> additionalOnSuccessHeaders(software.amazon.awssdk.awscore.AwsRequest request, software.amazon.awssdk.awscore.AwsResponse response) - Specified by:
additionalOnSuccessHeaders
in classAbstractAwsMessageHandler<Void>
-
setMessageConverter(org.springframework.messaging.converter.MessageConverter)