aws_sdk_ses/operation/set_identity_notification_topic/
builders.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::set_identity_notification_topic::_set_identity_notification_topic_output::SetIdentityNotificationTopicOutputBuilder;
3
4pub use crate::operation::set_identity_notification_topic::_set_identity_notification_topic_input::SetIdentityNotificationTopicInputBuilder;
5
6impl crate::operation::set_identity_notification_topic::builders::SetIdentityNotificationTopicInputBuilder {
7    /// Sends a request with this input using the given client.
8    pub async fn send_with(
9        self,
10        client: &crate::Client,
11    ) -> ::std::result::Result<
12        crate::operation::set_identity_notification_topic::SetIdentityNotificationTopicOutput,
13        ::aws_smithy_runtime_api::client::result::SdkError<
14            crate::operation::set_identity_notification_topic::SetIdentityNotificationTopicError,
15            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16        >,
17    > {
18        let mut fluent_builder = client.set_identity_notification_topic();
19        fluent_builder.inner = self;
20        fluent_builder.send().await
21    }
22}
23/// Fluent builder constructing a request to `SetIdentityNotificationTopic`.
24///
25/// <p>Sets an Amazon Simple Notification Service (Amazon SNS) topic to use when delivering notifications. When you use this operation, you specify a verified identity, such as an email address or domain. When you send an email that uses the chosen identity in the Source field, Amazon SES sends notifications to the topic you specified. You can send bounce, complaint, or delivery notifications (or any combination of the three) to the Amazon SNS topic that you specify.</p>
26/// <p>You can execute this operation no more than once per second.</p>
27/// <p>For more information about feedback notification, see the <a href="https://docs.aws.amazon.com/ses/latest/dg/monitor-sending-activity-using-notifications.html">Amazon SES Developer Guide</a>.</p>
28#[derive(::std::clone::Clone, ::std::fmt::Debug)]
29pub struct SetIdentityNotificationTopicFluentBuilder {
30    handle: ::std::sync::Arc<crate::client::Handle>,
31    inner: crate::operation::set_identity_notification_topic::builders::SetIdentityNotificationTopicInputBuilder,
32    config_override: ::std::option::Option<crate::config::Builder>,
33}
34impl
35    crate::client::customize::internal::CustomizableSend<
36        crate::operation::set_identity_notification_topic::SetIdentityNotificationTopicOutput,
37        crate::operation::set_identity_notification_topic::SetIdentityNotificationTopicError,
38    > for SetIdentityNotificationTopicFluentBuilder
39{
40    fn send(
41        self,
42        config_override: crate::config::Builder,
43    ) -> crate::client::customize::internal::BoxFuture<
44        crate::client::customize::internal::SendResult<
45            crate::operation::set_identity_notification_topic::SetIdentityNotificationTopicOutput,
46            crate::operation::set_identity_notification_topic::SetIdentityNotificationTopicError,
47        >,
48    > {
49        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
50    }
51}
52impl SetIdentityNotificationTopicFluentBuilder {
53    /// Creates a new `SetIdentityNotificationTopicFluentBuilder`.
54    pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
55        Self {
56            handle,
57            inner: ::std::default::Default::default(),
58            config_override: ::std::option::Option::None,
59        }
60    }
61    /// Access the SetIdentityNotificationTopic as a reference.
62    pub fn as_input(&self) -> &crate::operation::set_identity_notification_topic::builders::SetIdentityNotificationTopicInputBuilder {
63        &self.inner
64    }
65    /// Sends the request and returns the response.
66    ///
67    /// If an error occurs, an `SdkError` will be returned with additional details that
68    /// can be matched against.
69    ///
70    /// By default, any retryable failures will be retried twice. Retry behavior
71    /// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
72    /// set when configuring the client.
73    pub async fn send(
74        self,
75    ) -> ::std::result::Result<
76        crate::operation::set_identity_notification_topic::SetIdentityNotificationTopicOutput,
77        ::aws_smithy_runtime_api::client::result::SdkError<
78            crate::operation::set_identity_notification_topic::SetIdentityNotificationTopicError,
79            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
80        >,
81    > {
82        let input = self
83            .inner
84            .build()
85            .map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
86        let runtime_plugins = crate::operation::set_identity_notification_topic::SetIdentityNotificationTopic::operation_runtime_plugins(
87            self.handle.runtime_plugins.clone(),
88            &self.handle.conf,
89            self.config_override,
90        );
91        crate::operation::set_identity_notification_topic::SetIdentityNotificationTopic::orchestrate(&runtime_plugins, input).await
92    }
93
94    /// Consumes this builder, creating a customizable operation that can be modified before being sent.
95    pub fn customize(
96        self,
97    ) -> crate::client::customize::CustomizableOperation<
98        crate::operation::set_identity_notification_topic::SetIdentityNotificationTopicOutput,
99        crate::operation::set_identity_notification_topic::SetIdentityNotificationTopicError,
100        Self,
101    > {
102        crate::client::customize::CustomizableOperation::new(self)
103    }
104    pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
105        self.set_config_override(::std::option::Option::Some(config_override.into()));
106        self
107    }
108
109    pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
110        self.config_override = config_override;
111        self
112    }
113    /// <p>The identity (email address or domain) for the Amazon SNS topic.</p><important>
114    /// <p>You can only specify a verified identity for this parameter.</p>
115    /// </important>
116    /// <p>You can specify an identity by using its name or by using its Amazon Resource Name (ARN). The following examples are all valid identities: <code>sender@example.com</code>, <code>example.com</code>, <code>arn:aws:ses:us-east-1:123456789012:identity/example.com</code>.</p>
117    pub fn identity(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
118        self.inner = self.inner.identity(input.into());
119        self
120    }
121    /// <p>The identity (email address or domain) for the Amazon SNS topic.</p><important>
122    /// <p>You can only specify a verified identity for this parameter.</p>
123    /// </important>
124    /// <p>You can specify an identity by using its name or by using its Amazon Resource Name (ARN). The following examples are all valid identities: <code>sender@example.com</code>, <code>example.com</code>, <code>arn:aws:ses:us-east-1:123456789012:identity/example.com</code>.</p>
125    pub fn set_identity(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
126        self.inner = self.inner.set_identity(input);
127        self
128    }
129    /// <p>The identity (email address or domain) for the Amazon SNS topic.</p><important>
130    /// <p>You can only specify a verified identity for this parameter.</p>
131    /// </important>
132    /// <p>You can specify an identity by using its name or by using its Amazon Resource Name (ARN). The following examples are all valid identities: <code>sender@example.com</code>, <code>example.com</code>, <code>arn:aws:ses:us-east-1:123456789012:identity/example.com</code>.</p>
133    pub fn get_identity(&self) -> &::std::option::Option<::std::string::String> {
134        self.inner.get_identity()
135    }
136    /// <p>The type of notifications that are published to the specified Amazon SNS topic.</p>
137    pub fn notification_type(mut self, input: crate::types::NotificationType) -> Self {
138        self.inner = self.inner.notification_type(input);
139        self
140    }
141    /// <p>The type of notifications that are published to the specified Amazon SNS topic.</p>
142    pub fn set_notification_type(mut self, input: ::std::option::Option<crate::types::NotificationType>) -> Self {
143        self.inner = self.inner.set_notification_type(input);
144        self
145    }
146    /// <p>The type of notifications that are published to the specified Amazon SNS topic.</p>
147    pub fn get_notification_type(&self) -> &::std::option::Option<crate::types::NotificationType> {
148        self.inner.get_notification_type()
149    }
150    /// <p>The Amazon Resource Name (ARN) of the Amazon SNS topic. If the parameter is omitted from the request or a null value is passed, <code>SnsTopic</code> is cleared and publishing is disabled.</p>
151    pub fn sns_topic(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
152        self.inner = self.inner.sns_topic(input.into());
153        self
154    }
155    /// <p>The Amazon Resource Name (ARN) of the Amazon SNS topic. If the parameter is omitted from the request or a null value is passed, <code>SnsTopic</code> is cleared and publishing is disabled.</p>
156    pub fn set_sns_topic(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
157        self.inner = self.inner.set_sns_topic(input);
158        self
159    }
160    /// <p>The Amazon Resource Name (ARN) of the Amazon SNS topic. If the parameter is omitted from the request or a null value is passed, <code>SnsTopic</code> is cleared and publishing is disabled.</p>
161    pub fn get_sns_topic(&self) -> &::std::option::Option<::std::string::String> {
162        self.inner.get_sns_topic()
163    }
164}