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
80        if let ::std::option::Option::Some(config_override) = config_override {
81            for plugin in config_override.runtime_plugins.iter().cloned() {
82                runtime_plugins = runtime_plugins.with_operation_plugin(plugin);
83            }
84            runtime_plugins = runtime_plugins.with_operation_plugin(crate::config::ConfigOverrideRuntimePlugin::new(
85                config_override,
86                client_config.config.clone(),
87                &client_config.runtime_components,
88            ));
89        }
90        runtime_plugins
91    }
92}
93impl ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugin for CreateLoadBalancer {
94    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
95        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("CreateLoadBalancer");
96
97        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
98            CreateLoadBalancerRequestSerializer,
99        ));
100        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
101            CreateLoadBalancerResponseDeserializer,
102        ));
103
104        cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
105            crate::config::auth::Params::builder()
106                .operation_name("CreateLoadBalancer")
107                .build()
108                .expect("required fields set"),
109        ));
110
111        cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new(
112            "CreateLoadBalancer",
113            "Elastic Load Balancing",
114        ));
115        let mut signing_options = ::aws_runtime::auth::SigningOptions::default();
116        signing_options.double_uri_encode = true;
117        signing_options.content_sha256_header = false;
118        signing_options.normalize_uri_path = true;
119        signing_options.payload_override = None;
120
121        cfg.store_put(::aws_runtime::auth::SigV4OperationSigningConfig {
122            signing_options,
123            ..::std::default::Default::default()
124        });
125
126        ::std::option::Option::Some(cfg.freeze())
127    }
128
129    fn runtime_components(
130        &self,
131        _: &::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder,
132    ) -> ::std::borrow::Cow<'_, ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder> {
133        #[allow(unused_mut)]
134        let mut rcb = ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder::new("CreateLoadBalancer")
135            .with_interceptor(::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default())
136            .with_interceptor(CreateLoadBalancerEndpointParamsInterceptor)
137            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
138                crate::operation::create_load_balancer::CreateLoadBalancerError,
139            >::new())
140            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
141                crate::operation::create_load_balancer::CreateLoadBalancerError,
142            >::new())
143            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
144                crate::operation::create_load_balancer::CreateLoadBalancerError,
145            >::new());
146
147        ::std::borrow::Cow::Owned(rcb)
148    }
149}
150
151#[derive(Debug)]
152struct CreateLoadBalancerResponseDeserializer;
153impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CreateLoadBalancerResponseDeserializer {
154    fn deserialize_nonstreaming(
155        &self,
156        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
157    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
158        let (success, status) = (response.status().is_success(), response.status().as_u16());
159        let headers = response.headers();
160        let body = response.body().bytes().expect("body loaded");
161        #[allow(unused_mut)]
162        let mut force_error = false;
163        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
164        let parse_result = if !success && status != 200 || force_error {
165            crate::protocol_serde::shape_create_load_balancer::de_create_load_balancer_http_error(status, headers, body)
166        } else {
167            crate::protocol_serde::shape_create_load_balancer::de_create_load_balancer_http_response(status, headers, body)
168        };
169        crate::protocol_serde::type_erase_result(parse_result)
170    }
171}
172#[derive(Debug)]
173struct CreateLoadBalancerRequestSerializer;
174impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for CreateLoadBalancerRequestSerializer {
175    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
176    fn serialize_input(
177        &self,
178        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
179        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
180    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
181        let input = input
182            .downcast::<crate::operation::create_load_balancer::CreateLoadBalancerInput>()
183            .expect("correct type");
184        let _header_serialization_settings = _cfg
185            .load::<crate::serialization_settings::HeaderSerializationSettings>()
186            .cloned()
187            .unwrap_or_default();
188        let mut request_builder = {
189            #[allow(clippy::uninlined_format_args)]
190            fn uri_base(
191                _input: &crate::operation::create_load_balancer::CreateLoadBalancerInput,
192                output: &mut ::std::string::String,
193            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
194                use ::std::fmt::Write as _;
195                ::std::write!(output, "/").expect("formatting should succeed");
196                ::std::result::Result::Ok(())
197            }
198            #[allow(clippy::unnecessary_wraps)]
199            fn update_http_builder(
200                input: &crate::operation::create_load_balancer::CreateLoadBalancerInput,
201                builder: ::http::request::Builder,
202            ) -> ::std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
203                let mut uri = ::std::string::String::new();
204                uri_base(input, &mut uri)?;
205                ::std::result::Result::Ok(builder.method("POST").uri(uri))
206            }
207            let mut builder = update_http_builder(&input, ::http::request::Builder::new())?;
208            builder = _header_serialization_settings.set_default_header(builder, ::http::header::CONTENT_TYPE, "application/x-www-form-urlencoded");
209            builder
210        };
211        let body = ::aws_smithy_types::body::SdkBody::from(
212            crate::protocol_serde::shape_create_load_balancer_input::ser_create_load_balancer_input_input_input(&input)?,
213        );
214        if let Some(content_length) = body.content_length() {
215            let content_length = content_length.to_string();
216            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http::header::CONTENT_LENGTH, &content_length);
217        }
218        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
219    }
220}
221#[derive(Debug)]
222struct CreateLoadBalancerEndpointParamsInterceptor;
223
224impl ::aws_smithy_runtime_api::client::interceptors::Intercept for CreateLoadBalancerEndpointParamsInterceptor {
225    fn name(&self) -> &'static str {
226        "CreateLoadBalancerEndpointParamsInterceptor"
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::<CreateLoadBalancerInput>()
242            .ok_or("failed to downcast to CreateLoadBalancerInput")?;
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 `CreateLoadBalancerError` operation.
263#[non_exhaustive]
264#[derive(::std::fmt::Debug)]
265pub enum CreateLoadBalancerError {
266    /// <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>
267    CertificateNotFoundException(crate::types::error::CertificateNotFoundException),
268    /// <p>The specified load balancer name already exists for this account.</p>
269    DuplicateAccessPointNameException(crate::types::error::DuplicateAccessPointNameException),
270    /// <p>A tag key was specified more than once.</p>
271    DuplicateTagKeysException(crate::types::error::DuplicateTagKeysException),
272    /// <p>The requested configuration change is not valid.</p>
273    InvalidConfigurationRequestException(crate::types::error::InvalidConfigurationRequestException),
274    /// <p>The specified value for the schema is not valid. You can only specify a scheme for load balancers in a VPC.</p>
275    InvalidSchemeException(crate::types::error::InvalidSchemeException),
276    /// <p>One or more of the specified security groups do not exist.</p>
277    InvalidSecurityGroupException(crate::types::error::InvalidSecurityGroupException),
278    /// <p>The specified VPC has no associated Internet gateway.</p>
279    InvalidSubnetException(crate::types::error::InvalidSubnetException),
280    /// <p>This operation is not allowed.</p>
281    OperationNotPermittedException(crate::types::error::OperationNotPermittedException),
282    /// <p>One or more of the specified subnets do not exist.</p>
283    SubnetNotFoundException(crate::types::error::SubnetNotFoundException),
284    /// <p>The quota for the number of load balancers has been reached.</p>
285    TooManyAccessPointsException(crate::types::error::TooManyAccessPointsException),
286    /// <p>The quota for the number of tags that can be assigned to a load balancer has been reached.</p>
287    TooManyTagsException(crate::types::error::TooManyTagsException),
288    /// <p>The specified protocol or signature version is not supported.</p>
289    UnsupportedProtocolException(crate::types::error::UnsupportedProtocolException),
290    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
291    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
292    variable wildcard pattern and check `.code()`:
293     \
294    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
295     \
296    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-CreateLoadBalancerError) for what information is available for the error.")]
297    Unhandled(crate::error::sealed_unhandled::Unhandled),
298}
299impl CreateLoadBalancerError {
300    /// Creates the `CreateLoadBalancerError::Unhandled` variant from any error type.
301    pub fn unhandled(
302        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
303    ) -> Self {
304        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
305            source: err.into(),
306            meta: ::std::default::Default::default(),
307        })
308    }
309
310    /// Creates the `CreateLoadBalancerError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
311    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
312        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
313            source: err.clone().into(),
314            meta: err,
315        })
316    }
317    ///
318    /// Returns error metadata, which includes the error code, message,
319    /// request ID, and potentially additional information.
320    ///
321    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
322        match self {
323            Self::CertificateNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
324            Self::DuplicateAccessPointNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
325            Self::DuplicateTagKeysException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
326            Self::InvalidConfigurationRequestException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
327            Self::InvalidSchemeException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
328            Self::InvalidSecurityGroupException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
329            Self::InvalidSubnetException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
330            Self::OperationNotPermittedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
331            Self::SubnetNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
332            Self::TooManyAccessPointsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
333            Self::TooManyTagsException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
334            Self::UnsupportedProtocolException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
335            Self::Unhandled(e) => &e.meta,
336        }
337    }
338    /// Returns `true` if the error kind is `CreateLoadBalancerError::CertificateNotFoundException`.
339    pub fn is_certificate_not_found_exception(&self) -> bool {
340        matches!(self, Self::CertificateNotFoundException(_))
341    }
342    /// Returns `true` if the error kind is `CreateLoadBalancerError::DuplicateAccessPointNameException`.
343    pub fn is_duplicate_access_point_name_exception(&self) -> bool {
344        matches!(self, Self::DuplicateAccessPointNameException(_))
345    }
346    /// Returns `true` if the error kind is `CreateLoadBalancerError::DuplicateTagKeysException`.
347    pub fn is_duplicate_tag_keys_exception(&self) -> bool {
348        matches!(self, Self::DuplicateTagKeysException(_))
349    }
350    /// Returns `true` if the error kind is `CreateLoadBalancerError::InvalidConfigurationRequestException`.
351    pub fn is_invalid_configuration_request_exception(&self) -> bool {
352        matches!(self, Self::InvalidConfigurationRequestException(_))
353    }
354    /// Returns `true` if the error kind is `CreateLoadBalancerError::InvalidSchemeException`.
355    pub fn is_invalid_scheme_exception(&self) -> bool {
356        matches!(self, Self::InvalidSchemeException(_))
357    }
358    /// Returns `true` if the error kind is `CreateLoadBalancerError::InvalidSecurityGroupException`.
359    pub fn is_invalid_security_group_exception(&self) -> bool {
360        matches!(self, Self::InvalidSecurityGroupException(_))
361    }
362    /// Returns `true` if the error kind is `CreateLoadBalancerError::InvalidSubnetException`.
363    pub fn is_invalid_subnet_exception(&self) -> bool {
364        matches!(self, Self::InvalidSubnetException(_))
365    }
366    /// Returns `true` if the error kind is `CreateLoadBalancerError::OperationNotPermittedException`.
367    pub fn is_operation_not_permitted_exception(&self) -> bool {
368        matches!(self, Self::OperationNotPermittedException(_))
369    }
370    /// Returns `true` if the error kind is `CreateLoadBalancerError::SubnetNotFoundException`.
371    pub fn is_subnet_not_found_exception(&self) -> bool {
372        matches!(self, Self::SubnetNotFoundException(_))
373    }
374    /// Returns `true` if the error kind is `CreateLoadBalancerError::TooManyAccessPointsException`.
375    pub fn is_too_many_access_points_exception(&self) -> bool {
376        matches!(self, Self::TooManyAccessPointsException(_))
377    }
378    /// Returns `true` if the error kind is `CreateLoadBalancerError::TooManyTagsException`.
379    pub fn is_too_many_tags_exception(&self) -> bool {
380        matches!(self, Self::TooManyTagsException(_))
381    }
382    /// Returns `true` if the error kind is `CreateLoadBalancerError::UnsupportedProtocolException`.
383    pub fn is_unsupported_protocol_exception(&self) -> bool {
384        matches!(self, Self::UnsupportedProtocolException(_))
385    }
386}
387impl ::std::error::Error for CreateLoadBalancerError {
388    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
389        match self {
390            Self::CertificateNotFoundException(_inner) => ::std::option::Option::Some(_inner),
391            Self::DuplicateAccessPointNameException(_inner) => ::std::option::Option::Some(_inner),
392            Self::DuplicateTagKeysException(_inner) => ::std::option::Option::Some(_inner),
393            Self::InvalidConfigurationRequestException(_inner) => ::std::option::Option::Some(_inner),
394            Self::InvalidSchemeException(_inner) => ::std::option::Option::Some(_inner),
395            Self::InvalidSecurityGroupException(_inner) => ::std::option::Option::Some(_inner),
396            Self::InvalidSubnetException(_inner) => ::std::option::Option::Some(_inner),
397            Self::OperationNotPermittedException(_inner) => ::std::option::Option::Some(_inner),
398            Self::SubnetNotFoundException(_inner) => ::std::option::Option::Some(_inner),
399            Self::TooManyAccessPointsException(_inner) => ::std::option::Option::Some(_inner),
400            Self::TooManyTagsException(_inner) => ::std::option::Option::Some(_inner),
401            Self::UnsupportedProtocolException(_inner) => ::std::option::Option::Some(_inner),
402            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
403        }
404    }
405}
406impl ::std::fmt::Display for CreateLoadBalancerError {
407    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
408        match self {
409            Self::CertificateNotFoundException(_inner) => _inner.fmt(f),
410            Self::DuplicateAccessPointNameException(_inner) => _inner.fmt(f),
411            Self::DuplicateTagKeysException(_inner) => _inner.fmt(f),
412            Self::InvalidConfigurationRequestException(_inner) => _inner.fmt(f),
413            Self::InvalidSchemeException(_inner) => _inner.fmt(f),
414            Self::InvalidSecurityGroupException(_inner) => _inner.fmt(f),
415            Self::InvalidSubnetException(_inner) => _inner.fmt(f),
416            Self::OperationNotPermittedException(_inner) => _inner.fmt(f),
417            Self::SubnetNotFoundException(_inner) => _inner.fmt(f),
418            Self::TooManyAccessPointsException(_inner) => _inner.fmt(f),
419            Self::TooManyTagsException(_inner) => _inner.fmt(f),
420            Self::UnsupportedProtocolException(_inner) => _inner.fmt(f),
421            Self::Unhandled(_inner) => {
422                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
423                    write!(f, "unhandled error ({code})")
424                } else {
425                    f.write_str("unhandled error")
426                }
427            }
428        }
429    }
430}
431impl ::aws_smithy_types::retry::ProvideErrorKind for CreateLoadBalancerError {
432    fn code(&self) -> ::std::option::Option<&str> {
433        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
434    }
435    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
436        ::std::option::Option::None
437    }
438}
439impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for CreateLoadBalancerError {
440    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
441        match self {
442            Self::CertificateNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
443            Self::DuplicateAccessPointNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
444            Self::DuplicateTagKeysException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
445            Self::InvalidConfigurationRequestException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
446            Self::InvalidSchemeException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
447            Self::InvalidSecurityGroupException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
448            Self::InvalidSubnetException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
449            Self::OperationNotPermittedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
450            Self::SubnetNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
451            Self::TooManyAccessPointsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
452            Self::TooManyTagsException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
453            Self::UnsupportedProtocolException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
454            Self::Unhandled(_inner) => &_inner.meta,
455        }
456    }
457}
458impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for CreateLoadBalancerError {
459    fn create_unhandled_error(
460        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
461        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
462    ) -> Self {
463        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
464            source,
465            meta: meta.unwrap_or_default(),
466        })
467    }
468}
469impl ::aws_types::request_id::RequestId for crate::operation::create_load_balancer::CreateLoadBalancerError {
470    fn request_id(&self) -> Option<&str> {
471        self.meta().request_id()
472    }
473}
474
475pub use crate::operation::create_load_balancer::_create_load_balancer_output::CreateLoadBalancerOutput;
476
477pub use crate::operation::create_load_balancer::_create_load_balancer_input::CreateLoadBalancerInput;
478
479mod _create_load_balancer_input;
480
481mod _create_load_balancer_output;
482
483/// Builders
484pub mod builders;