Skip to main content

aws_sdk_vpclattice/protocol_serde/
shape_create_access_log_subscription.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[allow(clippy::unnecessary_wraps)]
3pub fn de_create_access_log_subscription_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::create_access_log_subscription::CreateAccessLogSubscriptionOutput,
9    crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError,
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::create_access_log_subscription::CreateAccessLogSubscriptionError::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 => return Err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled(generic)),
19    };
20
21    let _error_message = generic.message().map(|msg| msg.to_owned());
22    Err(match error_code {
23        "AccessDeniedException" => crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::AccessDeniedException({
24            #[allow(unused_mut)]
25            let mut tmp = {
26                #[allow(unused_mut)]
27                let mut output = crate::types::error::builders::AccessDeniedExceptionBuilder::default();
28                output = crate::protocol_serde::shape_access_denied_exception::de_access_denied_exception_json_err(_response_body, output)
29                    .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?;
30                let output = output.meta(generic);
31                crate::serde_util::access_denied_exception_correct_errors(output)
32                    .build()
33                    .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?
34            };
35            tmp
36        }),
37        "ConflictException" => crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::ConflictException({
38            #[allow(unused_mut)]
39            let mut tmp = {
40                #[allow(unused_mut)]
41                let mut output = crate::types::error::builders::ConflictExceptionBuilder::default();
42                output = crate::protocol_serde::shape_conflict_exception::de_conflict_exception_json_err(_response_body, output)
43                    .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?;
44                let output = output.meta(generic);
45                crate::serde_util::conflict_exception_correct_errors(output)
46                    .build()
47                    .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?
48            };
49            tmp
50        }),
51        "InternalServerException" => crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::InternalServerException({
52            #[allow(unused_mut)]
53            let mut tmp = {
54                #[allow(unused_mut)]
55                let mut output = crate::types::error::builders::InternalServerExceptionBuilder::default();
56                output = crate::protocol_serde::shape_internal_server_exception::de_internal_server_exception_json_err(_response_body, output)
57                    .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?;
58                output = output.set_retry_after_seconds(
59                    crate::protocol_serde::shape_internal_server_exception::de_retry_after_seconds_header(_response_headers).map_err(|_| {
60                        crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled(
61                            "Failed to parse retryAfterSeconds from header `Retry-After",
62                        )
63                    })?,
64                );
65                let output = output.meta(generic);
66                crate::serde_util::internal_server_exception_correct_errors(output)
67                    .build()
68                    .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?
69            };
70            tmp
71        }),
72        "ResourceNotFoundException" => {
73            crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::ResourceNotFoundException({
74                #[allow(unused_mut)]
75                let mut tmp = {
76                    #[allow(unused_mut)]
77                    let mut output = crate::types::error::builders::ResourceNotFoundExceptionBuilder::default();
78                    output =
79                        crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
80                            .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?;
81                    let output = output.meta(generic);
82                    crate::serde_util::resource_not_found_exception_correct_errors(output)
83                        .build()
84                        .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?
85                };
86                tmp
87            })
88        }
89        "ThrottlingException" => crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::ThrottlingException({
90            #[allow(unused_mut)]
91            let mut tmp = {
92                #[allow(unused_mut)]
93                let mut output = crate::types::error::builders::ThrottlingExceptionBuilder::default();
94                output = crate::protocol_serde::shape_throttling_exception::de_throttling_exception_json_err(_response_body, output)
95                    .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?;
96                output = output.set_retry_after_seconds(
97                    crate::protocol_serde::shape_throttling_exception::de_retry_after_seconds_header(_response_headers).map_err(|_| {
98                        crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled(
99                            "Failed to parse retryAfterSeconds from header `Retry-After",
100                        )
101                    })?,
102                );
103                let output = output.meta(generic);
104                crate::serde_util::throttling_exception_correct_errors(output)
105                    .build()
106                    .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?
107            };
108            tmp
109        }),
110        "ValidationException" => crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::ValidationException({
111            #[allow(unused_mut)]
112            let mut tmp = {
113                #[allow(unused_mut)]
114                let mut output = crate::types::error::builders::ValidationExceptionBuilder::default();
115                output = crate::protocol_serde::shape_validation_exception::de_validation_exception_json_err(_response_body, output)
116                    .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?;
117                let output = output.meta(generic);
118                crate::serde_util::validation_exception_correct_errors(output)
119                    .build()
120                    .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?
121            };
122            tmp
123        }),
124        _ => crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::generic(generic),
125    })
126}
127
128#[allow(clippy::unnecessary_wraps)]
129pub fn de_create_access_log_subscription_http_response(
130    _response_status: u16,
131    _response_headers: &::aws_smithy_runtime_api::http::Headers,
132    _response_body: &[u8],
133) -> std::result::Result<
134    crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionOutput,
135    crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError,
136> {
137    Ok({
138        #[allow(unused_mut)]
139        let mut output = crate::operation::create_access_log_subscription::builders::CreateAccessLogSubscriptionOutputBuilder::default();
140        output = crate::protocol_serde::shape_create_access_log_subscription::de_create_access_log_subscription(_response_body, output)
141            .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?;
142        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
143        crate::serde_util::create_access_log_subscription_output_output_correct_errors(output)
144            .build()
145            .map_err(crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionError::unhandled)?
146    })
147}
148
149pub fn ser_create_access_log_subscription_input(
150    input: &crate::operation::create_access_log_subscription::CreateAccessLogSubscriptionInput,
151) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
152    let mut out = String::new();
153    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
154    crate::protocol_serde::shape_create_access_log_subscription_input::ser_create_access_log_subscription_input_input(&mut object, input)?;
155    object.finish();
156    Ok(::aws_smithy_types::body::SdkBody::from(out))
157}
158
159pub(crate) fn de_create_access_log_subscription(
160    _value: &[u8],
161    mut builder: crate::operation::create_access_log_subscription::builders::CreateAccessLogSubscriptionOutputBuilder,
162) -> ::std::result::Result<
163    crate::operation::create_access_log_subscription::builders::CreateAccessLogSubscriptionOutputBuilder,
164    ::aws_smithy_json::deserialize::error::DeserializeError,
165> {
166    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(_value)).peekable();
167    let tokens = &mut tokens_owned;
168    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
169    loop {
170        match tokens.next().transpose()? {
171            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
172            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
173                "arn" => {
174                    builder = builder.set_arn(
175                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
176                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
177                            .transpose()?,
178                    );
179                }
180                "destinationArn" => {
181                    builder = builder.set_destination_arn(
182                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
183                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
184                            .transpose()?,
185                    );
186                }
187                "id" => {
188                    builder = builder.set_id(
189                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
190                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
191                            .transpose()?,
192                    );
193                }
194                "resourceArn" => {
195                    builder = builder.set_resource_arn(
196                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
197                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
198                            .transpose()?,
199                    );
200                }
201                "resourceId" => {
202                    builder = builder.set_resource_id(
203                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
204                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
205                            .transpose()?,
206                    );
207                }
208                "serviceNetworkLogType" => {
209                    builder = builder.set_service_network_log_type(
210                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
211                            .map(|s| s.to_unescaped().map(|u| crate::types::ServiceNetworkLogType::from(u.as_ref())))
212                            .transpose()?,
213                    );
214                }
215                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
216            },
217            other => {
218                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
219                    "expected object key or end object, found: {other:?}"
220                )))
221            }
222        }
223    }
224    if tokens.next().is_some() {
225        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
226            "found more JSON tokens after completing parsing",
227        ));
228    }
229    Ok(builder)
230}