serde-human-bytes 0.1.3

Optimized handling of `&[u8]` and `Vec<u8>` for Serde
Documentation
//! Base64 encoding support for human-readable serialization.
//!
//! This module provides an alternative to the default hex encoding.
//! Use it with `#[serde(with = "serde_human_bytes::base64")]`.
//!
//! # Example
//!
//! ```
//! use serde_derive::{Deserialize, Serialize};
//!
//! #[derive(Deserialize, Serialize)]
//! struct Example {
//!     #[serde(with = "serde_human_bytes::base64")]
//!     data: Vec<u8>,
//!
//!     #[serde(with = "serde_human_bytes::base64")]
//!     byte_buf: serde_human_bytes::ByteBuf,
//!
//!     #[serde(with = "serde_human_bytes::base64")]
//!     boxed: Box<[u8]>,
//! }
//! ```

use serde::{Deserializer, Serializer};

/// Serde `serialize_with` function emitting standard base64.
pub fn serialize<T, S>(bytes: &T, serializer: S) -> Result<S::Ok, S::Error>
where
    T: ?Sized + crate::Serialize<crate::Base64>,
    S: Serializer,
{
    crate::Serialize::<crate::Base64>::serialize(bytes, serializer)
}

/// Serde `deserialize_with` function accepting standard base64.
pub fn deserialize<'de, T, D>(deserializer: D) -> Result<T, D::Error>
where
    T: crate::Deserialize<'de, crate::Base64>,
    D: Deserializer<'de>,
{
    crate::Deserialize::<'de, crate::Base64>::deserialize(deserializer)
}