cry 0.1.5

Advance cryptography based on ECC and permutation cryptography.
Documentation
use crate::primitive::bytes::{self, Bytes, FromBytesRef};
use crate::primitive::scalar::ScalarNumber;
use core::convert::TryInto;
use curve25519_dalek::scalar;
use generic_array::typenum::U32;

#[derive(Debug, Clone)]
pub struct Scalar(pub scalar::Scalar);

impl Bytes for Scalar {
    type OutputSize = U32;

    fn to_bytes(&self) -> bytes::Output<Self> {
        self.0.to_bytes().into()
    }

    fn from_bytes(data: bytes::Output<Self>) -> Self {
        Self(scalar::Scalar::from_bytes_mod_order(data.into()))
    }
}

impl FromBytesRef for Scalar {
    fn from_bytes_ref(data: &[u8]) -> Option<Self> {
        if data.len() != 64 {
            return None;
        }
        let s_inner: &[u8; 64] = data.try_into().unwrap();
        Some(Self(scalar::Scalar::from_bytes_mod_order_wide(s_inner)))
    }
}

impl ScalarNumber for Scalar {
    const SIZE: usize = 32;

    fn zero() -> Self {
        Self(scalar::Scalar::zero())
    }

    fn one() -> Self {
        Self(scalar::Scalar::one())
    }

    fn invert(&self) -> Self {
        Self(self.0.invert())
    }

    fn reduce(&self) -> Self {
        Self(self.0.reduce())
    }

    fn neg(&self) -> Self {
        Self(-self.0)
    }

    fn add(&self, _rhs: &Self) -> Self {
        Self(self.0 + _rhs.0)
    }

    fn mul(&self, _rhs: &Self) -> Self {
        Self(self.0 * _rhs.0)
    }

    fn sub(&self, _rhs: &Self) -> Self {
        Self(self.0 - _rhs.0)
    }
}