Skip to main content

aws_sdk_cloudtrail/operation/
restore_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 `RestoreEventDataStore`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct RestoreEventDataStore;
6impl RestoreEventDataStore {
7    /// Creates a new `RestoreEventDataStore`
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::restore_event_data_store::RestoreEventDataStoreInput,
14    ) -> ::std::result::Result<
15        crate::operation::restore_event_data_store::RestoreEventDataStoreOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::restore_event_data_store::RestoreEventDataStoreError,
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::restore_event_data_store::RestoreEventDataStoreError>()
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::restore_event_data_store::RestoreEventDataStoreOutput>()
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::restore_event_data_store::RestoreEventDataStoreInput,
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", "RestoreEventDataStore", 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.RestoreEventDataStore",
59                "rpc.service" = "CloudTrail",
60                "rpc.method" = "RestoreEventDataStore",
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 RestoreEventDataStore {
88    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
89        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("RestoreEventDataStore");
90
91        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
92            RestoreEventDataStoreRequestSerializer,
93        ));
94        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
95            RestoreEventDataStoreResponseDeserializer,
96        ));
97
98        cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
99            crate::config::auth::Params::builder()
100                .operation_name("RestoreEventDataStore")
101                .build()
102                .expect("required fields set"),
103        ));
104
105        cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new(
106            "RestoreEventDataStore",
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("RestoreEventDataStore")
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                RestoreEventDataStoreEndpointParamsInterceptor,
134            ))
135            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
136                crate::operation::restore_event_data_store::RestoreEventDataStoreError,
137            >::new())
138            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
139                crate::operation::restore_event_data_store::RestoreEventDataStoreError,
140            >::new())
141            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
142                crate::operation::restore_event_data_store::RestoreEventDataStoreError,
143            >::new());
144
145        ::std::borrow::Cow::Owned(rcb)
146    }
147}
148
149#[derive(Debug)]
150struct RestoreEventDataStoreResponseDeserializer;
151impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for RestoreEventDataStoreResponseDeserializer {
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_restore_event_data_store::de_restore_event_data_store_http_error(status, headers, body)
165        } else {
166            crate::protocol_serde::shape_restore_event_data_store::de_restore_event_data_store_http_response(status, headers, body)
167        };
168        crate::protocol_serde::type_erase_result(parse_result)
169    }
170}
171#[derive(Debug)]
172struct RestoreEventDataStoreRequestSerializer;
173impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for RestoreEventDataStoreRequestSerializer {
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::restore_event_data_store::RestoreEventDataStoreInput>()
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::restore_event_data_store::RestoreEventDataStoreInput,
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::restore_event_data_store::RestoreEventDataStoreInput,
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.RestoreEventDataStore",
212            );
213            builder
214        };
215        let body = ::aws_smithy_types::body::SdkBody::from(
216            crate::protocol_serde::shape_restore_event_data_store::ser_restore_event_data_store_input(&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 RestoreEventDataStoreEndpointParamsInterceptor;
227
228#[::aws_smithy_runtime_api::client::interceptors::dyn_dispatch_hint]
229impl ::aws_smithy_runtime_api::client::interceptors::Intercept for RestoreEventDataStoreEndpointParamsInterceptor {
230    fn name(&self) -> &'static str {
231        "RestoreEventDataStoreEndpointParamsInterceptor"
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::<RestoreEventDataStoreInput>()
247            .ok_or("failed to downcast to RestoreEventDataStoreInput")?;
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 `RestoreEventDataStoreError` operation.
268#[non_exhaustive]
269#[derive(::std::fmt::Debug)]
270pub enum RestoreEventDataStoreError {
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>The specified event data store ARN is not valid or does not map to an event data store in your account.</p>
274    EventDataStoreArnInvalidException(crate::types::error::EventDataStoreArnInvalidException),
275    /// <p>Your account has used the maximum number of event data stores.</p>
276    EventDataStoreMaxLimitExceededException(crate::types::error::EventDataStoreMaxLimitExceededException),
277    /// <p>The specified event data store was not found.</p>
278    EventDataStoreNotFoundException(crate::types::error::EventDataStoreNotFoundException),
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>The event data store is not in a status that supports the operation.</p>
282    InvalidEventDataStoreStatusException(crate::types::error::InvalidEventDataStoreStatusException),
283    /// <p>The request includes a parameter that is not valid.</p>
284    InvalidParameterException(crate::types::error::InvalidParameterException),
285    /// <p>This exception is thrown when the management account does not have a service-linked role.</p>
286    NoManagementAccountSlrExistsException(crate::types::error::NoManagementAccountSlrExistsException),
287    /// <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>
288    NotOrganizationMasterAccountException(crate::types::error::NotOrganizationMasterAccountException),
289    /// <p>This exception is thrown when the requested operation is not permitted.</p>
290    OperationNotPermittedException(crate::types::error::OperationNotPermittedException),
291    /// <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>
292    OrganizationNotInAllFeaturesModeException(crate::types::error::OrganizationNotInAllFeaturesModeException),
293    /// <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>
294    OrganizationsNotInUseException(crate::types::error::OrganizationsNotInUseException),
295    /// <p>This exception is thrown when the requested operation is not supported.</p>
296    UnsupportedOperationException(crate::types::error::UnsupportedOperationException),
297    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
298    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
299    variable wildcard pattern and check `.code()`:
300     \
301    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
302     \
303    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-RestoreEventDataStoreError) for what information is available for the error.")]
304    Unhandled(crate::error::sealed_unhandled::Unhandled),
305}
306impl RestoreEventDataStoreError {
307    /// Creates the `RestoreEventDataStoreError::Unhandled` variant from any error type.
308    pub fn unhandled(
309        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
310    ) -> Self {
311        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
312            source: err.into(),
313            meta: ::std::default::Default::default(),
314        })
315    }
316
317    /// Creates the `RestoreEventDataStoreError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
318    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
319        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
320            source: err.clone().into(),
321            meta: err,
322        })
323    }
324    ///
325    /// Returns error metadata, which includes the error code, message,
326    /// request ID, and potentially additional information.
327    ///
328    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
329        match self {
330            Self::CloudTrailAccessNotEnabledException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
331            Self::EventDataStoreArnInvalidException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
332            Self::EventDataStoreMaxLimitExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
333            Self::EventDataStoreNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
334            Self::InsufficientDependencyServiceAccessPermissionException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
335            Self::InvalidEventDataStoreStatusException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
336            Self::InvalidParameterException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
337            Self::NoManagementAccountSlrExistsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
338            Self::NotOrganizationMasterAccountException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
339            Self::OperationNotPermittedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
340            Self::OrganizationNotInAllFeaturesModeException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
341            Self::OrganizationsNotInUseException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
342            Self::UnsupportedOperationException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
343            Self::Unhandled(e) => &e.meta,
344        }
345    }
346    /// Returns `true` if the error kind is `RestoreEventDataStoreError::CloudTrailAccessNotEnabledException`.
347    pub fn is_cloud_trail_access_not_enabled_exception(&self) -> bool {
348        matches!(self, Self::CloudTrailAccessNotEnabledException(_))
349    }
350    /// Returns `true` if the error kind is `RestoreEventDataStoreError::EventDataStoreArnInvalidException`.
351    pub fn is_event_data_store_arn_invalid_exception(&self) -> bool {
352        matches!(self, Self::EventDataStoreArnInvalidException(_))
353    }
354    /// Returns `true` if the error kind is `RestoreEventDataStoreError::EventDataStoreMaxLimitExceededException`.
355    pub fn is_event_data_store_max_limit_exceeded_exception(&self) -> bool {
356        matches!(self, Self::EventDataStoreMaxLimitExceededException(_))
357    }
358    /// Returns `true` if the error kind is `RestoreEventDataStoreError::EventDataStoreNotFoundException`.
359    pub fn is_event_data_store_not_found_exception(&self) -> bool {
360        matches!(self, Self::EventDataStoreNotFoundException(_))
361    }
362    /// Returns `true` if the error kind is `RestoreEventDataStoreError::InsufficientDependencyServiceAccessPermissionException`.
363    pub fn is_insufficient_dependency_service_access_permission_exception(&self) -> bool {
364        matches!(self, Self::InsufficientDependencyServiceAccessPermissionException(_))
365    }
366    /// Returns `true` if the error kind is `RestoreEventDataStoreError::InvalidEventDataStoreStatusException`.
367    pub fn is_invalid_event_data_store_status_exception(&self) -> bool {
368        matches!(self, Self::InvalidEventDataStoreStatusException(_))
369    }
370    /// Returns `true` if the error kind is `RestoreEventDataStoreError::InvalidParameterException`.
371    pub fn is_invalid_parameter_exception(&self) -> bool {
372        matches!(self, Self::InvalidParameterException(_))
373    }
374    /// Returns `true` if the error kind is `RestoreEventDataStoreError::NoManagementAccountSlrExistsException`.
375    pub fn is_no_management_account_slr_exists_exception(&self) -> bool {
376        matches!(self, Self::NoManagementAccountSlrExistsException(_))
377    }
378    /// Returns `true` if the error kind is `RestoreEventDataStoreError::NotOrganizationMasterAccountException`.
379    pub fn is_not_organization_master_account_exception(&self) -> bool {
380        matches!(self, Self::NotOrganizationMasterAccountException(_))
381    }
382    /// Returns `true` if the error kind is `RestoreEventDataStoreError::OperationNotPermittedException`.
383    pub fn is_operation_not_permitted_exception(&self) -> bool {
384        matches!(self, Self::OperationNotPermittedException(_))
385    }
386    /// Returns `true` if the error kind is `RestoreEventDataStoreError::OrganizationNotInAllFeaturesModeException`.
387    pub fn is_organization_not_in_all_features_mode_exception(&self) -> bool {
388        matches!(self, Self::OrganizationNotInAllFeaturesModeException(_))
389    }
390    /// Returns `true` if the error kind is `RestoreEventDataStoreError::OrganizationsNotInUseException`.
391    pub fn is_organizations_not_in_use_exception(&self) -> bool {
392        matches!(self, Self::OrganizationsNotInUseException(_))
393    }
394    /// Returns `true` if the error kind is `RestoreEventDataStoreError::UnsupportedOperationException`.
395    pub fn is_unsupported_operation_exception(&self) -> bool {
396        matches!(self, Self::UnsupportedOperationException(_))
397    }
398}
399impl ::std::error::Error for RestoreEventDataStoreError {
400    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
401        match self {
402            Self::CloudTrailAccessNotEnabledException(_inner) => ::std::option::Option::Some(_inner),
403            Self::EventDataStoreArnInvalidException(_inner) => ::std::option::Option::Some(_inner),
404            Self::EventDataStoreMaxLimitExceededException(_inner) => ::std::option::Option::Some(_inner),
405            Self::EventDataStoreNotFoundException(_inner) => ::std::option::Option::Some(_inner),
406            Self::InsufficientDependencyServiceAccessPermissionException(_inner) => ::std::option::Option::Some(_inner),
407            Self::InvalidEventDataStoreStatusException(_inner) => ::std::option::Option::Some(_inner),
408            Self::InvalidParameterException(_inner) => ::std::option::Option::Some(_inner),
409            Self::NoManagementAccountSlrExistsException(_inner) => ::std::option::Option::Some(_inner),
410            Self::NotOrganizationMasterAccountException(_inner) => ::std::option::Option::Some(_inner),
411            Self::OperationNotPermittedException(_inner) => ::std::option::Option::Some(_inner),
412            Self::OrganizationNotInAllFeaturesModeException(_inner) => ::std::option::Option::Some(_inner),
413            Self::OrganizationsNotInUseException(_inner) => ::std::option::Option::Some(_inner),
414            Self::UnsupportedOperationException(_inner) => ::std::option::Option::Some(_inner),
415            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
416        }
417    }
418}
419impl ::std::fmt::Display for RestoreEventDataStoreError {
420    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
421        match self {
422            Self::CloudTrailAccessNotEnabledException(_inner) => _inner.fmt(f),
423            Self::EventDataStoreArnInvalidException(_inner) => _inner.fmt(f),
424            Self::EventDataStoreMaxLimitExceededException(_inner) => _inner.fmt(f),
425            Self::EventDataStoreNotFoundException(_inner) => _inner.fmt(f),
426            Self::InsufficientDependencyServiceAccessPermissionException(_inner) => _inner.fmt(f),
427            Self::InvalidEventDataStoreStatusException(_inner) => _inner.fmt(f),
428            Self::InvalidParameterException(_inner) => _inner.fmt(f),
429            Self::NoManagementAccountSlrExistsException(_inner) => _inner.fmt(f),
430            Self::NotOrganizationMasterAccountException(_inner) => _inner.fmt(f),
431            Self::OperationNotPermittedException(_inner) => _inner.fmt(f),
432            Self::OrganizationNotInAllFeaturesModeException(_inner) => _inner.fmt(f),
433            Self::OrganizationsNotInUseException(_inner) => _inner.fmt(f),
434            Self::UnsupportedOperationException(_inner) => _inner.fmt(f),
435            Self::Unhandled(_inner) => {
436                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
437                    write!(f, "unhandled error ({code})")
438                } else {
439                    f.write_str("unhandled error")
440                }
441            }
442        }
443    }
444}
445impl ::aws_smithy_types::retry::ProvideErrorKind for RestoreEventDataStoreError {
446    fn code(&self) -> ::std::option::Option<&str> {
447        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
448    }
449    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
450        ::std::option::Option::None
451    }
452}
453impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for RestoreEventDataStoreError {
454    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
455        match self {
456            Self::CloudTrailAccessNotEnabledException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
457            Self::EventDataStoreArnInvalidException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
458            Self::EventDataStoreMaxLimitExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
459            Self::EventDataStoreNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
460            Self::InsufficientDependencyServiceAccessPermissionException(_inner) => {
461                ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner)
462            }
463            Self::InvalidEventDataStoreStatusException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
464            Self::InvalidParameterException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
465            Self::NoManagementAccountSlrExistsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
466            Self::NotOrganizationMasterAccountException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
467            Self::OperationNotPermittedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
468            Self::OrganizationNotInAllFeaturesModeException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
469            Self::OrganizationsNotInUseException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
470            Self::UnsupportedOperationException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
471            Self::Unhandled(_inner) => &_inner.meta,
472        }
473    }
474}
475impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for RestoreEventDataStoreError {
476    fn create_unhandled_error(
477        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
478        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
479    ) -> Self {
480        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
481            source,
482            meta: meta.unwrap_or_default(),
483        })
484    }
485}
486impl ::aws_types::request_id::RequestId for crate::operation::restore_event_data_store::RestoreEventDataStoreError {
487    fn request_id(&self) -> Option<&str> {
488        self.meta().request_id()
489    }
490}
491
492pub use crate::operation::restore_event_data_store::_restore_event_data_store_input::RestoreEventDataStoreInput;
493
494pub use crate::operation::restore_event_data_store::_restore_event_data_store_output::RestoreEventDataStoreOutput;
495
496mod _restore_event_data_store_input;
497
498mod _restore_event_data_store_output;
499
500/// Builders
501pub mod builders;