aws_sdk_quicksight/operation/
update_role_custom_permission.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Orchestration and serialization glue logic for `UpdateRoleCustomPermission`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct UpdateRoleCustomPermission;
6impl UpdateRoleCustomPermission {
7    /// Creates a new `UpdateRoleCustomPermission`
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::update_role_custom_permission::UpdateRoleCustomPermissionInput,
14    ) -> ::std::result::Result<
15        crate::operation::update_role_custom_permission::UpdateRoleCustomPermissionOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::update_role_custom_permission::UpdateRoleCustomPermissionError,
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::update_role_custom_permission::UpdateRoleCustomPermissionError>()
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::update_role_custom_permission::UpdateRoleCustomPermissionOutput>()
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::update_role_custom_permission::UpdateRoleCustomPermissionInput,
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            "QuickSight",
56            "UpdateRoleCustomPermission",
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            "QuickSight.UpdateRoleCustomPermission",
65            "rpc.service" = "QuickSight",
66            "rpc.method" = "UpdateRoleCustomPermission",
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 UpdateRoleCustomPermission {
96    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
97        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("UpdateRoleCustomPermission");
98
99        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
100            UpdateRoleCustomPermissionRequestSerializer,
101        ));
102        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
103            UpdateRoleCustomPermissionResponseDeserializer,
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            "UpdateRoleCustomPermission",
112            "QuickSight",
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("UpdateRoleCustomPermission")
134            .with_interceptor(::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default())
135            .with_interceptor(UpdateRoleCustomPermissionEndpointParamsInterceptor)
136            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
137                crate::operation::update_role_custom_permission::UpdateRoleCustomPermissionError,
138            >::new())
139            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
140                crate::operation::update_role_custom_permission::UpdateRoleCustomPermissionError,
141            >::new())
142            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
143                crate::operation::update_role_custom_permission::UpdateRoleCustomPermissionError,
144            >::new());
145
146        ::std::borrow::Cow::Owned(rcb)
147    }
148}
149
150#[derive(Debug)]
151struct UpdateRoleCustomPermissionResponseDeserializer;
152impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for UpdateRoleCustomPermissionResponseDeserializer {
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_update_role_custom_permission::de_update_role_custom_permission_http_error(status, headers, body)
165        } else {
166            crate::protocol_serde::shape_update_role_custom_permission::de_update_role_custom_permission_http_response(status, headers, body)
167        };
168        crate::protocol_serde::type_erase_result(parse_result)
169    }
170}
171#[derive(Debug)]
172struct UpdateRoleCustomPermissionRequestSerializer;
173impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for UpdateRoleCustomPermissionRequestSerializer {
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::update_role_custom_permission::UpdateRoleCustomPermissionInput>()
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::update_role_custom_permission::UpdateRoleCustomPermissionInput,
190                output: &mut ::std::string::String,
191            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
192                use ::std::fmt::Write as _;
193                let input_1 = &_input.aws_account_id;
194                let input_1 = input_1
195                    .as_ref()
196                    .ok_or_else(|| ::aws_smithy_types::error::operation::BuildError::missing_field("aws_account_id", "cannot be empty or unset"))?;
197                let aws_account_id = ::aws_smithy_http::label::fmt_string(input_1, ::aws_smithy_http::label::EncodingStrategy::Default);
198                if aws_account_id.is_empty() {
199                    return ::std::result::Result::Err(::aws_smithy_types::error::operation::BuildError::missing_field(
200                        "aws_account_id",
201                        "cannot be empty or unset",
202                    ));
203                }
204                let input_2 = &_input.namespace;
205                let input_2 = input_2
206                    .as_ref()
207                    .ok_or_else(|| ::aws_smithy_types::error::operation::BuildError::missing_field("namespace", "cannot be empty or unset"))?;
208                let namespace = ::aws_smithy_http::label::fmt_string(input_2, ::aws_smithy_http::label::EncodingStrategy::Default);
209                if namespace.is_empty() {
210                    return ::std::result::Result::Err(::aws_smithy_types::error::operation::BuildError::missing_field(
211                        "namespace",
212                        "cannot be empty or unset",
213                    ));
214                }
215                let input_3 = &_input.role;
216                let input_3 = input_3
217                    .as_ref()
218                    .ok_or_else(|| ::aws_smithy_types::error::operation::BuildError::missing_field("role", "cannot be empty or unset"))?;
219                let role = ::aws_smithy_http::label::fmt_string(input_3, ::aws_smithy_http::label::EncodingStrategy::Default);
220                if role.is_empty() {
221                    return ::std::result::Result::Err(::aws_smithy_types::error::operation::BuildError::missing_field(
222                        "role",
223                        "cannot be empty or unset",
224                    ));
225                }
226                ::std::write!(
227                    output,
228                    "/accounts/{AwsAccountId}/namespaces/{Namespace}/roles/{Role}/custom-permission",
229                    AwsAccountId = aws_account_id,
230                    Namespace = namespace,
231                    Role = role
232                )
233                .expect("formatting should succeed");
234                ::std::result::Result::Ok(())
235            }
236            #[allow(clippy::unnecessary_wraps)]
237            fn update_http_builder(
238                input: &crate::operation::update_role_custom_permission::UpdateRoleCustomPermissionInput,
239                builder: ::http::request::Builder,
240            ) -> ::std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
241                let mut uri = ::std::string::String::new();
242                uri_base(input, &mut uri)?;
243                ::std::result::Result::Ok(builder.method("PUT").uri(uri))
244            }
245            let mut builder = update_http_builder(&input, ::http::request::Builder::new())?;
246            builder = _header_serialization_settings.set_default_header(builder, ::http::header::CONTENT_TYPE, "application/json");
247            builder
248        };
249        let body = ::aws_smithy_types::body::SdkBody::from(
250            crate::protocol_serde::shape_update_role_custom_permission::ser_update_role_custom_permission_input(&input)?,
251        );
252        if let Some(content_length) = body.content_length() {
253            let content_length = content_length.to_string();
254            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http::header::CONTENT_LENGTH, &content_length);
255        }
256        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
257    }
258}
259#[derive(Debug)]
260struct UpdateRoleCustomPermissionEndpointParamsInterceptor;
261
262impl ::aws_smithy_runtime_api::client::interceptors::Intercept for UpdateRoleCustomPermissionEndpointParamsInterceptor {
263    fn name(&self) -> &'static str {
264        "UpdateRoleCustomPermissionEndpointParamsInterceptor"
265    }
266
267    fn read_before_execution(
268        &self,
269        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
270            '_,
271            ::aws_smithy_runtime_api::client::interceptors::context::Input,
272            ::aws_smithy_runtime_api::client::interceptors::context::Output,
273            ::aws_smithy_runtime_api::client::interceptors::context::Error,
274        >,
275        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
276    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
277        let _input = context
278            .input()
279            .downcast_ref::<UpdateRoleCustomPermissionInput>()
280            .ok_or("failed to downcast to UpdateRoleCustomPermissionInput")?;
281
282        let params = crate::config::endpoint::Params::builder()
283            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
284            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
285            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
286            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
287            .build()
288            .map_err(|err| {
289                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
290            })?;
291        cfg.interceptor_state()
292            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
293        ::std::result::Result::Ok(())
294    }
295}
296
297// The get_* functions below are generated from JMESPath expressions in the
298// operationContextParams trait. They target the operation's input shape.
299
300/// Error type for the `UpdateRoleCustomPermissionError` operation.
301#[non_exhaustive]
302#[derive(::std::fmt::Debug)]
303pub enum UpdateRoleCustomPermissionError {
304    /// <p>You don't have access to this item. The provided credentials couldn't be validated. You might not be authorized to carry out the request. Make sure that your account is authorized to use the Amazon QuickSight service, that your policies have the correct permissions, and that you are using the correct credentials.</p>
305    AccessDeniedException(crate::types::error::AccessDeniedException),
306    /// <p>An internal failure occurred.</p>
307    InternalFailureException(crate::types::error::InternalFailureException),
308    /// <p>One or more parameters has a value that isn't valid.</p>
309    InvalidParameterValueException(crate::types::error::InvalidParameterValueException),
310    /// <p>One or more preconditions aren't met.</p>
311    PreconditionNotMetException(crate::types::error::PreconditionNotMetException),
312    /// <p>One or more resources can't be found.</p>
313    ResourceNotFoundException(crate::types::error::ResourceNotFoundException),
314    /// <p>This resource is currently unavailable.</p>
315    ResourceUnavailableException(crate::types::error::ResourceUnavailableException),
316    /// <p>Access is throttled.</p>
317    ThrottlingException(crate::types::error::ThrottlingException),
318    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
319    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
320    variable wildcard pattern and check `.code()`:
321     \
322    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
323     \
324    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-UpdateRoleCustomPermissionError) for what information is available for the error.")]
325    Unhandled(crate::error::sealed_unhandled::Unhandled),
326}
327impl UpdateRoleCustomPermissionError {
328    /// Creates the `UpdateRoleCustomPermissionError::Unhandled` variant from any error type.
329    pub fn unhandled(
330        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
331    ) -> Self {
332        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
333            source: err.into(),
334            meta: ::std::default::Default::default(),
335        })
336    }
337
338    /// Creates the `UpdateRoleCustomPermissionError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
339    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
340        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
341            source: err.clone().into(),
342            meta: err,
343        })
344    }
345    ///
346    /// Returns error metadata, which includes the error code, message,
347    /// request ID, and potentially additional information.
348    ///
349    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
350        match self {
351            Self::AccessDeniedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
352            Self::InternalFailureException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
353            Self::InvalidParameterValueException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
354            Self::PreconditionNotMetException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
355            Self::ResourceNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
356            Self::ResourceUnavailableException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
357            Self::ThrottlingException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
358            Self::Unhandled(e) => &e.meta,
359        }
360    }
361    /// Returns `true` if the error kind is `UpdateRoleCustomPermissionError::AccessDeniedException`.
362    pub fn is_access_denied_exception(&self) -> bool {
363        matches!(self, Self::AccessDeniedException(_))
364    }
365    /// Returns `true` if the error kind is `UpdateRoleCustomPermissionError::InternalFailureException`.
366    pub fn is_internal_failure_exception(&self) -> bool {
367        matches!(self, Self::InternalFailureException(_))
368    }
369    /// Returns `true` if the error kind is `UpdateRoleCustomPermissionError::InvalidParameterValueException`.
370    pub fn is_invalid_parameter_value_exception(&self) -> bool {
371        matches!(self, Self::InvalidParameterValueException(_))
372    }
373    /// Returns `true` if the error kind is `UpdateRoleCustomPermissionError::PreconditionNotMetException`.
374    pub fn is_precondition_not_met_exception(&self) -> bool {
375        matches!(self, Self::PreconditionNotMetException(_))
376    }
377    /// Returns `true` if the error kind is `UpdateRoleCustomPermissionError::ResourceNotFoundException`.
378    pub fn is_resource_not_found_exception(&self) -> bool {
379        matches!(self, Self::ResourceNotFoundException(_))
380    }
381    /// Returns `true` if the error kind is `UpdateRoleCustomPermissionError::ResourceUnavailableException`.
382    pub fn is_resource_unavailable_exception(&self) -> bool {
383        matches!(self, Self::ResourceUnavailableException(_))
384    }
385    /// Returns `true` if the error kind is `UpdateRoleCustomPermissionError::ThrottlingException`.
386    pub fn is_throttling_exception(&self) -> bool {
387        matches!(self, Self::ThrottlingException(_))
388    }
389}
390impl ::std::error::Error for UpdateRoleCustomPermissionError {
391    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
392        match self {
393            Self::AccessDeniedException(_inner) => ::std::option::Option::Some(_inner),
394            Self::InternalFailureException(_inner) => ::std::option::Option::Some(_inner),
395            Self::InvalidParameterValueException(_inner) => ::std::option::Option::Some(_inner),
396            Self::PreconditionNotMetException(_inner) => ::std::option::Option::Some(_inner),
397            Self::ResourceNotFoundException(_inner) => ::std::option::Option::Some(_inner),
398            Self::ResourceUnavailableException(_inner) => ::std::option::Option::Some(_inner),
399            Self::ThrottlingException(_inner) => ::std::option::Option::Some(_inner),
400            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
401        }
402    }
403}
404impl ::std::fmt::Display for UpdateRoleCustomPermissionError {
405    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
406        match self {
407            Self::AccessDeniedException(_inner) => _inner.fmt(f),
408            Self::InternalFailureException(_inner) => _inner.fmt(f),
409            Self::InvalidParameterValueException(_inner) => _inner.fmt(f),
410            Self::PreconditionNotMetException(_inner) => _inner.fmt(f),
411            Self::ResourceNotFoundException(_inner) => _inner.fmt(f),
412            Self::ResourceUnavailableException(_inner) => _inner.fmt(f),
413            Self::ThrottlingException(_inner) => _inner.fmt(f),
414            Self::Unhandled(_inner) => {
415                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
416                    write!(f, "unhandled error ({code})")
417                } else {
418                    f.write_str("unhandled error")
419                }
420            }
421        }
422    }
423}
424impl ::aws_smithy_types::retry::ProvideErrorKind for UpdateRoleCustomPermissionError {
425    fn code(&self) -> ::std::option::Option<&str> {
426        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
427    }
428    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
429        ::std::option::Option::None
430    }
431}
432impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for UpdateRoleCustomPermissionError {
433    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
434        match self {
435            Self::AccessDeniedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
436            Self::InternalFailureException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
437            Self::InvalidParameterValueException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
438            Self::PreconditionNotMetException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
439            Self::ResourceNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
440            Self::ResourceUnavailableException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
441            Self::ThrottlingException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
442            Self::Unhandled(_inner) => &_inner.meta,
443        }
444    }
445}
446impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for UpdateRoleCustomPermissionError {
447    fn create_unhandled_error(
448        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
449        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
450    ) -> Self {
451        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
452            source,
453            meta: meta.unwrap_or_default(),
454        })
455    }
456}
457impl ::aws_types::request_id::RequestId for crate::operation::update_role_custom_permission::UpdateRoleCustomPermissionError {
458    fn request_id(&self) -> Option<&str> {
459        self.meta().request_id()
460    }
461}
462
463pub use crate::operation::update_role_custom_permission::_update_role_custom_permission_output::UpdateRoleCustomPermissionOutput;
464
465pub use crate::operation::update_role_custom_permission::_update_role_custom_permission_input::UpdateRoleCustomPermissionInput;
466
467mod _update_role_custom_permission_input;
468
469mod _update_role_custom_permission_output;
470
471/// Builders
472pub mod builders;