use serde::{Deserialize, Deserializer, Serialize, Serializer};
#[non_exhaustive]
#[derive(Clone, Debug, Eq, PartialEq)]
pub enum ObservabilityPipelineKafkaDestinationCompression {
NONE,
GZIP,
SNAPPY,
LZ4,
ZSTD,
UnparsedObject(crate::datadog::UnparsedObject),
}
impl ToString for ObservabilityPipelineKafkaDestinationCompression {
fn to_string(&self) -> String {
match self {
Self::NONE => String::from("none"),
Self::GZIP => String::from("gzip"),
Self::SNAPPY => String::from("snappy"),
Self::LZ4 => String::from("lz4"),
Self::ZSTD => String::from("zstd"),
Self::UnparsedObject(v) => v.value.to_string(),
}
}
}
impl Serialize for ObservabilityPipelineKafkaDestinationCompression {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: Serializer,
{
match self {
Self::UnparsedObject(v) => v.serialize(serializer),
_ => serializer.serialize_str(self.to_string().as_str()),
}
}
}
impl<'de> Deserialize<'de> for ObservabilityPipelineKafkaDestinationCompression {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where
D: Deserializer<'de>,
{
let s: String = String::deserialize(deserializer)?;
Ok(match s.as_str() {
"none" => Self::NONE,
"gzip" => Self::GZIP,
"snappy" => Self::SNAPPY,
"lz4" => Self::LZ4,
"zstd" => Self::ZSTD,
_ => Self::UnparsedObject(crate::datadog::UnparsedObject {
value: serde_json::Value::String(s.into()),
}),
})
}
}