aws_sdk_pinpointemail/operation/create_email_identity/
builders.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::create_email_identity::_create_email_identity_output::CreateEmailIdentityOutputBuilder;
3
4pub use crate::operation::create_email_identity::_create_email_identity_input::CreateEmailIdentityInputBuilder;
5
6impl crate::operation::create_email_identity::builders::CreateEmailIdentityInputBuilder {
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::create_email_identity::CreateEmailIdentityOutput,
13        ::aws_smithy_runtime_api::client::result::SdkError<
14            crate::operation::create_email_identity::CreateEmailIdentityError,
15            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16        >,
17    > {
18        let mut fluent_builder = client.create_email_identity();
19        fluent_builder.inner = self;
20        fluent_builder.send().await
21    }
22}
23/// Fluent builder constructing a request to `CreateEmailIdentity`.
24///
25/// <p>Verifies an email identity for use with Amazon Pinpoint. In Amazon Pinpoint, an identity is an email address or domain that you use when you send email. Before you can use an identity to send email with Amazon Pinpoint, you first have to verify it. By verifying an address, you demonstrate that you're the owner of the address, and that you've given Amazon Pinpoint permission to send email from the address.</p>
26/// <p>When you verify an email address, Amazon Pinpoint sends an email to the address. Your email address is verified as soon as you follow the link in the verification email.</p>
27/// <p>When you verify a domain, this operation provides a set of DKIM tokens, which you can convert into CNAME tokens. You add these CNAME tokens to the DNS configuration for your domain. Your domain is verified when Amazon Pinpoint detects these records in the DNS configuration for your domain. It usually takes around 72 hours to complete the domain verification process.</p>
28#[derive(::std::clone::Clone, ::std::fmt::Debug)]
29pub struct CreateEmailIdentityFluentBuilder {
30    handle: ::std::sync::Arc<crate::client::Handle>,
31    inner: crate::operation::create_email_identity::builders::CreateEmailIdentityInputBuilder,
32    config_override: ::std::option::Option<crate::config::Builder>,
33}
34impl
35    crate::client::customize::internal::CustomizableSend<
36        crate::operation::create_email_identity::CreateEmailIdentityOutput,
37        crate::operation::create_email_identity::CreateEmailIdentityError,
38    > for CreateEmailIdentityFluentBuilder
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::create_email_identity::CreateEmailIdentityOutput,
46            crate::operation::create_email_identity::CreateEmailIdentityError,
47        >,
48    > {
49        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
50    }
51}
52impl CreateEmailIdentityFluentBuilder {
53    /// Creates a new `CreateEmailIdentityFluentBuilder`.
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 CreateEmailIdentity as a reference.
62    pub fn as_input(&self) -> &crate::operation::create_email_identity::builders::CreateEmailIdentityInputBuilder {
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::create_email_identity::CreateEmailIdentityOutput,
77        ::aws_smithy_runtime_api::client::result::SdkError<
78            crate::operation::create_email_identity::CreateEmailIdentityError,
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::create_email_identity::CreateEmailIdentity::operation_runtime_plugins(
87            self.handle.runtime_plugins.clone(),
88            &self.handle.conf,
89            self.config_override,
90        );
91        crate::operation::create_email_identity::CreateEmailIdentity::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::create_email_identity::CreateEmailIdentityOutput,
99        crate::operation::create_email_identity::CreateEmailIdentityError,
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 email address or domain that you want to verify.</p>
114    pub fn email_identity(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
115        self.inner = self.inner.email_identity(input.into());
116        self
117    }
118    /// <p>The email address or domain that you want to verify.</p>
119    pub fn set_email_identity(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
120        self.inner = self.inner.set_email_identity(input);
121        self
122    }
123    /// <p>The email address or domain that you want to verify.</p>
124    pub fn get_email_identity(&self) -> &::std::option::Option<::std::string::String> {
125        self.inner.get_email_identity()
126    }
127    ///
128    /// Appends an item to `Tags`.
129    ///
130    /// To override the contents of this collection use [`set_tags`](Self::set_tags).
131    ///
132    /// <p>An array of objects that define the tags (keys and values) that you want to associate with the email identity.</p>
133    pub fn tags(mut self, input: crate::types::Tag) -> Self {
134        self.inner = self.inner.tags(input);
135        self
136    }
137    /// <p>An array of objects that define the tags (keys and values) that you want to associate with the email identity.</p>
138    pub fn set_tags(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::Tag>>) -> Self {
139        self.inner = self.inner.set_tags(input);
140        self
141    }
142    /// <p>An array of objects that define the tags (keys and values) that you want to associate with the email identity.</p>
143    pub fn get_tags(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::Tag>> {
144        self.inner.get_tags()
145    }
146}