aws_sdk_dynamodb/waiters/
table_not_exists.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2
3/// 
4/// Fluent builder for the `table_not_exists` waiter.
5/// 
6/// This builder is intended to be used similar to the other fluent builders for
7/// normal operations on the client. However, instead of a `send` method, it has
8/// a `wait` method that takes a maximum amount of time to wait.
9/// 
10/// Construct this fluent builder using the client by importing the
11/// [`Waiters`](crate::client::Waiters) trait and calling the methods
12/// prefixed with `wait_until`.
13/// 
14#[derive(::std::clone::Clone, ::std::fmt::Debug)]
15pub struct TableNotExistsFluentBuilder {
16                handle: ::std::sync::Arc<crate::client::Handle>,
17                inner: crate::operation::describe_table::builders::DescribeTableInputBuilder,
18            }
19impl TableNotExistsFluentBuilder {
20    /// Creates a new `TableNotExistsFluentBuilder`.
21                    pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
22                        Self {
23                            handle,
24                            inner: ::std::default::Default::default(),
25                        }
26                    }
27    /// Access the DescribeTable as a reference.
28                    pub fn as_input(&self) -> &crate::operation::describe_table::builders::DescribeTableInputBuilder {
29                        &self.inner
30                    }
31    /// Wait for `table_not_exists`
32    pub async fn wait(self, max_wait: ::std::time::Duration) -> ::std::result::Result<crate::waiters::table_not_exists::TableNotExistsFinalPoll, crate::waiters::table_not_exists::WaitUntilTableNotExistsError> {
33                        let input = self.inner.build()
34                            .map_err(::aws_smithy_runtime_api::client::waiters::error::WaiterError::construction_failure)?;
35                        let runtime_plugins = crate::operation::describe_table::DescribeTable::operation_runtime_plugins(
36                            self.handle.runtime_plugins.clone(),
37                            &self.handle.conf,
38                            ::std::option::Option::None,
39                        ).with_operation_plugin(crate::sdk_feature_tracker::waiter::WaiterFeatureTrackerRuntimePlugin::new());
40                        let mut cfg = ::aws_smithy_types::config_bag::ConfigBag::base();
41                        let runtime_components_builder = runtime_plugins.apply_client_configuration(&mut cfg)
42                            .map_err(::aws_smithy_runtime_api::client::waiters::error::WaiterError::construction_failure)?;
43                        let time_components = runtime_components_builder.into_time_components();
44                        let sleep_impl = time_components.sleep_impl().expect("a sleep impl is required by waiters");
45                        let time_source = time_components.time_source().expect("a time source is required by waiters");
46    
47                        let acceptor = move |result: ::std::result::Result<&crate::operation::describe_table::DescribeTableOutput, &crate::operation::describe_table::DescribeTableError>| {
48                    // Matches: {"errorType":"ResourceNotFoundException"}
49                                if crate::waiters::matchers::match_describe_table_1cce2c05524fb92d4(result) { return ::aws_smithy_runtime::client::waiters::AcceptorState::Success; }
50    ::aws_smithy_runtime::client::waiters::AcceptorState::NoAcceptorsMatched
51                };
52                        let operation = move || {
53                            let input = input.clone();
54                            let runtime_plugins = runtime_plugins.clone();
55                            async move {
56                                crate::operation::describe_table::DescribeTable::orchestrate(&runtime_plugins, input).await
57                            }
58                        };
59                        let orchestrator = ::aws_smithy_runtime::client::waiters::WaiterOrchestrator::builder()
60                            .min_delay(::std::time::Duration::from_secs(20))
61                            .max_delay(::std::time::Duration::from_secs(120))
62                            .max_wait(max_wait)
63                            .time_source(time_source)
64                            .sleep_impl(sleep_impl)
65                            .acceptor(acceptor)
66                            .operation(operation)
67                            .build();
68                        ::aws_smithy_runtime::client::waiters::attach_waiter_tracing_span(orchestrator.orchestrate()).await
69                    }
70    /// <p>The name of the table to describe. You can also provide the Amazon Resource Name (ARN) of the table in this parameter.</p>
71    pub fn table_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
72                    self.inner = self.inner.table_name(input.into());
73                    self
74                }
75    /// <p>The name of the table to describe. You can also provide the Amazon Resource Name (ARN) of the table in this parameter.</p>
76    pub fn set_table_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
77                    self.inner = self.inner.set_table_name(input);
78                    self
79                }
80    /// <p>The name of the table to describe. You can also provide the Amazon Resource Name (ARN) of the table in this parameter.</p>
81    pub fn get_table_name(&self) -> &::std::option::Option<::std::string::String> {
82                    self.inner.get_table_name()
83                }
84}
85
86/// Successful return type for the `table_not_exists` waiter.
87pub type TableNotExistsFinalPoll = ::aws_smithy_runtime_api::client::waiters::FinalPoll<crate::operation::describe_table::DescribeTableOutput, ::aws_smithy_runtime_api::client::result::SdkError<crate::operation::describe_table::DescribeTableError, ::aws_smithy_runtime_api::client::orchestrator::HttpResponse>>;
88
89/// Error type for the `table_not_exists` waiter.
90pub type WaitUntilTableNotExistsError = ::aws_smithy_runtime_api::client::waiters::error::WaiterError<crate::operation::describe_table::DescribeTableOutput, crate::operation::describe_table::DescribeTableError>;
91