Skip to main content

aws_sdk_cloudtrail/operation/
create_event_data_store.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Orchestration and serialization glue logic for `CreateEventDataStore`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct CreateEventDataStore;
6impl CreateEventDataStore {
7    /// Creates a new `CreateEventDataStore`
8    pub fn new() -> Self {
9        Self
10    }
11    pub(crate) async fn orchestrate(
12        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
13        input: crate::operation::create_event_data_store::CreateEventDataStoreInput,
14    ) -> ::std::result::Result<
15        crate::operation::create_event_data_store::CreateEventDataStoreOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::create_event_data_store::CreateEventDataStoreError,
18            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
19        >,
20    > {
21        let map_err = |err: ::aws_smithy_runtime_api::client::result::SdkError<
22            ::aws_smithy_runtime_api::client::interceptors::context::Error,
23            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
24        >| {
25            err.map_service_error(|err| {
26                err.downcast::<crate::operation::create_event_data_store::CreateEventDataStoreError>()
27                    .expect("correct error type")
28            })
29        };
30        let context = Self::orchestrate_with_stop_point(runtime_plugins, input, ::aws_smithy_runtime::client::orchestrator::StopPoint::None)
31            .await
32            .map_err(map_err)?;
33        let output = context.finalize().map_err(map_err)?;
34        ::std::result::Result::Ok(
35            output
36                .downcast::<crate::operation::create_event_data_store::CreateEventDataStoreOutput>()
37                .expect("correct output type"),
38        )
39    }
40
41    pub(crate) async fn orchestrate_with_stop_point(
42        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
43        input: crate::operation::create_event_data_store::CreateEventDataStoreInput,
44        stop_point: ::aws_smithy_runtime::client::orchestrator::StopPoint,
45    ) -> ::std::result::Result<
46        ::aws_smithy_runtime_api::client::interceptors::context::InterceptorContext,
47        ::aws_smithy_runtime_api::client::result::SdkError<
48            ::aws_smithy_runtime_api::client::interceptors::context::Error,
49            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
50        >,
51    > {
52        let input = ::aws_smithy_runtime_api::client::interceptors::context::Input::erase(input);
53        use ::tracing::Instrument;
54        ::aws_smithy_runtime::client::orchestrator::invoke_with_stop_point("CloudTrail", "CreateEventDataStore", input, runtime_plugins, stop_point)
55            // Create a parent span for the entire operation. Includes a random, internal-only,
56            // seven-digit ID for the operation orchestration so that it can be correlated in the logs.
57            .instrument(::tracing::debug_span!(
58                "CloudTrail.CreateEventDataStore",
59                "rpc.service" = "CloudTrail",
60                "rpc.method" = "CreateEventDataStore",
61                "sdk_invocation_id" = ::fastrand::u32(1_000_000..10_000_000),
62                "rpc.system" = "aws-api",
63            ))
64            .await
65    }
66
67    pub(crate) fn operation_runtime_plugins(
68        client_runtime_plugins: ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
69        client_config: &crate::config::Config,
70        config_override: ::std::option::Option<crate::config::Builder>,
71    ) -> ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins {
72        let mut runtime_plugins = client_runtime_plugins.with_operation_plugin(Self::new());
73
74        if let ::std::option::Option::Some(config_override) = config_override {
75            for plugin in config_override.runtime_plugins.iter().cloned() {
76                runtime_plugins = runtime_plugins.with_operation_plugin(plugin);
77            }
78            runtime_plugins = runtime_plugins.with_operation_plugin(crate::config::ConfigOverrideRuntimePlugin::new(
79                config_override,
80                client_config.config.clone(),
81                &client_config.runtime_components,
82            ));
83        }
84        runtime_plugins
85    }
86}
87impl ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugin for CreateEventDataStore {
88    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
89        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("CreateEventDataStore");
90
91        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
92            CreateEventDataStoreRequestSerializer,
93        ));
94        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
95            CreateEventDataStoreResponseDeserializer,
96        ));
97
98        cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
99            crate::config::auth::Params::builder()
100                .operation_name("CreateEventDataStore")
101                .build()
102                .expect("required fields set"),
103        ));
104
105        cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new(
106            "CreateEventDataStore",
107            "CloudTrail",
108        ));
109        let mut signing_options = ::aws_runtime::auth::SigningOptions::default();
110        signing_options.double_uri_encode = true;
111        signing_options.content_sha256_header = false;
112        signing_options.normalize_uri_path = true;
113        signing_options.payload_override = None;
114
115        cfg.store_put(::aws_runtime::auth::SigV4OperationSigningConfig {
116            signing_options,
117            ..::std::default::Default::default()
118        });
119
120        ::std::option::Option::Some(cfg.freeze())
121    }
122
123    fn runtime_components(
124        &self,
125        _: &::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder,
126    ) -> ::std::borrow::Cow<'_, ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder> {
127        #[allow(unused_mut)]
128        let mut rcb = ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder::new("CreateEventDataStore")
129            .with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
130                ::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default(),
131            ))
132            .with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
133                CreateEventDataStoreEndpointParamsInterceptor,
134            ))
135            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
136                crate::operation::create_event_data_store::CreateEventDataStoreError,
137            >::new())
138            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
139                crate::operation::create_event_data_store::CreateEventDataStoreError,
140            >::new())
141            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
142                crate::operation::create_event_data_store::CreateEventDataStoreError,
143            >::new());
144
145        ::std::borrow::Cow::Owned(rcb)
146    }
147}
148
149#[derive(Debug)]
150struct CreateEventDataStoreResponseDeserializer;
151impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CreateEventDataStoreResponseDeserializer {
152    fn deserialize_nonstreaming_with_config(
153        &self,
154        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
155        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
156    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
157        let (success, status) = (response.status().is_success(), response.status().as_u16());
158        let headers = response.headers();
159        let body = response.body().bytes().expect("body loaded");
160        #[allow(unused_mut)]
161        let mut force_error = false;
162        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
163        let parse_result = if !success && status != 200 || force_error {
164            crate::protocol_serde::shape_create_event_data_store::de_create_event_data_store_http_error(status, headers, body)
165        } else {
166            crate::protocol_serde::shape_create_event_data_store::de_create_event_data_store_http_response(status, headers, body)
167        };
168        crate::protocol_serde::type_erase_result(parse_result)
169    }
170}
171#[derive(Debug)]
172struct CreateEventDataStoreRequestSerializer;
173impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for CreateEventDataStoreRequestSerializer {
174    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
175    fn serialize_input(
176        &self,
177        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
178        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
179    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
180        let input = input
181            .downcast::<crate::operation::create_event_data_store::CreateEventDataStoreInput>()
182            .expect("correct type");
183        let _header_serialization_settings = _cfg
184            .load::<crate::serialization_settings::HeaderSerializationSettings>()
185            .cloned()
186            .unwrap_or_default();
187        let mut request_builder = {
188            #[allow(clippy::uninlined_format_args)]
189            fn uri_base(
190                _input: &crate::operation::create_event_data_store::CreateEventDataStoreInput,
191                output: &mut ::std::string::String,
192            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
193                use ::std::fmt::Write as _;
194                ::std::write!(output, "/").expect("formatting should succeed");
195                ::std::result::Result::Ok(())
196            }
197            #[allow(clippy::unnecessary_wraps)]
198            fn update_http_builder(
199                input: &crate::operation::create_event_data_store::CreateEventDataStoreInput,
200                builder: ::http_1x::request::Builder,
201            ) -> ::std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
202                let mut uri = ::std::string::String::new();
203                uri_base(input, &mut uri)?;
204                ::std::result::Result::Ok(builder.method("POST").uri(uri))
205            }
206            let mut builder = update_http_builder(&input, ::http_1x::request::Builder::new())?;
207            builder = _header_serialization_settings.set_default_header(builder, ::http_1x::header::CONTENT_TYPE, "application/x-amz-json-1.1");
208            builder = _header_serialization_settings.set_default_header(
209                builder,
210                ::http_1x::header::HeaderName::from_static("x-amz-target"),
211                "CloudTrail_20131101.CreateEventDataStore",
212            );
213            builder
214        };
215        let body = ::aws_smithy_types::body::SdkBody::from(crate::protocol_serde::shape_create_event_data_store::ser_create_event_data_store_input(
216            &input,
217        )?);
218        if let Some(content_length) = body.content_length() {
219            let content_length = content_length.to_string();
220            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http_1x::header::CONTENT_LENGTH, &content_length);
221        }
222        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
223    }
224}
225#[derive(Debug)]
226struct CreateEventDataStoreEndpointParamsInterceptor;
227
228#[::aws_smithy_runtime_api::client::interceptors::dyn_dispatch_hint]
229impl ::aws_smithy_runtime_api::client::interceptors::Intercept for CreateEventDataStoreEndpointParamsInterceptor {
230    fn name(&self) -> &'static str {
231        "CreateEventDataStoreEndpointParamsInterceptor"
232    }
233
234    fn read_before_execution(
235        &self,
236        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
237            '_,
238            ::aws_smithy_runtime_api::client::interceptors::context::Input,
239            ::aws_smithy_runtime_api::client::interceptors::context::Output,
240            ::aws_smithy_runtime_api::client::interceptors::context::Error,
241        >,
242        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
243    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
244        let _input = context
245            .input()
246            .downcast_ref::<CreateEventDataStoreInput>()
247            .ok_or("failed to downcast to CreateEventDataStoreInput")?;
248
249        let params = crate::config::endpoint::Params::builder()
250            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
251            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
252            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
253            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
254            .build()
255            .map_err(|err| {
256                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
257            })?;
258        cfg.interceptor_state()
259            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
260        ::std::result::Result::Ok(())
261    }
262}
263
264// The get_* functions below are generated from JMESPath expressions in the
265// operationContextParams trait. They target the operation's input shape.
266
267/// Error type for the `CreateEventDataStoreError` operation.
268#[non_exhaustive]
269#[derive(::std::fmt::Debug)]
270pub enum CreateEventDataStoreError {
271    /// <p>This exception is thrown when trusted access has not been enabled between CloudTrail and Organizations. For more information, see <a href="https://docs.aws.amazon.com/organizations/latest/userguide/orgs_integrate_services.html#orgs_how-to-enable-disable-trusted-access">How to enable or disable trusted access</a> in the <i>Organizations User Guide</i> and <a href="https://docs.aws.amazon.com/awscloudtrail/latest/userguide/creating-an-organizational-trail-prepare.html">Prepare For Creating a Trail For Your Organization</a> in the <i>CloudTrail User Guide</i>.</p>
272    CloudTrailAccessNotEnabledException(crate::types::error::CloudTrailAccessNotEnabledException),
273    /// <p>This exception is thrown when the specified resource is not ready for an operation. This can occur when you try to run an operation on a resource before CloudTrail has time to fully load the resource, or because another operation is modifying the resource. If this exception occurs, wait a few minutes, and then try the operation again.</p>
274    ConflictException(crate::types::error::ConflictException),
275    /// <p>An event data store with that name already exists.</p>
276    EventDataStoreAlreadyExistsException(crate::types::error::EventDataStoreAlreadyExistsException),
277    /// <p>Your account has used the maximum number of event data stores.</p>
278    EventDataStoreMaxLimitExceededException(crate::types::error::EventDataStoreMaxLimitExceededException),
279    /// <p>This exception is thrown when the IAM identity that is used to create the organization resource lacks one or more required permissions for creating an organization resource in a required service.</p>
280    InsufficientDependencyServiceAccessPermissionException(crate::types::error::InsufficientDependencyServiceAccessPermissionException),
281    /// <p>For the <code>CreateTrail</code> <code>PutInsightSelectors</code>, <code>UpdateTrail</code>, <code>StartQuery</code>, and <code>StartImport</code> operations, this exception is thrown when the policy on the S3 bucket or KMS key does not have sufficient permissions for the operation.</p>
282    /// <p>For all other operations, this exception is thrown when the policy for the KMS key does not have sufficient permissions for the operation.</p>
283    InsufficientEncryptionPolicyException(crate::types::error::InsufficientEncryptionPolicyException),
284    /// <p>This exception is thrown when the <code>PutEventSelectors</code> operation is called with a number of event selectors, advanced event selectors, or data resources that is not valid. The combination of event selectors or advanced event selectors and data resources is not valid. A trail can have up to 5 event selectors. If a trail uses advanced event selectors, a maximum of 500 total values for all conditions in all advanced event selectors is allowed. A trail is limited to 250 data resources. These data resources can be distributed across event selectors, but the overall total cannot exceed 250.</p>
285    /// <p>You can:</p>
286    /// <ul>
287    /// <li>
288    /// <p>Specify a valid number of event selectors (1 to 5) for a trail.</p></li>
289    /// <li>
290    /// <p>Specify a valid number of data resources (1 to 250) for an event selector. The limit of number of resources on an individual event selector is configurable up to 250. However, this upper limit is allowed only if the total number of data resources does not exceed 250 across all event selectors for a trail.</p></li>
291    /// <li>
292    /// <p>Specify up to 500 values for all conditions in all advanced event selectors for a trail.</p></li>
293    /// <li>
294    /// <p>Specify a valid value for a parameter. For example, specifying the <code>ReadWriteType</code> parameter with a value of <code>read-only</code> is not valid.</p></li>
295    /// </ul>
296    InvalidEventSelectorsException(crate::types::error::InvalidEventSelectorsException),
297    /// <p>This exception is thrown when the KMS key ARN is not valid.</p>
298    InvalidKmsKeyIdException(crate::types::error::InvalidKmsKeyIdException),
299    /// <p>The request includes a parameter that is not valid.</p>
300    InvalidParameterException(crate::types::error::InvalidParameterException),
301    /// <p>This exception is thrown when the specified tag key or values are not valid. It can also occur if there are duplicate tags or too many tags on the resource.</p>
302    InvalidTagParameterException(crate::types::error::InvalidTagParameterException),
303    /// <p>This exception is thrown when there is an issue with the specified KMS key and the trail or event data store can't be updated.</p>
304    KmsException(crate::types::error::KmsException),
305    /// <p>This exception is thrown when the KMS key does not exist, when the S3 bucket and the KMS key are not in the same Region, or when the KMS key associated with the Amazon SNS topic either does not exist or is not in the same Region.</p>
306    KmsKeyNotFoundException(crate::types::error::KmsKeyNotFoundException),
307    /// <p>This exception is thrown when the management account does not have a service-linked role.</p>
308    NoManagementAccountSlrExistsException(crate::types::error::NoManagementAccountSlrExistsException),
309    /// <p>This exception is thrown when the Amazon Web Services account making the request to create or update an organization trail or event data store is not the management account for an organization in Organizations. For more information, see <a href="https://docs.aws.amazon.com/awscloudtrail/latest/userguide/creating-an-organizational-trail-prepare.html">Prepare For Creating a Trail For Your Organization</a> or <a href="https://docs.aws.amazon.com/awscloudtrail/latest/userguide/cloudtrail-lake-organizations.html">Organization event data stores</a>.</p>
310    NotOrganizationMasterAccountException(crate::types::error::NotOrganizationMasterAccountException),
311    /// <p>This exception is thrown when the requested operation is not permitted.</p>
312    OperationNotPermittedException(crate::types::error::OperationNotPermittedException),
313    /// <p>This exception is thrown when Organizations is not configured to support all features. All features must be enabled in Organizations to support creating an organization trail or event data store.</p>
314    OrganizationNotInAllFeaturesModeException(crate::types::error::OrganizationNotInAllFeaturesModeException),
315    /// <p>This exception is thrown when the request is made from an Amazon Web Services account that is not a member of an organization. To make this request, sign in using the credentials of an account that belongs to an organization.</p>
316    OrganizationsNotInUseException(crate::types::error::OrganizationsNotInUseException),
317    /// <p>This exception is thrown when the request rate exceeds the limit.</p>
318    ThrottlingException(crate::types::error::ThrottlingException),
319    /// <p>This exception is thrown when the requested operation is not supported.</p>
320    UnsupportedOperationException(crate::types::error::UnsupportedOperationException),
321    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
322    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
323    variable wildcard pattern and check `.code()`:
324     \
325    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
326     \
327    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-CreateEventDataStoreError) for what information is available for the error.")]
328    Unhandled(crate::error::sealed_unhandled::Unhandled),
329}
330impl CreateEventDataStoreError {
331    /// Creates the `CreateEventDataStoreError::Unhandled` variant from any error type.
332    pub fn unhandled(
333        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
334    ) -> Self {
335        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
336            source: err.into(),
337            meta: ::std::default::Default::default(),
338        })
339    }
340
341    /// Creates the `CreateEventDataStoreError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
342    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
343        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
344            source: err.clone().into(),
345            meta: err,
346        })
347    }
348    ///
349    /// Returns error metadata, which includes the error code, message,
350    /// request ID, and potentially additional information.
351    ///
352    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
353        match self {
354            Self::CloudTrailAccessNotEnabledException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
355            Self::ConflictException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
356            Self::EventDataStoreAlreadyExistsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
357            Self::EventDataStoreMaxLimitExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
358            Self::InsufficientDependencyServiceAccessPermissionException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
359            Self::InsufficientEncryptionPolicyException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
360            Self::InvalidEventSelectorsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
361            Self::InvalidKmsKeyIdException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
362            Self::InvalidParameterException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
363            Self::InvalidTagParameterException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
364            Self::KmsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
365            Self::KmsKeyNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
366            Self::NoManagementAccountSlrExistsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
367            Self::NotOrganizationMasterAccountException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
368            Self::OperationNotPermittedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
369            Self::OrganizationNotInAllFeaturesModeException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
370            Self::OrganizationsNotInUseException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
371            Self::ThrottlingException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
372            Self::UnsupportedOperationException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
373            Self::Unhandled(e) => &e.meta,
374        }
375    }
376    /// Returns `true` if the error kind is `CreateEventDataStoreError::CloudTrailAccessNotEnabledException`.
377    pub fn is_cloud_trail_access_not_enabled_exception(&self) -> bool {
378        matches!(self, Self::CloudTrailAccessNotEnabledException(_))
379    }
380    /// Returns `true` if the error kind is `CreateEventDataStoreError::ConflictException`.
381    pub fn is_conflict_exception(&self) -> bool {
382        matches!(self, Self::ConflictException(_))
383    }
384    /// Returns `true` if the error kind is `CreateEventDataStoreError::EventDataStoreAlreadyExistsException`.
385    pub fn is_event_data_store_already_exists_exception(&self) -> bool {
386        matches!(self, Self::EventDataStoreAlreadyExistsException(_))
387    }
388    /// Returns `true` if the error kind is `CreateEventDataStoreError::EventDataStoreMaxLimitExceededException`.
389    pub fn is_event_data_store_max_limit_exceeded_exception(&self) -> bool {
390        matches!(self, Self::EventDataStoreMaxLimitExceededException(_))
391    }
392    /// Returns `true` if the error kind is `CreateEventDataStoreError::InsufficientDependencyServiceAccessPermissionException`.
393    pub fn is_insufficient_dependency_service_access_permission_exception(&self) -> bool {
394        matches!(self, Self::InsufficientDependencyServiceAccessPermissionException(_))
395    }
396    /// Returns `true` if the error kind is `CreateEventDataStoreError::InsufficientEncryptionPolicyException`.
397    pub fn is_insufficient_encryption_policy_exception(&self) -> bool {
398        matches!(self, Self::InsufficientEncryptionPolicyException(_))
399    }
400    /// Returns `true` if the error kind is `CreateEventDataStoreError::InvalidEventSelectorsException`.
401    pub fn is_invalid_event_selectors_exception(&self) -> bool {
402        matches!(self, Self::InvalidEventSelectorsException(_))
403    }
404    /// Returns `true` if the error kind is `CreateEventDataStoreError::InvalidKmsKeyIdException`.
405    pub fn is_invalid_kms_key_id_exception(&self) -> bool {
406        matches!(self, Self::InvalidKmsKeyIdException(_))
407    }
408    /// Returns `true` if the error kind is `CreateEventDataStoreError::InvalidParameterException`.
409    pub fn is_invalid_parameter_exception(&self) -> bool {
410        matches!(self, Self::InvalidParameterException(_))
411    }
412    /// Returns `true` if the error kind is `CreateEventDataStoreError::InvalidTagParameterException`.
413    pub fn is_invalid_tag_parameter_exception(&self) -> bool {
414        matches!(self, Self::InvalidTagParameterException(_))
415    }
416    /// Returns `true` if the error kind is `CreateEventDataStoreError::KmsException`.
417    pub fn is_kms_exception(&self) -> bool {
418        matches!(self, Self::KmsException(_))
419    }
420    /// Returns `true` if the error kind is `CreateEventDataStoreError::KmsKeyNotFoundException`.
421    pub fn is_kms_key_not_found_exception(&self) -> bool {
422        matches!(self, Self::KmsKeyNotFoundException(_))
423    }
424    /// Returns `true` if the error kind is `CreateEventDataStoreError::NoManagementAccountSlrExistsException`.
425    pub fn is_no_management_account_slr_exists_exception(&self) -> bool {
426        matches!(self, Self::NoManagementAccountSlrExistsException(_))
427    }
428    /// Returns `true` if the error kind is `CreateEventDataStoreError::NotOrganizationMasterAccountException`.
429    pub fn is_not_organization_master_account_exception(&self) -> bool {
430        matches!(self, Self::NotOrganizationMasterAccountException(_))
431    }
432    /// Returns `true` if the error kind is `CreateEventDataStoreError::OperationNotPermittedException`.
433    pub fn is_operation_not_permitted_exception(&self) -> bool {
434        matches!(self, Self::OperationNotPermittedException(_))
435    }
436    /// Returns `true` if the error kind is `CreateEventDataStoreError::OrganizationNotInAllFeaturesModeException`.
437    pub fn is_organization_not_in_all_features_mode_exception(&self) -> bool {
438        matches!(self, Self::OrganizationNotInAllFeaturesModeException(_))
439    }
440    /// Returns `true` if the error kind is `CreateEventDataStoreError::OrganizationsNotInUseException`.
441    pub fn is_organizations_not_in_use_exception(&self) -> bool {
442        matches!(self, Self::OrganizationsNotInUseException(_))
443    }
444    /// Returns `true` if the error kind is `CreateEventDataStoreError::ThrottlingException`.
445    pub fn is_throttling_exception(&self) -> bool {
446        matches!(self, Self::ThrottlingException(_))
447    }
448    /// Returns `true` if the error kind is `CreateEventDataStoreError::UnsupportedOperationException`.
449    pub fn is_unsupported_operation_exception(&self) -> bool {
450        matches!(self, Self::UnsupportedOperationException(_))
451    }
452}
453impl ::std::error::Error for CreateEventDataStoreError {
454    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
455        match self {
456            Self::CloudTrailAccessNotEnabledException(_inner) => ::std::option::Option::Some(_inner),
457            Self::ConflictException(_inner) => ::std::option::Option::Some(_inner),
458            Self::EventDataStoreAlreadyExistsException(_inner) => ::std::option::Option::Some(_inner),
459            Self::EventDataStoreMaxLimitExceededException(_inner) => ::std::option::Option::Some(_inner),
460            Self::InsufficientDependencyServiceAccessPermissionException(_inner) => ::std::option::Option::Some(_inner),
461            Self::InsufficientEncryptionPolicyException(_inner) => ::std::option::Option::Some(_inner),
462            Self::InvalidEventSelectorsException(_inner) => ::std::option::Option::Some(_inner),
463            Self::InvalidKmsKeyIdException(_inner) => ::std::option::Option::Some(_inner),
464            Self::InvalidParameterException(_inner) => ::std::option::Option::Some(_inner),
465            Self::InvalidTagParameterException(_inner) => ::std::option::Option::Some(_inner),
466            Self::KmsException(_inner) => ::std::option::Option::Some(_inner),
467            Self::KmsKeyNotFoundException(_inner) => ::std::option::Option::Some(_inner),
468            Self::NoManagementAccountSlrExistsException(_inner) => ::std::option::Option::Some(_inner),
469            Self::NotOrganizationMasterAccountException(_inner) => ::std::option::Option::Some(_inner),
470            Self::OperationNotPermittedException(_inner) => ::std::option::Option::Some(_inner),
471            Self::OrganizationNotInAllFeaturesModeException(_inner) => ::std::option::Option::Some(_inner),
472            Self::OrganizationsNotInUseException(_inner) => ::std::option::Option::Some(_inner),
473            Self::ThrottlingException(_inner) => ::std::option::Option::Some(_inner),
474            Self::UnsupportedOperationException(_inner) => ::std::option::Option::Some(_inner),
475            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
476        }
477    }
478}
479impl ::std::fmt::Display for CreateEventDataStoreError {
480    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
481        match self {
482            Self::CloudTrailAccessNotEnabledException(_inner) => _inner.fmt(f),
483            Self::ConflictException(_inner) => _inner.fmt(f),
484            Self::EventDataStoreAlreadyExistsException(_inner) => _inner.fmt(f),
485            Self::EventDataStoreMaxLimitExceededException(_inner) => _inner.fmt(f),
486            Self::InsufficientDependencyServiceAccessPermissionException(_inner) => _inner.fmt(f),
487            Self::InsufficientEncryptionPolicyException(_inner) => _inner.fmt(f),
488            Self::InvalidEventSelectorsException(_inner) => _inner.fmt(f),
489            Self::InvalidKmsKeyIdException(_inner) => _inner.fmt(f),
490            Self::InvalidParameterException(_inner) => _inner.fmt(f),
491            Self::InvalidTagParameterException(_inner) => _inner.fmt(f),
492            Self::KmsException(_inner) => _inner.fmt(f),
493            Self::KmsKeyNotFoundException(_inner) => _inner.fmt(f),
494            Self::NoManagementAccountSlrExistsException(_inner) => _inner.fmt(f),
495            Self::NotOrganizationMasterAccountException(_inner) => _inner.fmt(f),
496            Self::OperationNotPermittedException(_inner) => _inner.fmt(f),
497            Self::OrganizationNotInAllFeaturesModeException(_inner) => _inner.fmt(f),
498            Self::OrganizationsNotInUseException(_inner) => _inner.fmt(f),
499            Self::ThrottlingException(_inner) => _inner.fmt(f),
500            Self::UnsupportedOperationException(_inner) => _inner.fmt(f),
501            Self::Unhandled(_inner) => {
502                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
503                    write!(f, "unhandled error ({code})")
504                } else {
505                    f.write_str("unhandled error")
506                }
507            }
508        }
509    }
510}
511impl ::aws_smithy_types::retry::ProvideErrorKind for CreateEventDataStoreError {
512    fn code(&self) -> ::std::option::Option<&str> {
513        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
514    }
515    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
516        ::std::option::Option::None
517    }
518}
519impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for CreateEventDataStoreError {
520    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
521        match self {
522            Self::CloudTrailAccessNotEnabledException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
523            Self::ConflictException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
524            Self::EventDataStoreAlreadyExistsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
525            Self::EventDataStoreMaxLimitExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
526            Self::InsufficientDependencyServiceAccessPermissionException(_inner) => {
527                ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner)
528            }
529            Self::InsufficientEncryptionPolicyException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
530            Self::InvalidEventSelectorsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
531            Self::InvalidKmsKeyIdException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
532            Self::InvalidParameterException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
533            Self::InvalidTagParameterException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
534            Self::KmsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
535            Self::KmsKeyNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
536            Self::NoManagementAccountSlrExistsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
537            Self::NotOrganizationMasterAccountException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
538            Self::OperationNotPermittedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
539            Self::OrganizationNotInAllFeaturesModeException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
540            Self::OrganizationsNotInUseException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
541            Self::ThrottlingException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
542            Self::UnsupportedOperationException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
543            Self::Unhandled(_inner) => &_inner.meta,
544        }
545    }
546}
547impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for CreateEventDataStoreError {
548    fn create_unhandled_error(
549        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
550        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
551    ) -> Self {
552        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
553            source,
554            meta: meta.unwrap_or_default(),
555        })
556    }
557}
558impl ::aws_types::request_id::RequestId for crate::operation::create_event_data_store::CreateEventDataStoreError {
559    fn request_id(&self) -> Option<&str> {
560        self.meta().request_id()
561    }
562}
563
564pub use crate::operation::create_event_data_store::_create_event_data_store_input::CreateEventDataStoreInput;
565
566pub use crate::operation::create_event_data_store::_create_event_data_store_output::CreateEventDataStoreOutput;
567
568mod _create_event_data_store_input;
569
570mod _create_event_data_store_output;
571
572/// Builders
573pub mod builders;