Skip to main content

aws_sdk_pcs/operation/
create_compute_node_group.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Orchestration and serialization glue logic for `CreateComputeNodeGroup`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct CreateComputeNodeGroup;
6impl CreateComputeNodeGroup {
7    /// Creates a new `CreateComputeNodeGroup`
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_compute_node_group::CreateComputeNodeGroupInput,
14    ) -> ::std::result::Result<
15        crate::operation::create_compute_node_group::CreateComputeNodeGroupOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::create_compute_node_group::CreateComputeNodeGroupError,
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_compute_node_group::CreateComputeNodeGroupError>()
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_compute_node_group::CreateComputeNodeGroupOutput>()
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_compute_node_group::CreateComputeNodeGroupInput,
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("PCS", "CreateComputeNodeGroup", 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                "PCS.CreateComputeNodeGroup",
59                "rpc.service" = "PCS",
60                "rpc.method" = "CreateComputeNodeGroup",
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        runtime_plugins = runtime_plugins.with_operation_plugin(crate::client_idempotency_token::IdempotencyTokenRuntimePlugin::new(
74            |token_provider, input| {
75                let input: &mut crate::operation::create_compute_node_group::CreateComputeNodeGroupInput =
76                    input.downcast_mut().expect("correct type");
77                if input.client_token.is_none() {
78                    input.client_token = ::std::option::Option::Some(token_provider.make_idempotency_token());
79                }
80            },
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 CreateComputeNodeGroup {
96    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
97        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("CreateComputeNodeGroup");
98
99        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
100            CreateComputeNodeGroupRequestSerializer,
101        ));
102        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
103            CreateComputeNodeGroupResponseDeserializer,
104        ));
105
106        cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
107            crate::config::auth::Params::builder()
108                .operation_name("CreateComputeNodeGroup")
109                .build()
110                .expect("required fields set"),
111        ));
112
113        cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new(
114            "CreateComputeNodeGroup",
115            "PCS",
116        ));
117        let mut signing_options = ::aws_runtime::auth::SigningOptions::default();
118        signing_options.double_uri_encode = true;
119        signing_options.content_sha256_header = false;
120        signing_options.normalize_uri_path = true;
121        signing_options.payload_override = None;
122
123        cfg.store_put(::aws_runtime::auth::SigV4OperationSigningConfig {
124            signing_options,
125            ..::std::default::Default::default()
126        });
127
128        ::std::option::Option::Some(cfg.freeze())
129    }
130
131    fn runtime_components(
132        &self,
133        _: &::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder,
134    ) -> ::std::borrow::Cow<'_, ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder> {
135        #[allow(unused_mut)]
136        let mut rcb = ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder::new("CreateComputeNodeGroup")
137            .with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
138                ::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default(),
139            ))
140            .with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
141                CreateComputeNodeGroupEndpointParamsInterceptor,
142            ))
143            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
144                crate::operation::create_compute_node_group::CreateComputeNodeGroupError,
145            >::new())
146            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
147                crate::operation::create_compute_node_group::CreateComputeNodeGroupError,
148            >::new())
149            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
150                crate::operation::create_compute_node_group::CreateComputeNodeGroupError,
151            >::new());
152
153        ::std::borrow::Cow::Owned(rcb)
154    }
155}
156
157#[derive(Debug)]
158struct CreateComputeNodeGroupResponseDeserializer;
159impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CreateComputeNodeGroupResponseDeserializer {
160    fn deserialize_nonstreaming_with_config(
161        &self,
162        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
163        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
164    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
165        let (success, status) = (response.status().is_success(), response.status().as_u16());
166        let headers = response.headers();
167        let body = response.body().bytes().expect("body loaded");
168        #[allow(unused_mut)]
169        let mut force_error = false;
170        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
171        let parse_result = if !success && status != 200 || force_error {
172            crate::protocol_serde::shape_create_compute_node_group::de_create_compute_node_group_http_error(status, headers, body)
173        } else {
174            crate::protocol_serde::shape_create_compute_node_group::de_create_compute_node_group_http_response(status, headers, body)
175        };
176        crate::protocol_serde::type_erase_result(parse_result)
177    }
178}
179#[derive(Debug)]
180struct CreateComputeNodeGroupRequestSerializer;
181impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for CreateComputeNodeGroupRequestSerializer {
182    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
183    fn serialize_input(
184        &self,
185        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
186        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
187    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
188        let input = input
189            .downcast::<crate::operation::create_compute_node_group::CreateComputeNodeGroupInput>()
190            .expect("correct type");
191        let _header_serialization_settings = _cfg
192            .load::<crate::serialization_settings::HeaderSerializationSettings>()
193            .cloned()
194            .unwrap_or_default();
195        let mut request_builder = {
196            #[allow(clippy::uninlined_format_args)]
197            fn uri_base(
198                _input: &crate::operation::create_compute_node_group::CreateComputeNodeGroupInput,
199                output: &mut ::std::string::String,
200            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
201                use ::std::fmt::Write as _;
202                ::std::write!(output, "/").expect("formatting should succeed");
203                ::std::result::Result::Ok(())
204            }
205            #[allow(clippy::unnecessary_wraps)]
206            fn update_http_builder(
207                input: &crate::operation::create_compute_node_group::CreateComputeNodeGroupInput,
208                builder: ::http_1x::request::Builder,
209            ) -> ::std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
210                let mut uri = ::std::string::String::new();
211                uri_base(input, &mut uri)?;
212                ::std::result::Result::Ok(builder.method("POST").uri(uri))
213            }
214            let mut builder = update_http_builder(&input, ::http_1x::request::Builder::new())?;
215            builder = _header_serialization_settings.set_default_header(builder, ::http_1x::header::CONTENT_TYPE, "application/x-amz-json-1.0");
216            builder = _header_serialization_settings.set_default_header(
217                builder,
218                ::http_1x::header::HeaderName::from_static("x-amz-target"),
219                "AWSParallelComputingService.CreateComputeNodeGroup",
220            );
221            builder
222        };
223        let body = ::aws_smithy_types::body::SdkBody::from(
224            crate::protocol_serde::shape_create_compute_node_group::ser_create_compute_node_group_input(&input)?,
225        );
226        if let Some(content_length) = body.content_length() {
227            let content_length = content_length.to_string();
228            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http_1x::header::CONTENT_LENGTH, &content_length);
229        }
230        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
231    }
232}
233#[derive(Debug)]
234struct CreateComputeNodeGroupEndpointParamsInterceptor;
235
236#[::aws_smithy_runtime_api::client::interceptors::dyn_dispatch_hint]
237impl ::aws_smithy_runtime_api::client::interceptors::Intercept for CreateComputeNodeGroupEndpointParamsInterceptor {
238    fn name(&self) -> &'static str {
239        "CreateComputeNodeGroupEndpointParamsInterceptor"
240    }
241
242    fn read_before_execution(
243        &self,
244        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
245            '_,
246            ::aws_smithy_runtime_api::client::interceptors::context::Input,
247            ::aws_smithy_runtime_api::client::interceptors::context::Output,
248            ::aws_smithy_runtime_api::client::interceptors::context::Error,
249        >,
250        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
251    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
252        let _input = context
253            .input()
254            .downcast_ref::<CreateComputeNodeGroupInput>()
255            .ok_or("failed to downcast to CreateComputeNodeGroupInput")?;
256
257        let params = crate::config::endpoint::Params::builder()
258            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
259            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
260            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
261            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
262            .build()
263            .map_err(|err| {
264                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
265            })?;
266        cfg.interceptor_state()
267            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
268        ::std::result::Result::Ok(())
269    }
270}
271
272// The get_* functions below are generated from JMESPath expressions in the
273// operationContextParams trait. They target the operation's input shape.
274
275/// Error type for the `CreateComputeNodeGroupError` operation.
276#[non_exhaustive]
277#[derive(::std::fmt::Debug)]
278pub enum CreateComputeNodeGroupError {
279    /// <p>You don't have permission to perform the action.</p>
280    /// <p><u>Examples</u></p>
281    /// <ul>
282    /// <li>
283    /// <p>The launch template instance profile doesn't pass <code>iam:PassRole</code> verification.</p></li>
284    /// <li>
285    /// <p>There is a mismatch between the account ID and cluster ID.</p></li>
286    /// <li>
287    /// <p>The cluster ID doesn't exist.</p></li>
288    /// <li>
289    /// <p>The EC2 instance isn't present.</p></li>
290    /// </ul>
291    AccessDeniedException(crate::types::error::AccessDeniedException),
292    /// <p>Your request has conflicting operations. This can occur if you're trying to perform more than 1 operation on the same resource at the same time.</p>
293    /// <p><u>Examples</u></p>
294    /// <ul>
295    /// <li>
296    /// <p>A cluster with the same name already exists.</p></li>
297    /// <li>
298    /// <p>A cluster isn't in <code>ACTIVE</code> status.</p></li>
299    /// <li>
300    /// <p>A cluster to delete is in an unstable state. For example, because it still has <code>ACTIVE</code> node groups or queues.</p></li>
301    /// <li>
302    /// <p>A queue already exists in a cluster.</p></li>
303    /// </ul>
304    ConflictException(crate::types::error::ConflictException),
305    /// <p>PCS can't process your request right now. Try again later.</p>
306    InternalServerException(crate::types::error::InternalServerException),
307    /// <p>The requested resource can't be found. The cluster, node group, or queue you're attempting to get, update, list, or delete doesn't exist.</p>
308    /// <p><u>Examples</u></p>
309    ResourceNotFoundException(crate::types::error::ResourceNotFoundException),
310    /// <p>You exceeded your service quota. Service quotas, also referred to as limits, are the maximum number of service resources or operations for your Amazon Web Services account. To learn how to increase your service quota, see <a href="https://docs.aws.amazon.com/servicequotas/latest/userguide/request-quota-increase.html">Requesting a quota increase</a> in the <i>Service Quotas User Guide</i></p>
311    /// <p><u>Examples</u></p>
312    /// <ul>
313    /// <li>
314    /// <p>The max number of clusters or queues has been reached for the account.</p></li>
315    /// <li>
316    /// <p>The max number of compute node groups has been reached for the associated cluster.</p></li>
317    /// <li>
318    /// <p>The total of <code>maxInstances</code> across all compute node groups has been reached for associated cluster.</p></li>
319    /// </ul>
320    ServiceQuotaExceededException(crate::types::error::ServiceQuotaExceededException),
321    /// <p>Your request exceeded a request rate quota. Check the resource's request rate quota and try again.</p>
322    ThrottlingException(crate::types::error::ThrottlingException),
323    /// <p>The request isn't valid.</p>
324    /// <p><u>Examples</u></p>
325    /// <ul>
326    /// <li>
327    /// <p>Your request contains malformed JSON or unsupported characters.</p></li>
328    /// <li>
329    /// <p>The scheduler version isn't supported.</p></li>
330    /// <li>
331    /// <p>There are networking related errors, such as network validation failure.</p></li>
332    /// <li>
333    /// <p>AMI type is <code>CUSTOM</code> and the launch template doesn't define the AMI ID, or the AMI type is AL2 and the launch template defines the AMI.</p></li>
334    /// </ul>
335    ValidationException(crate::types::error::ValidationException),
336    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
337    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
338    variable wildcard pattern and check `.code()`:
339     \
340    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
341     \
342    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-CreateComputeNodeGroupError) for what information is available for the error.")]
343    Unhandled(crate::error::sealed_unhandled::Unhandled),
344}
345impl CreateComputeNodeGroupError {
346    /// Creates the `CreateComputeNodeGroupError::Unhandled` variant from any error type.
347    pub fn unhandled(
348        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
349    ) -> Self {
350        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
351            source: err.into(),
352            meta: ::std::default::Default::default(),
353        })
354    }
355
356    /// Creates the `CreateComputeNodeGroupError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
357    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
358        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
359            source: err.clone().into(),
360            meta: err,
361        })
362    }
363    ///
364    /// Returns error metadata, which includes the error code, message,
365    /// request ID, and potentially additional information.
366    ///
367    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
368        match self {
369            Self::AccessDeniedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
370            Self::ConflictException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
371            Self::InternalServerException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
372            Self::ResourceNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
373            Self::ServiceQuotaExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
374            Self::ThrottlingException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
375            Self::ValidationException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
376            Self::Unhandled(e) => &e.meta,
377        }
378    }
379    /// Returns `true` if the error kind is `CreateComputeNodeGroupError::AccessDeniedException`.
380    pub fn is_access_denied_exception(&self) -> bool {
381        matches!(self, Self::AccessDeniedException(_))
382    }
383    /// Returns `true` if the error kind is `CreateComputeNodeGroupError::ConflictException`.
384    pub fn is_conflict_exception(&self) -> bool {
385        matches!(self, Self::ConflictException(_))
386    }
387    /// Returns `true` if the error kind is `CreateComputeNodeGroupError::InternalServerException`.
388    pub fn is_internal_server_exception(&self) -> bool {
389        matches!(self, Self::InternalServerException(_))
390    }
391    /// Returns `true` if the error kind is `CreateComputeNodeGroupError::ResourceNotFoundException`.
392    pub fn is_resource_not_found_exception(&self) -> bool {
393        matches!(self, Self::ResourceNotFoundException(_))
394    }
395    /// Returns `true` if the error kind is `CreateComputeNodeGroupError::ServiceQuotaExceededException`.
396    pub fn is_service_quota_exceeded_exception(&self) -> bool {
397        matches!(self, Self::ServiceQuotaExceededException(_))
398    }
399    /// Returns `true` if the error kind is `CreateComputeNodeGroupError::ThrottlingException`.
400    pub fn is_throttling_exception(&self) -> bool {
401        matches!(self, Self::ThrottlingException(_))
402    }
403    /// Returns `true` if the error kind is `CreateComputeNodeGroupError::ValidationException`.
404    pub fn is_validation_exception(&self) -> bool {
405        matches!(self, Self::ValidationException(_))
406    }
407}
408impl ::std::error::Error for CreateComputeNodeGroupError {
409    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
410        match self {
411            Self::AccessDeniedException(_inner) => ::std::option::Option::Some(_inner),
412            Self::ConflictException(_inner) => ::std::option::Option::Some(_inner),
413            Self::InternalServerException(_inner) => ::std::option::Option::Some(_inner),
414            Self::ResourceNotFoundException(_inner) => ::std::option::Option::Some(_inner),
415            Self::ServiceQuotaExceededException(_inner) => ::std::option::Option::Some(_inner),
416            Self::ThrottlingException(_inner) => ::std::option::Option::Some(_inner),
417            Self::ValidationException(_inner) => ::std::option::Option::Some(_inner),
418            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
419        }
420    }
421}
422impl ::std::fmt::Display for CreateComputeNodeGroupError {
423    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
424        match self {
425            Self::AccessDeniedException(_inner) => _inner.fmt(f),
426            Self::ConflictException(_inner) => _inner.fmt(f),
427            Self::InternalServerException(_inner) => _inner.fmt(f),
428            Self::ResourceNotFoundException(_inner) => _inner.fmt(f),
429            Self::ServiceQuotaExceededException(_inner) => _inner.fmt(f),
430            Self::ThrottlingException(_inner) => _inner.fmt(f),
431            Self::ValidationException(_inner) => _inner.fmt(f),
432            Self::Unhandled(_inner) => {
433                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
434                    write!(f, "unhandled error ({code})")
435                } else {
436                    f.write_str("unhandled error")
437                }
438            }
439        }
440    }
441}
442impl ::aws_smithy_types::retry::ProvideErrorKind for CreateComputeNodeGroupError {
443    fn code(&self) -> ::std::option::Option<&str> {
444        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
445    }
446    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
447        match self {
448            Self::InternalServerException(inner) => ::std::option::Option::Some(inner.retryable_error_kind()),
449            Self::ThrottlingException(inner) => ::std::option::Option::Some(inner.retryable_error_kind()),
450            _ => ::std::option::Option::None,
451        }
452    }
453}
454impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for CreateComputeNodeGroupError {
455    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
456        match self {
457            Self::AccessDeniedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
458            Self::ConflictException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
459            Self::InternalServerException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
460            Self::ResourceNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
461            Self::ServiceQuotaExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
462            Self::ThrottlingException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
463            Self::ValidationException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
464            Self::Unhandled(_inner) => &_inner.meta,
465        }
466    }
467}
468impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for CreateComputeNodeGroupError {
469    fn create_unhandled_error(
470        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
471        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
472    ) -> Self {
473        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
474            source,
475            meta: meta.unwrap_or_default(),
476        })
477    }
478}
479impl ::aws_types::request_id::RequestId for crate::operation::create_compute_node_group::CreateComputeNodeGroupError {
480    fn request_id(&self) -> Option<&str> {
481        self.meta().request_id()
482    }
483}
484
485pub use crate::operation::create_compute_node_group::_create_compute_node_group_input::CreateComputeNodeGroupInput;
486
487pub use crate::operation::create_compute_node_group::_create_compute_node_group_output::CreateComputeNodeGroupOutput;
488
489mod _create_compute_node_group_input;
490
491mod _create_compute_node_group_output;
492
493/// Builders
494pub mod builders;