1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
pub use crate::operation::import_table::_import_table_output::ImportTableOutputBuilder;
pub use crate::operation::import_table::_import_table_input::ImportTableInputBuilder;
/// Fluent builder constructing a request to `ImportTable`.
///
/// <p> Imports table data from an S3 bucket. </p>
#[derive(std::clone::Clone, std::fmt::Debug)]
pub struct ImportTableFluentBuilder {
handle: std::sync::Arc<crate::client::Handle>,
inner: crate::operation::import_table::builders::ImportTableInputBuilder,
}
impl ImportTableFluentBuilder {
/// Creates a new `ImportTable`.
pub(crate) fn new(handle: std::sync::Arc<crate::client::Handle>) -> Self {
Self {
handle,
inner: Default::default(),
}
}
/// Consume this builder, creating a customizable operation that can be modified before being
/// sent. The operation's inner [http::Request] can be modified as well.
pub async fn customize(
self,
) -> std::result::Result<
crate::client::customize::CustomizableOperation<
crate::operation::import_table::ImportTable,
aws_http::retry::AwsResponseRetryClassifier,
>,
aws_smithy_http::result::SdkError<crate::operation::import_table::ImportTableError>,
> {
let handle = self.handle.clone();
let operation = self
.inner
.build()
.map_err(aws_smithy_http::result::SdkError::construction_failure)?
.make_operation(&handle.conf)
.await
.map_err(aws_smithy_http::result::SdkError::construction_failure)?;
Ok(crate::client::customize::CustomizableOperation { handle, operation })
}
/// Sends the request and returns the response.
///
/// If an error occurs, an `SdkError` will be returned with additional details that
/// can be matched against.
///
/// By default, any retryable failures will be retried twice. Retry behavior
/// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
/// set when configuring the client.
pub async fn send(
self,
) -> std::result::Result<
crate::operation::import_table::ImportTableOutput,
aws_smithy_http::result::SdkError<crate::operation::import_table::ImportTableError>,
> {
let op = self
.inner
.build()
.map_err(aws_smithy_http::result::SdkError::construction_failure)?
.make_operation(&self.handle.conf)
.await
.map_err(aws_smithy_http::result::SdkError::construction_failure)?;
self.handle.client.call(op).await
}
/// <p>Providing a <code>ClientToken</code> makes the call to <code>ImportTableInput</code> idempotent, meaning that multiple identical calls have the same effect as one single call.</p>
/// <p>A client token is valid for 8 hours after the first request that uses it is completed. After 8 hours, any request with the same client token is treated as a new request. Do not resubmit the same request with the same client token for more than 8 hours, or the result might not be idempotent.</p>
/// <p>If you submit a request with the same client token but a change in other parameters within the 8-hour idempotency window, DynamoDB returns an <code>IdempotentParameterMismatch</code> exception.</p>
pub fn client_token(mut self, input: impl Into<std::string::String>) -> Self {
self.inner = self.inner.client_token(input.into());
self
}
/// <p>Providing a <code>ClientToken</code> makes the call to <code>ImportTableInput</code> idempotent, meaning that multiple identical calls have the same effect as one single call.</p>
/// <p>A client token is valid for 8 hours after the first request that uses it is completed. After 8 hours, any request with the same client token is treated as a new request. Do not resubmit the same request with the same client token for more than 8 hours, or the result might not be idempotent.</p>
/// <p>If you submit a request with the same client token but a change in other parameters within the 8-hour idempotency window, DynamoDB returns an <code>IdempotentParameterMismatch</code> exception.</p>
pub fn set_client_token(mut self, input: std::option::Option<std::string::String>) -> Self {
self.inner = self.inner.set_client_token(input);
self
}
/// <p> The S3 bucket that provides the source for the import. </p>
pub fn s3_bucket_source(mut self, input: crate::types::S3BucketSource) -> Self {
self.inner = self.inner.s3_bucket_source(input);
self
}
/// <p> The S3 bucket that provides the source for the import. </p>
pub fn set_s3_bucket_source(
mut self,
input: std::option::Option<crate::types::S3BucketSource>,
) -> Self {
self.inner = self.inner.set_s3_bucket_source(input);
self
}
/// <p> The format of the source data. Valid values for <code>ImportFormat</code> are <code>CSV</code>, <code>DYNAMODB_JSON</code> or <code>ION</code>. </p>
pub fn input_format(mut self, input: crate::types::InputFormat) -> Self {
self.inner = self.inner.input_format(input);
self
}
/// <p> The format of the source data. Valid values for <code>ImportFormat</code> are <code>CSV</code>, <code>DYNAMODB_JSON</code> or <code>ION</code>. </p>
pub fn set_input_format(
mut self,
input: std::option::Option<crate::types::InputFormat>,
) -> Self {
self.inner = self.inner.set_input_format(input);
self
}
/// <p> Additional properties that specify how the input is formatted, </p>
pub fn input_format_options(mut self, input: crate::types::InputFormatOptions) -> Self {
self.inner = self.inner.input_format_options(input);
self
}
/// <p> Additional properties that specify how the input is formatted, </p>
pub fn set_input_format_options(
mut self,
input: std::option::Option<crate::types::InputFormatOptions>,
) -> Self {
self.inner = self.inner.set_input_format_options(input);
self
}
/// <p> Type of compression to be used on the input coming from the imported table. </p>
pub fn input_compression_type(mut self, input: crate::types::InputCompressionType) -> Self {
self.inner = self.inner.input_compression_type(input);
self
}
/// <p> Type of compression to be used on the input coming from the imported table. </p>
pub fn set_input_compression_type(
mut self,
input: std::option::Option<crate::types::InputCompressionType>,
) -> Self {
self.inner = self.inner.set_input_compression_type(input);
self
}
/// <p>Parameters for the table to import the data into. </p>
pub fn table_creation_parameters(
mut self,
input: crate::types::TableCreationParameters,
) -> Self {
self.inner = self.inner.table_creation_parameters(input);
self
}
/// <p>Parameters for the table to import the data into. </p>
pub fn set_table_creation_parameters(
mut self,
input: std::option::Option<crate::types::TableCreationParameters>,
) -> Self {
self.inner = self.inner.set_table_creation_parameters(input);
self
}
}