#[derive(Debug, Default)]
pub struct FlowTemplate {
properties: FlowTemplateProperties
}
#[derive(Debug, Default)]
pub struct FlowTemplateProperties {
pub compatible_namespace_version: Option<::Value<f64>>,
pub definition: ::Value<self::flow_template::DefinitionDocument>,
}
impl ::serde::Serialize for FlowTemplateProperties {
fn serialize<S: ::serde::Serializer>(&self, s: S) -> Result<S::Ok, S::Error> {
let mut map = ::serde::Serializer::serialize_map(s, None)?;
if let Some(ref compatible_namespace_version) = self.compatible_namespace_version {
::serde::ser::SerializeMap::serialize_entry(&mut map, "CompatibleNamespaceVersion", compatible_namespace_version)?;
}
::serde::ser::SerializeMap::serialize_entry(&mut map, "Definition", &self.definition)?;
::serde::ser::SerializeMap::end(map)
}
}
impl<'de> ::serde::Deserialize<'de> for FlowTemplateProperties {
fn deserialize<D: ::serde::Deserializer<'de>>(d: D) -> Result<FlowTemplateProperties, D::Error> {
struct Visitor;
impl<'de> ::serde::de::Visitor<'de> for Visitor {
type Value = FlowTemplateProperties;
fn expecting(&self, f: &mut ::std::fmt::Formatter) -> ::std::fmt::Result {
write!(f, "a struct of type FlowTemplateProperties")
}
fn visit_map<A: ::serde::de::MapAccess<'de>>(self, mut map: A) -> Result<Self::Value, A::Error> {
let mut compatible_namespace_version: Option<::Value<f64>> = None;
let mut definition: Option<::Value<self::flow_template::DefinitionDocument>> = None;
while let Some(__cfn_key) = ::serde::de::MapAccess::next_key::<String>(&mut map)? {
match __cfn_key.as_ref() {
"CompatibleNamespaceVersion" => {
compatible_namespace_version = ::serde::de::MapAccess::next_value(&mut map)?;
}
"Definition" => {
definition = ::serde::de::MapAccess::next_value(&mut map)?;
}
_ => {}
}
}
Ok(FlowTemplateProperties {
compatible_namespace_version: compatible_namespace_version,
definition: definition.ok_or(::serde::de::Error::missing_field("Definition"))?,
})
}
}
d.deserialize_map(Visitor)
}
}
impl ::Resource for FlowTemplate {
type Properties = FlowTemplateProperties;
const TYPE: &'static str = "AWS::IoTThingsGraph::FlowTemplate";
fn properties(&self) -> &FlowTemplateProperties {
&self.properties
}
fn properties_mut(&mut self) -> &mut FlowTemplateProperties {
&mut self.properties
}
}
impl ::private::Sealed for FlowTemplate {}
impl From<FlowTemplateProperties> for FlowTemplate {
fn from(properties: FlowTemplateProperties) -> FlowTemplate {
FlowTemplate { properties }
}
}
pub mod flow_template {
#[derive(Debug, Default)]
pub struct DefinitionDocument {
pub language: ::Value<String>,
pub text: ::Value<String>,
}
impl ::codec::SerializeValue for DefinitionDocument {
fn serialize<S: ::serde::Serializer>(&self, s: S) -> Result<S::Ok, S::Error> {
let mut map = ::serde::Serializer::serialize_map(s, None)?;
::serde::ser::SerializeMap::serialize_entry(&mut map, "Language", &self.language)?;
::serde::ser::SerializeMap::serialize_entry(&mut map, "Text", &self.text)?;
::serde::ser::SerializeMap::end(map)
}
}
impl ::codec::DeserializeValue for DefinitionDocument {
fn deserialize<'de, D: ::serde::Deserializer<'de>>(d: D) -> Result<DefinitionDocument, D::Error> {
struct Visitor;
impl<'de> ::serde::de::Visitor<'de> for Visitor {
type Value = DefinitionDocument;
fn expecting(&self, f: &mut ::std::fmt::Formatter) -> ::std::fmt::Result {
write!(f, "a struct of type DefinitionDocument")
}
fn visit_map<A: ::serde::de::MapAccess<'de>>(self, mut map: A) -> Result<Self::Value, A::Error> {
let mut language: Option<::Value<String>> = None;
let mut text: Option<::Value<String>> = None;
while let Some(__cfn_key) = ::serde::de::MapAccess::next_key::<String>(&mut map)? {
match __cfn_key.as_ref() {
"Language" => {
language = ::serde::de::MapAccess::next_value(&mut map)?;
}
"Text" => {
text = ::serde::de::MapAccess::next_value(&mut map)?;
}
_ => {}
}
}
Ok(DefinitionDocument {
language: language.ok_or(::serde::de::Error::missing_field("Language"))?,
text: text.ok_or(::serde::de::Error::missing_field("Text"))?,
})
}
}
d.deserialize_map(Visitor)
}
}
}