Skip to main content

aws_sdk_efs/operation/
create_mount_target.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Orchestration and serialization glue logic for `CreateMountTarget`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct CreateMountTarget;
6impl CreateMountTarget {
7    /// Creates a new `CreateMountTarget`
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_mount_target::CreateMountTargetInput,
14    ) -> ::std::result::Result<
15        crate::operation::create_mount_target::CreateMountTargetOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::create_mount_target::CreateMountTargetError,
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_mount_target::CreateMountTargetError>()
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_mount_target::CreateMountTargetOutput>()
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_mount_target::CreateMountTargetInput,
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("EFS", "CreateMountTarget", 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                "EFS.CreateMountTarget",
59                "rpc.service" = "EFS",
60                "rpc.method" = "CreateMountTarget",
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 CreateMountTarget {
88    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
89        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("CreateMountTarget");
90
91        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
92            CreateMountTargetRequestSerializer,
93        ));
94        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
95            CreateMountTargetResponseDeserializer,
96        ));
97
98        cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
99            crate::config::auth::Params::builder()
100                .operation_name("CreateMountTarget")
101                .build()
102                .expect("required fields set"),
103        ));
104
105        cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new("CreateMountTarget", "EFS"));
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("CreateMountTarget")
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                CreateMountTargetEndpointParamsInterceptor,
131            ))
132            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
133                crate::operation::create_mount_target::CreateMountTargetError,
134            >::new())
135            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
136                crate::operation::create_mount_target::CreateMountTargetError,
137            >::new())
138            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
139                crate::operation::create_mount_target::CreateMountTargetError,
140            >::new());
141
142        ::std::borrow::Cow::Owned(rcb)
143    }
144}
145
146#[derive(Debug)]
147struct CreateMountTargetResponseDeserializer;
148impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CreateMountTargetResponseDeserializer {
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_mount_target::de_create_mount_target_http_error(status, headers, body)
162        } else {
163            crate::protocol_serde::shape_create_mount_target::de_create_mount_target_http_response(status, headers, body)
164        };
165        crate::protocol_serde::type_erase_result(parse_result)
166    }
167}
168#[derive(Debug)]
169struct CreateMountTargetRequestSerializer;
170impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for CreateMountTargetRequestSerializer {
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_mount_target::CreateMountTargetInput>()
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_mount_target::CreateMountTargetInput,
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, "/2015-02-01/mount-targets").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_mount_target::CreateMountTargetInput,
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/json");
205            builder
206        };
207        let body = ::aws_smithy_types::body::SdkBody::from(crate::protocol_serde::shape_create_mount_target::ser_create_mount_target_input(&input)?);
208        if let Some(content_length) = body.content_length() {
209            let content_length = content_length.to_string();
210            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http_1x::header::CONTENT_LENGTH, &content_length);
211        }
212        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
213    }
214}
215#[derive(Debug)]
216struct CreateMountTargetEndpointParamsInterceptor;
217
218#[::aws_smithy_runtime_api::client::interceptors::dyn_dispatch_hint]
219impl ::aws_smithy_runtime_api::client::interceptors::Intercept for CreateMountTargetEndpointParamsInterceptor {
220    fn name(&self) -> &'static str {
221        "CreateMountTargetEndpointParamsInterceptor"
222    }
223
224    fn read_before_execution(
225        &self,
226        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
227            '_,
228            ::aws_smithy_runtime_api::client::interceptors::context::Input,
229            ::aws_smithy_runtime_api::client::interceptors::context::Output,
230            ::aws_smithy_runtime_api::client::interceptors::context::Error,
231        >,
232        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
233    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
234        let _input = context
235            .input()
236            .downcast_ref::<CreateMountTargetInput>()
237            .ok_or("failed to downcast to CreateMountTargetInput")?;
238
239        let params = crate::config::endpoint::Params::builder()
240            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
241            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
242            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
243            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
244            .build()
245            .map_err(|err| {
246                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
247            })?;
248        cfg.interceptor_state()
249            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
250        ::std::result::Result::Ok(())
251    }
252}
253
254// The get_* functions below are generated from JMESPath expressions in the
255// operationContextParams trait. They target the operation's input shape.
256
257/// Error type for the `CreateMountTargetError` operation.
258#[non_exhaustive]
259#[derive(::std::fmt::Debug)]
260pub enum CreateMountTargetError {
261    /// <p>Returned if the Availability Zone that was specified for a mount target is different from the Availability Zone that was specified for One Zone storage. For more information, see <a href="https://docs.aws.amazon.com/efs/latest/ug/availability-durability.html">Regional and One Zone storage redundancy</a>.</p>
262    AvailabilityZonesMismatch(crate::types::error::AvailabilityZonesMismatch),
263    /// <p>Returned if the request is malformed or contains an error such as an invalid parameter value or a missing required parameter.</p>
264    BadRequest(crate::types::error::BadRequest),
265    /// <p>Returned if the specified <code>FileSystemId</code> value doesn't exist in the requester's Amazon Web Services account.</p>
266    FileSystemNotFound(crate::types::error::FileSystemNotFound),
267    /// <p>Returned if the file system's lifecycle state is not "available".</p>
268    IncorrectFileSystemLifeCycleState(crate::types::error::IncorrectFileSystemLifeCycleState),
269    /// <p>Returned if an error occurred on the server side.</p>
270    InternalServerError(crate::types::error::InternalServerError),
271    /// <p>Returned if the request specified an <code>IpAddress</code> that is already in use in the subnet.</p>
272    IpAddressInUse(crate::types::error::IpAddressInUse),
273    /// <p>Returned if the mount target would violate one of the specified restrictions based on the file system's existing mount targets.</p>
274    MountTargetConflict(crate::types::error::MountTargetConflict),
275    /// <p>The calling account has reached the limit for elastic network interfaces for the specific Amazon Web Services Region. Either delete some network interfaces or request that the account quota be raised. For more information, see <a href="https://docs.aws.amazon.com/vpc/latest/userguide/amazon-vpc-limits.html">Amazon VPC Quotas</a> in the <i>Amazon VPC User Guide</i> (see the <b>Network interfaces per Region</b> entry in the <b>Network interfaces</b> table).</p>
276    NetworkInterfaceLimitExceeded(crate::types::error::NetworkInterfaceLimitExceeded),
277    /// <p>Returned if <code>IpAddress</code> was not specified in the request and there are no free IP addresses in the subnet.</p>
278    NoFreeAddressesInSubnet(crate::types::error::NoFreeAddressesInSubnet),
279    /// <p>Returned if the number of <code>SecurityGroups</code> specified in the request is greater than the limit, which is based on account quota. Either delete some security groups or request that the account quota be raised. For more information, see <a href="https://docs.aws.amazon.com/vpc/latest/userguide/amazon-vpc-limits.html">Amazon VPC Quotas</a> in the <i>Amazon VPC User Guide</i> (see the <b>Security Groups</b> table).</p>
280    SecurityGroupLimitExceeded(crate::types::error::SecurityGroupLimitExceeded),
281    /// <p>Returned if one of the specified security groups doesn't exist in the subnet's virtual private cloud (VPC).</p>
282    SecurityGroupNotFound(crate::types::error::SecurityGroupNotFound),
283    /// <p>Returned if there is no subnet with ID <code>SubnetId</code> provided in the request.</p>
284    SubnetNotFound(crate::types::error::SubnetNotFound),
285    /// <p>Returned if the requested Amazon EFS functionality is not available in the specified Availability Zone.</p>
286    UnsupportedAvailabilityZone(crate::types::error::UnsupportedAvailabilityZone),
287    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
288    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
289    variable wildcard pattern and check `.code()`:
290     \
291    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
292     \
293    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-CreateMountTargetError) for what information is available for the error.")]
294    Unhandled(crate::error::sealed_unhandled::Unhandled),
295}
296impl CreateMountTargetError {
297    /// Creates the `CreateMountTargetError::Unhandled` variant from any error type.
298    pub fn unhandled(
299        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
300    ) -> Self {
301        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
302            source: err.into(),
303            meta: ::std::default::Default::default(),
304        })
305    }
306
307    /// Creates the `CreateMountTargetError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
308    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
309        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
310            source: err.clone().into(),
311            meta: err,
312        })
313    }
314    ///
315    /// Returns error metadata, which includes the error code, message,
316    /// request ID, and potentially additional information.
317    ///
318    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
319        match self {
320            Self::AvailabilityZonesMismatch(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
321            Self::BadRequest(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
322            Self::FileSystemNotFound(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
323            Self::IncorrectFileSystemLifeCycleState(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
324            Self::InternalServerError(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
325            Self::IpAddressInUse(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
326            Self::MountTargetConflict(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
327            Self::NetworkInterfaceLimitExceeded(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
328            Self::NoFreeAddressesInSubnet(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
329            Self::SecurityGroupLimitExceeded(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
330            Self::SecurityGroupNotFound(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
331            Self::SubnetNotFound(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
332            Self::UnsupportedAvailabilityZone(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
333            Self::Unhandled(e) => &e.meta,
334        }
335    }
336    /// Returns `true` if the error kind is `CreateMountTargetError::AvailabilityZonesMismatch`.
337    pub fn is_availability_zones_mismatch(&self) -> bool {
338        matches!(self, Self::AvailabilityZonesMismatch(_))
339    }
340    /// Returns `true` if the error kind is `CreateMountTargetError::BadRequest`.
341    pub fn is_bad_request(&self) -> bool {
342        matches!(self, Self::BadRequest(_))
343    }
344    /// Returns `true` if the error kind is `CreateMountTargetError::FileSystemNotFound`.
345    pub fn is_file_system_not_found(&self) -> bool {
346        matches!(self, Self::FileSystemNotFound(_))
347    }
348    /// Returns `true` if the error kind is `CreateMountTargetError::IncorrectFileSystemLifeCycleState`.
349    pub fn is_incorrect_file_system_life_cycle_state(&self) -> bool {
350        matches!(self, Self::IncorrectFileSystemLifeCycleState(_))
351    }
352    /// Returns `true` if the error kind is `CreateMountTargetError::InternalServerError`.
353    pub fn is_internal_server_error(&self) -> bool {
354        matches!(self, Self::InternalServerError(_))
355    }
356    /// Returns `true` if the error kind is `CreateMountTargetError::IpAddressInUse`.
357    pub fn is_ip_address_in_use(&self) -> bool {
358        matches!(self, Self::IpAddressInUse(_))
359    }
360    /// Returns `true` if the error kind is `CreateMountTargetError::MountTargetConflict`.
361    pub fn is_mount_target_conflict(&self) -> bool {
362        matches!(self, Self::MountTargetConflict(_))
363    }
364    /// Returns `true` if the error kind is `CreateMountTargetError::NetworkInterfaceLimitExceeded`.
365    pub fn is_network_interface_limit_exceeded(&self) -> bool {
366        matches!(self, Self::NetworkInterfaceLimitExceeded(_))
367    }
368    /// Returns `true` if the error kind is `CreateMountTargetError::NoFreeAddressesInSubnet`.
369    pub fn is_no_free_addresses_in_subnet(&self) -> bool {
370        matches!(self, Self::NoFreeAddressesInSubnet(_))
371    }
372    /// Returns `true` if the error kind is `CreateMountTargetError::SecurityGroupLimitExceeded`.
373    pub fn is_security_group_limit_exceeded(&self) -> bool {
374        matches!(self, Self::SecurityGroupLimitExceeded(_))
375    }
376    /// Returns `true` if the error kind is `CreateMountTargetError::SecurityGroupNotFound`.
377    pub fn is_security_group_not_found(&self) -> bool {
378        matches!(self, Self::SecurityGroupNotFound(_))
379    }
380    /// Returns `true` if the error kind is `CreateMountTargetError::SubnetNotFound`.
381    pub fn is_subnet_not_found(&self) -> bool {
382        matches!(self, Self::SubnetNotFound(_))
383    }
384    /// Returns `true` if the error kind is `CreateMountTargetError::UnsupportedAvailabilityZone`.
385    pub fn is_unsupported_availability_zone(&self) -> bool {
386        matches!(self, Self::UnsupportedAvailabilityZone(_))
387    }
388}
389impl ::std::error::Error for CreateMountTargetError {
390    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
391        match self {
392            Self::AvailabilityZonesMismatch(_inner) => ::std::option::Option::Some(_inner),
393            Self::BadRequest(_inner) => ::std::option::Option::Some(_inner),
394            Self::FileSystemNotFound(_inner) => ::std::option::Option::Some(_inner),
395            Self::IncorrectFileSystemLifeCycleState(_inner) => ::std::option::Option::Some(_inner),
396            Self::InternalServerError(_inner) => ::std::option::Option::Some(_inner),
397            Self::IpAddressInUse(_inner) => ::std::option::Option::Some(_inner),
398            Self::MountTargetConflict(_inner) => ::std::option::Option::Some(_inner),
399            Self::NetworkInterfaceLimitExceeded(_inner) => ::std::option::Option::Some(_inner),
400            Self::NoFreeAddressesInSubnet(_inner) => ::std::option::Option::Some(_inner),
401            Self::SecurityGroupLimitExceeded(_inner) => ::std::option::Option::Some(_inner),
402            Self::SecurityGroupNotFound(_inner) => ::std::option::Option::Some(_inner),
403            Self::SubnetNotFound(_inner) => ::std::option::Option::Some(_inner),
404            Self::UnsupportedAvailabilityZone(_inner) => ::std::option::Option::Some(_inner),
405            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
406        }
407    }
408}
409impl ::std::fmt::Display for CreateMountTargetError {
410    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
411        match self {
412            Self::AvailabilityZonesMismatch(_inner) => _inner.fmt(f),
413            Self::BadRequest(_inner) => _inner.fmt(f),
414            Self::FileSystemNotFound(_inner) => _inner.fmt(f),
415            Self::IncorrectFileSystemLifeCycleState(_inner) => _inner.fmt(f),
416            Self::InternalServerError(_inner) => _inner.fmt(f),
417            Self::IpAddressInUse(_inner) => _inner.fmt(f),
418            Self::MountTargetConflict(_inner) => _inner.fmt(f),
419            Self::NetworkInterfaceLimitExceeded(_inner) => _inner.fmt(f),
420            Self::NoFreeAddressesInSubnet(_inner) => _inner.fmt(f),
421            Self::SecurityGroupLimitExceeded(_inner) => _inner.fmt(f),
422            Self::SecurityGroupNotFound(_inner) => _inner.fmt(f),
423            Self::SubnetNotFound(_inner) => _inner.fmt(f),
424            Self::UnsupportedAvailabilityZone(_inner) => _inner.fmt(f),
425            Self::Unhandled(_inner) => {
426                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
427                    write!(f, "unhandled error ({code})")
428                } else {
429                    f.write_str("unhandled error")
430                }
431            }
432        }
433    }
434}
435impl ::aws_smithy_types::retry::ProvideErrorKind for CreateMountTargetError {
436    fn code(&self) -> ::std::option::Option<&str> {
437        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
438    }
439    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
440        ::std::option::Option::None
441    }
442}
443impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for CreateMountTargetError {
444    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
445        match self {
446            Self::AvailabilityZonesMismatch(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
447            Self::BadRequest(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
448            Self::FileSystemNotFound(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
449            Self::IncorrectFileSystemLifeCycleState(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
450            Self::InternalServerError(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
451            Self::IpAddressInUse(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
452            Self::MountTargetConflict(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
453            Self::NetworkInterfaceLimitExceeded(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
454            Self::NoFreeAddressesInSubnet(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
455            Self::SecurityGroupLimitExceeded(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
456            Self::SecurityGroupNotFound(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
457            Self::SubnetNotFound(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
458            Self::UnsupportedAvailabilityZone(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
459            Self::Unhandled(_inner) => &_inner.meta,
460        }
461    }
462}
463impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for CreateMountTargetError {
464    fn create_unhandled_error(
465        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
466        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
467    ) -> Self {
468        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
469            source,
470            meta: meta.unwrap_or_default(),
471        })
472    }
473}
474impl ::aws_types::request_id::RequestId for crate::operation::create_mount_target::CreateMountTargetError {
475    fn request_id(&self) -> Option<&str> {
476        self.meta().request_id()
477    }
478}
479
480pub use crate::operation::create_mount_target::_create_mount_target_input::CreateMountTargetInput;
481
482pub use crate::operation::create_mount_target::_create_mount_target_output::CreateMountTargetOutput;
483
484mod _create_mount_target_input;
485
486mod _create_mount_target_output;
487
488/// Builders
489pub mod builders;