AWS SDK for C++

AWS SDK for C++ Version 1.11.606

Loading...
Searching...
No Matches
S3HudiDirectTarget.h
1
6#pragma once
7#include <aws/glue/Glue_EXPORTS.h>
8#include <aws/core/utils/memory/stl/AWSString.h>
9#include <aws/core/utils/memory/stl/AWSVector.h>
10#include <aws/glue/model/HudiTargetCompressionType.h>
11#include <aws/glue/model/TargetFormat.h>
12#include <aws/core/utils/memory/stl/AWSMap.h>
13#include <aws/glue/model/DirectSchemaChangePolicy.h>
14#include <utility>
15
16namespace Aws
17{
18namespace Utils
19{
20namespace Json
21{
22 class JsonValue;
23 class JsonView;
24} // namespace Json
25} // namespace Utils
26namespace Glue
27{
28namespace Model
29{
30
38 {
39 public:
40 AWS_GLUE_API S3HudiDirectTarget() = default;
44
45
47
50 inline const Aws::String& GetName() const { return m_name; }
51 inline bool NameHasBeenSet() const { return m_nameHasBeenSet; }
52 template<typename NameT = Aws::String>
53 void SetName(NameT&& value) { m_nameHasBeenSet = true; m_name = std::forward<NameT>(value); }
54 template<typename NameT = Aws::String>
55 S3HudiDirectTarget& WithName(NameT&& value) { SetName(std::forward<NameT>(value)); return *this;}
57
59
62 inline const Aws::Vector<Aws::String>& GetInputs() const { return m_inputs; }
63 inline bool InputsHasBeenSet() const { return m_inputsHasBeenSet; }
64 template<typename InputsT = Aws::Vector<Aws::String>>
65 void SetInputs(InputsT&& value) { m_inputsHasBeenSet = true; m_inputs = std::forward<InputsT>(value); }
66 template<typename InputsT = Aws::Vector<Aws::String>>
67 S3HudiDirectTarget& WithInputs(InputsT&& value) { SetInputs(std::forward<InputsT>(value)); return *this;}
68 template<typename InputsT = Aws::String>
69 S3HudiDirectTarget& AddInputs(InputsT&& value) { m_inputsHasBeenSet = true; m_inputs.emplace_back(std::forward<InputsT>(value)); return *this; }
71
73
76 inline const Aws::String& GetPath() const { return m_path; }
77 inline bool PathHasBeenSet() const { return m_pathHasBeenSet; }
78 template<typename PathT = Aws::String>
79 void SetPath(PathT&& value) { m_pathHasBeenSet = true; m_path = std::forward<PathT>(value); }
80 template<typename PathT = Aws::String>
81 S3HudiDirectTarget& WithPath(PathT&& value) { SetPath(std::forward<PathT>(value)); return *this;}
83
85
90 inline HudiTargetCompressionType GetCompression() const { return m_compression; }
91 inline bool CompressionHasBeenSet() const { return m_compressionHasBeenSet; }
92 inline void SetCompression(HudiTargetCompressionType value) { m_compressionHasBeenSet = true; m_compression = value; }
95
97
101 inline const Aws::String& GetNumberTargetPartitions() const { return m_numberTargetPartitions; }
102 inline bool NumberTargetPartitionsHasBeenSet() const { return m_numberTargetPartitionsHasBeenSet; }
103 template<typename NumberTargetPartitionsT = Aws::String>
104 void SetNumberTargetPartitions(NumberTargetPartitionsT&& value) { m_numberTargetPartitionsHasBeenSet = true; m_numberTargetPartitions = std::forward<NumberTargetPartitionsT>(value); }
105 template<typename NumberTargetPartitionsT = Aws::String>
106 S3HudiDirectTarget& WithNumberTargetPartitions(NumberTargetPartitionsT&& value) { SetNumberTargetPartitions(std::forward<NumberTargetPartitionsT>(value)); return *this;}
108
110
113 inline const Aws::Vector<Aws::Vector<Aws::String>>& GetPartitionKeys() const { return m_partitionKeys; }
114 inline bool PartitionKeysHasBeenSet() const { return m_partitionKeysHasBeenSet; }
115 template<typename PartitionKeysT = Aws::Vector<Aws::Vector<Aws::String>>>
116 void SetPartitionKeys(PartitionKeysT&& value) { m_partitionKeysHasBeenSet = true; m_partitionKeys = std::forward<PartitionKeysT>(value); }
117 template<typename PartitionKeysT = Aws::Vector<Aws::Vector<Aws::String>>>
118 S3HudiDirectTarget& WithPartitionKeys(PartitionKeysT&& value) { SetPartitionKeys(std::forward<PartitionKeysT>(value)); return *this;}
119 template<typename PartitionKeysT = Aws::Vector<Aws::String>>
120 S3HudiDirectTarget& AddPartitionKeys(PartitionKeysT&& value) { m_partitionKeysHasBeenSet = true; m_partitionKeys.emplace_back(std::forward<PartitionKeysT>(value)); return *this; }
122
124
127 inline TargetFormat GetFormat() const { return m_format; }
128 inline bool FormatHasBeenSet() const { return m_formatHasBeenSet; }
129 inline void SetFormat(TargetFormat value) { m_formatHasBeenSet = true; m_format = value; }
130 inline S3HudiDirectTarget& WithFormat(TargetFormat value) { SetFormat(value); return *this;}
132
134
137 inline const Aws::Map<Aws::String, Aws::String>& GetAdditionalOptions() const { return m_additionalOptions; }
138 inline bool AdditionalOptionsHasBeenSet() const { return m_additionalOptionsHasBeenSet; }
139 template<typename AdditionalOptionsT = Aws::Map<Aws::String, Aws::String>>
140 void SetAdditionalOptions(AdditionalOptionsT&& value) { m_additionalOptionsHasBeenSet = true; m_additionalOptions = std::forward<AdditionalOptionsT>(value); }
141 template<typename AdditionalOptionsT = Aws::Map<Aws::String, Aws::String>>
142 S3HudiDirectTarget& WithAdditionalOptions(AdditionalOptionsT&& value) { SetAdditionalOptions(std::forward<AdditionalOptionsT>(value)); return *this;}
143 template<typename AdditionalOptionsKeyT = Aws::String, typename AdditionalOptionsValueT = Aws::String>
144 S3HudiDirectTarget& AddAdditionalOptions(AdditionalOptionsKeyT&& key, AdditionalOptionsValueT&& value) {
145 m_additionalOptionsHasBeenSet = true; m_additionalOptions.emplace(std::forward<AdditionalOptionsKeyT>(key), std::forward<AdditionalOptionsValueT>(value)); return *this;
146 }
148
150
153 inline const DirectSchemaChangePolicy& GetSchemaChangePolicy() const { return m_schemaChangePolicy; }
154 inline bool SchemaChangePolicyHasBeenSet() const { return m_schemaChangePolicyHasBeenSet; }
155 template<typename SchemaChangePolicyT = DirectSchemaChangePolicy>
156 void SetSchemaChangePolicy(SchemaChangePolicyT&& value) { m_schemaChangePolicyHasBeenSet = true; m_schemaChangePolicy = std::forward<SchemaChangePolicyT>(value); }
157 template<typename SchemaChangePolicyT = DirectSchemaChangePolicy>
158 S3HudiDirectTarget& WithSchemaChangePolicy(SchemaChangePolicyT&& value) { SetSchemaChangePolicy(std::forward<SchemaChangePolicyT>(value)); return *this;}
160 private:
161
162 Aws::String m_name;
163 bool m_nameHasBeenSet = false;
164
166 bool m_inputsHasBeenSet = false;
167
168 Aws::String m_path;
169 bool m_pathHasBeenSet = false;
170
172 bool m_compressionHasBeenSet = false;
173
174 Aws::String m_numberTargetPartitions;
175 bool m_numberTargetPartitionsHasBeenSet = false;
176
178 bool m_partitionKeysHasBeenSet = false;
179
181 bool m_formatHasBeenSet = false;
182
183 Aws::Map<Aws::String, Aws::String> m_additionalOptions;
184 bool m_additionalOptionsHasBeenSet = false;
185
186 DirectSchemaChangePolicy m_schemaChangePolicy;
187 bool m_schemaChangePolicyHasBeenSet = false;
188 };
189
190} // namespace Model
191} // namespace Glue
192} // namespace Aws
S3HudiDirectTarget & WithCompression(HudiTargetCompressionType value)
S3HudiDirectTarget & WithAdditionalOptions(AdditionalOptionsT &&value)
void SetNumberTargetPartitions(NumberTargetPartitionsT &&value)
S3HudiDirectTarget & WithFormat(TargetFormat value)
S3HudiDirectTarget & WithInputs(InputsT &&value)
const Aws::String & GetPath() const
S3HudiDirectTarget & AddInputs(InputsT &&value)
void SetPartitionKeys(PartitionKeysT &&value)
const Aws::String & GetName() const
const Aws::Vector< Aws::Vector< Aws::String > > & GetPartitionKeys() const
S3HudiDirectTarget & AddPartitionKeys(PartitionKeysT &&value)
S3HudiDirectTarget & WithName(NameT &&value)
AWS_GLUE_API S3HudiDirectTarget(Aws::Utils::Json::JsonView jsonValue)
void SetCompression(HudiTargetCompressionType value)
S3HudiDirectTarget & WithPartitionKeys(PartitionKeysT &&value)
void SetSchemaChangePolicy(SchemaChangePolicyT &&value)
S3HudiDirectTarget & AddAdditionalOptions(AdditionalOptionsKeyT &&key, AdditionalOptionsValueT &&value)
AWS_GLUE_API S3HudiDirectTarget & operator=(Aws::Utils::Json::JsonView jsonValue)
HudiTargetCompressionType GetCompression() const
S3HudiDirectTarget & WithPath(PathT &&value)
S3HudiDirectTarget & WithSchemaChangePolicy(SchemaChangePolicyT &&value)
void SetAdditionalOptions(AdditionalOptionsT &&value)
const Aws::String & GetNumberTargetPartitions() const
const Aws::Vector< Aws::String > & GetInputs() const
S3HudiDirectTarget & WithNumberTargetPartitions(NumberTargetPartitionsT &&value)
const Aws::Map< Aws::String, Aws::String > & GetAdditionalOptions() const
AWS_GLUE_API S3HudiDirectTarget()=default
const DirectSchemaChangePolicy & GetSchemaChangePolicy() const
AWS_GLUE_API Aws::Utils::Json::JsonValue Jsonize() const
std::map< K, V, std::less< K >, Aws::Allocator< std::pair< const K, V > > > Map
std::basic_string< char, std::char_traits< char >, Aws::Allocator< char > > String
std::vector< T, Aws::Allocator< T > > Vector
Aws::Utils::Json::JsonValue JsonValue