/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include #include #include #include #include #include #include #include namespace Aws { namespace Utils { namespace Json { class JsonValue; class JsonView; } // namespace Json } // namespace Utils namespace Firehose { namespace Model { /** *

Describes the HTTP endpoint destination.

See Also:

AWS * API Reference

*/ class AWS_FIREHOSE_API HttpEndpointDestinationDescription { public: HttpEndpointDestinationDescription(); HttpEndpointDestinationDescription(Aws::Utils::Json::JsonView jsonValue); HttpEndpointDestinationDescription& operator=(Aws::Utils::Json::JsonView jsonValue); Aws::Utils::Json::JsonValue Jsonize() const; /** *

The configuration of the specified HTTP endpoint destination.

*/ inline const HttpEndpointDescription& GetEndpointConfiguration() const{ return m_endpointConfiguration; } /** *

The configuration of the specified HTTP endpoint destination.

*/ inline bool EndpointConfigurationHasBeenSet() const { return m_endpointConfigurationHasBeenSet; } /** *

The configuration of the specified HTTP endpoint destination.

*/ inline void SetEndpointConfiguration(const HttpEndpointDescription& value) { m_endpointConfigurationHasBeenSet = true; m_endpointConfiguration = value; } /** *

The configuration of the specified HTTP endpoint destination.

*/ inline void SetEndpointConfiguration(HttpEndpointDescription&& value) { m_endpointConfigurationHasBeenSet = true; m_endpointConfiguration = std::move(value); } /** *

The configuration of the specified HTTP endpoint destination.

*/ inline HttpEndpointDestinationDescription& WithEndpointConfiguration(const HttpEndpointDescription& value) { SetEndpointConfiguration(value); return *this;} /** *

The configuration of the specified HTTP endpoint destination.

*/ inline HttpEndpointDestinationDescription& WithEndpointConfiguration(HttpEndpointDescription&& value) { SetEndpointConfiguration(std::move(value)); return *this;} /** *

Describes buffering options that can be applied to the data before it is * delivered to the HTTPS endpoint destination. Kinesis Data Firehose teats these * options as hints, and it might choose to use more optimal values. The * SizeInMBs and IntervalInSeconds parameters are * optional. However, if specify a value for one of them, you must also provide a * value for the other.

*/ inline const HttpEndpointBufferingHints& GetBufferingHints() const{ return m_bufferingHints; } /** *

Describes buffering options that can be applied to the data before it is * delivered to the HTTPS endpoint destination. Kinesis Data Firehose teats these * options as hints, and it might choose to use more optimal values. The * SizeInMBs and IntervalInSeconds parameters are * optional. However, if specify a value for one of them, you must also provide a * value for the other.

*/ inline bool BufferingHintsHasBeenSet() const { return m_bufferingHintsHasBeenSet; } /** *

Describes buffering options that can be applied to the data before it is * delivered to the HTTPS endpoint destination. Kinesis Data Firehose teats these * options as hints, and it might choose to use more optimal values. The * SizeInMBs and IntervalInSeconds parameters are * optional. However, if specify a value for one of them, you must also provide a * value for the other.

*/ inline void SetBufferingHints(const HttpEndpointBufferingHints& value) { m_bufferingHintsHasBeenSet = true; m_bufferingHints = value; } /** *

Describes buffering options that can be applied to the data before it is * delivered to the HTTPS endpoint destination. Kinesis Data Firehose teats these * options as hints, and it might choose to use more optimal values. The * SizeInMBs and IntervalInSeconds parameters are * optional. However, if specify a value for one of them, you must also provide a * value for the other.

*/ inline void SetBufferingHints(HttpEndpointBufferingHints&& value) { m_bufferingHintsHasBeenSet = true; m_bufferingHints = std::move(value); } /** *

Describes buffering options that can be applied to the data before it is * delivered to the HTTPS endpoint destination. Kinesis Data Firehose teats these * options as hints, and it might choose to use more optimal values. The * SizeInMBs and IntervalInSeconds parameters are * optional. However, if specify a value for one of them, you must also provide a * value for the other.

*/ inline HttpEndpointDestinationDescription& WithBufferingHints(const HttpEndpointBufferingHints& value) { SetBufferingHints(value); return *this;} /** *

Describes buffering options that can be applied to the data before it is * delivered to the HTTPS endpoint destination. Kinesis Data Firehose teats these * options as hints, and it might choose to use more optimal values. The * SizeInMBs and IntervalInSeconds parameters are * optional. However, if specify a value for one of them, you must also provide a * value for the other.

*/ inline HttpEndpointDestinationDescription& WithBufferingHints(HttpEndpointBufferingHints&& value) { SetBufferingHints(std::move(value)); return *this;} inline const CloudWatchLoggingOptions& GetCloudWatchLoggingOptions() const{ return m_cloudWatchLoggingOptions; } inline bool CloudWatchLoggingOptionsHasBeenSet() const { return m_cloudWatchLoggingOptionsHasBeenSet; } inline void SetCloudWatchLoggingOptions(const CloudWatchLoggingOptions& value) { m_cloudWatchLoggingOptionsHasBeenSet = true; m_cloudWatchLoggingOptions = value; } inline void SetCloudWatchLoggingOptions(CloudWatchLoggingOptions&& value) { m_cloudWatchLoggingOptionsHasBeenSet = true; m_cloudWatchLoggingOptions = std::move(value); } inline HttpEndpointDestinationDescription& WithCloudWatchLoggingOptions(const CloudWatchLoggingOptions& value) { SetCloudWatchLoggingOptions(value); return *this;} inline HttpEndpointDestinationDescription& WithCloudWatchLoggingOptions(CloudWatchLoggingOptions&& value) { SetCloudWatchLoggingOptions(std::move(value)); return *this;} /** *

The configuration of request sent to the HTTP endpoint specified as the * destination.

*/ inline const HttpEndpointRequestConfiguration& GetRequestConfiguration() const{ return m_requestConfiguration; } /** *

The configuration of request sent to the HTTP endpoint specified as the * destination.

*/ inline bool RequestConfigurationHasBeenSet() const { return m_requestConfigurationHasBeenSet; } /** *

The configuration of request sent to the HTTP endpoint specified as the * destination.

*/ inline void SetRequestConfiguration(const HttpEndpointRequestConfiguration& value) { m_requestConfigurationHasBeenSet = true; m_requestConfiguration = value; } /** *

The configuration of request sent to the HTTP endpoint specified as the * destination.

*/ inline void SetRequestConfiguration(HttpEndpointRequestConfiguration&& value) { m_requestConfigurationHasBeenSet = true; m_requestConfiguration = std::move(value); } /** *

The configuration of request sent to the HTTP endpoint specified as the * destination.

*/ inline HttpEndpointDestinationDescription& WithRequestConfiguration(const HttpEndpointRequestConfiguration& value) { SetRequestConfiguration(value); return *this;} /** *

The configuration of request sent to the HTTP endpoint specified as the * destination.

*/ inline HttpEndpointDestinationDescription& WithRequestConfiguration(HttpEndpointRequestConfiguration&& value) { SetRequestConfiguration(std::move(value)); return *this;} inline const ProcessingConfiguration& GetProcessingConfiguration() const{ return m_processingConfiguration; } inline bool ProcessingConfigurationHasBeenSet() const { return m_processingConfigurationHasBeenSet; } inline void SetProcessingConfiguration(const ProcessingConfiguration& value) { m_processingConfigurationHasBeenSet = true; m_processingConfiguration = value; } inline void SetProcessingConfiguration(ProcessingConfiguration&& value) { m_processingConfigurationHasBeenSet = true; m_processingConfiguration = std::move(value); } inline HttpEndpointDestinationDescription& WithProcessingConfiguration(const ProcessingConfiguration& value) { SetProcessingConfiguration(value); return *this;} inline HttpEndpointDestinationDescription& WithProcessingConfiguration(ProcessingConfiguration&& value) { SetProcessingConfiguration(std::move(value)); return *this;} /** *

Kinesis Data Firehose uses this IAM role for all the permissions that the * delivery stream needs.

*/ inline const Aws::String& GetRoleARN() const{ return m_roleARN; } /** *

Kinesis Data Firehose uses this IAM role for all the permissions that the * delivery stream needs.

*/ inline bool RoleARNHasBeenSet() const { return m_roleARNHasBeenSet; } /** *

Kinesis Data Firehose uses this IAM role for all the permissions that the * delivery stream needs.

*/ inline void SetRoleARN(const Aws::String& value) { m_roleARNHasBeenSet = true; m_roleARN = value; } /** *

Kinesis Data Firehose uses this IAM role for all the permissions that the * delivery stream needs.

*/ inline void SetRoleARN(Aws::String&& value) { m_roleARNHasBeenSet = true; m_roleARN = std::move(value); } /** *

Kinesis Data Firehose uses this IAM role for all the permissions that the * delivery stream needs.

*/ inline void SetRoleARN(const char* value) { m_roleARNHasBeenSet = true; m_roleARN.assign(value); } /** *

Kinesis Data Firehose uses this IAM role for all the permissions that the * delivery stream needs.

*/ inline HttpEndpointDestinationDescription& WithRoleARN(const Aws::String& value) { SetRoleARN(value); return *this;} /** *

Kinesis Data Firehose uses this IAM role for all the permissions that the * delivery stream needs.

*/ inline HttpEndpointDestinationDescription& WithRoleARN(Aws::String&& value) { SetRoleARN(std::move(value)); return *this;} /** *

Kinesis Data Firehose uses this IAM role for all the permissions that the * delivery stream needs.

*/ inline HttpEndpointDestinationDescription& WithRoleARN(const char* value) { SetRoleARN(value); return *this;} /** *

Describes the retry behavior in case Kinesis Data Firehose is unable to * deliver data to the specified HTTP endpoint destination, or if it doesn't * receive a valid acknowledgment of receipt from the specified HTTP endpoint * destination.

*/ inline const HttpEndpointRetryOptions& GetRetryOptions() const{ return m_retryOptions; } /** *

Describes the retry behavior in case Kinesis Data Firehose is unable to * deliver data to the specified HTTP endpoint destination, or if it doesn't * receive a valid acknowledgment of receipt from the specified HTTP endpoint * destination.

*/ inline bool RetryOptionsHasBeenSet() const { return m_retryOptionsHasBeenSet; } /** *

Describes the retry behavior in case Kinesis Data Firehose is unable to * deliver data to the specified HTTP endpoint destination, or if it doesn't * receive a valid acknowledgment of receipt from the specified HTTP endpoint * destination.

*/ inline void SetRetryOptions(const HttpEndpointRetryOptions& value) { m_retryOptionsHasBeenSet = true; m_retryOptions = value; } /** *

Describes the retry behavior in case Kinesis Data Firehose is unable to * deliver data to the specified HTTP endpoint destination, or if it doesn't * receive a valid acknowledgment of receipt from the specified HTTP endpoint * destination.

*/ inline void SetRetryOptions(HttpEndpointRetryOptions&& value) { m_retryOptionsHasBeenSet = true; m_retryOptions = std::move(value); } /** *

Describes the retry behavior in case Kinesis Data Firehose is unable to * deliver data to the specified HTTP endpoint destination, or if it doesn't * receive a valid acknowledgment of receipt from the specified HTTP endpoint * destination.

*/ inline HttpEndpointDestinationDescription& WithRetryOptions(const HttpEndpointRetryOptions& value) { SetRetryOptions(value); return *this;} /** *

Describes the retry behavior in case Kinesis Data Firehose is unable to * deliver data to the specified HTTP endpoint destination, or if it doesn't * receive a valid acknowledgment of receipt from the specified HTTP endpoint * destination.

*/ inline HttpEndpointDestinationDescription& WithRetryOptions(HttpEndpointRetryOptions&& value) { SetRetryOptions(std::move(value)); return *this;} /** *

Describes the S3 bucket backup options for the data that Kinesis Firehose * delivers to the HTTP endpoint destination. You can back up all documents * (AllData) or only the documents that Kinesis Data Firehose could * not deliver to the specified HTTP endpoint destination * (FailedDataOnly).

*/ inline const HttpEndpointS3BackupMode& GetS3BackupMode() const{ return m_s3BackupMode; } /** *

Describes the S3 bucket backup options for the data that Kinesis Firehose * delivers to the HTTP endpoint destination. You can back up all documents * (AllData) or only the documents that Kinesis Data Firehose could * not deliver to the specified HTTP endpoint destination * (FailedDataOnly).

*/ inline bool S3BackupModeHasBeenSet() const { return m_s3BackupModeHasBeenSet; } /** *

Describes the S3 bucket backup options for the data that Kinesis Firehose * delivers to the HTTP endpoint destination. You can back up all documents * (AllData) or only the documents that Kinesis Data Firehose could * not deliver to the specified HTTP endpoint destination * (FailedDataOnly).

*/ inline void SetS3BackupMode(const HttpEndpointS3BackupMode& value) { m_s3BackupModeHasBeenSet = true; m_s3BackupMode = value; } /** *

Describes the S3 bucket backup options for the data that Kinesis Firehose * delivers to the HTTP endpoint destination. You can back up all documents * (AllData) or only the documents that Kinesis Data Firehose could * not deliver to the specified HTTP endpoint destination * (FailedDataOnly).

*/ inline void SetS3BackupMode(HttpEndpointS3BackupMode&& value) { m_s3BackupModeHasBeenSet = true; m_s3BackupMode = std::move(value); } /** *

Describes the S3 bucket backup options for the data that Kinesis Firehose * delivers to the HTTP endpoint destination. You can back up all documents * (AllData) or only the documents that Kinesis Data Firehose could * not deliver to the specified HTTP endpoint destination * (FailedDataOnly).

*/ inline HttpEndpointDestinationDescription& WithS3BackupMode(const HttpEndpointS3BackupMode& value) { SetS3BackupMode(value); return *this;} /** *

Describes the S3 bucket backup options for the data that Kinesis Firehose * delivers to the HTTP endpoint destination. You can back up all documents * (AllData) or only the documents that Kinesis Data Firehose could * not deliver to the specified HTTP endpoint destination * (FailedDataOnly).

*/ inline HttpEndpointDestinationDescription& WithS3BackupMode(HttpEndpointS3BackupMode&& value) { SetS3BackupMode(std::move(value)); return *this;} inline const S3DestinationDescription& GetS3DestinationDescription() const{ return m_s3DestinationDescription; } inline bool S3DestinationDescriptionHasBeenSet() const { return m_s3DestinationDescriptionHasBeenSet; } inline void SetS3DestinationDescription(const S3DestinationDescription& value) { m_s3DestinationDescriptionHasBeenSet = true; m_s3DestinationDescription = value; } inline void SetS3DestinationDescription(S3DestinationDescription&& value) { m_s3DestinationDescriptionHasBeenSet = true; m_s3DestinationDescription = std::move(value); } inline HttpEndpointDestinationDescription& WithS3DestinationDescription(const S3DestinationDescription& value) { SetS3DestinationDescription(value); return *this;} inline HttpEndpointDestinationDescription& WithS3DestinationDescription(S3DestinationDescription&& value) { SetS3DestinationDescription(std::move(value)); return *this;} private: HttpEndpointDescription m_endpointConfiguration; bool m_endpointConfigurationHasBeenSet; HttpEndpointBufferingHints m_bufferingHints; bool m_bufferingHintsHasBeenSet; CloudWatchLoggingOptions m_cloudWatchLoggingOptions; bool m_cloudWatchLoggingOptionsHasBeenSet; HttpEndpointRequestConfiguration m_requestConfiguration; bool m_requestConfigurationHasBeenSet; ProcessingConfiguration m_processingConfiguration; bool m_processingConfigurationHasBeenSet; Aws::String m_roleARN; bool m_roleARNHasBeenSet; HttpEndpointRetryOptions m_retryOptions; bool m_retryOptionsHasBeenSet; HttpEndpointS3BackupMode m_s3BackupMode; bool m_s3BackupModeHasBeenSet; S3DestinationDescription m_s3DestinationDescription; bool m_s3DestinationDescriptionHasBeenSet; }; } // namespace Model } // namespace Firehose } // namespace Aws