// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT. #[allow(clippy::unnecessary_wraps)] pub fn de_list_attached_indices_http_error( _response_status: u16, _response_headers: &::aws_smithy_runtime_api::http::Headers, _response_body: &[u8], ) -> std::result::Result< crate::operation::list_attached_indices::ListAttachedIndicesOutput, crate::operation::list_attached_indices::ListAttachedIndicesError, > { #[allow(unused_mut)] let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body) .map_err(crate::operation::list_attached_indices::ListAttachedIndicesError::unhandled)?; generic_builder = ::aws_types::request_id::apply_request_id(generic_builder, _response_headers); let generic = generic_builder.build(); let error_code = match generic.code() { Some(code) => code, None => return Err(crate::operation::list_attached_indices::ListAttachedIndicesError::unhandled(generic)), }; let _error_message = generic.message().map(|msg| msg.to_owned()); Err(match error_code { "AccessDeniedException" => crate::operation::list_attached_indices::ListAttachedIndicesError::AccessDeniedException({ #[allow(unused_mut)] let mut tmp = { #[allow(unused_mut)] let mut output = crate::types::error::builders::AccessDeniedExceptionBuilder::default(); output = crate::protocol_serde::shape_access_denied_exception::de_access_denied_exception_json_err(_response_body, output) .map_err(crate::operation::list_attached_indices::ListAttachedIndicesError::unhandled)?; let output = output.meta(generic); output.build() }; if tmp.message.is_none() { tmp.message = _error_message; } tmp }), "DirectoryNotEnabledException" => crate::operation::list_attached_indices::ListAttachedIndicesError::DirectoryNotEnabledException({ #[allow(unused_mut)] let mut tmp = { #[allow(unused_mut)] let mut output = crate::types::error::builders::DirectoryNotEnabledExceptionBuilder::default(); output = crate::protocol_serde::shape_directory_not_enabled_exception::de_directory_not_enabled_exception_json_err(_response_body, output) .map_err(crate::operation::list_attached_indices::ListAttachedIndicesError::unhandled)?; let output = output.meta(generic); output.build() }; if tmp.message.is_none() { tmp.message = _error_message; } tmp }), "InternalServiceException" => crate::operation::list_attached_indices::ListAttachedIndicesError::InternalServiceException({ #[allow(unused_mut)] let mut tmp = { #[allow(unused_mut)] let mut output = crate::types::error::builders::InternalServiceExceptionBuilder::default(); output = crate::protocol_serde::shape_internal_service_exception::de_internal_service_exception_json_err(_response_body, output) .map_err(crate::operation::list_attached_indices::ListAttachedIndicesError::unhandled)?; let output = output.meta(generic); output.build() }; if tmp.message.is_none() { tmp.message = _error_message; } tmp }), "InvalidArnException" => crate::operation::list_attached_indices::ListAttachedIndicesError::InvalidArnException({ #[allow(unused_mut)] let mut tmp = { #[allow(unused_mut)] let mut output = crate::types::error::builders::InvalidArnExceptionBuilder::default(); output = crate::protocol_serde::shape_invalid_arn_exception::de_invalid_arn_exception_json_err(_response_body, output) .map_err(crate::operation::list_attached_indices::ListAttachedIndicesError::unhandled)?; let output = output.meta(generic); output.build() }; if tmp.message.is_none() { tmp.message = _error_message; } tmp }), "LimitExceededException" => crate::operation::list_attached_indices::ListAttachedIndicesError::LimitExceededException({ #[allow(unused_mut)] let mut tmp = { #[allow(unused_mut)] let mut output = crate::types::error::builders::LimitExceededExceptionBuilder::default(); output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output) .map_err(crate::operation::list_attached_indices::ListAttachedIndicesError::unhandled)?; let output = output.meta(generic); output.build() }; if tmp.message.is_none() { tmp.message = _error_message; } tmp }), "ResourceNotFoundException" => crate::operation::list_attached_indices::ListAttachedIndicesError::ResourceNotFoundException({ #[allow(unused_mut)] let mut tmp = { #[allow(unused_mut)] let mut output = crate::types::error::builders::ResourceNotFoundExceptionBuilder::default(); output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output) .map_err(crate::operation::list_attached_indices::ListAttachedIndicesError::unhandled)?; let output = output.meta(generic); output.build() }; if tmp.message.is_none() { tmp.message = _error_message; } tmp }), "RetryableConflictException" => crate::operation::list_attached_indices::ListAttachedIndicesError::RetryableConflictException({ #[allow(unused_mut)] let mut tmp = { #[allow(unused_mut)] let mut output = crate::types::error::builders::RetryableConflictExceptionBuilder::default(); output = crate::protocol_serde::shape_retryable_conflict_exception::de_retryable_conflict_exception_json_err(_response_body, output) .map_err(crate::operation::list_attached_indices::ListAttachedIndicesError::unhandled)?; let output = output.meta(generic); output.build() }; if tmp.message.is_none() { tmp.message = _error_message; } tmp }), "ValidationException" => crate::operation::list_attached_indices::ListAttachedIndicesError::ValidationException({ #[allow(unused_mut)] let mut tmp = { #[allow(unused_mut)] let mut output = crate::types::error::builders::ValidationExceptionBuilder::default(); output = crate::protocol_serde::shape_validation_exception::de_validation_exception_json_err(_response_body, output) .map_err(crate::operation::list_attached_indices::ListAttachedIndicesError::unhandled)?; let output = output.meta(generic); output.build() }; if tmp.message.is_none() { tmp.message = _error_message; } tmp }), _ => crate::operation::list_attached_indices::ListAttachedIndicesError::generic(generic), }) } #[allow(clippy::unnecessary_wraps)] pub fn de_list_attached_indices_http_response( _response_status: u16, _response_headers: &::aws_smithy_runtime_api::http::Headers, _response_body: &[u8], ) -> std::result::Result< crate::operation::list_attached_indices::ListAttachedIndicesOutput, crate::operation::list_attached_indices::ListAttachedIndicesError, > { Ok({ #[allow(unused_mut)] let mut output = crate::operation::list_attached_indices::builders::ListAttachedIndicesOutputBuilder::default(); output = crate::protocol_serde::shape_list_attached_indices::de_list_attached_indices(_response_body, output) .map_err(crate::operation::list_attached_indices::ListAttachedIndicesError::unhandled)?; output._set_request_id(::aws_types::request_id::RequestId::request_id(_response_headers).map(str::to_string)); output.build() }) } pub fn ser_list_attached_indices_headers( input: &crate::operation::list_attached_indices::ListAttachedIndicesInput, mut builder: ::http::request::Builder, ) -> std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> { if let ::std::option::Option::Some(inner_1) = &input.directory_arn { let formatted_2 = inner_1.as_str(); let header_value = formatted_2; let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| { ::aws_smithy_types::error::operation::BuildError::invalid_field( "directory_arn", format!("`{}` cannot be used as a header value: {}", &header_value, err), ) })?; builder = builder.header("x-amz-data-partition", header_value); } if let ::std::option::Option::Some(inner_3) = &input.consistency_level { let formatted_4 = inner_3.as_str(); let header_value = formatted_4; let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| { ::aws_smithy_types::error::operation::BuildError::invalid_field( "consistency_level", format!("`{}` cannot be used as a header value: {}", &header_value, err), ) })?; builder = builder.header("x-amz-consistency-level", header_value); } Ok(builder) } pub fn ser_list_attached_indices_input( input: &crate::operation::list_attached_indices::ListAttachedIndicesInput, ) -> Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> { let mut out = String::new(); let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out); crate::protocol_serde::shape_list_attached_indices_input::ser_list_attached_indices_input_input(&mut object, input)?; object.finish(); Ok(::aws_smithy_types::body::SdkBody::from(out)) } pub(crate) fn de_list_attached_indices( value: &[u8], mut builder: crate::operation::list_attached_indices::builders::ListAttachedIndicesOutputBuilder, ) -> Result< crate::operation::list_attached_indices::builders::ListAttachedIndicesOutputBuilder, ::aws_smithy_json::deserialize::error::DeserializeError, > { let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable(); let tokens = &mut tokens_owned; ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?; loop { match tokens.next().transpose()? { Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break, Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() { "IndexAttachments" => { builder = builder.set_index_attachments(crate::protocol_serde::shape_index_attachment_list::de_index_attachment_list(tokens)?); } "NextToken" => { builder = builder.set_next_token( ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())? .map(|s| s.to_unescaped().map(|u| u.into_owned())) .transpose()?, ); } _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, }, other => { return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!( "expected object key or end object, found: {:?}", other ))) } } } if tokens.next().is_some() { return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom( "found more JSON tokens after completing parsing", )); } Ok(builder) }