use crate::algorithms::{CRHError, CommitmentError, EncryptionError, PRFError, SignatureError};
#[derive(Debug, Error)]
pub enum AccountError {
#[error("{}", _0)]
CommitmentError(CommitmentError),
#[error("{}", _0)]
CRHError(CRHError),
#[error("{}: {}", _0, _1)]
Crate(&'static str, String),
#[error("{}", _0)]
EncryptionError(EncryptionError),
#[error("invalid account commitment")]
InvalidAccountCommitment,
#[error("invalid byte length: {}", _0)]
InvalidByteLength(usize),
#[error("invalid character length: {}", _0)]
InvalidCharacterLength(usize),
#[error("invalid prefix: {:?}", _0)]
InvalidPrefix(String),
#[error("invalid prefix bytes: {:?}", _0)]
InvalidPrefixBytes(Vec<u8>),
#[error("invalid account private key seed")]
InvalidPrivateKeySeed,
#[error("{}", _0)]
Message(String),
#[error("{}", _0)]
PRFError(PRFError),
#[error("{}", _0)]
SignatureError(SignatureError),
}
impl From<CommitmentError> for AccountError {
fn from(error: CommitmentError) -> Self {
AccountError::CommitmentError(error)
}
}
impl From<CRHError> for AccountError {
fn from(error: CRHError) -> Self {
AccountError::CRHError(error)
}
}
impl From<EncryptionError> for AccountError {
fn from(error: EncryptionError) -> Self {
AccountError::EncryptionError(error)
}
}
impl From<PRFError> for AccountError {
fn from(error: PRFError) -> Self {
AccountError::PRFError(error)
}
}
impl From<SignatureError> for AccountError {
fn from(error: SignatureError) -> Self {
AccountError::SignatureError(error)
}
}
impl From<base58::FromBase58Error> for AccountError {
fn from(error: base58::FromBase58Error) -> Self {
AccountError::Crate("base58", format!("{:?}", error))
}
}
impl From<bech32::Error> for AccountError {
fn from(error: bech32::Error) -> Self {
AccountError::Crate("bech32", format!("{:?}", error))
}
}
impl From<std::io::Error> for AccountError {
fn from(error: std::io::Error) -> Self {
AccountError::Crate("std::io", format!("{:?}", error))
}
}