Class KplMessageHandler
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.KplMessageHandler
- 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.context.Lifecycle
,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<?>>
public class KplMessageHandler
extends AbstractAwsMessageHandler<Void>
implements org.springframework.context.Lifecycle
The
AbstractMessageHandler
implementation for the Amazon Kinesis Producer
Library putRecord(s)
.- Since:
- 2.2
- Author:
- Arnaud Lecollaire, Artem Bilan
- See Also:
-
KinesisAsyncClient.putRecord(PutRecordRequest)
KinesisAsyncClient.putRecords(PutRecordsRequest)
AsyncHandler
-
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
ConstructorsConstructorDescriptionKplMessageHandler
(com.amazonaws.services.kinesis.producer.KinesisProducer kinesisProducer) -
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) boolean
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
setFlushDuration
(Duration flushDuration) Configure aDuration
how often to call aKinesisProducer.flush()
.void
setGlueSchema
(com.amazonaws.services.schemaregistry.common.Schema glueSchema) Set aSchema
to add into aUserRecord
built from the request message.void
setGlueSchemaExpression
(org.springframework.expression.Expression glueSchemaExpression) Set a SpEL expression forSchema
to add into aUserRecord
built from the request message.void
setGlueSchemaExpressionString
(String glueSchemaExpression) Set a SpEL expression forSchema
to add into aUserRecord
built from the request message.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) void
start()
void
stop()
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
-
KplMessageHandler
public KplMessageHandler(com.amazonaws.services.kinesis.producer.KinesisProducer kinesisProducer)
-
-
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
-
setFlushDuration
Configure aDuration
how often to call aKinesisProducer.flush()
.- Parameters:
flushDuration
- theDuration
to periodic call of aKinesisProducer.flush()
.- Since:
- 2.3.6
-
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:
-
setGlueSchema
public void setGlueSchema(com.amazonaws.services.schemaregistry.common.Schema glueSchema) Set aSchema
to add into aUserRecord
built from the request message.- Parameters:
glueSchema
- theSchema
to add into aUserRecord
.- Since:
- 2.5.2
- See Also:
-
UserRecord.setSchema(Schema)
-
setGlueSchemaExpressionString
Set a SpEL expression forSchema
to add into aUserRecord
built from the request message.- Parameters:
glueSchemaExpression
- the SpEL expression to evaluate aSchema
.- Since:
- 2.5.2
- See Also:
-
UserRecord.setSchema(Schema)
-
setGlueSchemaExpression
public void setGlueSchemaExpression(org.springframework.expression.Expression glueSchemaExpression) Set a SpEL expression forSchema
to add into aUserRecord
built from the request message.- Parameters:
glueSchemaExpression
- the SpEL expression to evaluate aSchema
.- Since:
- 2.5.2
- See Also:
-
UserRecord.setSchema(Schema)
-
start
public void start()- Specified by:
start
in interfaceorg.springframework.context.Lifecycle
-
stop
public void stop()- Specified by:
stop
in interfaceorg.springframework.context.Lifecycle
-
isRunning
public boolean isRunning()- Specified by:
isRunning
in interfaceorg.springframework.context.Lifecycle
-
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
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)