aws_sdk_s3/protocol_serde/
shape_get_bucket_logging.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[allow(clippy::unnecessary_wraps)]
3pub fn de_get_bucket_logging_http_error(
4    _response_status: u16,
5    _response_headers: &::aws_smithy_runtime_api::http::Headers,
6    _response_body: &[u8],
7) -> std::result::Result<crate::operation::get_bucket_logging::GetBucketLoggingOutput, crate::operation::get_bucket_logging::GetBucketLoggingError> {
8    #[allow(unused_mut)]
9    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
10        .map_err(crate::operation::get_bucket_logging::GetBucketLoggingError::unhandled)?;
11    generic_builder = crate::s3_request_id::apply_extended_request_id(generic_builder, _response_headers);
12    generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, _response_headers);
13    let generic = generic_builder.build();
14    Err(crate::operation::get_bucket_logging::GetBucketLoggingError::generic(generic))
15}
16
17#[allow(clippy::unnecessary_wraps)]
18pub fn de_get_bucket_logging_http_response(
19    _response_status: u16,
20    _response_headers: &::aws_smithy_runtime_api::http::Headers,
21    _response_body: &[u8],
22) -> std::result::Result<crate::operation::get_bucket_logging::GetBucketLoggingOutput, crate::operation::get_bucket_logging::GetBucketLoggingError> {
23    Ok({
24        #[allow(unused_mut)]
25        let mut output = crate::operation::get_bucket_logging::builders::GetBucketLoggingOutputBuilder::default();
26        output = crate::protocol_serde::shape_get_bucket_logging::de_get_bucket_logging(_response_body, output)
27            .map_err(crate::operation::get_bucket_logging::GetBucketLoggingError::unhandled)?;
28        output._set_extended_request_id(crate::s3_request_id::RequestIdExt::extended_request_id(_response_headers).map(str::to_string));
29        output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string));
30        output.build()
31    })
32}
33
34pub fn ser_get_bucket_logging_headers(
35    input: &crate::operation::get_bucket_logging::GetBucketLoggingInput,
36    mut builder: ::http::request::Builder,
37) -> std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
38    if let ::std::option::Option::Some(inner_1) = &input.expected_bucket_owner {
39        let formatted_2 = inner_1.as_str();
40        let header_value = formatted_2;
41        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
42            ::aws_smithy_types::error::operation::BuildError::invalid_field(
43                "expected_bucket_owner",
44                format!("`{}` cannot be used as a header value: {}", &header_value, err),
45            )
46        })?;
47        builder = builder.header("x-amz-expected-bucket-owner", header_value);
48    }
49    Ok(builder)
50}
51
52#[allow(unused_mut)]
53pub fn de_get_bucket_logging(
54    inp: &[u8],
55    mut builder: crate::operation::get_bucket_logging::builders::GetBucketLoggingOutputBuilder,
56) -> std::result::Result<crate::operation::get_bucket_logging::builders::GetBucketLoggingOutputBuilder, ::aws_smithy_xml::decode::XmlDecodeError> {
57    let mut doc = ::aws_smithy_xml::decode::Document::try_from(inp)?;
58
59    #[allow(unused_mut)]
60    let mut decoder = doc.root_element()?;
61    #[allow(unused_variables)]
62    let start_el = decoder.start_el();
63    if !start_el.matches("BucketLoggingStatus") {
64        return Err(::aws_smithy_xml::decode::XmlDecodeError::custom(format!(
65            "encountered invalid XML root: expected BucketLoggingStatus but got {:?}. This is likely a bug in the SDK.",
66            start_el
67        )));
68    }
69    while let Some(mut tag) = decoder.next_tag() {
70        match tag.start_el() {
71            s if s.matches("LoggingEnabled") /* LoggingEnabled com.amazonaws.s3.synthetic#GetBucketLoggingOutput$LoggingEnabled */ =>  {
72                let var_3 =
73                    Some(
74                        crate::protocol_serde::shape_logging_enabled::de_logging_enabled(&mut tag)
75                        ?
76                    )
77                ;
78                builder = builder.set_logging_enabled(var_3);
79            }
80            ,
81            _ => {}
82        }
83    }
84    Ok(builder)
85}