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

Describes the buffering to perform before delivering data to the Serverless * offering for Amazon OpenSearch Service destination.

See Also:

* AWS * API Reference

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

Buffer incoming data for the specified period of time, in seconds, before * delivering it to the destination. The default value is 300 (5 minutes).

*/ inline int GetIntervalInSeconds() const{ return m_intervalInSeconds; } /** *

Buffer incoming data for the specified period of time, in seconds, before * delivering it to the destination. The default value is 300 (5 minutes).

*/ inline bool IntervalInSecondsHasBeenSet() const { return m_intervalInSecondsHasBeenSet; } /** *

Buffer incoming data for the specified period of time, in seconds, before * delivering it to the destination. The default value is 300 (5 minutes).

*/ inline void SetIntervalInSeconds(int value) { m_intervalInSecondsHasBeenSet = true; m_intervalInSeconds = value; } /** *

Buffer incoming data for the specified period of time, in seconds, before * delivering it to the destination. The default value is 300 (5 minutes).

*/ inline AmazonOpenSearchServerlessBufferingHints& WithIntervalInSeconds(int value) { SetIntervalInSeconds(value); return *this;} /** *

Buffer incoming data to the specified size, in MBs, before delivering it to * the destination. The default value is 5.

We recommend setting this * parameter to a value greater than the amount of data you typically ingest into * the delivery stream in 10 seconds. For example, if you typically ingest data at * 1 MB/sec, the value should be 10 MB or higher.

*/ inline int GetSizeInMBs() const{ return m_sizeInMBs; } /** *

Buffer incoming data to the specified size, in MBs, before delivering it to * the destination. The default value is 5.

We recommend setting this * parameter to a value greater than the amount of data you typically ingest into * the delivery stream in 10 seconds. For example, if you typically ingest data at * 1 MB/sec, the value should be 10 MB or higher.

*/ inline bool SizeInMBsHasBeenSet() const { return m_sizeInMBsHasBeenSet; } /** *

Buffer incoming data to the specified size, in MBs, before delivering it to * the destination. The default value is 5.

We recommend setting this * parameter to a value greater than the amount of data you typically ingest into * the delivery stream in 10 seconds. For example, if you typically ingest data at * 1 MB/sec, the value should be 10 MB or higher.

*/ inline void SetSizeInMBs(int value) { m_sizeInMBsHasBeenSet = true; m_sizeInMBs = value; } /** *

Buffer incoming data to the specified size, in MBs, before delivering it to * the destination. The default value is 5.

We recommend setting this * parameter to a value greater than the amount of data you typically ingest into * the delivery stream in 10 seconds. For example, if you typically ingest data at * 1 MB/sec, the value should be 10 MB or higher.

*/ inline AmazonOpenSearchServerlessBufferingHints& WithSizeInMBs(int value) { SetSizeInMBs(value); return *this;} private: int m_intervalInSeconds; bool m_intervalInSecondsHasBeenSet = false; int m_sizeInMBs; bool m_sizeInMBsHasBeenSet = false; }; } // namespace Model } // namespace Firehose } // namespace Aws