#[derive(Debug, Default)]
pub struct Account {
properties: AccountProperties
}
#[derive(Debug, Default)]
pub struct AccountProperties {
pub expiry_events_configuration: ::Value<self::account::ExpiryEventsConfiguration>,
}
impl ::serde::Serialize for AccountProperties {
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, "ExpiryEventsConfiguration", &self.expiry_events_configuration)?;
::serde::ser::SerializeMap::end(map)
}
}
impl<'de> ::serde::Deserialize<'de> for AccountProperties {
fn deserialize<D: ::serde::Deserializer<'de>>(d: D) -> Result<AccountProperties, D::Error> {
struct Visitor;
impl<'de> ::serde::de::Visitor<'de> for Visitor {
type Value = AccountProperties;
fn expecting(&self, f: &mut ::std::fmt::Formatter) -> ::std::fmt::Result {
write!(f, "a struct of type AccountProperties")
}
fn visit_map<A: ::serde::de::MapAccess<'de>>(self, mut map: A) -> Result<Self::Value, A::Error> {
let mut expiry_events_configuration: Option<::Value<self::account::ExpiryEventsConfiguration>> = None;
while let Some(__cfn_key) = ::serde::de::MapAccess::next_key::<String>(&mut map)? {
match __cfn_key.as_ref() {
"ExpiryEventsConfiguration" => {
expiry_events_configuration = ::serde::de::MapAccess::next_value(&mut map)?;
}
_ => {}
}
}
Ok(AccountProperties {
expiry_events_configuration: expiry_events_configuration.ok_or(::serde::de::Error::missing_field("ExpiryEventsConfiguration"))?,
})
}
}
d.deserialize_map(Visitor)
}
}
impl ::Resource for Account {
type Properties = AccountProperties;
const TYPE: &'static str = "AWS::CertificateManager::Account";
fn properties(&self) -> &AccountProperties {
&self.properties
}
fn properties_mut(&mut self) -> &mut AccountProperties {
&mut self.properties
}
}
impl ::private::Sealed for Account {}
impl From<AccountProperties> for Account {
fn from(properties: AccountProperties) -> Account {
Account { properties }
}
}
#[derive(Debug, Default)]
pub struct Certificate {
properties: CertificateProperties
}
#[derive(Debug, Default)]
pub struct CertificateProperties {
pub certificate_authority_arn: Option<::Value<String>>,
pub certificate_transparency_logging_preference: Option<::Value<String>>,
pub domain_name: ::Value<String>,
pub domain_validation_options: Option<::ValueList<self::certificate::DomainValidationOption>>,
pub subject_alternative_names: Option<::ValueList<String>>,
pub tags: Option<::ValueList<::Tag>>,
pub validation_method: Option<::Value<String>>,
}
impl ::serde::Serialize for CertificateProperties {
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 certificate_authority_arn) = self.certificate_authority_arn {
::serde::ser::SerializeMap::serialize_entry(&mut map, "CertificateAuthorityArn", certificate_authority_arn)?;
}
if let Some(ref certificate_transparency_logging_preference) = self.certificate_transparency_logging_preference {
::serde::ser::SerializeMap::serialize_entry(&mut map, "CertificateTransparencyLoggingPreference", certificate_transparency_logging_preference)?;
}
::serde::ser::SerializeMap::serialize_entry(&mut map, "DomainName", &self.domain_name)?;
if let Some(ref domain_validation_options) = self.domain_validation_options {
::serde::ser::SerializeMap::serialize_entry(&mut map, "DomainValidationOptions", domain_validation_options)?;
}
if let Some(ref subject_alternative_names) = self.subject_alternative_names {
::serde::ser::SerializeMap::serialize_entry(&mut map, "SubjectAlternativeNames", subject_alternative_names)?;
}
if let Some(ref tags) = self.tags {
::serde::ser::SerializeMap::serialize_entry(&mut map, "Tags", tags)?;
}
if let Some(ref validation_method) = self.validation_method {
::serde::ser::SerializeMap::serialize_entry(&mut map, "ValidationMethod", validation_method)?;
}
::serde::ser::SerializeMap::end(map)
}
}
impl<'de> ::serde::Deserialize<'de> for CertificateProperties {
fn deserialize<D: ::serde::Deserializer<'de>>(d: D) -> Result<CertificateProperties, D::Error> {
struct Visitor;
impl<'de> ::serde::de::Visitor<'de> for Visitor {
type Value = CertificateProperties;
fn expecting(&self, f: &mut ::std::fmt::Formatter) -> ::std::fmt::Result {
write!(f, "a struct of type CertificateProperties")
}
fn visit_map<A: ::serde::de::MapAccess<'de>>(self, mut map: A) -> Result<Self::Value, A::Error> {
let mut certificate_authority_arn: Option<::Value<String>> = None;
let mut certificate_transparency_logging_preference: Option<::Value<String>> = None;
let mut domain_name: Option<::Value<String>> = None;
let mut domain_validation_options: Option<::ValueList<self::certificate::DomainValidationOption>> = None;
let mut subject_alternative_names: Option<::ValueList<String>> = None;
let mut tags: Option<::ValueList<::Tag>> = None;
let mut validation_method: Option<::Value<String>> = None;
while let Some(__cfn_key) = ::serde::de::MapAccess::next_key::<String>(&mut map)? {
match __cfn_key.as_ref() {
"CertificateAuthorityArn" => {
certificate_authority_arn = ::serde::de::MapAccess::next_value(&mut map)?;
}
"CertificateTransparencyLoggingPreference" => {
certificate_transparency_logging_preference = ::serde::de::MapAccess::next_value(&mut map)?;
}
"DomainName" => {
domain_name = ::serde::de::MapAccess::next_value(&mut map)?;
}
"DomainValidationOptions" => {
domain_validation_options = ::serde::de::MapAccess::next_value(&mut map)?;
}
"SubjectAlternativeNames" => {
subject_alternative_names = ::serde::de::MapAccess::next_value(&mut map)?;
}
"Tags" => {
tags = ::serde::de::MapAccess::next_value(&mut map)?;
}
"ValidationMethod" => {
validation_method = ::serde::de::MapAccess::next_value(&mut map)?;
}
_ => {}
}
}
Ok(CertificateProperties {
certificate_authority_arn: certificate_authority_arn,
certificate_transparency_logging_preference: certificate_transparency_logging_preference,
domain_name: domain_name.ok_or(::serde::de::Error::missing_field("DomainName"))?,
domain_validation_options: domain_validation_options,
subject_alternative_names: subject_alternative_names,
tags: tags,
validation_method: validation_method,
})
}
}
d.deserialize_map(Visitor)
}
}
impl ::Resource for Certificate {
type Properties = CertificateProperties;
const TYPE: &'static str = "AWS::CertificateManager::Certificate";
fn properties(&self) -> &CertificateProperties {
&self.properties
}
fn properties_mut(&mut self) -> &mut CertificateProperties {
&mut self.properties
}
}
impl ::private::Sealed for Certificate {}
impl From<CertificateProperties> for Certificate {
fn from(properties: CertificateProperties) -> Certificate {
Certificate { properties }
}
}
pub mod account {
#[derive(Debug, Default)]
pub struct ExpiryEventsConfiguration {
pub days_before_expiry: Option<::Value<u32>>,
}
impl ::codec::SerializeValue for ExpiryEventsConfiguration {
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 days_before_expiry) = self.days_before_expiry {
::serde::ser::SerializeMap::serialize_entry(&mut map, "DaysBeforeExpiry", days_before_expiry)?;
}
::serde::ser::SerializeMap::end(map)
}
}
impl ::codec::DeserializeValue for ExpiryEventsConfiguration {
fn deserialize<'de, D: ::serde::Deserializer<'de>>(d: D) -> Result<ExpiryEventsConfiguration, D::Error> {
struct Visitor;
impl<'de> ::serde::de::Visitor<'de> for Visitor {
type Value = ExpiryEventsConfiguration;
fn expecting(&self, f: &mut ::std::fmt::Formatter) -> ::std::fmt::Result {
write!(f, "a struct of type ExpiryEventsConfiguration")
}
fn visit_map<A: ::serde::de::MapAccess<'de>>(self, mut map: A) -> Result<Self::Value, A::Error> {
let mut days_before_expiry: Option<::Value<u32>> = None;
while let Some(__cfn_key) = ::serde::de::MapAccess::next_key::<String>(&mut map)? {
match __cfn_key.as_ref() {
"DaysBeforeExpiry" => {
days_before_expiry = ::serde::de::MapAccess::next_value(&mut map)?;
}
_ => {}
}
}
Ok(ExpiryEventsConfiguration {
days_before_expiry: days_before_expiry,
})
}
}
d.deserialize_map(Visitor)
}
}
}
pub mod certificate {
#[derive(Debug, Default)]
pub struct DomainValidationOption {
pub domain_name: ::Value<String>,
pub hosted_zone_id: Option<::Value<String>>,
pub validation_domain: Option<::Value<String>>,
}
impl ::codec::SerializeValue for DomainValidationOption {
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, "DomainName", &self.domain_name)?;
if let Some(ref hosted_zone_id) = self.hosted_zone_id {
::serde::ser::SerializeMap::serialize_entry(&mut map, "HostedZoneId", hosted_zone_id)?;
}
if let Some(ref validation_domain) = self.validation_domain {
::serde::ser::SerializeMap::serialize_entry(&mut map, "ValidationDomain", validation_domain)?;
}
::serde::ser::SerializeMap::end(map)
}
}
impl ::codec::DeserializeValue for DomainValidationOption {
fn deserialize<'de, D: ::serde::Deserializer<'de>>(d: D) -> Result<DomainValidationOption, D::Error> {
struct Visitor;
impl<'de> ::serde::de::Visitor<'de> for Visitor {
type Value = DomainValidationOption;
fn expecting(&self, f: &mut ::std::fmt::Formatter) -> ::std::fmt::Result {
write!(f, "a struct of type DomainValidationOption")
}
fn visit_map<A: ::serde::de::MapAccess<'de>>(self, mut map: A) -> Result<Self::Value, A::Error> {
let mut domain_name: Option<::Value<String>> = None;
let mut hosted_zone_id: Option<::Value<String>> = None;
let mut validation_domain: Option<::Value<String>> = None;
while let Some(__cfn_key) = ::serde::de::MapAccess::next_key::<String>(&mut map)? {
match __cfn_key.as_ref() {
"DomainName" => {
domain_name = ::serde::de::MapAccess::next_value(&mut map)?;
}
"HostedZoneId" => {
hosted_zone_id = ::serde::de::MapAccess::next_value(&mut map)?;
}
"ValidationDomain" => {
validation_domain = ::serde::de::MapAccess::next_value(&mut map)?;
}
_ => {}
}
}
Ok(DomainValidationOption {
domain_name: domain_name.ok_or(::serde::de::Error::missing_field("DomainName"))?,
hosted_zone_id: hosted_zone_id,
validation_domain: validation_domain,
})
}
}
d.deserialize_map(Visitor)
}
}
}