abe_gpsw 2.0.0

ABE GPSW scheme for BLS pairing implemented in rust
Documentation
use std::{
    array::TryFromSliceError,
    convert::{From, Infallible},
    ffi::NulError,
    num::{ParseIntError, TryFromIntError},
    str::Utf8Error,
};

#[cfg(feature = "interfaces")]
use cosmian_crypto_base::{CryptoBaseError, CryptoCoreError};
use hex::FromHexError;
use thiserror::Error;

#[derive(Error, Debug)]
pub enum FormatErr {
    //
    // External errors conversion
    #[error("{0}")]
    CryptoError(String),
    #[error(transparent)]
    PolicyError(#[from] abe_policy::Error),
    #[error(transparent)]
    Infallible(Infallible),
    #[error(transparent)]
    NulError(NulError),
    #[error(transparent)]
    TryFromIntError(#[from] TryFromIntError),
    #[error(transparent)]
    ParsingError(#[from] ParsingError),
    #[error(transparent)]
    FromHexError(#[from] FromHexError),
    #[error(transparent)]
    Utf8Error(#[from] Utf8Error),

    //
    // Internal errors
    #[error("attribute not found: {0}")]
    AttributeNotFound(String),
    #[error("{} is missing{}",
        .item.clone().unwrap_or_else(|| "attribute".to_string()),
        match .axis_name {
            Some(axis) => format!(" in axis {}", axis),
            None => "".to_string(),
    })]
    MissingAttribute {
        item: Option<String>,
        axis_name: Option<String>,
    },
    #[error("{0} is missing")]
    MissingAxis(String),
    #[error("attribute {0} expected in {1:?}")]
    ExpectedAttribute(String, Vec<String>),
    #[error("symmetric key generation {0}")]
    SymmetricKeyGeneration(String),
    #[error("symmetric encryption {0}")]
    SymmetricEncryption(String),
    #[error("symmetric decryption {0}")]
    SymmetricDecryption(String),
    #[error("asymmetric decryption {0}")]
    AsymmetricDecryption(String),
    #[error("invalid size")]
    InvalidSize(String),
    #[error("{0}")]
    Deserialization(String),
    #[error("{0}")]
    Serialization(String),
    #[error("{0}")]
    InternalOperation(String),
    #[error("invalid formula: {0}")]
    InvalidFormula(String),
    #[error("invalid encrypted data")]
    InvalidEncryptedData,
    #[error("conversion failed")]
    ConversionFailed,
    #[error("Empty private key")]
    EmptyPrivateKey,
    #[error("Empty ciphertext")]
    EmptyCiphertext,
    #[error("Empty plaintext")]
    EmptyPlaintext,
    #[error("Header length must be at least 4 bytes. Found {0}")]
    InvalidHeaderSize(usize),
}

impl From<TryFromSliceError> for FormatErr {
    fn from(_e: TryFromSliceError) -> Self {
        Self::ConversionFailed
    }
}

impl From<serde_json::Error> for FormatErr {
    fn from(e: serde_json::Error) -> Self {
        Self::Deserialization(e.to_string())
    }
}

#[cfg(feature = "interfaces")]
impl From<CryptoBaseError> for FormatErr {
    fn from(e: CryptoBaseError) -> Self {
        match e {
            CryptoBaseError::SizeError { given, expected } => {
                Self::InvalidSize(format!("expected: {}, given: {}", expected, given))
            }
            CryptoBaseError::InvalidSize(e) => Self::InvalidSize(e),
            e => Self::CryptoError(e.to_string()),
        }
    }
}

#[cfg(feature = "interfaces")]
impl From<CryptoCoreError> for FormatErr {
    fn from(e: CryptoCoreError) -> Self {
        Self::CryptoError(e.to_string())
    }
}

impl From<Infallible> for FormatErr {
    fn from(e: Infallible) -> Self {
        Self::Infallible(e)
    }
}

#[cfg(feature = "ffi")]
impl From<std::ffi::NulError> for FormatErr {
    fn from(e: std::ffi::NulError) -> Self {
        Self::NulError(e)
    }
}

#[derive(Error, Debug, Clone, PartialEq)]
pub enum ParsingError {
    #[error("{0}")]
    UnexpectedCharacter(String),
    #[error("{0}")]
    UnexpectedEnd(String),
    #[error("empty string")]
    EmptyString,
    #[error("wrong range")]
    RangeError,
    #[error(transparent)]
    RegexError(#[from] regex::Error),
    #[error(transparent)]
    ParseIntError(#[from] ParseIntError),
    #[error("unsupported operand {0}")]
    UnsupportedOperand(String),
    #[error("unsupported operator {0}")]
    UnsupportedOperator(String),
}