#[derive(Debug, Default)]
pub struct Channel {
properties: ChannelProperties
}
#[derive(Debug, Default)]
pub struct ChannelProperties {
pub authorized: Option<::Value<bool>>,
pub latency_mode: Option<::Value<String>>,
pub name: Option<::Value<String>>,
pub recording_configuration_arn: Option<::Value<String>>,
pub tags: Option<::ValueList<::Tag>>,
pub r#type: Option<::Value<String>>,
}
impl ::serde::Serialize for ChannelProperties {
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 authorized) = self.authorized {
::serde::ser::SerializeMap::serialize_entry(&mut map, "Authorized", authorized)?;
}
if let Some(ref latency_mode) = self.latency_mode {
::serde::ser::SerializeMap::serialize_entry(&mut map, "LatencyMode", latency_mode)?;
}
if let Some(ref name) = self.name {
::serde::ser::SerializeMap::serialize_entry(&mut map, "Name", name)?;
}
if let Some(ref recording_configuration_arn) = self.recording_configuration_arn {
::serde::ser::SerializeMap::serialize_entry(&mut map, "RecordingConfigurationArn", recording_configuration_arn)?;
}
if let Some(ref tags) = self.tags {
::serde::ser::SerializeMap::serialize_entry(&mut map, "Tags", tags)?;
}
if let Some(ref r#type) = self.r#type {
::serde::ser::SerializeMap::serialize_entry(&mut map, "Type", r#type)?;
}
::serde::ser::SerializeMap::end(map)
}
}
impl<'de> ::serde::Deserialize<'de> for ChannelProperties {
fn deserialize<D: ::serde::Deserializer<'de>>(d: D) -> Result<ChannelProperties, D::Error> {
struct Visitor;
impl<'de> ::serde::de::Visitor<'de> for Visitor {
type Value = ChannelProperties;
fn expecting(&self, f: &mut ::std::fmt::Formatter) -> ::std::fmt::Result {
write!(f, "a struct of type ChannelProperties")
}
fn visit_map<A: ::serde::de::MapAccess<'de>>(self, mut map: A) -> Result<Self::Value, A::Error> {
let mut authorized: Option<::Value<bool>> = None;
let mut latency_mode: Option<::Value<String>> = None;
let mut name: Option<::Value<String>> = None;
let mut recording_configuration_arn: Option<::Value<String>> = None;
let mut tags: Option<::ValueList<::Tag>> = None;
let mut r#type: Option<::Value<String>> = None;
while let Some(__cfn_key) = ::serde::de::MapAccess::next_key::<String>(&mut map)? {
match __cfn_key.as_ref() {
"Authorized" => {
authorized = ::serde::de::MapAccess::next_value(&mut map)?;
}
"LatencyMode" => {
latency_mode = ::serde::de::MapAccess::next_value(&mut map)?;
}
"Name" => {
name = ::serde::de::MapAccess::next_value(&mut map)?;
}
"RecordingConfigurationArn" => {
recording_configuration_arn = ::serde::de::MapAccess::next_value(&mut map)?;
}
"Tags" => {
tags = ::serde::de::MapAccess::next_value(&mut map)?;
}
"Type" => {
r#type = ::serde::de::MapAccess::next_value(&mut map)?;
}
_ => {}
}
}
Ok(ChannelProperties {
authorized: authorized,
latency_mode: latency_mode,
name: name,
recording_configuration_arn: recording_configuration_arn,
tags: tags,
r#type: r#type,
})
}
}
d.deserialize_map(Visitor)
}
}
impl ::Resource for Channel {
type Properties = ChannelProperties;
const TYPE: &'static str = "AWS::IVS::Channel";
fn properties(&self) -> &ChannelProperties {
&self.properties
}
fn properties_mut(&mut self) -> &mut ChannelProperties {
&mut self.properties
}
}
impl ::private::Sealed for Channel {}
impl From<ChannelProperties> for Channel {
fn from(properties: ChannelProperties) -> Channel {
Channel { properties }
}
}
#[derive(Debug, Default)]
pub struct PlaybackKeyPair {
properties: PlaybackKeyPairProperties
}
#[derive(Debug, Default)]
pub struct PlaybackKeyPairProperties {
pub name: Option<::Value<String>>,
pub public_key_material: ::Value<String>,
pub tags: Option<::ValueList<::Tag>>,
}
impl ::serde::Serialize for PlaybackKeyPairProperties {
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 name) = self.name {
::serde::ser::SerializeMap::serialize_entry(&mut map, "Name", name)?;
}
::serde::ser::SerializeMap::serialize_entry(&mut map, "PublicKeyMaterial", &self.public_key_material)?;
if let Some(ref tags) = self.tags {
::serde::ser::SerializeMap::serialize_entry(&mut map, "Tags", tags)?;
}
::serde::ser::SerializeMap::end(map)
}
}
impl<'de> ::serde::Deserialize<'de> for PlaybackKeyPairProperties {
fn deserialize<D: ::serde::Deserializer<'de>>(d: D) -> Result<PlaybackKeyPairProperties, D::Error> {
struct Visitor;
impl<'de> ::serde::de::Visitor<'de> for Visitor {
type Value = PlaybackKeyPairProperties;
fn expecting(&self, f: &mut ::std::fmt::Formatter) -> ::std::fmt::Result {
write!(f, "a struct of type PlaybackKeyPairProperties")
}
fn visit_map<A: ::serde::de::MapAccess<'de>>(self, mut map: A) -> Result<Self::Value, A::Error> {
let mut name: Option<::Value<String>> = None;
let mut public_key_material: Option<::Value<String>> = None;
let mut tags: Option<::ValueList<::Tag>> = None;
while let Some(__cfn_key) = ::serde::de::MapAccess::next_key::<String>(&mut map)? {
match __cfn_key.as_ref() {
"Name" => {
name = ::serde::de::MapAccess::next_value(&mut map)?;
}
"PublicKeyMaterial" => {
public_key_material = ::serde::de::MapAccess::next_value(&mut map)?;
}
"Tags" => {
tags = ::serde::de::MapAccess::next_value(&mut map)?;
}
_ => {}
}
}
Ok(PlaybackKeyPairProperties {
name: name,
public_key_material: public_key_material.ok_or(::serde::de::Error::missing_field("PublicKeyMaterial"))?,
tags: tags,
})
}
}
d.deserialize_map(Visitor)
}
}
impl ::Resource for PlaybackKeyPair {
type Properties = PlaybackKeyPairProperties;
const TYPE: &'static str = "AWS::IVS::PlaybackKeyPair";
fn properties(&self) -> &PlaybackKeyPairProperties {
&self.properties
}
fn properties_mut(&mut self) -> &mut PlaybackKeyPairProperties {
&mut self.properties
}
}
impl ::private::Sealed for PlaybackKeyPair {}
impl From<PlaybackKeyPairProperties> for PlaybackKeyPair {
fn from(properties: PlaybackKeyPairProperties) -> PlaybackKeyPair {
PlaybackKeyPair { properties }
}
}
#[derive(Debug, Default)]
pub struct RecordingConfiguration {
properties: RecordingConfigurationProperties
}
#[derive(Debug, Default)]
pub struct RecordingConfigurationProperties {
pub destination_configuration: ::Value<self::recording_configuration::DestinationConfiguration>,
pub name: Option<::Value<String>>,
pub tags: Option<::ValueList<::Tag>>,
}
impl ::serde::Serialize for RecordingConfigurationProperties {
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, "DestinationConfiguration", &self.destination_configuration)?;
if let Some(ref name) = self.name {
::serde::ser::SerializeMap::serialize_entry(&mut map, "Name", name)?;
}
if let Some(ref tags) = self.tags {
::serde::ser::SerializeMap::serialize_entry(&mut map, "Tags", tags)?;
}
::serde::ser::SerializeMap::end(map)
}
}
impl<'de> ::serde::Deserialize<'de> for RecordingConfigurationProperties {
fn deserialize<D: ::serde::Deserializer<'de>>(d: D) -> Result<RecordingConfigurationProperties, D::Error> {
struct Visitor;
impl<'de> ::serde::de::Visitor<'de> for Visitor {
type Value = RecordingConfigurationProperties;
fn expecting(&self, f: &mut ::std::fmt::Formatter) -> ::std::fmt::Result {
write!(f, "a struct of type RecordingConfigurationProperties")
}
fn visit_map<A: ::serde::de::MapAccess<'de>>(self, mut map: A) -> Result<Self::Value, A::Error> {
let mut destination_configuration: Option<::Value<self::recording_configuration::DestinationConfiguration>> = None;
let mut name: Option<::Value<String>> = None;
let mut tags: Option<::ValueList<::Tag>> = None;
while let Some(__cfn_key) = ::serde::de::MapAccess::next_key::<String>(&mut map)? {
match __cfn_key.as_ref() {
"DestinationConfiguration" => {
destination_configuration = ::serde::de::MapAccess::next_value(&mut map)?;
}
"Name" => {
name = ::serde::de::MapAccess::next_value(&mut map)?;
}
"Tags" => {
tags = ::serde::de::MapAccess::next_value(&mut map)?;
}
_ => {}
}
}
Ok(RecordingConfigurationProperties {
destination_configuration: destination_configuration.ok_or(::serde::de::Error::missing_field("DestinationConfiguration"))?,
name: name,
tags: tags,
})
}
}
d.deserialize_map(Visitor)
}
}
impl ::Resource for RecordingConfiguration {
type Properties = RecordingConfigurationProperties;
const TYPE: &'static str = "AWS::IVS::RecordingConfiguration";
fn properties(&self) -> &RecordingConfigurationProperties {
&self.properties
}
fn properties_mut(&mut self) -> &mut RecordingConfigurationProperties {
&mut self.properties
}
}
impl ::private::Sealed for RecordingConfiguration {}
impl From<RecordingConfigurationProperties> for RecordingConfiguration {
fn from(properties: RecordingConfigurationProperties) -> RecordingConfiguration {
RecordingConfiguration { properties }
}
}
#[derive(Debug, Default)]
pub struct StreamKey {
properties: StreamKeyProperties
}
#[derive(Debug, Default)]
pub struct StreamKeyProperties {
pub channel_arn: ::Value<String>,
pub tags: Option<::ValueList<::Tag>>,
}
impl ::serde::Serialize for StreamKeyProperties {
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, "ChannelArn", &self.channel_arn)?;
if let Some(ref tags) = self.tags {
::serde::ser::SerializeMap::serialize_entry(&mut map, "Tags", tags)?;
}
::serde::ser::SerializeMap::end(map)
}
}
impl<'de> ::serde::Deserialize<'de> for StreamKeyProperties {
fn deserialize<D: ::serde::Deserializer<'de>>(d: D) -> Result<StreamKeyProperties, D::Error> {
struct Visitor;
impl<'de> ::serde::de::Visitor<'de> for Visitor {
type Value = StreamKeyProperties;
fn expecting(&self, f: &mut ::std::fmt::Formatter) -> ::std::fmt::Result {
write!(f, "a struct of type StreamKeyProperties")
}
fn visit_map<A: ::serde::de::MapAccess<'de>>(self, mut map: A) -> Result<Self::Value, A::Error> {
let mut channel_arn: Option<::Value<String>> = None;
let mut tags: Option<::ValueList<::Tag>> = None;
while let Some(__cfn_key) = ::serde::de::MapAccess::next_key::<String>(&mut map)? {
match __cfn_key.as_ref() {
"ChannelArn" => {
channel_arn = ::serde::de::MapAccess::next_value(&mut map)?;
}
"Tags" => {
tags = ::serde::de::MapAccess::next_value(&mut map)?;
}
_ => {}
}
}
Ok(StreamKeyProperties {
channel_arn: channel_arn.ok_or(::serde::de::Error::missing_field("ChannelArn"))?,
tags: tags,
})
}
}
d.deserialize_map(Visitor)
}
}
impl ::Resource for StreamKey {
type Properties = StreamKeyProperties;
const TYPE: &'static str = "AWS::IVS::StreamKey";
fn properties(&self) -> &StreamKeyProperties {
&self.properties
}
fn properties_mut(&mut self) -> &mut StreamKeyProperties {
&mut self.properties
}
}
impl ::private::Sealed for StreamKey {}
impl From<StreamKeyProperties> for StreamKey {
fn from(properties: StreamKeyProperties) -> StreamKey {
StreamKey { properties }
}
}
pub mod recording_configuration {
#[derive(Debug, Default)]
pub struct DestinationConfiguration {
pub s3: ::Value<S3DestinationConfiguration>,
}
impl ::codec::SerializeValue for DestinationConfiguration {
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, "S3", &self.s3)?;
::serde::ser::SerializeMap::end(map)
}
}
impl ::codec::DeserializeValue for DestinationConfiguration {
fn deserialize<'de, D: ::serde::Deserializer<'de>>(d: D) -> Result<DestinationConfiguration, D::Error> {
struct Visitor;
impl<'de> ::serde::de::Visitor<'de> for Visitor {
type Value = DestinationConfiguration;
fn expecting(&self, f: &mut ::std::fmt::Formatter) -> ::std::fmt::Result {
write!(f, "a struct of type DestinationConfiguration")
}
fn visit_map<A: ::serde::de::MapAccess<'de>>(self, mut map: A) -> Result<Self::Value, A::Error> {
let mut s3: Option<::Value<S3DestinationConfiguration>> = None;
while let Some(__cfn_key) = ::serde::de::MapAccess::next_key::<String>(&mut map)? {
match __cfn_key.as_ref() {
"S3" => {
s3 = ::serde::de::MapAccess::next_value(&mut map)?;
}
_ => {}
}
}
Ok(DestinationConfiguration {
s3: s3.ok_or(::serde::de::Error::missing_field("S3"))?,
})
}
}
d.deserialize_map(Visitor)
}
}
#[derive(Debug, Default)]
pub struct S3DestinationConfiguration {
pub bucket_name: ::Value<String>,
}
impl ::codec::SerializeValue for S3DestinationConfiguration {
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, "BucketName", &self.bucket_name)?;
::serde::ser::SerializeMap::end(map)
}
}
impl ::codec::DeserializeValue for S3DestinationConfiguration {
fn deserialize<'de, D: ::serde::Deserializer<'de>>(d: D) -> Result<S3DestinationConfiguration, D::Error> {
struct Visitor;
impl<'de> ::serde::de::Visitor<'de> for Visitor {
type Value = S3DestinationConfiguration;
fn expecting(&self, f: &mut ::std::fmt::Formatter) -> ::std::fmt::Result {
write!(f, "a struct of type S3DestinationConfiguration")
}
fn visit_map<A: ::serde::de::MapAccess<'de>>(self, mut map: A) -> Result<Self::Value, A::Error> {
let mut bucket_name: Option<::Value<String>> = None;
while let Some(__cfn_key) = ::serde::de::MapAccess::next_key::<String>(&mut map)? {
match __cfn_key.as_ref() {
"BucketName" => {
bucket_name = ::serde::de::MapAccess::next_value(&mut map)?;
}
_ => {}
}
}
Ok(S3DestinationConfiguration {
bucket_name: bucket_name.ok_or(::serde::de::Error::missing_field("BucketName"))?,
})
}
}
d.deserialize_map(Visitor)
}
}
}