vcard_parser 0.2.3

Parses and validates vCard data according to RFC 6350 specification.
Documentation
use crate::constants::{ParameterName, ValueType};
use crate::traits::HasName;
use crate::vcard::value::value_text::ValueTextData;
use crate::vcard::value::Value;
use crate::vcard::value::Value::ValueText;
use crate::{HasValue, VcardError};

#[derive(Clone, Debug, PartialEq)]
pub struct ValueParameterData {
    pub value: Value,
}

impl HasName for ValueParameterData {
    fn name(&self) -> &str {
        ParameterName::VALUE
    }
}

impl HasValue for ValueParameterData {
    fn get_value(&self) -> &Value {
        &self.value
    }

    fn set_value(&mut self, value: Value) -> Result<(), VcardError> {
        if !matches!(value, ValueText(_)) {
            return Err(VcardError::ValueNotAllowed(value.to_string(), self.name().to_string()));
        }

        if let ValueText(data) = &value {
            if !ValueType::TYPES.contains(&data.value.to_uppercase().as_str()) {
                return Err(VcardError::ValueInvalid(value.to_string(), self.name().to_string()));
            }
        }

        self.value = value;

        Ok(())
    }
}

impl Default for ValueParameterData {
    fn default() -> Self {
        Self {
            value: ValueText(ValueTextData::default()),
        }
    }
}

impl TryFrom<&str> for ValueParameterData {
    type Error = VcardError;
    fn try_from(str: &str) -> Result<Self, Self::Error> {
        Ok(Self {
            value: ValueText(ValueTextData::from(str)),
        })
    }
}