aws_sdk_organizations/operation/create_organization/
builders.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::create_organization::_create_organization_output::CreateOrganizationOutputBuilder;
3
4pub use crate::operation::create_organization::_create_organization_input::CreateOrganizationInputBuilder;
5
6impl crate::operation::create_organization::builders::CreateOrganizationInputBuilder {
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_organization::CreateOrganizationOutput,
13        ::aws_smithy_runtime_api::client::result::SdkError<
14            crate::operation::create_organization::CreateOrganizationError,
15            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16        >,
17    > {
18        let mut fluent_builder = client.create_organization();
19        fluent_builder.inner = self;
20        fluent_builder.send().await
21    }
22}
23/// Fluent builder constructing a request to `CreateOrganization`.
24///
25/// <p>Creates an Amazon Web Services organization. The account whose user is calling the <code>CreateOrganization</code> operation automatically becomes the <a href="https://docs.aws.amazon.com/organizations/latest/userguide/orgs_getting-started_concepts.html#account">management account</a> of the new organization.</p>
26/// <p>This operation must be called using credentials from the account that is to become the new organization's management account. The principal must also have the relevant IAM permissions.</p>
27/// <p>By default (or if you set the <code>FeatureSet</code> parameter to <code>ALL</code>), the new organization is created with all features enabled and service control policies automatically enabled in the root. If you instead choose to create the organization supporting only the consolidated billing features by setting the <code>FeatureSet</code> parameter to <code>CONSOLIDATED_BILLING</code>, no policy types are enabled by default and you can't use organization policies.</p>
28#[derive(::std::clone::Clone, ::std::fmt::Debug)]
29pub struct CreateOrganizationFluentBuilder {
30    handle: ::std::sync::Arc<crate::client::Handle>,
31    inner: crate::operation::create_organization::builders::CreateOrganizationInputBuilder,
32    config_override: ::std::option::Option<crate::config::Builder>,
33}
34impl
35    crate::client::customize::internal::CustomizableSend<
36        crate::operation::create_organization::CreateOrganizationOutput,
37        crate::operation::create_organization::CreateOrganizationError,
38    > for CreateOrganizationFluentBuilder
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_organization::CreateOrganizationOutput,
46            crate::operation::create_organization::CreateOrganizationError,
47        >,
48    > {
49        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
50    }
51}
52impl CreateOrganizationFluentBuilder {
53    /// Creates a new `CreateOrganizationFluentBuilder`.
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 CreateOrganization as a reference.
62    pub fn as_input(&self) -> &crate::operation::create_organization::builders::CreateOrganizationInputBuilder {
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_organization::CreateOrganizationOutput,
77        ::aws_smithy_runtime_api::client::result::SdkError<
78            crate::operation::create_organization::CreateOrganizationError,
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_organization::CreateOrganization::operation_runtime_plugins(
87            self.handle.runtime_plugins.clone(),
88            &self.handle.conf,
89            self.config_override,
90        );
91        crate::operation::create_organization::CreateOrganization::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_organization::CreateOrganizationOutput,
99        crate::operation::create_organization::CreateOrganizationError,
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>Specifies the feature set supported by the new organization. Each feature set supports different levels of functionality.</p>
114    /// <ul>
115    /// <li>
116    /// <p><code>CONSOLIDATED_BILLING</code>: All member accounts have their bills consolidated to and paid by the management account. For more information, see <a href="https://docs.aws.amazon.com/organizations/latest/userguide/orgs_getting-started_concepts.html#feature-set-cb-only">Consolidated billing</a> in the <i>Organizations User Guide</i>.</p>
117    /// <p>The consolidated billing feature subset isn't available for organizations in the Amazon Web Services GovCloud (US) Region.</p></li>
118    /// <li>
119    /// <p><code>ALL</code>: In addition to all the features supported by the consolidated billing feature set, the management account can also apply any policy type to any member account in the organization. For more information, see <a href="https://docs.aws.amazon.com/organizations/latest/userguide/orgs_getting-started_concepts.html#feature-set-all">All features</a> in the <i>Organizations User Guide</i>.</p></li>
120    /// </ul>
121    pub fn feature_set(mut self, input: crate::types::OrganizationFeatureSet) -> Self {
122        self.inner = self.inner.feature_set(input);
123        self
124    }
125    /// <p>Specifies the feature set supported by the new organization. Each feature set supports different levels of functionality.</p>
126    /// <ul>
127    /// <li>
128    /// <p><code>CONSOLIDATED_BILLING</code>: All member accounts have their bills consolidated to and paid by the management account. For more information, see <a href="https://docs.aws.amazon.com/organizations/latest/userguide/orgs_getting-started_concepts.html#feature-set-cb-only">Consolidated billing</a> in the <i>Organizations User Guide</i>.</p>
129    /// <p>The consolidated billing feature subset isn't available for organizations in the Amazon Web Services GovCloud (US) Region.</p></li>
130    /// <li>
131    /// <p><code>ALL</code>: In addition to all the features supported by the consolidated billing feature set, the management account can also apply any policy type to any member account in the organization. For more information, see <a href="https://docs.aws.amazon.com/organizations/latest/userguide/orgs_getting-started_concepts.html#feature-set-all">All features</a> in the <i>Organizations User Guide</i>.</p></li>
132    /// </ul>
133    pub fn set_feature_set(mut self, input: ::std::option::Option<crate::types::OrganizationFeatureSet>) -> Self {
134        self.inner = self.inner.set_feature_set(input);
135        self
136    }
137    /// <p>Specifies the feature set supported by the new organization. Each feature set supports different levels of functionality.</p>
138    /// <ul>
139    /// <li>
140    /// <p><code>CONSOLIDATED_BILLING</code>: All member accounts have their bills consolidated to and paid by the management account. For more information, see <a href="https://docs.aws.amazon.com/organizations/latest/userguide/orgs_getting-started_concepts.html#feature-set-cb-only">Consolidated billing</a> in the <i>Organizations User Guide</i>.</p>
141    /// <p>The consolidated billing feature subset isn't available for organizations in the Amazon Web Services GovCloud (US) Region.</p></li>
142    /// <li>
143    /// <p><code>ALL</code>: In addition to all the features supported by the consolidated billing feature set, the management account can also apply any policy type to any member account in the organization. For more information, see <a href="https://docs.aws.amazon.com/organizations/latest/userguide/orgs_getting-started_concepts.html#feature-set-all">All features</a> in the <i>Organizations User Guide</i>.</p></li>
144    /// </ul>
145    pub fn get_feature_set(&self) -> &::std::option::Option<crate::types::OrganizationFeatureSet> {
146        self.inner.get_feature_set()
147    }
148}