huskarl-core 0.5.0

Base library for huskarl (OAuth2 client) ecosystem.
Documentation
use std::borrow::Cow;

use serde::Serialize;

use crate::secrets::SecretString;

/// The types of form values that can be encoded when sending to an authorization server.
#[derive(Debug, Clone)]
pub enum FormValue<'a> {
    /// Represents a non-sensitive value (may be visible in logs, debug messages, etc.).
    NonSensitive(Cow<'a, str>),
    /// Represents a sensitive value (debug information is hidden, value is zeroed on drop).
    Sensitive(Cow<'a, SecretString>),
}

impl<'a> From<Cow<'a, str>> for FormValue<'a> {
    fn from(value: Cow<'a, str>) -> Self {
        Self::NonSensitive(value)
    }
}

impl From<String> for FormValue<'_> {
    fn from(value: String) -> Self {
        Self::NonSensitive(Cow::Owned(value))
    }
}

impl<'a> From<&'a str> for FormValue<'a> {
    fn from(value: &'a str) -> Self {
        Self::NonSensitive(Cow::Borrowed(value))
    }
}

impl<'a> From<&'a SecretString> for FormValue<'a> {
    fn from(value: &'a SecretString) -> Self {
        Self::Sensitive(Cow::Borrowed(value))
    }
}

impl From<SecretString> for FormValue<'_> {
    fn from(value: SecretString) -> Self {
        Self::Sensitive(Cow::Owned(value))
    }
}

impl Serialize for FormValue<'_> {
    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
    where
        S: serde::Serializer,
    {
        match self {
            FormValue::NonSensitive(cow) => cow.serialize(serializer),
            FormValue::Sensitive(secret_box) => secret_box.expose_secret().serialize(serializer),
        }
    }
}