Skip to main content

aws_sdk_cloudtrail/operation/
create_trail.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Orchestration and serialization glue logic for `CreateTrail`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct CreateTrail;
6impl CreateTrail {
7    /// Creates a new `CreateTrail`
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_trail::CreateTrailInput,
14    ) -> ::std::result::Result<
15        crate::operation::create_trail::CreateTrailOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::create_trail::CreateTrailError,
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_trail::CreateTrailError>()
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_trail::CreateTrailOutput>()
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_trail::CreateTrailInput,
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", "CreateTrail", 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.CreateTrail",
59                "rpc.service" = "CloudTrail",
60                "rpc.method" = "CreateTrail",
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 CreateTrail {
88    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
89        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("CreateTrail");
90
91        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
92            CreateTrailRequestSerializer,
93        ));
94        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
95            CreateTrailResponseDeserializer,
96        ));
97
98        cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
99            crate::config::auth::Params::builder()
100                .operation_name("CreateTrail")
101                .build()
102                .expect("required fields set"),
103        ));
104
105        cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new("CreateTrail", "CloudTrail"));
106        let mut signing_options = ::aws_runtime::auth::SigningOptions::default();
107        signing_options.double_uri_encode = true;
108        signing_options.content_sha256_header = false;
109        signing_options.normalize_uri_path = true;
110        signing_options.payload_override = None;
111
112        cfg.store_put(::aws_runtime::auth::SigV4OperationSigningConfig {
113            signing_options,
114            ..::std::default::Default::default()
115        });
116
117        ::std::option::Option::Some(cfg.freeze())
118    }
119
120    fn runtime_components(
121        &self,
122        _: &::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder,
123    ) -> ::std::borrow::Cow<'_, ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder> {
124        #[allow(unused_mut)]
125        let mut rcb = ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder::new("CreateTrail")
126            .with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
127                ::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default(),
128            ))
129            .with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
130                CreateTrailEndpointParamsInterceptor,
131            ))
132            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
133                crate::operation::create_trail::CreateTrailError,
134            >::new())
135            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
136                crate::operation::create_trail::CreateTrailError,
137            >::new())
138            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
139                crate::operation::create_trail::CreateTrailError,
140            >::new());
141
142        ::std::borrow::Cow::Owned(rcb)
143    }
144}
145
146#[derive(Debug)]
147struct CreateTrailResponseDeserializer;
148impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CreateTrailResponseDeserializer {
149    fn deserialize_nonstreaming_with_config(
150        &self,
151        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
152        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
153    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
154        let (success, status) = (response.status().is_success(), response.status().as_u16());
155        let headers = response.headers();
156        let body = response.body().bytes().expect("body loaded");
157        #[allow(unused_mut)]
158        let mut force_error = false;
159        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
160        let parse_result = if !success && status != 200 || force_error {
161            crate::protocol_serde::shape_create_trail::de_create_trail_http_error(status, headers, body)
162        } else {
163            crate::protocol_serde::shape_create_trail::de_create_trail_http_response(status, headers, body)
164        };
165        crate::protocol_serde::type_erase_result(parse_result)
166    }
167}
168#[derive(Debug)]
169struct CreateTrailRequestSerializer;
170impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for CreateTrailRequestSerializer {
171    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
172    fn serialize_input(
173        &self,
174        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
175        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
176    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
177        let input = input
178            .downcast::<crate::operation::create_trail::CreateTrailInput>()
179            .expect("correct type");
180        let _header_serialization_settings = _cfg
181            .load::<crate::serialization_settings::HeaderSerializationSettings>()
182            .cloned()
183            .unwrap_or_default();
184        let mut request_builder = {
185            #[allow(clippy::uninlined_format_args)]
186            fn uri_base(
187                _input: &crate::operation::create_trail::CreateTrailInput,
188                output: &mut ::std::string::String,
189            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
190                use ::std::fmt::Write as _;
191                ::std::write!(output, "/").expect("formatting should succeed");
192                ::std::result::Result::Ok(())
193            }
194            #[allow(clippy::unnecessary_wraps)]
195            fn update_http_builder(
196                input: &crate::operation::create_trail::CreateTrailInput,
197                builder: ::http_1x::request::Builder,
198            ) -> ::std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
199                let mut uri = ::std::string::String::new();
200                uri_base(input, &mut uri)?;
201                ::std::result::Result::Ok(builder.method("POST").uri(uri))
202            }
203            let mut builder = update_http_builder(&input, ::http_1x::request::Builder::new())?;
204            builder = _header_serialization_settings.set_default_header(builder, ::http_1x::header::CONTENT_TYPE, "application/x-amz-json-1.1");
205            builder = _header_serialization_settings.set_default_header(
206                builder,
207                ::http_1x::header::HeaderName::from_static("x-amz-target"),
208                "CloudTrail_20131101.CreateTrail",
209            );
210            builder
211        };
212        let body = ::aws_smithy_types::body::SdkBody::from(crate::protocol_serde::shape_create_trail::ser_create_trail_input(&input)?);
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_1x::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 CreateTrailEndpointParamsInterceptor;
222
223#[::aws_smithy_runtime_api::client::interceptors::dyn_dispatch_hint]
224impl ::aws_smithy_runtime_api::client::interceptors::Intercept for CreateTrailEndpointParamsInterceptor {
225    fn name(&self) -> &'static str {
226        "CreateTrailEndpointParamsInterceptor"
227    }
228
229    fn read_before_execution(
230        &self,
231        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
232            '_,
233            ::aws_smithy_runtime_api::client::interceptors::context::Input,
234            ::aws_smithy_runtime_api::client::interceptors::context::Output,
235            ::aws_smithy_runtime_api::client::interceptors::context::Error,
236        >,
237        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
238    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
239        let _input = context
240            .input()
241            .downcast_ref::<CreateTrailInput>()
242            .ok_or("failed to downcast to CreateTrailInput")?;
243
244        let params = crate::config::endpoint::Params::builder()
245            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
246            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
247            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
248            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
249            .build()
250            .map_err(|err| {
251                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
252            })?;
253        cfg.interceptor_state()
254            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
255        ::std::result::Result::Ok(())
256    }
257}
258
259// The get_* functions below are generated from JMESPath expressions in the
260// operationContextParams trait. They target the operation's input shape.
261
262/// Error type for the `CreateTrailError` operation.
263#[non_exhaustive]
264#[derive(::std::fmt::Debug)]
265pub enum CreateTrailError {
266    /// <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>
267    CloudTrailAccessNotEnabledException(crate::types::error::CloudTrailAccessNotEnabledException),
268    /// <p>This exception is thrown when a call results in the <code>InvalidClientTokenId</code> error code. This can occur when you are creating or updating a trail to send notifications to an Amazon SNS topic that is in a suspended Amazon Web Services account.</p>
269    CloudTrailInvalidClientTokenIdException(crate::types::error::CloudTrailInvalidClientTokenIdException),
270    /// <p>Cannot set a CloudWatch Logs delivery for this Region.</p>
271    CloudWatchLogsDeliveryUnavailableException(crate::types::error::CloudWatchLogsDeliveryUnavailableException),
272    /// <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>
273    ConflictException(crate::types::error::ConflictException),
274    /// <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>
275    InsufficientDependencyServiceAccessPermissionException(crate::types::error::InsufficientDependencyServiceAccessPermissionException),
276    /// <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>
277    /// <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>
278    InsufficientEncryptionPolicyException(crate::types::error::InsufficientEncryptionPolicyException),
279    /// <p>This exception is thrown when the policy on the S3 bucket is not sufficient.</p>
280    InsufficientS3BucketPolicyException(crate::types::error::InsufficientS3BucketPolicyException),
281    /// <p>This exception is thrown when the policy on the Amazon SNS topic is not sufficient.</p>
282    InsufficientSnsTopicPolicyException(crate::types::error::InsufficientSnsTopicPolicyException),
283    /// <p>This exception is thrown when the provided CloudWatch Logs log group is not valid.</p>
284    InvalidCloudWatchLogsLogGroupArnException(crate::types::error::InvalidCloudWatchLogsLogGroupArnException),
285    /// <p>This exception is thrown when the provided role is not valid.</p>
286    InvalidCloudWatchLogsRoleArnException(crate::types::error::InvalidCloudWatchLogsRoleArnException),
287    /// <p>This exception is thrown when the KMS key ARN is not valid.</p>
288    InvalidKmsKeyIdException(crate::types::error::InvalidKmsKeyIdException),
289    /// <p>This exception is thrown when the combination of parameters provided is not valid.</p>
290    InvalidParameterCombinationException(crate::types::error::InvalidParameterCombinationException),
291    /// <p>The request includes a parameter that is not valid.</p>
292    InvalidParameterException(crate::types::error::InvalidParameterException),
293    /// <p>This exception is thrown when the provided S3 bucket name is not valid.</p>
294    InvalidS3BucketNameException(crate::types::error::InvalidS3BucketNameException),
295    /// <p>This exception is thrown when the provided S3 prefix is not valid.</p>
296    InvalidS3PrefixException(crate::types::error::InvalidS3PrefixException),
297    /// <p>This exception is thrown when the provided SNS topic name is not valid.</p>
298    InvalidSnsTopicNameException(crate::types::error::InvalidSnsTopicNameException),
299    /// <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>
300    InvalidTagParameterException(crate::types::error::InvalidTagParameterException),
301    /// <p>This exception is thrown when the provided trail name is not valid. Trail names must meet the following requirements:</p>
302    /// <ul>
303    /// <li>
304    /// <p>Contain only ASCII letters (a-z, A-Z), numbers (0-9), periods (.), underscores (_), or dashes (-)</p></li>
305    /// <li>
306    /// <p>Start with a letter or number, and end with a letter or number</p></li>
307    /// <li>
308    /// <p>Be between 3 and 128 characters</p></li>
309    /// <li>
310    /// <p>Have no adjacent periods, underscores or dashes. Names like <code>my-_namespace</code> and <code>my--namespace</code> are not valid.</p></li>
311    /// <li>
312    /// <p>Not be in IP address format (for example, 192.168.5.4)</p></li>
313    /// </ul>
314    InvalidTrailNameException(crate::types::error::InvalidTrailNameException),
315    /// <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>
316    KmsException(crate::types::error::KmsException),
317    /// <p>This exception is no longer in use.</p>
318    #[deprecated]
319    KmsKeyDisabledException(crate::types::error::KmsKeyDisabledException),
320    /// <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>
321    KmsKeyNotFoundException(crate::types::error::KmsKeyNotFoundException),
322    /// <p>This exception is thrown when the maximum number of trails is reached.</p>
323    MaximumNumberOfTrailsExceededException(crate::types::error::MaximumNumberOfTrailsExceededException),
324    /// <p>This exception is thrown when the management account does not have a service-linked role.</p>
325    NoManagementAccountSlrExistsException(crate::types::error::NoManagementAccountSlrExistsException),
326    /// <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>
327    NotOrganizationMasterAccountException(crate::types::error::NotOrganizationMasterAccountException),
328    /// <p>This exception is thrown when the requested operation is not permitted.</p>
329    OperationNotPermittedException(crate::types::error::OperationNotPermittedException),
330    /// <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>
331    OrganizationNotInAllFeaturesModeException(crate::types::error::OrganizationNotInAllFeaturesModeException),
332    /// <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>
333    OrganizationsNotInUseException(crate::types::error::OrganizationsNotInUseException),
334    /// <p>This exception is thrown when the specified S3 bucket does not exist.</p>
335    S3BucketDoesNotExistException(crate::types::error::S3BucketDoesNotExistException),
336    /// <p>The number of tags per trail, event data store, dashboard, or channel has exceeded the permitted amount. Currently, the limit is 50.</p>
337    TagsLimitExceededException(crate::types::error::TagsLimitExceededException),
338    /// <p>This exception is thrown when the request rate exceeds the limit.</p>
339    ThrottlingException(crate::types::error::ThrottlingException),
340    /// <p>This exception is thrown when the specified trail already exists.</p>
341    TrailAlreadyExistsException(crate::types::error::TrailAlreadyExistsException),
342    /// <p>This exception is no longer in use.</p>
343    TrailNotProvidedException(crate::types::error::TrailNotProvidedException),
344    /// <p>This exception is thrown when the requested operation is not supported.</p>
345    UnsupportedOperationException(crate::types::error::UnsupportedOperationException),
346    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
347    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
348    variable wildcard pattern and check `.code()`:
349     \
350    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
351     \
352    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-CreateTrailError) for what information is available for the error.")]
353    Unhandled(crate::error::sealed_unhandled::Unhandled),
354}
355impl CreateTrailError {
356    /// Creates the `CreateTrailError::Unhandled` variant from any error type.
357    pub fn unhandled(
358        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
359    ) -> Self {
360        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
361            source: err.into(),
362            meta: ::std::default::Default::default(),
363        })
364    }
365
366    /// Creates the `CreateTrailError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
367    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
368        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
369            source: err.clone().into(),
370            meta: err,
371        })
372    }
373    ///
374    /// Returns error metadata, which includes the error code, message,
375    /// request ID, and potentially additional information.
376    ///
377    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
378        match self {
379            Self::CloudTrailAccessNotEnabledException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
380            Self::CloudTrailInvalidClientTokenIdException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
381            Self::CloudWatchLogsDeliveryUnavailableException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
382            Self::ConflictException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
383            Self::InsufficientDependencyServiceAccessPermissionException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
384            Self::InsufficientEncryptionPolicyException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
385            Self::InsufficientS3BucketPolicyException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
386            Self::InsufficientSnsTopicPolicyException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
387            Self::InvalidCloudWatchLogsLogGroupArnException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
388            Self::InvalidCloudWatchLogsRoleArnException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
389            Self::InvalidKmsKeyIdException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
390            Self::InvalidParameterCombinationException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
391            Self::InvalidParameterException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
392            Self::InvalidS3BucketNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
393            Self::InvalidS3PrefixException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
394            Self::InvalidSnsTopicNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
395            Self::InvalidTagParameterException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
396            Self::InvalidTrailNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
397            Self::KmsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
398            Self::KmsKeyDisabledException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
399            Self::KmsKeyNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
400            Self::MaximumNumberOfTrailsExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
401            Self::NoManagementAccountSlrExistsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
402            Self::NotOrganizationMasterAccountException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
403            Self::OperationNotPermittedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
404            Self::OrganizationNotInAllFeaturesModeException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
405            Self::OrganizationsNotInUseException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
406            Self::S3BucketDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
407            Self::TagsLimitExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
408            Self::ThrottlingException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
409            Self::TrailAlreadyExistsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
410            Self::TrailNotProvidedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
411            Self::UnsupportedOperationException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
412            Self::Unhandled(e) => &e.meta,
413        }
414    }
415    /// Returns `true` if the error kind is `CreateTrailError::CloudTrailAccessNotEnabledException`.
416    pub fn is_cloud_trail_access_not_enabled_exception(&self) -> bool {
417        matches!(self, Self::CloudTrailAccessNotEnabledException(_))
418    }
419    /// Returns `true` if the error kind is `CreateTrailError::CloudTrailInvalidClientTokenIdException`.
420    pub fn is_cloud_trail_invalid_client_token_id_exception(&self) -> bool {
421        matches!(self, Self::CloudTrailInvalidClientTokenIdException(_))
422    }
423    /// Returns `true` if the error kind is `CreateTrailError::CloudWatchLogsDeliveryUnavailableException`.
424    pub fn is_cloud_watch_logs_delivery_unavailable_exception(&self) -> bool {
425        matches!(self, Self::CloudWatchLogsDeliveryUnavailableException(_))
426    }
427    /// Returns `true` if the error kind is `CreateTrailError::ConflictException`.
428    pub fn is_conflict_exception(&self) -> bool {
429        matches!(self, Self::ConflictException(_))
430    }
431    /// Returns `true` if the error kind is `CreateTrailError::InsufficientDependencyServiceAccessPermissionException`.
432    pub fn is_insufficient_dependency_service_access_permission_exception(&self) -> bool {
433        matches!(self, Self::InsufficientDependencyServiceAccessPermissionException(_))
434    }
435    /// Returns `true` if the error kind is `CreateTrailError::InsufficientEncryptionPolicyException`.
436    pub fn is_insufficient_encryption_policy_exception(&self) -> bool {
437        matches!(self, Self::InsufficientEncryptionPolicyException(_))
438    }
439    /// Returns `true` if the error kind is `CreateTrailError::InsufficientS3BucketPolicyException`.
440    pub fn is_insufficient_s3_bucket_policy_exception(&self) -> bool {
441        matches!(self, Self::InsufficientS3BucketPolicyException(_))
442    }
443    /// Returns `true` if the error kind is `CreateTrailError::InsufficientSnsTopicPolicyException`.
444    pub fn is_insufficient_sns_topic_policy_exception(&self) -> bool {
445        matches!(self, Self::InsufficientSnsTopicPolicyException(_))
446    }
447    /// Returns `true` if the error kind is `CreateTrailError::InvalidCloudWatchLogsLogGroupArnException`.
448    pub fn is_invalid_cloud_watch_logs_log_group_arn_exception(&self) -> bool {
449        matches!(self, Self::InvalidCloudWatchLogsLogGroupArnException(_))
450    }
451    /// Returns `true` if the error kind is `CreateTrailError::InvalidCloudWatchLogsRoleArnException`.
452    pub fn is_invalid_cloud_watch_logs_role_arn_exception(&self) -> bool {
453        matches!(self, Self::InvalidCloudWatchLogsRoleArnException(_))
454    }
455    /// Returns `true` if the error kind is `CreateTrailError::InvalidKmsKeyIdException`.
456    pub fn is_invalid_kms_key_id_exception(&self) -> bool {
457        matches!(self, Self::InvalidKmsKeyIdException(_))
458    }
459    /// Returns `true` if the error kind is `CreateTrailError::InvalidParameterCombinationException`.
460    pub fn is_invalid_parameter_combination_exception(&self) -> bool {
461        matches!(self, Self::InvalidParameterCombinationException(_))
462    }
463    /// Returns `true` if the error kind is `CreateTrailError::InvalidParameterException`.
464    pub fn is_invalid_parameter_exception(&self) -> bool {
465        matches!(self, Self::InvalidParameterException(_))
466    }
467    /// Returns `true` if the error kind is `CreateTrailError::InvalidS3BucketNameException`.
468    pub fn is_invalid_s3_bucket_name_exception(&self) -> bool {
469        matches!(self, Self::InvalidS3BucketNameException(_))
470    }
471    /// Returns `true` if the error kind is `CreateTrailError::InvalidS3PrefixException`.
472    pub fn is_invalid_s3_prefix_exception(&self) -> bool {
473        matches!(self, Self::InvalidS3PrefixException(_))
474    }
475    /// Returns `true` if the error kind is `CreateTrailError::InvalidSnsTopicNameException`.
476    pub fn is_invalid_sns_topic_name_exception(&self) -> bool {
477        matches!(self, Self::InvalidSnsTopicNameException(_))
478    }
479    /// Returns `true` if the error kind is `CreateTrailError::InvalidTagParameterException`.
480    pub fn is_invalid_tag_parameter_exception(&self) -> bool {
481        matches!(self, Self::InvalidTagParameterException(_))
482    }
483    /// Returns `true` if the error kind is `CreateTrailError::InvalidTrailNameException`.
484    pub fn is_invalid_trail_name_exception(&self) -> bool {
485        matches!(self, Self::InvalidTrailNameException(_))
486    }
487    /// Returns `true` if the error kind is `CreateTrailError::KmsException`.
488    pub fn is_kms_exception(&self) -> bool {
489        matches!(self, Self::KmsException(_))
490    }
491    /// Returns `true` if the error kind is `CreateTrailError::KmsKeyDisabledException`.
492    pub fn is_kms_key_disabled_exception(&self) -> bool {
493        matches!(self, Self::KmsKeyDisabledException(_))
494    }
495    /// Returns `true` if the error kind is `CreateTrailError::KmsKeyNotFoundException`.
496    pub fn is_kms_key_not_found_exception(&self) -> bool {
497        matches!(self, Self::KmsKeyNotFoundException(_))
498    }
499    /// Returns `true` if the error kind is `CreateTrailError::MaximumNumberOfTrailsExceededException`.
500    pub fn is_maximum_number_of_trails_exceeded_exception(&self) -> bool {
501        matches!(self, Self::MaximumNumberOfTrailsExceededException(_))
502    }
503    /// Returns `true` if the error kind is `CreateTrailError::NoManagementAccountSlrExistsException`.
504    pub fn is_no_management_account_slr_exists_exception(&self) -> bool {
505        matches!(self, Self::NoManagementAccountSlrExistsException(_))
506    }
507    /// Returns `true` if the error kind is `CreateTrailError::NotOrganizationMasterAccountException`.
508    pub fn is_not_organization_master_account_exception(&self) -> bool {
509        matches!(self, Self::NotOrganizationMasterAccountException(_))
510    }
511    /// Returns `true` if the error kind is `CreateTrailError::OperationNotPermittedException`.
512    pub fn is_operation_not_permitted_exception(&self) -> bool {
513        matches!(self, Self::OperationNotPermittedException(_))
514    }
515    /// Returns `true` if the error kind is `CreateTrailError::OrganizationNotInAllFeaturesModeException`.
516    pub fn is_organization_not_in_all_features_mode_exception(&self) -> bool {
517        matches!(self, Self::OrganizationNotInAllFeaturesModeException(_))
518    }
519    /// Returns `true` if the error kind is `CreateTrailError::OrganizationsNotInUseException`.
520    pub fn is_organizations_not_in_use_exception(&self) -> bool {
521        matches!(self, Self::OrganizationsNotInUseException(_))
522    }
523    /// Returns `true` if the error kind is `CreateTrailError::S3BucketDoesNotExistException`.
524    pub fn is_s3_bucket_does_not_exist_exception(&self) -> bool {
525        matches!(self, Self::S3BucketDoesNotExistException(_))
526    }
527    /// Returns `true` if the error kind is `CreateTrailError::TagsLimitExceededException`.
528    pub fn is_tags_limit_exceeded_exception(&self) -> bool {
529        matches!(self, Self::TagsLimitExceededException(_))
530    }
531    /// Returns `true` if the error kind is `CreateTrailError::ThrottlingException`.
532    pub fn is_throttling_exception(&self) -> bool {
533        matches!(self, Self::ThrottlingException(_))
534    }
535    /// Returns `true` if the error kind is `CreateTrailError::TrailAlreadyExistsException`.
536    pub fn is_trail_already_exists_exception(&self) -> bool {
537        matches!(self, Self::TrailAlreadyExistsException(_))
538    }
539    /// Returns `true` if the error kind is `CreateTrailError::TrailNotProvidedException`.
540    pub fn is_trail_not_provided_exception(&self) -> bool {
541        matches!(self, Self::TrailNotProvidedException(_))
542    }
543    /// Returns `true` if the error kind is `CreateTrailError::UnsupportedOperationException`.
544    pub fn is_unsupported_operation_exception(&self) -> bool {
545        matches!(self, Self::UnsupportedOperationException(_))
546    }
547}
548impl ::std::error::Error for CreateTrailError {
549    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
550        match self {
551            Self::CloudTrailAccessNotEnabledException(_inner) => ::std::option::Option::Some(_inner),
552            Self::CloudTrailInvalidClientTokenIdException(_inner) => ::std::option::Option::Some(_inner),
553            Self::CloudWatchLogsDeliveryUnavailableException(_inner) => ::std::option::Option::Some(_inner),
554            Self::ConflictException(_inner) => ::std::option::Option::Some(_inner),
555            Self::InsufficientDependencyServiceAccessPermissionException(_inner) => ::std::option::Option::Some(_inner),
556            Self::InsufficientEncryptionPolicyException(_inner) => ::std::option::Option::Some(_inner),
557            Self::InsufficientS3BucketPolicyException(_inner) => ::std::option::Option::Some(_inner),
558            Self::InsufficientSnsTopicPolicyException(_inner) => ::std::option::Option::Some(_inner),
559            Self::InvalidCloudWatchLogsLogGroupArnException(_inner) => ::std::option::Option::Some(_inner),
560            Self::InvalidCloudWatchLogsRoleArnException(_inner) => ::std::option::Option::Some(_inner),
561            Self::InvalidKmsKeyIdException(_inner) => ::std::option::Option::Some(_inner),
562            Self::InvalidParameterCombinationException(_inner) => ::std::option::Option::Some(_inner),
563            Self::InvalidParameterException(_inner) => ::std::option::Option::Some(_inner),
564            Self::InvalidS3BucketNameException(_inner) => ::std::option::Option::Some(_inner),
565            Self::InvalidS3PrefixException(_inner) => ::std::option::Option::Some(_inner),
566            Self::InvalidSnsTopicNameException(_inner) => ::std::option::Option::Some(_inner),
567            Self::InvalidTagParameterException(_inner) => ::std::option::Option::Some(_inner),
568            Self::InvalidTrailNameException(_inner) => ::std::option::Option::Some(_inner),
569            Self::KmsException(_inner) => ::std::option::Option::Some(_inner),
570            Self::KmsKeyDisabledException(_inner) => ::std::option::Option::Some(_inner),
571            Self::KmsKeyNotFoundException(_inner) => ::std::option::Option::Some(_inner),
572            Self::MaximumNumberOfTrailsExceededException(_inner) => ::std::option::Option::Some(_inner),
573            Self::NoManagementAccountSlrExistsException(_inner) => ::std::option::Option::Some(_inner),
574            Self::NotOrganizationMasterAccountException(_inner) => ::std::option::Option::Some(_inner),
575            Self::OperationNotPermittedException(_inner) => ::std::option::Option::Some(_inner),
576            Self::OrganizationNotInAllFeaturesModeException(_inner) => ::std::option::Option::Some(_inner),
577            Self::OrganizationsNotInUseException(_inner) => ::std::option::Option::Some(_inner),
578            Self::S3BucketDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
579            Self::TagsLimitExceededException(_inner) => ::std::option::Option::Some(_inner),
580            Self::ThrottlingException(_inner) => ::std::option::Option::Some(_inner),
581            Self::TrailAlreadyExistsException(_inner) => ::std::option::Option::Some(_inner),
582            Self::TrailNotProvidedException(_inner) => ::std::option::Option::Some(_inner),
583            Self::UnsupportedOperationException(_inner) => ::std::option::Option::Some(_inner),
584            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
585        }
586    }
587}
588impl ::std::fmt::Display for CreateTrailError {
589    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
590        match self {
591            Self::CloudTrailAccessNotEnabledException(_inner) => _inner.fmt(f),
592            Self::CloudTrailInvalidClientTokenIdException(_inner) => _inner.fmt(f),
593            Self::CloudWatchLogsDeliveryUnavailableException(_inner) => _inner.fmt(f),
594            Self::ConflictException(_inner) => _inner.fmt(f),
595            Self::InsufficientDependencyServiceAccessPermissionException(_inner) => _inner.fmt(f),
596            Self::InsufficientEncryptionPolicyException(_inner) => _inner.fmt(f),
597            Self::InsufficientS3BucketPolicyException(_inner) => _inner.fmt(f),
598            Self::InsufficientSnsTopicPolicyException(_inner) => _inner.fmt(f),
599            Self::InvalidCloudWatchLogsLogGroupArnException(_inner) => _inner.fmt(f),
600            Self::InvalidCloudWatchLogsRoleArnException(_inner) => _inner.fmt(f),
601            Self::InvalidKmsKeyIdException(_inner) => _inner.fmt(f),
602            Self::InvalidParameterCombinationException(_inner) => _inner.fmt(f),
603            Self::InvalidParameterException(_inner) => _inner.fmt(f),
604            Self::InvalidS3BucketNameException(_inner) => _inner.fmt(f),
605            Self::InvalidS3PrefixException(_inner) => _inner.fmt(f),
606            Self::InvalidSnsTopicNameException(_inner) => _inner.fmt(f),
607            Self::InvalidTagParameterException(_inner) => _inner.fmt(f),
608            Self::InvalidTrailNameException(_inner) => _inner.fmt(f),
609            Self::KmsException(_inner) => _inner.fmt(f),
610            Self::KmsKeyDisabledException(_inner) => _inner.fmt(f),
611            Self::KmsKeyNotFoundException(_inner) => _inner.fmt(f),
612            Self::MaximumNumberOfTrailsExceededException(_inner) => _inner.fmt(f),
613            Self::NoManagementAccountSlrExistsException(_inner) => _inner.fmt(f),
614            Self::NotOrganizationMasterAccountException(_inner) => _inner.fmt(f),
615            Self::OperationNotPermittedException(_inner) => _inner.fmt(f),
616            Self::OrganizationNotInAllFeaturesModeException(_inner) => _inner.fmt(f),
617            Self::OrganizationsNotInUseException(_inner) => _inner.fmt(f),
618            Self::S3BucketDoesNotExistException(_inner) => _inner.fmt(f),
619            Self::TagsLimitExceededException(_inner) => _inner.fmt(f),
620            Self::ThrottlingException(_inner) => _inner.fmt(f),
621            Self::TrailAlreadyExistsException(_inner) => _inner.fmt(f),
622            Self::TrailNotProvidedException(_inner) => _inner.fmt(f),
623            Self::UnsupportedOperationException(_inner) => _inner.fmt(f),
624            Self::Unhandled(_inner) => {
625                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
626                    write!(f, "unhandled error ({code})")
627                } else {
628                    f.write_str("unhandled error")
629                }
630            }
631        }
632    }
633}
634impl ::aws_smithy_types::retry::ProvideErrorKind for CreateTrailError {
635    fn code(&self) -> ::std::option::Option<&str> {
636        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
637    }
638    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
639        ::std::option::Option::None
640    }
641}
642impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for CreateTrailError {
643    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
644        match self {
645            Self::CloudTrailAccessNotEnabledException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
646            Self::CloudTrailInvalidClientTokenIdException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
647            Self::CloudWatchLogsDeliveryUnavailableException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
648            Self::ConflictException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
649            Self::InsufficientDependencyServiceAccessPermissionException(_inner) => {
650                ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner)
651            }
652            Self::InsufficientEncryptionPolicyException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
653            Self::InsufficientS3BucketPolicyException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
654            Self::InsufficientSnsTopicPolicyException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
655            Self::InvalidCloudWatchLogsLogGroupArnException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
656            Self::InvalidCloudWatchLogsRoleArnException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
657            Self::InvalidKmsKeyIdException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
658            Self::InvalidParameterCombinationException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
659            Self::InvalidParameterException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
660            Self::InvalidS3BucketNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
661            Self::InvalidS3PrefixException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
662            Self::InvalidSnsTopicNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
663            Self::InvalidTagParameterException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
664            Self::InvalidTrailNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
665            Self::KmsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
666            Self::KmsKeyDisabledException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
667            Self::KmsKeyNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
668            Self::MaximumNumberOfTrailsExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
669            Self::NoManagementAccountSlrExistsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
670            Self::NotOrganizationMasterAccountException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
671            Self::OperationNotPermittedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
672            Self::OrganizationNotInAllFeaturesModeException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
673            Self::OrganizationsNotInUseException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
674            Self::S3BucketDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
675            Self::TagsLimitExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
676            Self::ThrottlingException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
677            Self::TrailAlreadyExistsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
678            Self::TrailNotProvidedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
679            Self::UnsupportedOperationException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
680            Self::Unhandled(_inner) => &_inner.meta,
681        }
682    }
683}
684impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for CreateTrailError {
685    fn create_unhandled_error(
686        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
687        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
688    ) -> Self {
689        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
690            source,
691            meta: meta.unwrap_or_default(),
692        })
693    }
694}
695impl ::aws_types::request_id::RequestId for crate::operation::create_trail::CreateTrailError {
696    fn request_id(&self) -> Option<&str> {
697        self.meta().request_id()
698    }
699}
700
701pub use crate::operation::create_trail::_create_trail_input::CreateTrailInput;
702
703pub use crate::operation::create_trail::_create_trail_output::CreateTrailOutput;
704
705mod _create_trail_input;
706
707mod _create_trail_output;
708
709/// Builders
710pub mod builders;