aws_sdk_appstream/protocol_serde/
shape_update_image_permissions.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[allow(clippy::unnecessary_wraps)]
3pub fn de_update_image_permissions_http_error(
4    _response_status: u16,
5    _response_headers: &::aws_smithy_runtime_api::http::Headers,
6    _response_body: &[u8],
7) -> std::result::Result<
8    crate::operation::update_image_permissions::UpdateImagePermissionsOutput,
9    crate::operation::update_image_permissions::UpdateImagePermissionsError,
10> {
11    #[allow(unused_mut)]
12    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
13        .map_err(crate::operation::update_image_permissions::UpdateImagePermissionsError::unhandled)?;
14    generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, _response_headers);
15    let generic = generic_builder.build();
16    let error_code = match generic.code() {
17        Some(code) => code,
18        None => {
19            return Err(crate::operation::update_image_permissions::UpdateImagePermissionsError::unhandled(
20                generic,
21            ))
22        }
23    };
24
25    let _error_message = generic.message().map(|msg| msg.to_owned());
26    Err(match error_code {
27        "LimitExceededException" => crate::operation::update_image_permissions::UpdateImagePermissionsError::LimitExceededException({
28            #[allow(unused_mut)]
29            let mut tmp = {
30                #[allow(unused_mut)]
31                let mut output = crate::types::error::builders::LimitExceededExceptionBuilder::default();
32                output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output)
33                    .map_err(crate::operation::update_image_permissions::UpdateImagePermissionsError::unhandled)?;
34                let output = output.meta(generic);
35                output.build()
36            };
37            if tmp.message.is_none() {
38                tmp.message = _error_message;
39            }
40            tmp
41        }),
42        "ResourceNotAvailableException" => crate::operation::update_image_permissions::UpdateImagePermissionsError::ResourceNotAvailableException({
43            #[allow(unused_mut)]
44            let mut tmp = {
45                #[allow(unused_mut)]
46                let mut output = crate::types::error::builders::ResourceNotAvailableExceptionBuilder::default();
47                output = crate::protocol_serde::shape_resource_not_available_exception::de_resource_not_available_exception_json_err(
48                    _response_body,
49                    output,
50                )
51                .map_err(crate::operation::update_image_permissions::UpdateImagePermissionsError::unhandled)?;
52                let output = output.meta(generic);
53                output.build()
54            };
55            if tmp.message.is_none() {
56                tmp.message = _error_message;
57            }
58            tmp
59        }),
60        "ResourceNotFoundException" => crate::operation::update_image_permissions::UpdateImagePermissionsError::ResourceNotFoundException({
61            #[allow(unused_mut)]
62            let mut tmp = {
63                #[allow(unused_mut)]
64                let mut output = crate::types::error::builders::ResourceNotFoundExceptionBuilder::default();
65                output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
66                    .map_err(crate::operation::update_image_permissions::UpdateImagePermissionsError::unhandled)?;
67                let output = output.meta(generic);
68                output.build()
69            };
70            if tmp.message.is_none() {
71                tmp.message = _error_message;
72            }
73            tmp
74        }),
75        _ => crate::operation::update_image_permissions::UpdateImagePermissionsError::generic(generic),
76    })
77}
78
79#[allow(clippy::unnecessary_wraps)]
80pub fn de_update_image_permissions_http_response(
81    _response_status: u16,
82    _response_headers: &::aws_smithy_runtime_api::http::Headers,
83    _response_body: &[u8],
84) -> std::result::Result<
85    crate::operation::update_image_permissions::UpdateImagePermissionsOutput,
86    crate::operation::update_image_permissions::UpdateImagePermissionsError,
87> {
88    Ok({
89        #[allow(unused_mut)]
90        let mut output = crate::operation::update_image_permissions::builders::UpdateImagePermissionsOutputBuilder::default();
91        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
92        output.build()
93    })
94}
95
96pub fn ser_update_image_permissions_input(
97    input: &crate::operation::update_image_permissions::UpdateImagePermissionsInput,
98) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
99    let mut out = String::new();
100    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
101    crate::protocol_serde::shape_update_image_permissions_input::ser_update_image_permissions_input_input(&mut object, input)?;
102    object.finish();
103    Ok(::aws_smithy_types::body::SdkBody::from(out))
104}