#[allow(clippy::unnecessary_wraps)]
pub fn de_get_experiment_config_http_error(_response_status: u16, _response_headers: &::aws_smithy_runtime_api::http::Headers, _response_body: &[u8]) -> std::result::Result<crate::operation::get_experiment_config::GetExperimentConfigOutput, crate::operation::get_experiment_config::GetExperimentConfigError> {
#[allow(unused_mut)]
let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body).map_err(crate::operation::get_experiment_config::GetExperimentConfigError::unhandled)?;
let generic = generic_builder.build();
let error_code = match generic.code() {
Some(code) => code,
None => return Err(crate::operation::get_experiment_config::GetExperimentConfigError::unhandled(generic))
};
let _error_message = generic.message().map(|msg|msg.to_owned());
Err(match error_code {
"InternalServerError" => crate::operation::get_experiment_config::GetExperimentConfigError::InternalServerError({
#[allow(unused_mut)]
let mut tmp =
{
#[allow(unused_mut)]
let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::get_experiment_config::GetExperimentConfigError::unhandled)?;
let output = output.meta(generic);
output.build()
}
;
if tmp.message.is_none() {
tmp.message = _error_message;
}
tmp
}),
_ => crate::operation::get_experiment_config::GetExperimentConfigError::generic(generic)
})
}
#[allow(clippy::unnecessary_wraps)]
pub fn de_get_experiment_config_http_response(_response_status: u16, _response_headers: &::aws_smithy_runtime_api::http::Headers, _response_body: &[u8]) -> std::result::Result<crate::operation::get_experiment_config::GetExperimentConfigOutput, crate::operation::get_experiment_config::GetExperimentConfigError> {
Ok({
#[allow(unused_mut)]
let mut output = crate::operation::get_experiment_config::builders::GetExperimentConfigOutputBuilder::default();
output = crate::protocol_serde::shape_get_experiment_config::de_get_experiment_config(_response_body, output).map_err(crate::operation::get_experiment_config::GetExperimentConfigError::unhandled)?;
output = output.set_last_modified(
crate::protocol_serde::shape_get_experiment_config_output::de_last_modified_header(_response_headers)
.map_err(|_|crate::operation::get_experiment_config::GetExperimentConfigError::unhandled("Failed to parse last_modified from header `last-modified"))?
);
crate::serde_util::get_experiment_config_output_output_correct_errors(output).build().map_err(crate::operation::get_experiment_config::GetExperimentConfigError::unhandled)?
})
}
pub fn ser_get_experiment_config_headers(
input: &crate::operation::get_experiment_config::GetExperimentConfigInput,
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.workspace_id {
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("workspace_id", format!(
"`{}` cannot be used as a header value: {}",
&header_value,
err
))
})?;
builder = builder.header("x-workspace", header_value);
}
if let ::std::option::Option::Some(inner_3) = &input.org_id {
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("org_id", format!(
"`{}` cannot be used as a header value: {}",
&header_value,
err
))
})?;
builder = builder.header("x-org-id", header_value);
}
if let ::std::option::Option::Some(inner_5) = &input.if_modified_since {
let formatted_6 = inner_5.fmt(::aws_smithy_types::date_time::Format::DateTime)?;
let header_value = formatted_6;
let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
::aws_smithy_types::error::operation::BuildError::invalid_field("if_modified_since", format!(
"`{}` cannot be used as a header value: {}",
&header_value,
err
))
})?;
builder = builder.header("if-modified-since", header_value);
}
Ok(builder)
}
pub fn ser_get_experiment_config_input(input: &crate::operation::get_experiment_config::GetExperimentConfigInput) -> ::std::result::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_get_experiment_config_input::ser_get_experiment_config_input_input(&mut object, input)?;
object.finish();
Ok(::aws_smithy_types::body::SdkBody::from(out))
}
pub(crate) fn de_get_experiment_config(value: &[u8], mut builder: crate::operation::get_experiment_config::builders::GetExperimentConfigOutputBuilder) -> ::std::result::Result<crate::operation::get_experiment_config::builders::GetExperimentConfigOutputBuilder, ::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() {
"experiment_groups" => {
builder = builder.set_experiment_groups(
crate::protocol_serde::shape_experiment_group_list::de_experiment_group_list(tokens)?
);
}
"experiments" => {
builder = builder.set_experiments(
crate::protocol_serde::shape_experiment_list::de_experiment_list(tokens)?
);
}
_ => ::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)
}