/** * 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 Amazon ES * destination.

See Also:

AWS * API Reference

*/ class AWS_FIREHOSE_API ElasticsearchBufferingHints { public: ElasticsearchBufferingHints(); ElasticsearchBufferingHints(Aws::Utils::Json::JsonView jsonValue); ElasticsearchBufferingHints& operator=(Aws::Utils::Json::JsonView jsonValue); 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 ElasticsearchBufferingHints& 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 ElasticsearchBufferingHints& WithSizeInMBs(int value) { SetSizeInMBs(value); return *this;} private: int m_intervalInSeconds; bool m_intervalInSecondsHasBeenSet; int m_sizeInMBs; bool m_sizeInMBsHasBeenSet; }; } // namespace Model } // namespace Firehose } // namespace Aws