aws_sdk_elasticloadbalancing/operation/
create_load_balancer.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Orchestration and serialization glue logic for `CreateLoadBalancer`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct CreateLoadBalancer;
6impl CreateLoadBalancer {
7    /// Creates a new `CreateLoadBalancer`
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_load_balancer::CreateLoadBalancerInput,
14    ) -> ::std::result::Result<
15        crate::operation::create_load_balancer::CreateLoadBalancerOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::create_load_balancer::CreateLoadBalancerError,
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_load_balancer::CreateLoadBalancerError>()
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_load_balancer::CreateLoadBalancerOutput>()
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_load_balancer::CreateLoadBalancerInput,
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(
55            "Elastic Load Balancing",
56            "CreateLoadBalancer",
57            input,
58            runtime_plugins,
59            stop_point,
60        )
61        // Create a parent span for the entire operation. Includes a random, internal-only,
62        // seven-digit ID for the operation orchestration so that it can be correlated in the logs.
63        .instrument(::tracing::debug_span!(
64            "Elastic Load Balancing.CreateLoadBalancer",
65            "rpc.service" = "Elastic Load Balancing",
66            "rpc.method" = "CreateLoadBalancer",
67            "sdk_invocation_id" = ::fastrand::u32(1_000_000..10_000_000),
68            "rpc.system" = "aws-api",
69        ))
70        .await
71    }
72
73    pub(crate) fn operation_runtime_plugins(
74        client_runtime_plugins: ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
75        client_config: &crate::config::Config,
76        config_override: ::std::option::Option<crate::config::Builder>,
77    ) -> ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins {
78        let mut runtime_plugins = client_runtime_plugins.with_operation_plugin(Self::new());
79        runtime_plugins = runtime_plugins.with_client_plugin(crate::auth_plugin::DefaultAuthOptionsPlugin::new(vec![
80            ::aws_runtime::auth::sigv4::SCHEME_ID,
81        ]));
82        if let ::std::option::Option::Some(config_override) = config_override {
83            for plugin in config_override.runtime_plugins.iter().cloned() {
84                runtime_plugins = runtime_plugins.with_operation_plugin(plugin);
85            }
86            runtime_plugins = runtime_plugins.with_operation_plugin(crate::config::ConfigOverrideRuntimePlugin::new(
87                config_override,
88                client_config.config.clone(),
89                &client_config.runtime_components,
90            ));
91        }
92        runtime_plugins
93    }
94}
95impl ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugin for CreateLoadBalancer {
96    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
97        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("CreateLoadBalancer");
98
99        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
100            CreateLoadBalancerRequestSerializer,
101        ));
102        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
103            CreateLoadBalancerResponseDeserializer,
104        ));
105
106        cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
107            ::aws_smithy_runtime_api::client::auth::static_resolver::StaticAuthSchemeOptionResolverParams::new(),
108        ));
109
110        cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new(
111            "CreateLoadBalancer",
112            "Elastic Load Balancing",
113        ));
114        let mut signing_options = ::aws_runtime::auth::SigningOptions::default();
115        signing_options.double_uri_encode = true;
116        signing_options.content_sha256_header = false;
117        signing_options.normalize_uri_path = true;
118        signing_options.payload_override = None;
119
120        cfg.store_put(::aws_runtime::auth::SigV4OperationSigningConfig {
121            signing_options,
122            ..::std::default::Default::default()
123        });
124
125        ::std::option::Option::Some(cfg.freeze())
126    }
127
128    fn runtime_components(
129        &self,
130        _: &::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder,
131    ) -> ::std::borrow::Cow<'_, ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder> {
132        #[allow(unused_mut)]
133        let mut rcb = ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder::new("CreateLoadBalancer")
134            .with_interceptor(::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default())
135            .with_interceptor(CreateLoadBalancerEndpointParamsInterceptor)
136            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
137                crate::operation::create_load_balancer::CreateLoadBalancerError,
138            >::new())
139            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
140                crate::operation::create_load_balancer::CreateLoadBalancerError,
141            >::new())
142            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
143                crate::operation::create_load_balancer::CreateLoadBalancerError,
144            >::new());
145
146        ::std::borrow::Cow::Owned(rcb)
147    }
148}
149
150#[derive(Debug)]
151struct CreateLoadBalancerResponseDeserializer;
152impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CreateLoadBalancerResponseDeserializer {
153    fn deserialize_nonstreaming(
154        &self,
155        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
156    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
157        let (success, status) = (response.status().is_success(), response.status().as_u16());
158        let headers = response.headers();
159        let body = response.body().bytes().expect("body loaded");
160        #[allow(unused_mut)]
161        let mut force_error = false;
162        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
163        let parse_result = if !success && status != 200 || force_error {
164            crate::protocol_serde::shape_create_load_balancer::de_create_load_balancer_http_error(status, headers, body)
165        } else {
166            crate::protocol_serde::shape_create_load_balancer::de_create_load_balancer_http_response(status, headers, body)
167        };
168        crate::protocol_serde::type_erase_result(parse_result)
169    }
170}
171#[derive(Debug)]
172struct CreateLoadBalancerRequestSerializer;
173impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for CreateLoadBalancerRequestSerializer {
174    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
175    fn serialize_input(
176        &self,
177        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
178        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
179    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
180        let input = input
181            .downcast::<crate::operation::create_load_balancer::CreateLoadBalancerInput>()
182            .expect("correct type");
183        let _header_serialization_settings = _cfg
184            .load::<crate::serialization_settings::HeaderSerializationSettings>()
185            .cloned()
186            .unwrap_or_default();
187        let mut request_builder = {
188            fn uri_base(
189                _input: &crate::operation::create_load_balancer::CreateLoadBalancerInput,
190                output: &mut ::std::string::String,
191            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
192                use ::std::fmt::Write as _;
193                ::std::write!(output, "/").expect("formatting should succeed");
194                ::std::result::Result::Ok(())
195            }
196            #[allow(clippy::unnecessary_wraps)]
197            fn update_http_builder(
198                input: &crate::operation::create_load_balancer::CreateLoadBalancerInput,
199                builder: ::http::request::Builder,
200            ) -> ::std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
201                let mut uri = ::std::string::String::new();
202                uri_base(input, &mut uri)?;
203                ::std::result::Result::Ok(builder.method("POST").uri(uri))
204            }
205            let mut builder = update_http_builder(&input, ::http::request::Builder::new())?;
206            builder = _header_serialization_settings.set_default_header(builder, ::http::header::CONTENT_TYPE, "application/x-www-form-urlencoded");
207            builder
208        };
209        let body = ::aws_smithy_types::body::SdkBody::from(
210            crate::protocol_serde::shape_create_load_balancer_input::ser_create_load_balancer_input_input_input(&input)?,
211        );
212        if let Some(content_length) = body.content_length() {
213            let content_length = content_length.to_string();
214            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http::header::CONTENT_LENGTH, &content_length);
215        }
216        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
217    }
218}
219#[derive(Debug)]
220struct CreateLoadBalancerEndpointParamsInterceptor;
221
222impl ::aws_smithy_runtime_api::client::interceptors::Intercept for CreateLoadBalancerEndpointParamsInterceptor {
223    fn name(&self) -> &'static str {
224        "CreateLoadBalancerEndpointParamsInterceptor"
225    }
226
227    fn read_before_execution(
228        &self,
229        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
230            '_,
231            ::aws_smithy_runtime_api::client::interceptors::context::Input,
232            ::aws_smithy_runtime_api::client::interceptors::context::Output,
233            ::aws_smithy_runtime_api::client::interceptors::context::Error,
234        >,
235        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
236    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
237        let _input = context
238            .input()
239            .downcast_ref::<CreateLoadBalancerInput>()
240            .ok_or("failed to downcast to CreateLoadBalancerInput")?;
241
242        let params = crate::config::endpoint::Params::builder()
243            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
244            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
245            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
246            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
247            .build()
248            .map_err(|err| {
249                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
250            })?;
251        cfg.interceptor_state()
252            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
253        ::std::result::Result::Ok(())
254    }
255}
256
257// The get_* functions below are generated from JMESPath expressions in the
258// operationContextParams trait. They target the operation's input shape.
259
260/// Error type for the `CreateLoadBalancerError` operation.
261#[non_exhaustive]
262#[derive(::std::fmt::Debug)]
263pub enum CreateLoadBalancerError {
264    /// <p>The specified ARN does not refer to a valid SSL certificate in AWS Identity and Access Management (IAM) or AWS Certificate Manager (ACM). Note that if you recently uploaded the certificate to IAM, this error might indicate that the certificate is not fully available yet.</p>
265    CertificateNotFoundException(crate::types::error::CertificateNotFoundException),
266    /// <p>The specified load balancer name already exists for this account.</p>
267    DuplicateAccessPointNameException(crate::types::error::DuplicateAccessPointNameException),
268    /// <p>A tag key was specified more than once.</p>
269    DuplicateTagKeysException(crate::types::error::DuplicateTagKeysException),
270    /// <p>The requested configuration change is not valid.</p>
271    InvalidConfigurationRequestException(crate::types::error::InvalidConfigurationRequestException),
272    /// <p>The specified value for the schema is not valid. You can only specify a scheme for load balancers in a VPC.</p>
273    InvalidSchemeException(crate::types::error::InvalidSchemeException),
274    /// <p>One or more of the specified security groups do not exist.</p>
275    InvalidSecurityGroupException(crate::types::error::InvalidSecurityGroupException),
276    /// <p>The specified VPC has no associated Internet gateway.</p>
277    InvalidSubnetException(crate::types::error::InvalidSubnetException),
278    /// <p>This operation is not allowed.</p>
279    OperationNotPermittedException(crate::types::error::OperationNotPermittedException),
280    /// <p>One or more of the specified subnets do not exist.</p>
281    SubnetNotFoundException(crate::types::error::SubnetNotFoundException),
282    /// <p>The quota for the number of load balancers has been reached.</p>
283    TooManyAccessPointsException(crate::types::error::TooManyAccessPointsException),
284    /// <p>The quota for the number of tags that can be assigned to a load balancer has been reached.</p>
285    TooManyTagsException(crate::types::error::TooManyTagsException),
286    /// <p>The specified protocol or signature version is not supported.</p>
287    UnsupportedProtocolException(crate::types::error::UnsupportedProtocolException),
288    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
289    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
290    variable wildcard pattern and check `.code()`:
291     \
292    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
293     \
294    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-CreateLoadBalancerError) for what information is available for the error.")]
295    Unhandled(crate::error::sealed_unhandled::Unhandled),
296}
297impl CreateLoadBalancerError {
298    /// Creates the `CreateLoadBalancerError::Unhandled` variant from any error type.
299    pub fn unhandled(
300        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
301    ) -> Self {
302        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
303            source: err.into(),
304            meta: ::std::default::Default::default(),
305        })
306    }
307
308    /// Creates the `CreateLoadBalancerError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
309    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
310        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
311            source: err.clone().into(),
312            meta: err,
313        })
314    }
315    ///
316    /// Returns error metadata, which includes the error code, message,
317    /// request ID, and potentially additional information.
318    ///
319    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
320        match self {
321            Self::CertificateNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
322            Self::DuplicateAccessPointNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
323            Self::DuplicateTagKeysException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
324            Self::InvalidConfigurationRequestException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
325            Self::InvalidSchemeException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
326            Self::InvalidSecurityGroupException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
327            Self::InvalidSubnetException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
328            Self::OperationNotPermittedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
329            Self::SubnetNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
330            Self::TooManyAccessPointsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
331            Self::TooManyTagsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
332            Self::UnsupportedProtocolException(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 `CreateLoadBalancerError::CertificateNotFoundException`.
337    pub fn is_certificate_not_found_exception(&self) -> bool {
338        matches!(self, Self::CertificateNotFoundException(_))
339    }
340    /// Returns `true` if the error kind is `CreateLoadBalancerError::DuplicateAccessPointNameException`.
341    pub fn is_duplicate_access_point_name_exception(&self) -> bool {
342        matches!(self, Self::DuplicateAccessPointNameException(_))
343    }
344    /// Returns `true` if the error kind is `CreateLoadBalancerError::DuplicateTagKeysException`.
345    pub fn is_duplicate_tag_keys_exception(&self) -> bool {
346        matches!(self, Self::DuplicateTagKeysException(_))
347    }
348    /// Returns `true` if the error kind is `CreateLoadBalancerError::InvalidConfigurationRequestException`.
349    pub fn is_invalid_configuration_request_exception(&self) -> bool {
350        matches!(self, Self::InvalidConfigurationRequestException(_))
351    }
352    /// Returns `true` if the error kind is `CreateLoadBalancerError::InvalidSchemeException`.
353    pub fn is_invalid_scheme_exception(&self) -> bool {
354        matches!(self, Self::InvalidSchemeException(_))
355    }
356    /// Returns `true` if the error kind is `CreateLoadBalancerError::InvalidSecurityGroupException`.
357    pub fn is_invalid_security_group_exception(&self) -> bool {
358        matches!(self, Self::InvalidSecurityGroupException(_))
359    }
360    /// Returns `true` if the error kind is `CreateLoadBalancerError::InvalidSubnetException`.
361    pub fn is_invalid_subnet_exception(&self) -> bool {
362        matches!(self, Self::InvalidSubnetException(_))
363    }
364    /// Returns `true` if the error kind is `CreateLoadBalancerError::OperationNotPermittedException`.
365    pub fn is_operation_not_permitted_exception(&self) -> bool {
366        matches!(self, Self::OperationNotPermittedException(_))
367    }
368    /// Returns `true` if the error kind is `CreateLoadBalancerError::SubnetNotFoundException`.
369    pub fn is_subnet_not_found_exception(&self) -> bool {
370        matches!(self, Self::SubnetNotFoundException(_))
371    }
372    /// Returns `true` if the error kind is `CreateLoadBalancerError::TooManyAccessPointsException`.
373    pub fn is_too_many_access_points_exception(&self) -> bool {
374        matches!(self, Self::TooManyAccessPointsException(_))
375    }
376    /// Returns `true` if the error kind is `CreateLoadBalancerError::TooManyTagsException`.
377    pub fn is_too_many_tags_exception(&self) -> bool {
378        matches!(self, Self::TooManyTagsException(_))
379    }
380    /// Returns `true` if the error kind is `CreateLoadBalancerError::UnsupportedProtocolException`.
381    pub fn is_unsupported_protocol_exception(&self) -> bool {
382        matches!(self, Self::UnsupportedProtocolException(_))
383    }
384}
385impl ::std::error::Error for CreateLoadBalancerError {
386    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
387        match self {
388            Self::CertificateNotFoundException(_inner) => ::std::option::Option::Some(_inner),
389            Self::DuplicateAccessPointNameException(_inner) => ::std::option::Option::Some(_inner),
390            Self::DuplicateTagKeysException(_inner) => ::std::option::Option::Some(_inner),
391            Self::InvalidConfigurationRequestException(_inner) => ::std::option::Option::Some(_inner),
392            Self::InvalidSchemeException(_inner) => ::std::option::Option::Some(_inner),
393            Self::InvalidSecurityGroupException(_inner) => ::std::option::Option::Some(_inner),
394            Self::InvalidSubnetException(_inner) => ::std::option::Option::Some(_inner),
395            Self::OperationNotPermittedException(_inner) => ::std::option::Option::Some(_inner),
396            Self::SubnetNotFoundException(_inner) => ::std::option::Option::Some(_inner),
397            Self::TooManyAccessPointsException(_inner) => ::std::option::Option::Some(_inner),
398            Self::TooManyTagsException(_inner) => ::std::option::Option::Some(_inner),
399            Self::UnsupportedProtocolException(_inner) => ::std::option::Option::Some(_inner),
400            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
401        }
402    }
403}
404impl ::std::fmt::Display for CreateLoadBalancerError {
405    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
406        match self {
407            Self::CertificateNotFoundException(_inner) => _inner.fmt(f),
408            Self::DuplicateAccessPointNameException(_inner) => _inner.fmt(f),
409            Self::DuplicateTagKeysException(_inner) => _inner.fmt(f),
410            Self::InvalidConfigurationRequestException(_inner) => _inner.fmt(f),
411            Self::InvalidSchemeException(_inner) => _inner.fmt(f),
412            Self::InvalidSecurityGroupException(_inner) => _inner.fmt(f),
413            Self::InvalidSubnetException(_inner) => _inner.fmt(f),
414            Self::OperationNotPermittedException(_inner) => _inner.fmt(f),
415            Self::SubnetNotFoundException(_inner) => _inner.fmt(f),
416            Self::TooManyAccessPointsException(_inner) => _inner.fmt(f),
417            Self::TooManyTagsException(_inner) => _inner.fmt(f),
418            Self::UnsupportedProtocolException(_inner) => _inner.fmt(f),
419            Self::Unhandled(_inner) => {
420                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
421                    write!(f, "unhandled error ({code})")
422                } else {
423                    f.write_str("unhandled error")
424                }
425            }
426        }
427    }
428}
429impl ::aws_smithy_types::retry::ProvideErrorKind for CreateLoadBalancerError {
430    fn code(&self) -> ::std::option::Option<&str> {
431        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
432    }
433    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
434        ::std::option::Option::None
435    }
436}
437impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for CreateLoadBalancerError {
438    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
439        match self {
440            Self::CertificateNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
441            Self::DuplicateAccessPointNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
442            Self::DuplicateTagKeysException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
443            Self::InvalidConfigurationRequestException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
444            Self::InvalidSchemeException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
445            Self::InvalidSecurityGroupException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
446            Self::InvalidSubnetException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
447            Self::OperationNotPermittedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
448            Self::SubnetNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
449            Self::TooManyAccessPointsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
450            Self::TooManyTagsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
451            Self::UnsupportedProtocolException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
452            Self::Unhandled(_inner) => &_inner.meta,
453        }
454    }
455}
456impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for CreateLoadBalancerError {
457    fn create_unhandled_error(
458        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
459        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
460    ) -> Self {
461        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
462            source,
463            meta: meta.unwrap_or_default(),
464        })
465    }
466}
467impl ::aws_types::request_id::RequestId for crate::operation::create_load_balancer::CreateLoadBalancerError {
468    fn request_id(&self) -> Option<&str> {
469        self.meta().request_id()
470    }
471}
472
473pub use crate::operation::create_load_balancer::_create_load_balancer_output::CreateLoadBalancerOutput;
474
475pub use crate::operation::create_load_balancer::_create_load_balancer_input::CreateLoadBalancerInput;
476
477mod _create_load_balancer_input;
478
479mod _create_load_balancer_output;
480
481/// Builders
482pub mod builders;