pub(crate) fn de_default_run_setting<'a, I>(
tokens: &mut ::std::iter::Peekable<I>,
_value: &'a [u8],
) -> ::std::result::Result<Option<crate::types::DefaultRunSetting>, ::aws_smithy_json::deserialize::error::DeserializeError>
where
I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
{
match tokens.next().transpose()? {
Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
#[allow(unused_mut)]
let mut builder = crate::types::builders::DefaultRunSettingBuilder::default();
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() {
"workflowId" => {
builder = builder.set_workflow_id(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| u.into_owned()))
.transpose()?,
);
}
"workflowType" => {
builder = builder.set_workflow_type(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| crate::types::WorkflowType::from(u.as_ref())))
.transpose()?,
);
}
"roleArn" => {
builder = builder.set_role_arn(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| u.into_owned()))
.transpose()?,
);
}
"name" => {
builder = builder.set_name(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| u.into_owned()))
.transpose()?,
);
}
"cacheId" => {
builder = builder.set_cache_id(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| u.into_owned()))
.transpose()?,
);
}
"cacheBehavior" => {
builder = builder.set_cache_behavior(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| crate::types::CacheBehavior::from(u.as_ref())))
.transpose()?,
);
}
"runGroupId" => {
builder = builder.set_run_group_id(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| u.into_owned()))
.transpose()?,
);
}
"priority" => {
builder = builder.set_priority(
::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
.map(i32::try_from)
.transpose()?,
);
}
"parameters" => {
builder = builder.set_parameters(Some(::aws_smithy_json::deserialize::token::expect_document(tokens)?));
}
"storageCapacity" => {
builder = builder.set_storage_capacity(
::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
.map(i32::try_from)
.transpose()?,
);
}
"outputUri" => {
builder = builder.set_output_uri(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| u.into_owned()))
.transpose()?,
);
}
"logLevel" => {
builder = builder.set_log_level(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| crate::types::RunLogLevel::from(u.as_ref())))
.transpose()?,
);
}
"runTags" => {
builder = builder.set_run_tags(crate::protocol_serde::shape_tag_map::de_tag_map(tokens, _value)?);
}
"retentionMode" => {
builder = builder.set_retention_mode(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| crate::types::RunRetentionMode::from(u.as_ref())))
.transpose()?,
);
}
"storageType" => {
builder = builder.set_storage_type(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| crate::types::StorageType::from(u.as_ref())))
.transpose()?,
);
}
"workflowOwnerId" => {
builder = builder.set_workflow_owner_id(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| u.into_owned()))
.transpose()?,
);
}
"outputBucketOwnerId" => {
builder = builder.set_output_bucket_owner_id(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| u.into_owned()))
.transpose()?,
);
}
"workflowVersionName" => {
builder = builder.set_workflow_version_name(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| u.into_owned()))
.transpose()?,
);
}
"networkingMode" => {
builder = builder.set_networking_mode(
::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
.map(|s| s.to_unescaped().map(|u| crate::types::NetworkingMode::from(u.as_ref())))
.transpose()?,
);
}
"configurationName" => {
builder = builder.set_configuration_name(
::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:?}"
)))
}
}
}
Ok(Some(crate::serde_util::default_run_setting_correct_errors(builder).build().map_err(
|err| ::aws_smithy_json::deserialize::error::DeserializeError::custom_source("Response was invalid", err),
)?))
}
_ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
"expected start object or null",
)),
}
}
pub fn ser_default_run_setting(
object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
input: &crate::types::DefaultRunSetting,
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
{
object.key("workflowId").string(input.workflow_id.as_str());
}
if let Some(var_1) = &input.workflow_type {
object.key("workflowType").string(var_1.as_str());
}
{
object.key("roleArn").string(input.role_arn.as_str());
}
if let Some(var_2) = &input.name {
object.key("name").string(var_2.as_str());
}
if let Some(var_3) = &input.cache_id {
object.key("cacheId").string(var_3.as_str());
}
if let Some(var_4) = &input.cache_behavior {
object.key("cacheBehavior").string(var_4.as_str());
}
if let Some(var_5) = &input.run_group_id {
object.key("runGroupId").string(var_5.as_str());
}
if let Some(var_6) = &input.priority {
object.key("priority").number(
#[allow(clippy::useless_conversion)]
::aws_smithy_types::Number::NegInt((*var_6).into()),
);
}
if let Some(var_7) = &input.parameters {
object.key("parameters").document(var_7);
}
if let Some(var_8) = &input.storage_capacity {
object.key("storageCapacity").number(
#[allow(clippy::useless_conversion)]
::aws_smithy_types::Number::NegInt((*var_8).into()),
);
}
if let Some(var_9) = &input.output_uri {
object.key("outputUri").string(var_9.as_str());
}
if let Some(var_10) = &input.log_level {
object.key("logLevel").string(var_10.as_str());
}
if let Some(var_11) = &input.run_tags {
#[allow(unused_mut)]
let mut object_12 = object.key("runTags").start_object();
for (key_13, value_14) in var_11 {
{
object_12.key(key_13.as_str()).string(value_14.as_str());
}
}
object_12.finish();
}
if let Some(var_15) = &input.retention_mode {
object.key("retentionMode").string(var_15.as_str());
}
if let Some(var_16) = &input.storage_type {
object.key("storageType").string(var_16.as_str());
}
if let Some(var_17) = &input.workflow_owner_id {
object.key("workflowOwnerId").string(var_17.as_str());
}
if let Some(var_18) = &input.output_bucket_owner_id {
object.key("outputBucketOwnerId").string(var_18.as_str());
}
if let Some(var_19) = &input.workflow_version_name {
object.key("workflowVersionName").string(var_19.as_str());
}
if let Some(var_20) = &input.networking_mode {
object.key("networkingMode").string(var_20.as_str());
}
if let Some(var_21) = &input.configuration_name {
object.key("configurationName").string(var_21.as_str());
}
Ok(())
}