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::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default())
130            .with_interceptor(RestoreEventDataStoreEndpointParamsInterceptor)
131            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
132                crate::operation::restore_event_data_store::RestoreEventDataStoreError,
133            >::new())
134            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
135                crate::operation::restore_event_data_store::RestoreEventDataStoreError,
136            >::new())
137            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
138                crate::operation::restore_event_data_store::RestoreEventDataStoreError,
139            >::new());
140
141        ::std::borrow::Cow::Owned(rcb)
142    }
143}
144
145#[derive(Debug)]
146struct RestoreEventDataStoreResponseDeserializer;
147impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for RestoreEventDataStoreResponseDeserializer {
148    fn deserialize_nonstreaming(
149        &self,
150        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
151    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
152        let (success, status) = (response.status().is_success(), response.status().as_u16());
153        let headers = response.headers();
154        let body = response.body().bytes().expect("body loaded");
155        #[allow(unused_mut)]
156        let mut force_error = false;
157        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
158        let parse_result = if !success && status != 200 || force_error {
159            crate::protocol_serde::shape_restore_event_data_store::de_restore_event_data_store_http_error(status, headers, body)
160        } else {
161            crate::protocol_serde::shape_restore_event_data_store::de_restore_event_data_store_http_response(status, headers, body)
162        };
163        crate::protocol_serde::type_erase_result(parse_result)
164    }
165}
166#[derive(Debug)]
167struct RestoreEventDataStoreRequestSerializer;
168impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for RestoreEventDataStoreRequestSerializer {
169    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
170    fn serialize_input(
171        &self,
172        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
173        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
174    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
175        let input = input
176            .downcast::<crate::operation::restore_event_data_store::RestoreEventDataStoreInput>()
177            .expect("correct type");
178        let _header_serialization_settings = _cfg
179            .load::<crate::serialization_settings::HeaderSerializationSettings>()
180            .cloned()
181            .unwrap_or_default();
182        let mut request_builder = {
183            #[allow(clippy::uninlined_format_args)]
184            fn uri_base(
185                _input: &crate::operation::restore_event_data_store::RestoreEventDataStoreInput,
186                output: &mut ::std::string::String,
187            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
188                use ::std::fmt::Write as _;
189                ::std::write!(output, "/").expect("formatting should succeed");
190                ::std::result::Result::Ok(())
191            }
192            #[allow(clippy::unnecessary_wraps)]
193            fn update_http_builder(
194                input: &crate::operation::restore_event_data_store::RestoreEventDataStoreInput,
195                builder: ::http::request::Builder,
196            ) -> ::std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
197                let mut uri = ::std::string::String::new();
198                uri_base(input, &mut uri)?;
199                ::std::result::Result::Ok(builder.method("POST").uri(uri))
200            }
201            let mut builder = update_http_builder(&input, ::http::request::Builder::new())?;
202            builder = _header_serialization_settings.set_default_header(builder, ::http::header::CONTENT_TYPE, "application/x-amz-json-1.1");
203            builder = _header_serialization_settings.set_default_header(
204                builder,
205                ::http::header::HeaderName::from_static("x-amz-target"),
206                "CloudTrail_20131101.RestoreEventDataStore",
207            );
208            builder
209        };
210        let body = ::aws_smithy_types::body::SdkBody::from(
211            crate::protocol_serde::shape_restore_event_data_store::ser_restore_event_data_store_input(&input)?,
212        );
213        if let Some(content_length) = body.content_length() {
214            let content_length = content_length.to_string();
215            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http::header::CONTENT_LENGTH, &content_length);
216        }
217        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
218    }
219}
220#[derive(Debug)]
221struct RestoreEventDataStoreEndpointParamsInterceptor;
222
223impl ::aws_smithy_runtime_api::client::interceptors::Intercept for RestoreEventDataStoreEndpointParamsInterceptor {
224    fn name(&self) -> &'static str {
225        "RestoreEventDataStoreEndpointParamsInterceptor"
226    }
227
228    fn read_before_execution(
229        &self,
230        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
231            '_,
232            ::aws_smithy_runtime_api::client::interceptors::context::Input,
233            ::aws_smithy_runtime_api::client::interceptors::context::Output,
234            ::aws_smithy_runtime_api::client::interceptors::context::Error,
235        >,
236        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
237    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
238        let _input = context
239            .input()
240            .downcast_ref::<RestoreEventDataStoreInput>()
241            .ok_or("failed to downcast to RestoreEventDataStoreInput")?;
242
243        let params = crate::config::endpoint::Params::builder()
244            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
245            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
246            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
247            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
248            .build()
249            .map_err(|err| {
250                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
251            })?;
252        cfg.interceptor_state()
253            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
254        ::std::result::Result::Ok(())
255    }
256}
257
258// The get_* functions below are generated from JMESPath expressions in the
259// operationContextParams trait. They target the operation's input shape.
260
261/// Error type for the `RestoreEventDataStoreError` operation.
262#[non_exhaustive]
263#[derive(::std::fmt::Debug)]
264pub enum RestoreEventDataStoreError {
265    /// <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>
266    CloudTrailAccessNotEnabledException(crate::types::error::CloudTrailAccessNotEnabledException),
267    /// <p>The specified event data store ARN is not valid or does not map to an event data store in your account.</p>
268    EventDataStoreArnInvalidException(crate::types::error::EventDataStoreArnInvalidException),
269    /// <p>Your account has used the maximum number of event data stores.</p>
270    EventDataStoreMaxLimitExceededException(crate::types::error::EventDataStoreMaxLimitExceededException),
271    /// <p>The specified event data store was not found.</p>
272    EventDataStoreNotFoundException(crate::types::error::EventDataStoreNotFoundException),
273    /// <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>
274    InsufficientDependencyServiceAccessPermissionException(crate::types::error::InsufficientDependencyServiceAccessPermissionException),
275    /// <p>The event data store is not in a status that supports the operation.</p>
276    InvalidEventDataStoreStatusException(crate::types::error::InvalidEventDataStoreStatusException),
277    /// <p>The request includes a parameter that is not valid.</p>
278    InvalidParameterException(crate::types::error::InvalidParameterException),
279    /// <p>This exception is thrown when the management account does not have a service-linked role.</p>
280    NoManagementAccountSlrExistsException(crate::types::error::NoManagementAccountSlrExistsException),
281    /// <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>
282    NotOrganizationMasterAccountException(crate::types::error::NotOrganizationMasterAccountException),
283    /// <p>This exception is thrown when the requested operation is not permitted.</p>
284    OperationNotPermittedException(crate::types::error::OperationNotPermittedException),
285    /// <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>
286    OrganizationNotInAllFeaturesModeException(crate::types::error::OrganizationNotInAllFeaturesModeException),
287    /// <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>
288    OrganizationsNotInUseException(crate::types::error::OrganizationsNotInUseException),
289    /// <p>This exception is thrown when the requested operation is not supported.</p>
290    UnsupportedOperationException(crate::types::error::UnsupportedOperationException),
291    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
292    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
293    variable wildcard pattern and check `.code()`:
294     \
295    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
296     \
297    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-RestoreEventDataStoreError) for what information is available for the error.")]
298    Unhandled(crate::error::sealed_unhandled::Unhandled),
299}
300impl RestoreEventDataStoreError {
301    /// Creates the `RestoreEventDataStoreError::Unhandled` variant from any error type.
302    pub fn unhandled(
303        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
304    ) -> Self {
305        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
306            source: err.into(),
307            meta: ::std::default::Default::default(),
308        })
309    }
310
311    /// Creates the `RestoreEventDataStoreError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
312    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
313        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
314            source: err.clone().into(),
315            meta: err,
316        })
317    }
318    ///
319    /// Returns error metadata, which includes the error code, message,
320    /// request ID, and potentially additional information.
321    ///
322    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
323        match self {
324            Self::CloudTrailAccessNotEnabledException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
325            Self::EventDataStoreArnInvalidException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
326            Self::EventDataStoreMaxLimitExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
327            Self::EventDataStoreNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
328            Self::InsufficientDependencyServiceAccessPermissionException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
329            Self::InvalidEventDataStoreStatusException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
330            Self::InvalidParameterException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
331            Self::NoManagementAccountSlrExistsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
332            Self::NotOrganizationMasterAccountException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
333            Self::OperationNotPermittedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
334            Self::OrganizationNotInAllFeaturesModeException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
335            Self::OrganizationsNotInUseException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
336            Self::UnsupportedOperationException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
337            Self::Unhandled(e) => &e.meta,
338        }
339    }
340    /// Returns `true` if the error kind is `RestoreEventDataStoreError::CloudTrailAccessNotEnabledException`.
341    pub fn is_cloud_trail_access_not_enabled_exception(&self) -> bool {
342        matches!(self, Self::CloudTrailAccessNotEnabledException(_))
343    }
344    /// Returns `true` if the error kind is `RestoreEventDataStoreError::EventDataStoreArnInvalidException`.
345    pub fn is_event_data_store_arn_invalid_exception(&self) -> bool {
346        matches!(self, Self::EventDataStoreArnInvalidException(_))
347    }
348    /// Returns `true` if the error kind is `RestoreEventDataStoreError::EventDataStoreMaxLimitExceededException`.
349    pub fn is_event_data_store_max_limit_exceeded_exception(&self) -> bool {
350        matches!(self, Self::EventDataStoreMaxLimitExceededException(_))
351    }
352    /// Returns `true` if the error kind is `RestoreEventDataStoreError::EventDataStoreNotFoundException`.
353    pub fn is_event_data_store_not_found_exception(&self) -> bool {
354        matches!(self, Self::EventDataStoreNotFoundException(_))
355    }
356    /// Returns `true` if the error kind is `RestoreEventDataStoreError::InsufficientDependencyServiceAccessPermissionException`.
357    pub fn is_insufficient_dependency_service_access_permission_exception(&self) -> bool {
358        matches!(self, Self::InsufficientDependencyServiceAccessPermissionException(_))
359    }
360    /// Returns `true` if the error kind is `RestoreEventDataStoreError::InvalidEventDataStoreStatusException`.
361    pub fn is_invalid_event_data_store_status_exception(&self) -> bool {
362        matches!(self, Self::InvalidEventDataStoreStatusException(_))
363    }
364    /// Returns `true` if the error kind is `RestoreEventDataStoreError::InvalidParameterException`.
365    pub fn is_invalid_parameter_exception(&self) -> bool {
366        matches!(self, Self::InvalidParameterException(_))
367    }
368    /// Returns `true` if the error kind is `RestoreEventDataStoreError::NoManagementAccountSlrExistsException`.
369    pub fn is_no_management_account_slr_exists_exception(&self) -> bool {
370        matches!(self, Self::NoManagementAccountSlrExistsException(_))
371    }
372    /// Returns `true` if the error kind is `RestoreEventDataStoreError::NotOrganizationMasterAccountException`.
373    pub fn is_not_organization_master_account_exception(&self) -> bool {
374        matches!(self, Self::NotOrganizationMasterAccountException(_))
375    }
376    /// Returns `true` if the error kind is `RestoreEventDataStoreError::OperationNotPermittedException`.
377    pub fn is_operation_not_permitted_exception(&self) -> bool {
378        matches!(self, Self::OperationNotPermittedException(_))
379    }
380    /// Returns `true` if the error kind is `RestoreEventDataStoreError::OrganizationNotInAllFeaturesModeException`.
381    pub fn is_organization_not_in_all_features_mode_exception(&self) -> bool {
382        matches!(self, Self::OrganizationNotInAllFeaturesModeException(_))
383    }
384    /// Returns `true` if the error kind is `RestoreEventDataStoreError::OrganizationsNotInUseException`.
385    pub fn is_organizations_not_in_use_exception(&self) -> bool {
386        matches!(self, Self::OrganizationsNotInUseException(_))
387    }
388    /// Returns `true` if the error kind is `RestoreEventDataStoreError::UnsupportedOperationException`.
389    pub fn is_unsupported_operation_exception(&self) -> bool {
390        matches!(self, Self::UnsupportedOperationException(_))
391    }
392}
393impl ::std::error::Error for RestoreEventDataStoreError {
394    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
395        match self {
396            Self::CloudTrailAccessNotEnabledException(_inner) => ::std::option::Option::Some(_inner),
397            Self::EventDataStoreArnInvalidException(_inner) => ::std::option::Option::Some(_inner),
398            Self::EventDataStoreMaxLimitExceededException(_inner) => ::std::option::Option::Some(_inner),
399            Self::EventDataStoreNotFoundException(_inner) => ::std::option::Option::Some(_inner),
400            Self::InsufficientDependencyServiceAccessPermissionException(_inner) => ::std::option::Option::Some(_inner),
401            Self::InvalidEventDataStoreStatusException(_inner) => ::std::option::Option::Some(_inner),
402            Self::InvalidParameterException(_inner) => ::std::option::Option::Some(_inner),
403            Self::NoManagementAccountSlrExistsException(_inner) => ::std::option::Option::Some(_inner),
404            Self::NotOrganizationMasterAccountException(_inner) => ::std::option::Option::Some(_inner),
405            Self::OperationNotPermittedException(_inner) => ::std::option::Option::Some(_inner),
406            Self::OrganizationNotInAllFeaturesModeException(_inner) => ::std::option::Option::Some(_inner),
407            Self::OrganizationsNotInUseException(_inner) => ::std::option::Option::Some(_inner),
408            Self::UnsupportedOperationException(_inner) => ::std::option::Option::Some(_inner),
409            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
410        }
411    }
412}
413impl ::std::fmt::Display for RestoreEventDataStoreError {
414    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
415        match self {
416            Self::CloudTrailAccessNotEnabledException(_inner) => _inner.fmt(f),
417            Self::EventDataStoreArnInvalidException(_inner) => _inner.fmt(f),
418            Self::EventDataStoreMaxLimitExceededException(_inner) => _inner.fmt(f),
419            Self::EventDataStoreNotFoundException(_inner) => _inner.fmt(f),
420            Self::InsufficientDependencyServiceAccessPermissionException(_inner) => _inner.fmt(f),
421            Self::InvalidEventDataStoreStatusException(_inner) => _inner.fmt(f),
422            Self::InvalidParameterException(_inner) => _inner.fmt(f),
423            Self::NoManagementAccountSlrExistsException(_inner) => _inner.fmt(f),
424            Self::NotOrganizationMasterAccountException(_inner) => _inner.fmt(f),
425            Self::OperationNotPermittedException(_inner) => _inner.fmt(f),
426            Self::OrganizationNotInAllFeaturesModeException(_inner) => _inner.fmt(f),
427            Self::OrganizationsNotInUseException(_inner) => _inner.fmt(f),
428            Self::UnsupportedOperationException(_inner) => _inner.fmt(f),
429            Self::Unhandled(_inner) => {
430                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
431                    write!(f, "unhandled error ({code})")
432                } else {
433                    f.write_str("unhandled error")
434                }
435            }
436        }
437    }
438}
439impl ::aws_smithy_types::retry::ProvideErrorKind for RestoreEventDataStoreError {
440    fn code(&self) -> ::std::option::Option<&str> {
441        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
442    }
443    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
444        ::std::option::Option::None
445    }
446}
447impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for RestoreEventDataStoreError {
448    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
449        match self {
450            Self::CloudTrailAccessNotEnabledException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
451            Self::EventDataStoreArnInvalidException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
452            Self::EventDataStoreMaxLimitExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
453            Self::EventDataStoreNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
454            Self::InsufficientDependencyServiceAccessPermissionException(_inner) => {
455                ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner)
456            }
457            Self::InvalidEventDataStoreStatusException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
458            Self::InvalidParameterException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
459            Self::NoManagementAccountSlrExistsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
460            Self::NotOrganizationMasterAccountException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
461            Self::OperationNotPermittedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
462            Self::OrganizationNotInAllFeaturesModeException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
463            Self::OrganizationsNotInUseException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
464            Self::UnsupportedOperationException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
465            Self::Unhandled(_inner) => &_inner.meta,
466        }
467    }
468}
469impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for RestoreEventDataStoreError {
470    fn create_unhandled_error(
471        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
472        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
473    ) -> Self {
474        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
475            source,
476            meta: meta.unwrap_or_default(),
477        })
478    }
479}
480impl ::aws_types::request_id::RequestId for crate::operation::restore_event_data_store::RestoreEventDataStoreError {
481    fn request_id(&self) -> Option<&str> {
482        self.meta().request_id()
483    }
484}
485
486pub use crate::operation::restore_event_data_store::_restore_event_data_store_output::RestoreEventDataStoreOutput;
487
488pub use crate::operation::restore_event_data_store::_restore_event_data_store_input::RestoreEventDataStoreInput;
489
490mod _restore_event_data_store_input;
491
492mod _restore_event_data_store_output;
493
494/// Builders
495pub mod builders;