aws_sdk_sagemaker/protocol_serde/
shape_monitoring_baseline_config.rs1pub fn ser_monitoring_baseline_config(
3 object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
4 input: &crate::types::MonitoringBaselineConfig,
5) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
6 if let Some(var_1) = &input.baselining_job_name {
7 object.key("BaseliningJobName").string(var_1.as_str());
8 }
9 if let Some(var_2) = &input.constraints_resource {
10 #[allow(unused_mut)]
11 let mut object_3 = object.key("ConstraintsResource").start_object();
12 crate::protocol_serde::shape_monitoring_constraints_resource::ser_monitoring_constraints_resource(&mut object_3, var_2)?;
13 object_3.finish();
14 }
15 if let Some(var_4) = &input.statistics_resource {
16 #[allow(unused_mut)]
17 let mut object_5 = object.key("StatisticsResource").start_object();
18 crate::protocol_serde::shape_monitoring_statistics_resource::ser_monitoring_statistics_resource(&mut object_5, var_4)?;
19 object_5.finish();
20 }
21 Ok(())
22}
23
24pub(crate) fn de_monitoring_baseline_config<'a, I>(
25 tokens: &mut ::std::iter::Peekable<I>,
26) -> ::std::result::Result<Option<crate::types::MonitoringBaselineConfig>, ::aws_smithy_json::deserialize::error::DeserializeError>
27where
28 I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
29{
30 match tokens.next().transpose()? {
31 Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
32 Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
33 #[allow(unused_mut)]
34 let mut builder = crate::types::builders::MonitoringBaselineConfigBuilder::default();
35 loop {
36 match tokens.next().transpose()? {
37 Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
38 Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
39 "BaseliningJobName" => {
40 builder = builder.set_baselining_job_name(
41 ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
42 .map(|s| s.to_unescaped().map(|u| u.into_owned()))
43 .transpose()?,
44 );
45 }
46 "ConstraintsResource" => {
47 builder = builder.set_constraints_resource(
48 crate::protocol_serde::shape_monitoring_constraints_resource::de_monitoring_constraints_resource(tokens)?,
49 );
50 }
51 "StatisticsResource" => {
52 builder = builder.set_statistics_resource(
53 crate::protocol_serde::shape_monitoring_statistics_resource::de_monitoring_statistics_resource(tokens)?,
54 );
55 }
56 _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
57 },
58 other => {
59 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
60 "expected object key or end object, found: {:?}",
61 other
62 )))
63 }
64 }
65 }
66 Ok(Some(builder.build()))
67 }
68 _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
69 "expected start object or null",
70 )),
71 }
72}