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

Specifies an Apache Kafka data store in the Data Catalog.

See * Also:

AWS * API Reference

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

The name of the data store.

*/ inline const Aws::String& GetName() const{ return m_name; } /** *

The name of the data store.

*/ inline bool NameHasBeenSet() const { return m_nameHasBeenSet; } /** *

The name of the data store.

*/ inline void SetName(const Aws::String& value) { m_nameHasBeenSet = true; m_name = value; } /** *

The name of the data store.

*/ inline void SetName(Aws::String&& value) { m_nameHasBeenSet = true; m_name = std::move(value); } /** *

The name of the data store.

*/ inline void SetName(const char* value) { m_nameHasBeenSet = true; m_name.assign(value); } /** *

The name of the data store.

*/ inline CatalogKafkaSource& WithName(const Aws::String& value) { SetName(value); return *this;} /** *

The name of the data store.

*/ inline CatalogKafkaSource& WithName(Aws::String&& value) { SetName(std::move(value)); return *this;} /** *

The name of the data store.

*/ inline CatalogKafkaSource& WithName(const char* value) { SetName(value); return *this;} /** *

The amount of time to spend processing each micro batch.

*/ inline int GetWindowSize() const{ return m_windowSize; } /** *

The amount of time to spend processing each micro batch.

*/ inline bool WindowSizeHasBeenSet() const { return m_windowSizeHasBeenSet; } /** *

The amount of time to spend processing each micro batch.

*/ inline void SetWindowSize(int value) { m_windowSizeHasBeenSet = true; m_windowSize = value; } /** *

The amount of time to spend processing each micro batch.

*/ inline CatalogKafkaSource& WithWindowSize(int value) { SetWindowSize(value); return *this;} /** *

Whether to automatically determine the schema from the incoming data.

*/ inline bool GetDetectSchema() const{ return m_detectSchema; } /** *

Whether to automatically determine the schema from the incoming data.

*/ inline bool DetectSchemaHasBeenSet() const { return m_detectSchemaHasBeenSet; } /** *

Whether to automatically determine the schema from the incoming data.

*/ inline void SetDetectSchema(bool value) { m_detectSchemaHasBeenSet = true; m_detectSchema = value; } /** *

Whether to automatically determine the schema from the incoming data.

*/ inline CatalogKafkaSource& WithDetectSchema(bool value) { SetDetectSchema(value); return *this;} /** *

The name of the table in the database to read from.

*/ inline const Aws::String& GetTable() const{ return m_table; } /** *

The name of the table in the database to read from.

*/ inline bool TableHasBeenSet() const { return m_tableHasBeenSet; } /** *

The name of the table in the database to read from.

*/ inline void SetTable(const Aws::String& value) { m_tableHasBeenSet = true; m_table = value; } /** *

The name of the table in the database to read from.

*/ inline void SetTable(Aws::String&& value) { m_tableHasBeenSet = true; m_table = std::move(value); } /** *

The name of the table in the database to read from.

*/ inline void SetTable(const char* value) { m_tableHasBeenSet = true; m_table.assign(value); } /** *

The name of the table in the database to read from.

*/ inline CatalogKafkaSource& WithTable(const Aws::String& value) { SetTable(value); return *this;} /** *

The name of the table in the database to read from.

*/ inline CatalogKafkaSource& WithTable(Aws::String&& value) { SetTable(std::move(value)); return *this;} /** *

The name of the table in the database to read from.

*/ inline CatalogKafkaSource& WithTable(const char* value) { SetTable(value); return *this;} /** *

The name of the database to read from.

*/ inline const Aws::String& GetDatabase() const{ return m_database; } /** *

The name of the database to read from.

*/ inline bool DatabaseHasBeenSet() const { return m_databaseHasBeenSet; } /** *

The name of the database to read from.

*/ inline void SetDatabase(const Aws::String& value) { m_databaseHasBeenSet = true; m_database = value; } /** *

The name of the database to read from.

*/ inline void SetDatabase(Aws::String&& value) { m_databaseHasBeenSet = true; m_database = std::move(value); } /** *

The name of the database to read from.

*/ inline void SetDatabase(const char* value) { m_databaseHasBeenSet = true; m_database.assign(value); } /** *

The name of the database to read from.

*/ inline CatalogKafkaSource& WithDatabase(const Aws::String& value) { SetDatabase(value); return *this;} /** *

The name of the database to read from.

*/ inline CatalogKafkaSource& WithDatabase(Aws::String&& value) { SetDatabase(std::move(value)); return *this;} /** *

The name of the database to read from.

*/ inline CatalogKafkaSource& WithDatabase(const char* value) { SetDatabase(value); return *this;} /** *

Specifies the streaming options.

*/ inline const KafkaStreamingSourceOptions& GetStreamingOptions() const{ return m_streamingOptions; } /** *

Specifies the streaming options.

*/ inline bool StreamingOptionsHasBeenSet() const { return m_streamingOptionsHasBeenSet; } /** *

Specifies the streaming options.

*/ inline void SetStreamingOptions(const KafkaStreamingSourceOptions& value) { m_streamingOptionsHasBeenSet = true; m_streamingOptions = value; } /** *

Specifies the streaming options.

*/ inline void SetStreamingOptions(KafkaStreamingSourceOptions&& value) { m_streamingOptionsHasBeenSet = true; m_streamingOptions = std::move(value); } /** *

Specifies the streaming options.

*/ inline CatalogKafkaSource& WithStreamingOptions(const KafkaStreamingSourceOptions& value) { SetStreamingOptions(value); return *this;} /** *

Specifies the streaming options.

*/ inline CatalogKafkaSource& WithStreamingOptions(KafkaStreamingSourceOptions&& value) { SetStreamingOptions(std::move(value)); return *this;} /** *

Specifies options related to data preview for viewing a sample of your * data.

*/ inline const StreamingDataPreviewOptions& GetDataPreviewOptions() const{ return m_dataPreviewOptions; } /** *

Specifies options related to data preview for viewing a sample of your * data.

*/ inline bool DataPreviewOptionsHasBeenSet() const { return m_dataPreviewOptionsHasBeenSet; } /** *

Specifies options related to data preview for viewing a sample of your * data.

*/ inline void SetDataPreviewOptions(const StreamingDataPreviewOptions& value) { m_dataPreviewOptionsHasBeenSet = true; m_dataPreviewOptions = value; } /** *

Specifies options related to data preview for viewing a sample of your * data.

*/ inline void SetDataPreviewOptions(StreamingDataPreviewOptions&& value) { m_dataPreviewOptionsHasBeenSet = true; m_dataPreviewOptions = std::move(value); } /** *

Specifies options related to data preview for viewing a sample of your * data.

*/ inline CatalogKafkaSource& WithDataPreviewOptions(const StreamingDataPreviewOptions& value) { SetDataPreviewOptions(value); return *this;} /** *

Specifies options related to data preview for viewing a sample of your * data.

*/ inline CatalogKafkaSource& WithDataPreviewOptions(StreamingDataPreviewOptions&& value) { SetDataPreviewOptions(std::move(value)); return *this;} private: Aws::String m_name; bool m_nameHasBeenSet = false; int m_windowSize; bool m_windowSizeHasBeenSet = false; bool m_detectSchema; bool m_detectSchemaHasBeenSet = false; Aws::String m_table; bool m_tableHasBeenSet = false; Aws::String m_database; bool m_databaseHasBeenSet = false; KafkaStreamingSourceOptions m_streamingOptions; bool m_streamingOptionsHasBeenSet = false; StreamingDataPreviewOptions m_dataPreviewOptions; bool m_dataPreviewOptionsHasBeenSet = false; }; } // namespace Model } // namespace Glue } // namespace Aws