com.amazonaws.services.lambda.model.EventSourceMappingConfiguration Maven / Gradle / Ivy
Show all versions of aws-java-sdk-lambda Show documentation
/*
* Copyright 2019-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
* the License. A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file 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 com.amazonaws.services.lambda.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* A mapping between an Amazon Web Services resource and a Lambda function. For details, see
* CreateEventSourceMapping.
*
*
* @see AWS API Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class EventSourceMappingConfiguration implements Serializable, Cloneable, StructuredPojo {
/**
*
* The identifier of the event source mapping.
*
*/
private String uUID;
/**
*
* The position in a stream from which to start reading. Required for Amazon Kinesis and Amazon DynamoDB Stream
* event sources. AT_TIMESTAMP
is supported only for Amazon Kinesis streams, Amazon DocumentDB, Amazon
* MSK, and self-managed Apache Kafka.
*
*/
private String startingPosition;
/**
*
* With StartingPosition
set to AT_TIMESTAMP
, the time from which to start reading.
* StartingPositionTimestamp
cannot be in the future.
*
*/
private java.util.Date startingPositionTimestamp;
/**
*
* The maximum number of records in each batch that Lambda pulls from your stream or queue and sends to your
* function. Lambda passes all of the records in the batch to the function in a single call, up to the payload limit
* for synchronous invocation (6 MB).
*
*
* Default value: Varies by service. For Amazon SQS, the default is 10. For all other services, the default is 100.
*
*
* Related setting: When you set BatchSize
to a value greater than 10, you must set
* MaximumBatchingWindowInSeconds
to at least 1.
*
*/
private Integer batchSize;
/**
*
* The maximum amount of time, in seconds, that Lambda spends gathering records before invoking the function. You
* can configure MaximumBatchingWindowInSeconds
to any value from 0 seconds to 300 seconds in
* increments of seconds.
*
*
* For streams and Amazon SQS event sources, the default batching window is 0 seconds. For Amazon MSK, Self-managed
* Apache Kafka, Amazon MQ, and DocumentDB event sources, the default batching window is 500 ms. Note that because
* you can only change MaximumBatchingWindowInSeconds
in increments of seconds, you cannot revert back
* to the 500 ms default batching window after you have changed it. To restore the default batching window, you must
* create a new event source mapping.
*
*
* Related setting: For streams and Amazon SQS event sources, when you set BatchSize
to a value greater
* than 10, you must set MaximumBatchingWindowInSeconds
to at least 1.
*
*/
private Integer maximumBatchingWindowInSeconds;
/**
*
* (Kinesis and DynamoDB Streams only) The number of batches to process concurrently from each shard. The default
* value is 1.
*
*/
private Integer parallelizationFactor;
/**
*
* The Amazon Resource Name (ARN) of the event source.
*
*/
private String eventSourceArn;
/**
*
* An object that defines the filter criteria that determine whether Lambda should process an event. For more
* information, see Lambda
* event filtering.
*
*/
private FilterCriteria filterCriteria;
/**
*
* The ARN of the Lambda function.
*
*/
private String functionArn;
/**
*
* The date that the event source mapping was last updated or that its state changed.
*
*/
private java.util.Date lastModified;
/**
*
* The result of the last Lambda invocation of your function.
*
*/
private String lastProcessingResult;
/**
*
* The state of the event source mapping. It can be one of the following: Creating
,
* Enabling
, Enabled
, Disabling
, Disabled
, Updating
* , or Deleting
.
*
*/
private String state;
/**
*
* Indicates whether a user or Lambda made the last change to the event source mapping.
*
*/
private String stateTransitionReason;
/**
*
* (Kinesis, DynamoDB Streams, Amazon MSK, and self-managed Apache Kafka event sources only) A configuration object
* that specifies the destination of an event after Lambda processes it.
*
*/
private DestinationConfig destinationConfig;
/**
*
* The name of the Kafka topic.
*
*/
private com.amazonaws.internal.SdkInternalList topics;
/**
*
* (Amazon MQ) The name of the Amazon MQ broker destination queue to consume.
*
*/
private com.amazonaws.internal.SdkInternalList queues;
/**
*
* An array of the authentication protocol, VPC components, or virtual host to secure and define your event source.
*
*/
private com.amazonaws.internal.SdkInternalList sourceAccessConfigurations;
/**
*
* The self-managed Apache Kafka cluster for your event source.
*
*/
private SelfManagedEventSource selfManagedEventSource;
/**
*
* (Kinesis and DynamoDB Streams only) Discard records older than the specified age. The default value is -1, which
* sets the maximum age to infinite. When the value is set to infinite, Lambda never discards old records.
*
*
*
* The minimum valid value for maximum record age is 60s. Although values less than 60 and greater than -1 fall
* within the parameter's absolute range, they are not allowed
*
*
*/
private Integer maximumRecordAgeInSeconds;
/**
*
* (Kinesis and DynamoDB Streams only) If the function returns an error, split the batch in two and retry. The
* default value is false.
*
*/
private Boolean bisectBatchOnFunctionError;
/**
*
* (Kinesis and DynamoDB Streams only) Discard records after the specified number of retries. The default value is
* -1, which sets the maximum number of retries to infinite. When MaximumRetryAttempts is infinite, Lambda retries
* failed records until the record expires in the event source.
*
*/
private Integer maximumRetryAttempts;
/**
*
* (Kinesis and DynamoDB Streams only) The duration in seconds of a processing window for DynamoDB and Kinesis
* Streams event sources. A value of 0 seconds indicates no tumbling window.
*
*/
private Integer tumblingWindowInSeconds;
/**
*
* (Kinesis, DynamoDB Streams, and Amazon SQS) A list of current response type enums applied to the event source
* mapping.
*
*/
private com.amazonaws.internal.SdkInternalList functionResponseTypes;
/**
*
* Specific configuration settings for an Amazon Managed Streaming for Apache Kafka (Amazon MSK) event source.
*
*/
private AmazonManagedKafkaEventSourceConfig amazonManagedKafkaEventSourceConfig;
/**
*
* Specific configuration settings for a self-managed Apache Kafka event source.
*
*/
private SelfManagedKafkaEventSourceConfig selfManagedKafkaEventSourceConfig;
/**
*
* (Amazon SQS only) The scaling configuration for the event source. For more information, see Configuring maximum
* concurrency for Amazon SQS event sources.
*
*/
private ScalingConfig scalingConfig;
/**
*
* Specific configuration settings for a DocumentDB event source.
*
*/
private DocumentDBEventSourceConfig documentDBEventSourceConfig;
/**
*
* The identifier of the event source mapping.
*
*
* @param uUID
* The identifier of the event source mapping.
*/
public void setUUID(String uUID) {
this.uUID = uUID;
}
/**
*
* The identifier of the event source mapping.
*
*
* @return The identifier of the event source mapping.
*/
public String getUUID() {
return this.uUID;
}
/**
*
* The identifier of the event source mapping.
*
*
* @param uUID
* The identifier of the event source mapping.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withUUID(String uUID) {
setUUID(uUID);
return this;
}
/**
*
* The position in a stream from which to start reading. Required for Amazon Kinesis and Amazon DynamoDB Stream
* event sources. AT_TIMESTAMP
is supported only for Amazon Kinesis streams, Amazon DocumentDB, Amazon
* MSK, and self-managed Apache Kafka.
*
*
* @param startingPosition
* The position in a stream from which to start reading. Required for Amazon Kinesis and Amazon DynamoDB
* Stream event sources. AT_TIMESTAMP
is supported only for Amazon Kinesis streams, Amazon
* DocumentDB, Amazon MSK, and self-managed Apache Kafka.
* @see EventSourcePosition
*/
public void setStartingPosition(String startingPosition) {
this.startingPosition = startingPosition;
}
/**
*
* The position in a stream from which to start reading. Required for Amazon Kinesis and Amazon DynamoDB Stream
* event sources. AT_TIMESTAMP
is supported only for Amazon Kinesis streams, Amazon DocumentDB, Amazon
* MSK, and self-managed Apache Kafka.
*
*
* @return The position in a stream from which to start reading. Required for Amazon Kinesis and Amazon DynamoDB
* Stream event sources. AT_TIMESTAMP
is supported only for Amazon Kinesis streams, Amazon
* DocumentDB, Amazon MSK, and self-managed Apache Kafka.
* @see EventSourcePosition
*/
public String getStartingPosition() {
return this.startingPosition;
}
/**
*
* The position in a stream from which to start reading. Required for Amazon Kinesis and Amazon DynamoDB Stream
* event sources. AT_TIMESTAMP
is supported only for Amazon Kinesis streams, Amazon DocumentDB, Amazon
* MSK, and self-managed Apache Kafka.
*
*
* @param startingPosition
* The position in a stream from which to start reading. Required for Amazon Kinesis and Amazon DynamoDB
* Stream event sources. AT_TIMESTAMP
is supported only for Amazon Kinesis streams, Amazon
* DocumentDB, Amazon MSK, and self-managed Apache Kafka.
* @return Returns a reference to this object so that method calls can be chained together.
* @see EventSourcePosition
*/
public EventSourceMappingConfiguration withStartingPosition(String startingPosition) {
setStartingPosition(startingPosition);
return this;
}
/**
*
* The position in a stream from which to start reading. Required for Amazon Kinesis and Amazon DynamoDB Stream
* event sources. AT_TIMESTAMP
is supported only for Amazon Kinesis streams, Amazon DocumentDB, Amazon
* MSK, and self-managed Apache Kafka.
*
*
* @param startingPosition
* The position in a stream from which to start reading. Required for Amazon Kinesis and Amazon DynamoDB
* Stream event sources. AT_TIMESTAMP
is supported only for Amazon Kinesis streams, Amazon
* DocumentDB, Amazon MSK, and self-managed Apache Kafka.
* @return Returns a reference to this object so that method calls can be chained together.
* @see EventSourcePosition
*/
public EventSourceMappingConfiguration withStartingPosition(EventSourcePosition startingPosition) {
this.startingPosition = startingPosition.toString();
return this;
}
/**
*
* With StartingPosition
set to AT_TIMESTAMP
, the time from which to start reading.
* StartingPositionTimestamp
cannot be in the future.
*
*
* @param startingPositionTimestamp
* With StartingPosition
set to AT_TIMESTAMP
, the time from which to start reading.
* StartingPositionTimestamp
cannot be in the future.
*/
public void setStartingPositionTimestamp(java.util.Date startingPositionTimestamp) {
this.startingPositionTimestamp = startingPositionTimestamp;
}
/**
*
* With StartingPosition
set to AT_TIMESTAMP
, the time from which to start reading.
* StartingPositionTimestamp
cannot be in the future.
*
*
* @return With StartingPosition
set to AT_TIMESTAMP
, the time from which to start
* reading. StartingPositionTimestamp
cannot be in the future.
*/
public java.util.Date getStartingPositionTimestamp() {
return this.startingPositionTimestamp;
}
/**
*
* With StartingPosition
set to AT_TIMESTAMP
, the time from which to start reading.
* StartingPositionTimestamp
cannot be in the future.
*
*
* @param startingPositionTimestamp
* With StartingPosition
set to AT_TIMESTAMP
, the time from which to start reading.
* StartingPositionTimestamp
cannot be in the future.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withStartingPositionTimestamp(java.util.Date startingPositionTimestamp) {
setStartingPositionTimestamp(startingPositionTimestamp);
return this;
}
/**
*
* The maximum number of records in each batch that Lambda pulls from your stream or queue and sends to your
* function. Lambda passes all of the records in the batch to the function in a single call, up to the payload limit
* for synchronous invocation (6 MB).
*
*
* Default value: Varies by service. For Amazon SQS, the default is 10. For all other services, the default is 100.
*
*
* Related setting: When you set BatchSize
to a value greater than 10, you must set
* MaximumBatchingWindowInSeconds
to at least 1.
*
*
* @param batchSize
* The maximum number of records in each batch that Lambda pulls from your stream or queue and sends to your
* function. Lambda passes all of the records in the batch to the function in a single call, up to the
* payload limit for synchronous invocation (6 MB).
*
* Default value: Varies by service. For Amazon SQS, the default is 10. For all other services, the default
* is 100.
*
*
* Related setting: When you set BatchSize
to a value greater than 10, you must set
* MaximumBatchingWindowInSeconds
to at least 1.
*/
public void setBatchSize(Integer batchSize) {
this.batchSize = batchSize;
}
/**
*
* The maximum number of records in each batch that Lambda pulls from your stream or queue and sends to your
* function. Lambda passes all of the records in the batch to the function in a single call, up to the payload limit
* for synchronous invocation (6 MB).
*
*
* Default value: Varies by service. For Amazon SQS, the default is 10. For all other services, the default is 100.
*
*
* Related setting: When you set BatchSize
to a value greater than 10, you must set
* MaximumBatchingWindowInSeconds
to at least 1.
*
*
* @return The maximum number of records in each batch that Lambda pulls from your stream or queue and sends to your
* function. Lambda passes all of the records in the batch to the function in a single call, up to the
* payload limit for synchronous invocation (6 MB).
*
* Default value: Varies by service. For Amazon SQS, the default is 10. For all other services, the default
* is 100.
*
*
* Related setting: When you set BatchSize
to a value greater than 10, you must set
* MaximumBatchingWindowInSeconds
to at least 1.
*/
public Integer getBatchSize() {
return this.batchSize;
}
/**
*
* The maximum number of records in each batch that Lambda pulls from your stream or queue and sends to your
* function. Lambda passes all of the records in the batch to the function in a single call, up to the payload limit
* for synchronous invocation (6 MB).
*
*
* Default value: Varies by service. For Amazon SQS, the default is 10. For all other services, the default is 100.
*
*
* Related setting: When you set BatchSize
to a value greater than 10, you must set
* MaximumBatchingWindowInSeconds
to at least 1.
*
*
* @param batchSize
* The maximum number of records in each batch that Lambda pulls from your stream or queue and sends to your
* function. Lambda passes all of the records in the batch to the function in a single call, up to the
* payload limit for synchronous invocation (6 MB).
*
* Default value: Varies by service. For Amazon SQS, the default is 10. For all other services, the default
* is 100.
*
*
* Related setting: When you set BatchSize
to a value greater than 10, you must set
* MaximumBatchingWindowInSeconds
to at least 1.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withBatchSize(Integer batchSize) {
setBatchSize(batchSize);
return this;
}
/**
*
* The maximum amount of time, in seconds, that Lambda spends gathering records before invoking the function. You
* can configure MaximumBatchingWindowInSeconds
to any value from 0 seconds to 300 seconds in
* increments of seconds.
*
*
* For streams and Amazon SQS event sources, the default batching window is 0 seconds. For Amazon MSK, Self-managed
* Apache Kafka, Amazon MQ, and DocumentDB event sources, the default batching window is 500 ms. Note that because
* you can only change MaximumBatchingWindowInSeconds
in increments of seconds, you cannot revert back
* to the 500 ms default batching window after you have changed it. To restore the default batching window, you must
* create a new event source mapping.
*
*
* Related setting: For streams and Amazon SQS event sources, when you set BatchSize
to a value greater
* than 10, you must set MaximumBatchingWindowInSeconds
to at least 1.
*
*
* @param maximumBatchingWindowInSeconds
* The maximum amount of time, in seconds, that Lambda spends gathering records before invoking the function.
* You can configure MaximumBatchingWindowInSeconds
to any value from 0 seconds to 300 seconds
* in increments of seconds.
*
* For streams and Amazon SQS event sources, the default batching window is 0 seconds. For Amazon MSK,
* Self-managed Apache Kafka, Amazon MQ, and DocumentDB event sources, the default batching window is 500 ms.
* Note that because you can only change MaximumBatchingWindowInSeconds
in increments of
* seconds, you cannot revert back to the 500 ms default batching window after you have changed it. To
* restore the default batching window, you must create a new event source mapping.
*
*
* Related setting: For streams and Amazon SQS event sources, when you set BatchSize
to a value
* greater than 10, you must set MaximumBatchingWindowInSeconds
to at least 1.
*/
public void setMaximumBatchingWindowInSeconds(Integer maximumBatchingWindowInSeconds) {
this.maximumBatchingWindowInSeconds = maximumBatchingWindowInSeconds;
}
/**
*
* The maximum amount of time, in seconds, that Lambda spends gathering records before invoking the function. You
* can configure MaximumBatchingWindowInSeconds
to any value from 0 seconds to 300 seconds in
* increments of seconds.
*
*
* For streams and Amazon SQS event sources, the default batching window is 0 seconds. For Amazon MSK, Self-managed
* Apache Kafka, Amazon MQ, and DocumentDB event sources, the default batching window is 500 ms. Note that because
* you can only change MaximumBatchingWindowInSeconds
in increments of seconds, you cannot revert back
* to the 500 ms default batching window after you have changed it. To restore the default batching window, you must
* create a new event source mapping.
*
*
* Related setting: For streams and Amazon SQS event sources, when you set BatchSize
to a value greater
* than 10, you must set MaximumBatchingWindowInSeconds
to at least 1.
*
*
* @return The maximum amount of time, in seconds, that Lambda spends gathering records before invoking the
* function. You can configure MaximumBatchingWindowInSeconds
to any value from 0 seconds to
* 300 seconds in increments of seconds.
*
* For streams and Amazon SQS event sources, the default batching window is 0 seconds. For Amazon MSK,
* Self-managed Apache Kafka, Amazon MQ, and DocumentDB event sources, the default batching window is 500
* ms. Note that because you can only change MaximumBatchingWindowInSeconds
in increments of
* seconds, you cannot revert back to the 500 ms default batching window after you have changed it. To
* restore the default batching window, you must create a new event source mapping.
*
*
* Related setting: For streams and Amazon SQS event sources, when you set BatchSize
to a value
* greater than 10, you must set MaximumBatchingWindowInSeconds
to at least 1.
*/
public Integer getMaximumBatchingWindowInSeconds() {
return this.maximumBatchingWindowInSeconds;
}
/**
*
* The maximum amount of time, in seconds, that Lambda spends gathering records before invoking the function. You
* can configure MaximumBatchingWindowInSeconds
to any value from 0 seconds to 300 seconds in
* increments of seconds.
*
*
* For streams and Amazon SQS event sources, the default batching window is 0 seconds. For Amazon MSK, Self-managed
* Apache Kafka, Amazon MQ, and DocumentDB event sources, the default batching window is 500 ms. Note that because
* you can only change MaximumBatchingWindowInSeconds
in increments of seconds, you cannot revert back
* to the 500 ms default batching window after you have changed it. To restore the default batching window, you must
* create a new event source mapping.
*
*
* Related setting: For streams and Amazon SQS event sources, when you set BatchSize
to a value greater
* than 10, you must set MaximumBatchingWindowInSeconds
to at least 1.
*
*
* @param maximumBatchingWindowInSeconds
* The maximum amount of time, in seconds, that Lambda spends gathering records before invoking the function.
* You can configure MaximumBatchingWindowInSeconds
to any value from 0 seconds to 300 seconds
* in increments of seconds.
*
* For streams and Amazon SQS event sources, the default batching window is 0 seconds. For Amazon MSK,
* Self-managed Apache Kafka, Amazon MQ, and DocumentDB event sources, the default batching window is 500 ms.
* Note that because you can only change MaximumBatchingWindowInSeconds
in increments of
* seconds, you cannot revert back to the 500 ms default batching window after you have changed it. To
* restore the default batching window, you must create a new event source mapping.
*
*
* Related setting: For streams and Amazon SQS event sources, when you set BatchSize
to a value
* greater than 10, you must set MaximumBatchingWindowInSeconds
to at least 1.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withMaximumBatchingWindowInSeconds(Integer maximumBatchingWindowInSeconds) {
setMaximumBatchingWindowInSeconds(maximumBatchingWindowInSeconds);
return this;
}
/**
*
* (Kinesis and DynamoDB Streams only) The number of batches to process concurrently from each shard. The default
* value is 1.
*
*
* @param parallelizationFactor
* (Kinesis and DynamoDB Streams only) The number of batches to process concurrently from each shard. The
* default value is 1.
*/
public void setParallelizationFactor(Integer parallelizationFactor) {
this.parallelizationFactor = parallelizationFactor;
}
/**
*
* (Kinesis and DynamoDB Streams only) The number of batches to process concurrently from each shard. The default
* value is 1.
*
*
* @return (Kinesis and DynamoDB Streams only) The number of batches to process concurrently from each shard. The
* default value is 1.
*/
public Integer getParallelizationFactor() {
return this.parallelizationFactor;
}
/**
*
* (Kinesis and DynamoDB Streams only) The number of batches to process concurrently from each shard. The default
* value is 1.
*
*
* @param parallelizationFactor
* (Kinesis and DynamoDB Streams only) The number of batches to process concurrently from each shard. The
* default value is 1.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withParallelizationFactor(Integer parallelizationFactor) {
setParallelizationFactor(parallelizationFactor);
return this;
}
/**
*
* The Amazon Resource Name (ARN) of the event source.
*
*
* @param eventSourceArn
* The Amazon Resource Name (ARN) of the event source.
*/
public void setEventSourceArn(String eventSourceArn) {
this.eventSourceArn = eventSourceArn;
}
/**
*
* The Amazon Resource Name (ARN) of the event source.
*
*
* @return The Amazon Resource Name (ARN) of the event source.
*/
public String getEventSourceArn() {
return this.eventSourceArn;
}
/**
*
* The Amazon Resource Name (ARN) of the event source.
*
*
* @param eventSourceArn
* The Amazon Resource Name (ARN) of the event source.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withEventSourceArn(String eventSourceArn) {
setEventSourceArn(eventSourceArn);
return this;
}
/**
*
* An object that defines the filter criteria that determine whether Lambda should process an event. For more
* information, see Lambda
* event filtering.
*
*
* @param filterCriteria
* An object that defines the filter criteria that determine whether Lambda should process an event. For more
* information, see Lambda event
* filtering.
*/
public void setFilterCriteria(FilterCriteria filterCriteria) {
this.filterCriteria = filterCriteria;
}
/**
*
* An object that defines the filter criteria that determine whether Lambda should process an event. For more
* information, see Lambda
* event filtering.
*
*
* @return An object that defines the filter criteria that determine whether Lambda should process an event. For
* more information, see Lambda event
* filtering.
*/
public FilterCriteria getFilterCriteria() {
return this.filterCriteria;
}
/**
*
* An object that defines the filter criteria that determine whether Lambda should process an event. For more
* information, see Lambda
* event filtering.
*
*
* @param filterCriteria
* An object that defines the filter criteria that determine whether Lambda should process an event. For more
* information, see Lambda event
* filtering.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withFilterCriteria(FilterCriteria filterCriteria) {
setFilterCriteria(filterCriteria);
return this;
}
/**
*
* The ARN of the Lambda function.
*
*
* @param functionArn
* The ARN of the Lambda function.
*/
public void setFunctionArn(String functionArn) {
this.functionArn = functionArn;
}
/**
*
* The ARN of the Lambda function.
*
*
* @return The ARN of the Lambda function.
*/
public String getFunctionArn() {
return this.functionArn;
}
/**
*
* The ARN of the Lambda function.
*
*
* @param functionArn
* The ARN of the Lambda function.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withFunctionArn(String functionArn) {
setFunctionArn(functionArn);
return this;
}
/**
*
* The date that the event source mapping was last updated or that its state changed.
*
*
* @param lastModified
* The date that the event source mapping was last updated or that its state changed.
*/
public void setLastModified(java.util.Date lastModified) {
this.lastModified = lastModified;
}
/**
*
* The date that the event source mapping was last updated or that its state changed.
*
*
* @return The date that the event source mapping was last updated or that its state changed.
*/
public java.util.Date getLastModified() {
return this.lastModified;
}
/**
*
* The date that the event source mapping was last updated or that its state changed.
*
*
* @param lastModified
* The date that the event source mapping was last updated or that its state changed.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withLastModified(java.util.Date lastModified) {
setLastModified(lastModified);
return this;
}
/**
*
* The result of the last Lambda invocation of your function.
*
*
* @param lastProcessingResult
* The result of the last Lambda invocation of your function.
*/
public void setLastProcessingResult(String lastProcessingResult) {
this.lastProcessingResult = lastProcessingResult;
}
/**
*
* The result of the last Lambda invocation of your function.
*
*
* @return The result of the last Lambda invocation of your function.
*/
public String getLastProcessingResult() {
return this.lastProcessingResult;
}
/**
*
* The result of the last Lambda invocation of your function.
*
*
* @param lastProcessingResult
* The result of the last Lambda invocation of your function.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withLastProcessingResult(String lastProcessingResult) {
setLastProcessingResult(lastProcessingResult);
return this;
}
/**
*
* The state of the event source mapping. It can be one of the following: Creating
,
* Enabling
, Enabled
, Disabling
, Disabled
, Updating
* , or Deleting
.
*
*
* @param state
* The state of the event source mapping. It can be one of the following: Creating
,
* Enabling
, Enabled
, Disabling
, Disabled
,
* Updating
, or Deleting
.
*/
public void setState(String state) {
this.state = state;
}
/**
*
* The state of the event source mapping. It can be one of the following: Creating
,
* Enabling
, Enabled
, Disabling
, Disabled
, Updating
* , or Deleting
.
*
*
* @return The state of the event source mapping. It can be one of the following: Creating
,
* Enabling
, Enabled
, Disabling
, Disabled
,
* Updating
, or Deleting
.
*/
public String getState() {
return this.state;
}
/**
*
* The state of the event source mapping. It can be one of the following: Creating
,
* Enabling
, Enabled
, Disabling
, Disabled
, Updating
* , or Deleting
.
*
*
* @param state
* The state of the event source mapping. It can be one of the following: Creating
,
* Enabling
, Enabled
, Disabling
, Disabled
,
* Updating
, or Deleting
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withState(String state) {
setState(state);
return this;
}
/**
*
* Indicates whether a user or Lambda made the last change to the event source mapping.
*
*
* @param stateTransitionReason
* Indicates whether a user or Lambda made the last change to the event source mapping.
*/
public void setStateTransitionReason(String stateTransitionReason) {
this.stateTransitionReason = stateTransitionReason;
}
/**
*
* Indicates whether a user or Lambda made the last change to the event source mapping.
*
*
* @return Indicates whether a user or Lambda made the last change to the event source mapping.
*/
public String getStateTransitionReason() {
return this.stateTransitionReason;
}
/**
*
* Indicates whether a user or Lambda made the last change to the event source mapping.
*
*
* @param stateTransitionReason
* Indicates whether a user or Lambda made the last change to the event source mapping.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withStateTransitionReason(String stateTransitionReason) {
setStateTransitionReason(stateTransitionReason);
return this;
}
/**
*
* (Kinesis, DynamoDB Streams, Amazon MSK, and self-managed Apache Kafka event sources only) A configuration object
* that specifies the destination of an event after Lambda processes it.
*
*
* @param destinationConfig
* (Kinesis, DynamoDB Streams, Amazon MSK, and self-managed Apache Kafka event sources only) A configuration
* object that specifies the destination of an event after Lambda processes it.
*/
public void setDestinationConfig(DestinationConfig destinationConfig) {
this.destinationConfig = destinationConfig;
}
/**
*
* (Kinesis, DynamoDB Streams, Amazon MSK, and self-managed Apache Kafka event sources only) A configuration object
* that specifies the destination of an event after Lambda processes it.
*
*
* @return (Kinesis, DynamoDB Streams, Amazon MSK, and self-managed Apache Kafka event sources only) A configuration
* object that specifies the destination of an event after Lambda processes it.
*/
public DestinationConfig getDestinationConfig() {
return this.destinationConfig;
}
/**
*
* (Kinesis, DynamoDB Streams, Amazon MSK, and self-managed Apache Kafka event sources only) A configuration object
* that specifies the destination of an event after Lambda processes it.
*
*
* @param destinationConfig
* (Kinesis, DynamoDB Streams, Amazon MSK, and self-managed Apache Kafka event sources only) A configuration
* object that specifies the destination of an event after Lambda processes it.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withDestinationConfig(DestinationConfig destinationConfig) {
setDestinationConfig(destinationConfig);
return this;
}
/**
*
* The name of the Kafka topic.
*
*
* @return The name of the Kafka topic.
*/
public java.util.List getTopics() {
if (topics == null) {
topics = new com.amazonaws.internal.SdkInternalList();
}
return topics;
}
/**
*
* The name of the Kafka topic.
*
*
* @param topics
* The name of the Kafka topic.
*/
public void setTopics(java.util.Collection topics) {
if (topics == null) {
this.topics = null;
return;
}
this.topics = new com.amazonaws.internal.SdkInternalList(topics);
}
/**
*
* The name of the Kafka topic.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setTopics(java.util.Collection)} or {@link #withTopics(java.util.Collection)} if you want to override the
* existing values.
*
*
* @param topics
* The name of the Kafka topic.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withTopics(String... topics) {
if (this.topics == null) {
setTopics(new com.amazonaws.internal.SdkInternalList(topics.length));
}
for (String ele : topics) {
this.topics.add(ele);
}
return this;
}
/**
*
* The name of the Kafka topic.
*
*
* @param topics
* The name of the Kafka topic.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withTopics(java.util.Collection topics) {
setTopics(topics);
return this;
}
/**
*
* (Amazon MQ) The name of the Amazon MQ broker destination queue to consume.
*
*
* @return (Amazon MQ) The name of the Amazon MQ broker destination queue to consume.
*/
public java.util.List getQueues() {
if (queues == null) {
queues = new com.amazonaws.internal.SdkInternalList();
}
return queues;
}
/**
*
* (Amazon MQ) The name of the Amazon MQ broker destination queue to consume.
*
*
* @param queues
* (Amazon MQ) The name of the Amazon MQ broker destination queue to consume.
*/
public void setQueues(java.util.Collection queues) {
if (queues == null) {
this.queues = null;
return;
}
this.queues = new com.amazonaws.internal.SdkInternalList(queues);
}
/**
*
* (Amazon MQ) The name of the Amazon MQ broker destination queue to consume.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setQueues(java.util.Collection)} or {@link #withQueues(java.util.Collection)} if you want to override the
* existing values.
*
*
* @param queues
* (Amazon MQ) The name of the Amazon MQ broker destination queue to consume.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withQueues(String... queues) {
if (this.queues == null) {
setQueues(new com.amazonaws.internal.SdkInternalList(queues.length));
}
for (String ele : queues) {
this.queues.add(ele);
}
return this;
}
/**
*
* (Amazon MQ) The name of the Amazon MQ broker destination queue to consume.
*
*
* @param queues
* (Amazon MQ) The name of the Amazon MQ broker destination queue to consume.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withQueues(java.util.Collection queues) {
setQueues(queues);
return this;
}
/**
*
* An array of the authentication protocol, VPC components, or virtual host to secure and define your event source.
*
*
* @return An array of the authentication protocol, VPC components, or virtual host to secure and define your event
* source.
*/
public java.util.List getSourceAccessConfigurations() {
if (sourceAccessConfigurations == null) {
sourceAccessConfigurations = new com.amazonaws.internal.SdkInternalList();
}
return sourceAccessConfigurations;
}
/**
*
* An array of the authentication protocol, VPC components, or virtual host to secure and define your event source.
*
*
* @param sourceAccessConfigurations
* An array of the authentication protocol, VPC components, or virtual host to secure and define your event
* source.
*/
public void setSourceAccessConfigurations(java.util.Collection sourceAccessConfigurations) {
if (sourceAccessConfigurations == null) {
this.sourceAccessConfigurations = null;
return;
}
this.sourceAccessConfigurations = new com.amazonaws.internal.SdkInternalList(sourceAccessConfigurations);
}
/**
*
* An array of the authentication protocol, VPC components, or virtual host to secure and define your event source.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setSourceAccessConfigurations(java.util.Collection)} or
* {@link #withSourceAccessConfigurations(java.util.Collection)} if you want to override the existing values.
*
*
* @param sourceAccessConfigurations
* An array of the authentication protocol, VPC components, or virtual host to secure and define your event
* source.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withSourceAccessConfigurations(SourceAccessConfiguration... sourceAccessConfigurations) {
if (this.sourceAccessConfigurations == null) {
setSourceAccessConfigurations(new com.amazonaws.internal.SdkInternalList(sourceAccessConfigurations.length));
}
for (SourceAccessConfiguration ele : sourceAccessConfigurations) {
this.sourceAccessConfigurations.add(ele);
}
return this;
}
/**
*
* An array of the authentication protocol, VPC components, or virtual host to secure and define your event source.
*
*
* @param sourceAccessConfigurations
* An array of the authentication protocol, VPC components, or virtual host to secure and define your event
* source.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withSourceAccessConfigurations(java.util.Collection sourceAccessConfigurations) {
setSourceAccessConfigurations(sourceAccessConfigurations);
return this;
}
/**
*
* The self-managed Apache Kafka cluster for your event source.
*
*
* @param selfManagedEventSource
* The self-managed Apache Kafka cluster for your event source.
*/
public void setSelfManagedEventSource(SelfManagedEventSource selfManagedEventSource) {
this.selfManagedEventSource = selfManagedEventSource;
}
/**
*
* The self-managed Apache Kafka cluster for your event source.
*
*
* @return The self-managed Apache Kafka cluster for your event source.
*/
public SelfManagedEventSource getSelfManagedEventSource() {
return this.selfManagedEventSource;
}
/**
*
* The self-managed Apache Kafka cluster for your event source.
*
*
* @param selfManagedEventSource
* The self-managed Apache Kafka cluster for your event source.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withSelfManagedEventSource(SelfManagedEventSource selfManagedEventSource) {
setSelfManagedEventSource(selfManagedEventSource);
return this;
}
/**
*
* (Kinesis and DynamoDB Streams only) Discard records older than the specified age. The default value is -1, which
* sets the maximum age to infinite. When the value is set to infinite, Lambda never discards old records.
*
*
*
* The minimum valid value for maximum record age is 60s. Although values less than 60 and greater than -1 fall
* within the parameter's absolute range, they are not allowed
*
*
*
* @param maximumRecordAgeInSeconds
* (Kinesis and DynamoDB Streams only) Discard records older than the specified age. The default value is -1,
* which sets the maximum age to infinite. When the value is set to infinite, Lambda never discards old
* records.
*
* The minimum valid value for maximum record age is 60s. Although values less than 60 and greater than -1
* fall within the parameter's absolute range, they are not allowed
*
*/
public void setMaximumRecordAgeInSeconds(Integer maximumRecordAgeInSeconds) {
this.maximumRecordAgeInSeconds = maximumRecordAgeInSeconds;
}
/**
*
* (Kinesis and DynamoDB Streams only) Discard records older than the specified age. The default value is -1, which
* sets the maximum age to infinite. When the value is set to infinite, Lambda never discards old records.
*
*
*
* The minimum valid value for maximum record age is 60s. Although values less than 60 and greater than -1 fall
* within the parameter's absolute range, they are not allowed
*
*
*
* @return (Kinesis and DynamoDB Streams only) Discard records older than the specified age. The default value is
* -1, which sets the maximum age to infinite. When the value is set to infinite, Lambda never discards old
* records.
*
* The minimum valid value for maximum record age is 60s. Although values less than 60 and greater than -1
* fall within the parameter's absolute range, they are not allowed
*
*/
public Integer getMaximumRecordAgeInSeconds() {
return this.maximumRecordAgeInSeconds;
}
/**
*
* (Kinesis and DynamoDB Streams only) Discard records older than the specified age. The default value is -1, which
* sets the maximum age to infinite. When the value is set to infinite, Lambda never discards old records.
*
*
*
* The minimum valid value for maximum record age is 60s. Although values less than 60 and greater than -1 fall
* within the parameter's absolute range, they are not allowed
*
*
*
* @param maximumRecordAgeInSeconds
* (Kinesis and DynamoDB Streams only) Discard records older than the specified age. The default value is -1,
* which sets the maximum age to infinite. When the value is set to infinite, Lambda never discards old
* records.
*
* The minimum valid value for maximum record age is 60s. Although values less than 60 and greater than -1
* fall within the parameter's absolute range, they are not allowed
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withMaximumRecordAgeInSeconds(Integer maximumRecordAgeInSeconds) {
setMaximumRecordAgeInSeconds(maximumRecordAgeInSeconds);
return this;
}
/**
*
* (Kinesis and DynamoDB Streams only) If the function returns an error, split the batch in two and retry. The
* default value is false.
*
*
* @param bisectBatchOnFunctionError
* (Kinesis and DynamoDB Streams only) If the function returns an error, split the batch in two and retry.
* The default value is false.
*/
public void setBisectBatchOnFunctionError(Boolean bisectBatchOnFunctionError) {
this.bisectBatchOnFunctionError = bisectBatchOnFunctionError;
}
/**
*
* (Kinesis and DynamoDB Streams only) If the function returns an error, split the batch in two and retry. The
* default value is false.
*
*
* @return (Kinesis and DynamoDB Streams only) If the function returns an error, split the batch in two and retry.
* The default value is false.
*/
public Boolean getBisectBatchOnFunctionError() {
return this.bisectBatchOnFunctionError;
}
/**
*
* (Kinesis and DynamoDB Streams only) If the function returns an error, split the batch in two and retry. The
* default value is false.
*
*
* @param bisectBatchOnFunctionError
* (Kinesis and DynamoDB Streams only) If the function returns an error, split the batch in two and retry.
* The default value is false.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withBisectBatchOnFunctionError(Boolean bisectBatchOnFunctionError) {
setBisectBatchOnFunctionError(bisectBatchOnFunctionError);
return this;
}
/**
*
* (Kinesis and DynamoDB Streams only) If the function returns an error, split the batch in two and retry. The
* default value is false.
*
*
* @return (Kinesis and DynamoDB Streams only) If the function returns an error, split the batch in two and retry.
* The default value is false.
*/
public Boolean isBisectBatchOnFunctionError() {
return this.bisectBatchOnFunctionError;
}
/**
*
* (Kinesis and DynamoDB Streams only) Discard records after the specified number of retries. The default value is
* -1, which sets the maximum number of retries to infinite. When MaximumRetryAttempts is infinite, Lambda retries
* failed records until the record expires in the event source.
*
*
* @param maximumRetryAttempts
* (Kinesis and DynamoDB Streams only) Discard records after the specified number of retries. The default
* value is -1, which sets the maximum number of retries to infinite. When MaximumRetryAttempts is infinite,
* Lambda retries failed records until the record expires in the event source.
*/
public void setMaximumRetryAttempts(Integer maximumRetryAttempts) {
this.maximumRetryAttempts = maximumRetryAttempts;
}
/**
*
* (Kinesis and DynamoDB Streams only) Discard records after the specified number of retries. The default value is
* -1, which sets the maximum number of retries to infinite. When MaximumRetryAttempts is infinite, Lambda retries
* failed records until the record expires in the event source.
*
*
* @return (Kinesis and DynamoDB Streams only) Discard records after the specified number of retries. The default
* value is -1, which sets the maximum number of retries to infinite. When MaximumRetryAttempts is infinite,
* Lambda retries failed records until the record expires in the event source.
*/
public Integer getMaximumRetryAttempts() {
return this.maximumRetryAttempts;
}
/**
*
* (Kinesis and DynamoDB Streams only) Discard records after the specified number of retries. The default value is
* -1, which sets the maximum number of retries to infinite. When MaximumRetryAttempts is infinite, Lambda retries
* failed records until the record expires in the event source.
*
*
* @param maximumRetryAttempts
* (Kinesis and DynamoDB Streams only) Discard records after the specified number of retries. The default
* value is -1, which sets the maximum number of retries to infinite. When MaximumRetryAttempts is infinite,
* Lambda retries failed records until the record expires in the event source.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withMaximumRetryAttempts(Integer maximumRetryAttempts) {
setMaximumRetryAttempts(maximumRetryAttempts);
return this;
}
/**
*
* (Kinesis and DynamoDB Streams only) The duration in seconds of a processing window for DynamoDB and Kinesis
* Streams event sources. A value of 0 seconds indicates no tumbling window.
*
*
* @param tumblingWindowInSeconds
* (Kinesis and DynamoDB Streams only) The duration in seconds of a processing window for DynamoDB and
* Kinesis Streams event sources. A value of 0 seconds indicates no tumbling window.
*/
public void setTumblingWindowInSeconds(Integer tumblingWindowInSeconds) {
this.tumblingWindowInSeconds = tumblingWindowInSeconds;
}
/**
*
* (Kinesis and DynamoDB Streams only) The duration in seconds of a processing window for DynamoDB and Kinesis
* Streams event sources. A value of 0 seconds indicates no tumbling window.
*
*
* @return (Kinesis and DynamoDB Streams only) The duration in seconds of a processing window for DynamoDB and
* Kinesis Streams event sources. A value of 0 seconds indicates no tumbling window.
*/
public Integer getTumblingWindowInSeconds() {
return this.tumblingWindowInSeconds;
}
/**
*
* (Kinesis and DynamoDB Streams only) The duration in seconds of a processing window for DynamoDB and Kinesis
* Streams event sources. A value of 0 seconds indicates no tumbling window.
*
*
* @param tumblingWindowInSeconds
* (Kinesis and DynamoDB Streams only) The duration in seconds of a processing window for DynamoDB and
* Kinesis Streams event sources. A value of 0 seconds indicates no tumbling window.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withTumblingWindowInSeconds(Integer tumblingWindowInSeconds) {
setTumblingWindowInSeconds(tumblingWindowInSeconds);
return this;
}
/**
*
* (Kinesis, DynamoDB Streams, and Amazon SQS) A list of current response type enums applied to the event source
* mapping.
*
*
* @return (Kinesis, DynamoDB Streams, and Amazon SQS) A list of current response type enums applied to the event
* source mapping.
* @see FunctionResponseType
*/
public java.util.List getFunctionResponseTypes() {
if (functionResponseTypes == null) {
functionResponseTypes = new com.amazonaws.internal.SdkInternalList();
}
return functionResponseTypes;
}
/**
*
* (Kinesis, DynamoDB Streams, and Amazon SQS) A list of current response type enums applied to the event source
* mapping.
*
*
* @param functionResponseTypes
* (Kinesis, DynamoDB Streams, and Amazon SQS) A list of current response type enums applied to the event
* source mapping.
* @see FunctionResponseType
*/
public void setFunctionResponseTypes(java.util.Collection functionResponseTypes) {
if (functionResponseTypes == null) {
this.functionResponseTypes = null;
return;
}
this.functionResponseTypes = new com.amazonaws.internal.SdkInternalList(functionResponseTypes);
}
/**
*
* (Kinesis, DynamoDB Streams, and Amazon SQS) A list of current response type enums applied to the event source
* mapping.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setFunctionResponseTypes(java.util.Collection)} or
* {@link #withFunctionResponseTypes(java.util.Collection)} if you want to override the existing values.
*
*
* @param functionResponseTypes
* (Kinesis, DynamoDB Streams, and Amazon SQS) A list of current response type enums applied to the event
* source mapping.
* @return Returns a reference to this object so that method calls can be chained together.
* @see FunctionResponseType
*/
public EventSourceMappingConfiguration withFunctionResponseTypes(String... functionResponseTypes) {
if (this.functionResponseTypes == null) {
setFunctionResponseTypes(new com.amazonaws.internal.SdkInternalList(functionResponseTypes.length));
}
for (String ele : functionResponseTypes) {
this.functionResponseTypes.add(ele);
}
return this;
}
/**
*
* (Kinesis, DynamoDB Streams, and Amazon SQS) A list of current response type enums applied to the event source
* mapping.
*
*
* @param functionResponseTypes
* (Kinesis, DynamoDB Streams, and Amazon SQS) A list of current response type enums applied to the event
* source mapping.
* @return Returns a reference to this object so that method calls can be chained together.
* @see FunctionResponseType
*/
public EventSourceMappingConfiguration withFunctionResponseTypes(java.util.Collection functionResponseTypes) {
setFunctionResponseTypes(functionResponseTypes);
return this;
}
/**
*
* (Kinesis, DynamoDB Streams, and Amazon SQS) A list of current response type enums applied to the event source
* mapping.
*
*
* @param functionResponseTypes
* (Kinesis, DynamoDB Streams, and Amazon SQS) A list of current response type enums applied to the event
* source mapping.
* @return Returns a reference to this object so that method calls can be chained together.
* @see FunctionResponseType
*/
public EventSourceMappingConfiguration withFunctionResponseTypes(FunctionResponseType... functionResponseTypes) {
com.amazonaws.internal.SdkInternalList functionResponseTypesCopy = new com.amazonaws.internal.SdkInternalList(
functionResponseTypes.length);
for (FunctionResponseType value : functionResponseTypes) {
functionResponseTypesCopy.add(value.toString());
}
if (getFunctionResponseTypes() == null) {
setFunctionResponseTypes(functionResponseTypesCopy);
} else {
getFunctionResponseTypes().addAll(functionResponseTypesCopy);
}
return this;
}
/**
*
* Specific configuration settings for an Amazon Managed Streaming for Apache Kafka (Amazon MSK) event source.
*
*
* @param amazonManagedKafkaEventSourceConfig
* Specific configuration settings for an Amazon Managed Streaming for Apache Kafka (Amazon MSK) event
* source.
*/
public void setAmazonManagedKafkaEventSourceConfig(AmazonManagedKafkaEventSourceConfig amazonManagedKafkaEventSourceConfig) {
this.amazonManagedKafkaEventSourceConfig = amazonManagedKafkaEventSourceConfig;
}
/**
*
* Specific configuration settings for an Amazon Managed Streaming for Apache Kafka (Amazon MSK) event source.
*
*
* @return Specific configuration settings for an Amazon Managed Streaming for Apache Kafka (Amazon MSK) event
* source.
*/
public AmazonManagedKafkaEventSourceConfig getAmazonManagedKafkaEventSourceConfig() {
return this.amazonManagedKafkaEventSourceConfig;
}
/**
*
* Specific configuration settings for an Amazon Managed Streaming for Apache Kafka (Amazon MSK) event source.
*
*
* @param amazonManagedKafkaEventSourceConfig
* Specific configuration settings for an Amazon Managed Streaming for Apache Kafka (Amazon MSK) event
* source.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withAmazonManagedKafkaEventSourceConfig(AmazonManagedKafkaEventSourceConfig amazonManagedKafkaEventSourceConfig) {
setAmazonManagedKafkaEventSourceConfig(amazonManagedKafkaEventSourceConfig);
return this;
}
/**
*
* Specific configuration settings for a self-managed Apache Kafka event source.
*
*
* @param selfManagedKafkaEventSourceConfig
* Specific configuration settings for a self-managed Apache Kafka event source.
*/
public void setSelfManagedKafkaEventSourceConfig(SelfManagedKafkaEventSourceConfig selfManagedKafkaEventSourceConfig) {
this.selfManagedKafkaEventSourceConfig = selfManagedKafkaEventSourceConfig;
}
/**
*
* Specific configuration settings for a self-managed Apache Kafka event source.
*
*
* @return Specific configuration settings for a self-managed Apache Kafka event source.
*/
public SelfManagedKafkaEventSourceConfig getSelfManagedKafkaEventSourceConfig() {
return this.selfManagedKafkaEventSourceConfig;
}
/**
*
* Specific configuration settings for a self-managed Apache Kafka event source.
*
*
* @param selfManagedKafkaEventSourceConfig
* Specific configuration settings for a self-managed Apache Kafka event source.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withSelfManagedKafkaEventSourceConfig(SelfManagedKafkaEventSourceConfig selfManagedKafkaEventSourceConfig) {
setSelfManagedKafkaEventSourceConfig(selfManagedKafkaEventSourceConfig);
return this;
}
/**
*
* (Amazon SQS only) The scaling configuration for the event source. For more information, see Configuring maximum
* concurrency for Amazon SQS event sources.
*
*
* @param scalingConfig
* (Amazon SQS only) The scaling configuration for the event source. For more information, see Configuring
* maximum concurrency for Amazon SQS event sources.
*/
public void setScalingConfig(ScalingConfig scalingConfig) {
this.scalingConfig = scalingConfig;
}
/**
*
* (Amazon SQS only) The scaling configuration for the event source. For more information, see Configuring maximum
* concurrency for Amazon SQS event sources.
*
*
* @return (Amazon SQS only) The scaling configuration for the event source. For more information, see Configuring
* maximum concurrency for Amazon SQS event sources.
*/
public ScalingConfig getScalingConfig() {
return this.scalingConfig;
}
/**
*
* (Amazon SQS only) The scaling configuration for the event source. For more information, see Configuring maximum
* concurrency for Amazon SQS event sources.
*
*
* @param scalingConfig
* (Amazon SQS only) The scaling configuration for the event source. For more information, see Configuring
* maximum concurrency for Amazon SQS event sources.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withScalingConfig(ScalingConfig scalingConfig) {
setScalingConfig(scalingConfig);
return this;
}
/**
*
* Specific configuration settings for a DocumentDB event source.
*
*
* @param documentDBEventSourceConfig
* Specific configuration settings for a DocumentDB event source.
*/
public void setDocumentDBEventSourceConfig(DocumentDBEventSourceConfig documentDBEventSourceConfig) {
this.documentDBEventSourceConfig = documentDBEventSourceConfig;
}
/**
*
* Specific configuration settings for a DocumentDB event source.
*
*
* @return Specific configuration settings for a DocumentDB event source.
*/
public DocumentDBEventSourceConfig getDocumentDBEventSourceConfig() {
return this.documentDBEventSourceConfig;
}
/**
*
* Specific configuration settings for a DocumentDB event source.
*
*
* @param documentDBEventSourceConfig
* Specific configuration settings for a DocumentDB event source.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public EventSourceMappingConfiguration withDocumentDBEventSourceConfig(DocumentDBEventSourceConfig documentDBEventSourceConfig) {
setDocumentDBEventSourceConfig(documentDBEventSourceConfig);
return this;
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
if (getUUID() != null)
sb.append("UUID: ").append(getUUID()).append(",");
if (getStartingPosition() != null)
sb.append("StartingPosition: ").append(getStartingPosition()).append(",");
if (getStartingPositionTimestamp() != null)
sb.append("StartingPositionTimestamp: ").append(getStartingPositionTimestamp()).append(",");
if (getBatchSize() != null)
sb.append("BatchSize: ").append(getBatchSize()).append(",");
if (getMaximumBatchingWindowInSeconds() != null)
sb.append("MaximumBatchingWindowInSeconds: ").append(getMaximumBatchingWindowInSeconds()).append(",");
if (getParallelizationFactor() != null)
sb.append("ParallelizationFactor: ").append(getParallelizationFactor()).append(",");
if (getEventSourceArn() != null)
sb.append("EventSourceArn: ").append(getEventSourceArn()).append(",");
if (getFilterCriteria() != null)
sb.append("FilterCriteria: ").append(getFilterCriteria()).append(",");
if (getFunctionArn() != null)
sb.append("FunctionArn: ").append(getFunctionArn()).append(",");
if (getLastModified() != null)
sb.append("LastModified: ").append(getLastModified()).append(",");
if (getLastProcessingResult() != null)
sb.append("LastProcessingResult: ").append(getLastProcessingResult()).append(",");
if (getState() != null)
sb.append("State: ").append(getState()).append(",");
if (getStateTransitionReason() != null)
sb.append("StateTransitionReason: ").append(getStateTransitionReason()).append(",");
if (getDestinationConfig() != null)
sb.append("DestinationConfig: ").append(getDestinationConfig()).append(",");
if (getTopics() != null)
sb.append("Topics: ").append(getTopics()).append(",");
if (getQueues() != null)
sb.append("Queues: ").append(getQueues()).append(",");
if (getSourceAccessConfigurations() != null)
sb.append("SourceAccessConfigurations: ").append(getSourceAccessConfigurations()).append(",");
if (getSelfManagedEventSource() != null)
sb.append("SelfManagedEventSource: ").append(getSelfManagedEventSource()).append(",");
if (getMaximumRecordAgeInSeconds() != null)
sb.append("MaximumRecordAgeInSeconds: ").append(getMaximumRecordAgeInSeconds()).append(",");
if (getBisectBatchOnFunctionError() != null)
sb.append("BisectBatchOnFunctionError: ").append(getBisectBatchOnFunctionError()).append(",");
if (getMaximumRetryAttempts() != null)
sb.append("MaximumRetryAttempts: ").append(getMaximumRetryAttempts()).append(",");
if (getTumblingWindowInSeconds() != null)
sb.append("TumblingWindowInSeconds: ").append(getTumblingWindowInSeconds()).append(",");
if (getFunctionResponseTypes() != null)
sb.append("FunctionResponseTypes: ").append(getFunctionResponseTypes()).append(",");
if (getAmazonManagedKafkaEventSourceConfig() != null)
sb.append("AmazonManagedKafkaEventSourceConfig: ").append(getAmazonManagedKafkaEventSourceConfig()).append(",");
if (getSelfManagedKafkaEventSourceConfig() != null)
sb.append("SelfManagedKafkaEventSourceConfig: ").append(getSelfManagedKafkaEventSourceConfig()).append(",");
if (getScalingConfig() != null)
sb.append("ScalingConfig: ").append(getScalingConfig()).append(",");
if (getDocumentDBEventSourceConfig() != null)
sb.append("DocumentDBEventSourceConfig: ").append(getDocumentDBEventSourceConfig());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof EventSourceMappingConfiguration == false)
return false;
EventSourceMappingConfiguration other = (EventSourceMappingConfiguration) obj;
if (other.getUUID() == null ^ this.getUUID() == null)
return false;
if (other.getUUID() != null && other.getUUID().equals(this.getUUID()) == false)
return false;
if (other.getStartingPosition() == null ^ this.getStartingPosition() == null)
return false;
if (other.getStartingPosition() != null && other.getStartingPosition().equals(this.getStartingPosition()) == false)
return false;
if (other.getStartingPositionTimestamp() == null ^ this.getStartingPositionTimestamp() == null)
return false;
if (other.getStartingPositionTimestamp() != null && other.getStartingPositionTimestamp().equals(this.getStartingPositionTimestamp()) == false)
return false;
if (other.getBatchSize() == null ^ this.getBatchSize() == null)
return false;
if (other.getBatchSize() != null && other.getBatchSize().equals(this.getBatchSize()) == false)
return false;
if (other.getMaximumBatchingWindowInSeconds() == null ^ this.getMaximumBatchingWindowInSeconds() == null)
return false;
if (other.getMaximumBatchingWindowInSeconds() != null
&& other.getMaximumBatchingWindowInSeconds().equals(this.getMaximumBatchingWindowInSeconds()) == false)
return false;
if (other.getParallelizationFactor() == null ^ this.getParallelizationFactor() == null)
return false;
if (other.getParallelizationFactor() != null && other.getParallelizationFactor().equals(this.getParallelizationFactor()) == false)
return false;
if (other.getEventSourceArn() == null ^ this.getEventSourceArn() == null)
return false;
if (other.getEventSourceArn() != null && other.getEventSourceArn().equals(this.getEventSourceArn()) == false)
return false;
if (other.getFilterCriteria() == null ^ this.getFilterCriteria() == null)
return false;
if (other.getFilterCriteria() != null && other.getFilterCriteria().equals(this.getFilterCriteria()) == false)
return false;
if (other.getFunctionArn() == null ^ this.getFunctionArn() == null)
return false;
if (other.getFunctionArn() != null && other.getFunctionArn().equals(this.getFunctionArn()) == false)
return false;
if (other.getLastModified() == null ^ this.getLastModified() == null)
return false;
if (other.getLastModified() != null && other.getLastModified().equals(this.getLastModified()) == false)
return false;
if (other.getLastProcessingResult() == null ^ this.getLastProcessingResult() == null)
return false;
if (other.getLastProcessingResult() != null && other.getLastProcessingResult().equals(this.getLastProcessingResult()) == false)
return false;
if (other.getState() == null ^ this.getState() == null)
return false;
if (other.getState() != null && other.getState().equals(this.getState()) == false)
return false;
if (other.getStateTransitionReason() == null ^ this.getStateTransitionReason() == null)
return false;
if (other.getStateTransitionReason() != null && other.getStateTransitionReason().equals(this.getStateTransitionReason()) == false)
return false;
if (other.getDestinationConfig() == null ^ this.getDestinationConfig() == null)
return false;
if (other.getDestinationConfig() != null && other.getDestinationConfig().equals(this.getDestinationConfig()) == false)
return false;
if (other.getTopics() == null ^ this.getTopics() == null)
return false;
if (other.getTopics() != null && other.getTopics().equals(this.getTopics()) == false)
return false;
if (other.getQueues() == null ^ this.getQueues() == null)
return false;
if (other.getQueues() != null && other.getQueues().equals(this.getQueues()) == false)
return false;
if (other.getSourceAccessConfigurations() == null ^ this.getSourceAccessConfigurations() == null)
return false;
if (other.getSourceAccessConfigurations() != null && other.getSourceAccessConfigurations().equals(this.getSourceAccessConfigurations()) == false)
return false;
if (other.getSelfManagedEventSource() == null ^ this.getSelfManagedEventSource() == null)
return false;
if (other.getSelfManagedEventSource() != null && other.getSelfManagedEventSource().equals(this.getSelfManagedEventSource()) == false)
return false;
if (other.getMaximumRecordAgeInSeconds() == null ^ this.getMaximumRecordAgeInSeconds() == null)
return false;
if (other.getMaximumRecordAgeInSeconds() != null && other.getMaximumRecordAgeInSeconds().equals(this.getMaximumRecordAgeInSeconds()) == false)
return false;
if (other.getBisectBatchOnFunctionError() == null ^ this.getBisectBatchOnFunctionError() == null)
return false;
if (other.getBisectBatchOnFunctionError() != null && other.getBisectBatchOnFunctionError().equals(this.getBisectBatchOnFunctionError()) == false)
return false;
if (other.getMaximumRetryAttempts() == null ^ this.getMaximumRetryAttempts() == null)
return false;
if (other.getMaximumRetryAttempts() != null && other.getMaximumRetryAttempts().equals(this.getMaximumRetryAttempts()) == false)
return false;
if (other.getTumblingWindowInSeconds() == null ^ this.getTumblingWindowInSeconds() == null)
return false;
if (other.getTumblingWindowInSeconds() != null && other.getTumblingWindowInSeconds().equals(this.getTumblingWindowInSeconds()) == false)
return false;
if (other.getFunctionResponseTypes() == null ^ this.getFunctionResponseTypes() == null)
return false;
if (other.getFunctionResponseTypes() != null && other.getFunctionResponseTypes().equals(this.getFunctionResponseTypes()) == false)
return false;
if (other.getAmazonManagedKafkaEventSourceConfig() == null ^ this.getAmazonManagedKafkaEventSourceConfig() == null)
return false;
if (other.getAmazonManagedKafkaEventSourceConfig() != null
&& other.getAmazonManagedKafkaEventSourceConfig().equals(this.getAmazonManagedKafkaEventSourceConfig()) == false)
return false;
if (other.getSelfManagedKafkaEventSourceConfig() == null ^ this.getSelfManagedKafkaEventSourceConfig() == null)
return false;
if (other.getSelfManagedKafkaEventSourceConfig() != null
&& other.getSelfManagedKafkaEventSourceConfig().equals(this.getSelfManagedKafkaEventSourceConfig()) == false)
return false;
if (other.getScalingConfig() == null ^ this.getScalingConfig() == null)
return false;
if (other.getScalingConfig() != null && other.getScalingConfig().equals(this.getScalingConfig()) == false)
return false;
if (other.getDocumentDBEventSourceConfig() == null ^ this.getDocumentDBEventSourceConfig() == null)
return false;
if (other.getDocumentDBEventSourceConfig() != null && other.getDocumentDBEventSourceConfig().equals(this.getDocumentDBEventSourceConfig()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getUUID() == null) ? 0 : getUUID().hashCode());
hashCode = prime * hashCode + ((getStartingPosition() == null) ? 0 : getStartingPosition().hashCode());
hashCode = prime * hashCode + ((getStartingPositionTimestamp() == null) ? 0 : getStartingPositionTimestamp().hashCode());
hashCode = prime * hashCode + ((getBatchSize() == null) ? 0 : getBatchSize().hashCode());
hashCode = prime * hashCode + ((getMaximumBatchingWindowInSeconds() == null) ? 0 : getMaximumBatchingWindowInSeconds().hashCode());
hashCode = prime * hashCode + ((getParallelizationFactor() == null) ? 0 : getParallelizationFactor().hashCode());
hashCode = prime * hashCode + ((getEventSourceArn() == null) ? 0 : getEventSourceArn().hashCode());
hashCode = prime * hashCode + ((getFilterCriteria() == null) ? 0 : getFilterCriteria().hashCode());
hashCode = prime * hashCode + ((getFunctionArn() == null) ? 0 : getFunctionArn().hashCode());
hashCode = prime * hashCode + ((getLastModified() == null) ? 0 : getLastModified().hashCode());
hashCode = prime * hashCode + ((getLastProcessingResult() == null) ? 0 : getLastProcessingResult().hashCode());
hashCode = prime * hashCode + ((getState() == null) ? 0 : getState().hashCode());
hashCode = prime * hashCode + ((getStateTransitionReason() == null) ? 0 : getStateTransitionReason().hashCode());
hashCode = prime * hashCode + ((getDestinationConfig() == null) ? 0 : getDestinationConfig().hashCode());
hashCode = prime * hashCode + ((getTopics() == null) ? 0 : getTopics().hashCode());
hashCode = prime * hashCode + ((getQueues() == null) ? 0 : getQueues().hashCode());
hashCode = prime * hashCode + ((getSourceAccessConfigurations() == null) ? 0 : getSourceAccessConfigurations().hashCode());
hashCode = prime * hashCode + ((getSelfManagedEventSource() == null) ? 0 : getSelfManagedEventSource().hashCode());
hashCode = prime * hashCode + ((getMaximumRecordAgeInSeconds() == null) ? 0 : getMaximumRecordAgeInSeconds().hashCode());
hashCode = prime * hashCode + ((getBisectBatchOnFunctionError() == null) ? 0 : getBisectBatchOnFunctionError().hashCode());
hashCode = prime * hashCode + ((getMaximumRetryAttempts() == null) ? 0 : getMaximumRetryAttempts().hashCode());
hashCode = prime * hashCode + ((getTumblingWindowInSeconds() == null) ? 0 : getTumblingWindowInSeconds().hashCode());
hashCode = prime * hashCode + ((getFunctionResponseTypes() == null) ? 0 : getFunctionResponseTypes().hashCode());
hashCode = prime * hashCode + ((getAmazonManagedKafkaEventSourceConfig() == null) ? 0 : getAmazonManagedKafkaEventSourceConfig().hashCode());
hashCode = prime * hashCode + ((getSelfManagedKafkaEventSourceConfig() == null) ? 0 : getSelfManagedKafkaEventSourceConfig().hashCode());
hashCode = prime * hashCode + ((getScalingConfig() == null) ? 0 : getScalingConfig().hashCode());
hashCode = prime * hashCode + ((getDocumentDBEventSourceConfig() == null) ? 0 : getDocumentDBEventSourceConfig().hashCode());
return hashCode;
}
@Override
public EventSourceMappingConfiguration clone() {
try {
return (EventSourceMappingConfiguration) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
@com.amazonaws.annotation.SdkInternalApi
@Override
public void marshall(ProtocolMarshaller protocolMarshaller) {
com.amazonaws.services.lambda.model.transform.EventSourceMappingConfigurationMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}