aws_sdk_quicksight/operation/
update_user_custom_permission.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Orchestration and serialization glue logic for `UpdateUserCustomPermission`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct UpdateUserCustomPermission;
6impl UpdateUserCustomPermission {
7    /// Creates a new `UpdateUserCustomPermission`
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_user_custom_permission::UpdateUserCustomPermissionInput,
14    ) -> ::std::result::Result<
15        crate::operation::update_user_custom_permission::UpdateUserCustomPermissionOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::update_user_custom_permission::UpdateUserCustomPermissionError,
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_user_custom_permission::UpdateUserCustomPermissionError>()
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_user_custom_permission::UpdateUserCustomPermissionOutput>()
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_user_custom_permission::UpdateUserCustomPermissionInput,
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            "UpdateUserCustomPermission",
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.UpdateUserCustomPermission",
65            "rpc.service" = "QuickSight",
66            "rpc.method" = "UpdateUserCustomPermission",
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 UpdateUserCustomPermission {
96    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
97        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("UpdateUserCustomPermission");
98
99        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
100            UpdateUserCustomPermissionRequestSerializer,
101        ));
102        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
103            UpdateUserCustomPermissionResponseDeserializer,
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            "UpdateUserCustomPermission",
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("UpdateUserCustomPermission")
134            .with_interceptor(::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default())
135            .with_interceptor(UpdateUserCustomPermissionEndpointParamsInterceptor)
136            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
137                crate::operation::update_user_custom_permission::UpdateUserCustomPermissionError,
138            >::new())
139            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
140                crate::operation::update_user_custom_permission::UpdateUserCustomPermissionError,
141            >::new())
142            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
143                crate::operation::update_user_custom_permission::UpdateUserCustomPermissionError,
144            >::new());
145
146        ::std::borrow::Cow::Owned(rcb)
147    }
148}
149
150#[derive(Debug)]
151struct UpdateUserCustomPermissionResponseDeserializer;
152impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for UpdateUserCustomPermissionResponseDeserializer {
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_user_custom_permission::de_update_user_custom_permission_http_error(status, headers, body)
165        } else {
166            crate::protocol_serde::shape_update_user_custom_permission::de_update_user_custom_permission_http_response(status, headers, body)
167        };
168        crate::protocol_serde::type_erase_result(parse_result)
169    }
170}
171#[derive(Debug)]
172struct UpdateUserCustomPermissionRequestSerializer;
173impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for UpdateUserCustomPermissionRequestSerializer {
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_user_custom_permission::UpdateUserCustomPermissionInput>()
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_user_custom_permission::UpdateUserCustomPermissionInput,
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.user_name;
216                let input_3 = input_3
217                    .as_ref()
218                    .ok_or_else(|| ::aws_smithy_types::error::operation::BuildError::missing_field("user_name", "cannot be empty or unset"))?;
219                let user_name = ::aws_smithy_http::label::fmt_string(input_3, ::aws_smithy_http::label::EncodingStrategy::Default);
220                if user_name.is_empty() {
221                    return ::std::result::Result::Err(::aws_smithy_types::error::operation::BuildError::missing_field(
222                        "user_name",
223                        "cannot be empty or unset",
224                    ));
225                }
226                ::std::write!(
227                    output,
228                    "/accounts/{AwsAccountId}/namespaces/{Namespace}/users/{UserName}/custom-permission",
229                    AwsAccountId = aws_account_id,
230                    Namespace = namespace,
231                    UserName = user_name
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_user_custom_permission::UpdateUserCustomPermissionInput,
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_user_custom_permission::ser_update_user_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 UpdateUserCustomPermissionEndpointParamsInterceptor;
261
262impl ::aws_smithy_runtime_api::client::interceptors::Intercept for UpdateUserCustomPermissionEndpointParamsInterceptor {
263    fn name(&self) -> &'static str {
264        "UpdateUserCustomPermissionEndpointParamsInterceptor"
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::<UpdateUserCustomPermissionInput>()
280            .ok_or("failed to downcast to UpdateUserCustomPermissionInput")?;
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 `UpdateUserCustomPermissionError` operation.
301#[non_exhaustive]
302#[derive(::std::fmt::Debug)]
303pub enum UpdateUserCustomPermissionError {
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>Updating or deleting a resource can cause an inconsistent state.</p>
307    ConflictException(crate::types::error::ConflictException),
308    /// <p>An internal failure occurred.</p>
309    InternalFailureException(crate::types::error::InternalFailureException),
310    /// <p>One or more parameters has a value that isn't valid.</p>
311    InvalidParameterValueException(crate::types::error::InvalidParameterValueException),
312    /// <p>One or more preconditions aren't met.</p>
313    PreconditionNotMetException(crate::types::error::PreconditionNotMetException),
314    /// <p>One or more resources can't be found.</p>
315    ResourceNotFoundException(crate::types::error::ResourceNotFoundException),
316    /// <p>This resource is currently unavailable.</p>
317    ResourceUnavailableException(crate::types::error::ResourceUnavailableException),
318    /// <p>Access is throttled.</p>
319    ThrottlingException(crate::types::error::ThrottlingException),
320    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
321    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
322    variable wildcard pattern and check `.code()`:
323     \
324    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
325     \
326    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-UpdateUserCustomPermissionError) for what information is available for the error.")]
327    Unhandled(crate::error::sealed_unhandled::Unhandled),
328}
329impl UpdateUserCustomPermissionError {
330    /// Creates the `UpdateUserCustomPermissionError::Unhandled` variant from any error type.
331    pub fn unhandled(
332        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
333    ) -> Self {
334        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
335            source: err.into(),
336            meta: ::std::default::Default::default(),
337        })
338    }
339
340    /// Creates the `UpdateUserCustomPermissionError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
341    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
342        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
343            source: err.clone().into(),
344            meta: err,
345        })
346    }
347    ///
348    /// Returns error metadata, which includes the error code, message,
349    /// request ID, and potentially additional information.
350    ///
351    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
352        match self {
353            Self::AccessDeniedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
354            Self::ConflictException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
355            Self::InternalFailureException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
356            Self::InvalidParameterValueException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
357            Self::PreconditionNotMetException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
358            Self::ResourceNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
359            Self::ResourceUnavailableException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
360            Self::ThrottlingException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
361            Self::Unhandled(e) => &e.meta,
362        }
363    }
364    /// Returns `true` if the error kind is `UpdateUserCustomPermissionError::AccessDeniedException`.
365    pub fn is_access_denied_exception(&self) -> bool {
366        matches!(self, Self::AccessDeniedException(_))
367    }
368    /// Returns `true` if the error kind is `UpdateUserCustomPermissionError::ConflictException`.
369    pub fn is_conflict_exception(&self) -> bool {
370        matches!(self, Self::ConflictException(_))
371    }
372    /// Returns `true` if the error kind is `UpdateUserCustomPermissionError::InternalFailureException`.
373    pub fn is_internal_failure_exception(&self) -> bool {
374        matches!(self, Self::InternalFailureException(_))
375    }
376    /// Returns `true` if the error kind is `UpdateUserCustomPermissionError::InvalidParameterValueException`.
377    pub fn is_invalid_parameter_value_exception(&self) -> bool {
378        matches!(self, Self::InvalidParameterValueException(_))
379    }
380    /// Returns `true` if the error kind is `UpdateUserCustomPermissionError::PreconditionNotMetException`.
381    pub fn is_precondition_not_met_exception(&self) -> bool {
382        matches!(self, Self::PreconditionNotMetException(_))
383    }
384    /// Returns `true` if the error kind is `UpdateUserCustomPermissionError::ResourceNotFoundException`.
385    pub fn is_resource_not_found_exception(&self) -> bool {
386        matches!(self, Self::ResourceNotFoundException(_))
387    }
388    /// Returns `true` if the error kind is `UpdateUserCustomPermissionError::ResourceUnavailableException`.
389    pub fn is_resource_unavailable_exception(&self) -> bool {
390        matches!(self, Self::ResourceUnavailableException(_))
391    }
392    /// Returns `true` if the error kind is `UpdateUserCustomPermissionError::ThrottlingException`.
393    pub fn is_throttling_exception(&self) -> bool {
394        matches!(self, Self::ThrottlingException(_))
395    }
396}
397impl ::std::error::Error for UpdateUserCustomPermissionError {
398    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
399        match self {
400            Self::AccessDeniedException(_inner) => ::std::option::Option::Some(_inner),
401            Self::ConflictException(_inner) => ::std::option::Option::Some(_inner),
402            Self::InternalFailureException(_inner) => ::std::option::Option::Some(_inner),
403            Self::InvalidParameterValueException(_inner) => ::std::option::Option::Some(_inner),
404            Self::PreconditionNotMetException(_inner) => ::std::option::Option::Some(_inner),
405            Self::ResourceNotFoundException(_inner) => ::std::option::Option::Some(_inner),
406            Self::ResourceUnavailableException(_inner) => ::std::option::Option::Some(_inner),
407            Self::ThrottlingException(_inner) => ::std::option::Option::Some(_inner),
408            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
409        }
410    }
411}
412impl ::std::fmt::Display for UpdateUserCustomPermissionError {
413    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
414        match self {
415            Self::AccessDeniedException(_inner) => _inner.fmt(f),
416            Self::ConflictException(_inner) => _inner.fmt(f),
417            Self::InternalFailureException(_inner) => _inner.fmt(f),
418            Self::InvalidParameterValueException(_inner) => _inner.fmt(f),
419            Self::PreconditionNotMetException(_inner) => _inner.fmt(f),
420            Self::ResourceNotFoundException(_inner) => _inner.fmt(f),
421            Self::ResourceUnavailableException(_inner) => _inner.fmt(f),
422            Self::ThrottlingException(_inner) => _inner.fmt(f),
423            Self::Unhandled(_inner) => {
424                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
425                    write!(f, "unhandled error ({code})")
426                } else {
427                    f.write_str("unhandled error")
428                }
429            }
430        }
431    }
432}
433impl ::aws_smithy_types::retry::ProvideErrorKind for UpdateUserCustomPermissionError {
434    fn code(&self) -> ::std::option::Option<&str> {
435        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
436    }
437    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
438        ::std::option::Option::None
439    }
440}
441impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for UpdateUserCustomPermissionError {
442    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
443        match self {
444            Self::AccessDeniedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
445            Self::ConflictException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
446            Self::InternalFailureException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
447            Self::InvalidParameterValueException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
448            Self::PreconditionNotMetException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
449            Self::ResourceNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
450            Self::ResourceUnavailableException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
451            Self::ThrottlingException(_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 UpdateUserCustomPermissionError {
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::update_user_custom_permission::UpdateUserCustomPermissionError {
468    fn request_id(&self) -> Option<&str> {
469        self.meta().request_id()
470    }
471}
472
473pub use crate::operation::update_user_custom_permission::_update_user_custom_permission_output::UpdateUserCustomPermissionOutput;
474
475pub use crate::operation::update_user_custom_permission::_update_user_custom_permission_input::UpdateUserCustomPermissionInput;
476
477mod _update_user_custom_permission_input;
478
479mod _update_user_custom_permission_output;
480
481/// Builders
482pub mod builders;