casper_types/crypto/
error.rsuse alloc::string::String;
use core::fmt::{self, Display, Formatter};
#[cfg(any(feature = "std", feature = "testing", test))]
use std::error::Error as StdError;
#[cfg(feature = "datasize")]
use datasize::DataSize;
use ed25519_dalek::ed25519::Error as SignatureError;
#[cfg(any(feature = "std", test))]
use pem::PemError;
use serde::Serialize;
#[cfg(any(feature = "std", feature = "testing", test))]
use thiserror::Error;
#[cfg(any(feature = "std-fs-io", test))]
use crate::file_utils::{ReadFileError, WriteFileError};
#[derive(Clone, Eq, PartialEq, Debug, Serialize)]
#[cfg_attr(feature = "datasize", derive(DataSize))]
#[non_exhaustive]
pub enum Error {
AsymmetricKey(String),
#[serde(with = "serde_helpers::Base16DecodeError")]
#[cfg_attr(feature = "datasize", data_size(skip))]
FromHex(base16::DecodeError),
#[serde(with = "serde_helpers::Base64DecodeError")]
#[cfg_attr(feature = "datasize", data_size(skip))]
FromBase64(base64::DecodeError),
SignatureError,
System(String),
}
impl Display for Error {
fn fmt(&self, formatter: &mut Formatter<'_>) -> fmt::Result {
match self {
Error::AsymmetricKey(error_msg) => {
write!(formatter, "asymmetric key error: {}", error_msg)
}
Error::FromHex(error) => {
write!(formatter, "decoding from hex: {}", error)
}
Error::FromBase64(error) => {
write!(formatter, "decoding from base 64: {}", error)
}
Error::SignatureError => {
write!(formatter, "error in signature")
}
Error::System(error_msg) => {
write!(formatter, "invalid operation on system key: {}", error_msg)
}
}
}
}
impl From<base16::DecodeError> for Error {
fn from(error: base16::DecodeError) -> Self {
Error::FromHex(error)
}
}
impl From<SignatureError> for Error {
fn from(_error: SignatureError) -> Self {
Error::SignatureError
}
}
#[cfg(any(feature = "std", feature = "testing", test))]
impl StdError for Error {
fn source(&self) -> Option<&(dyn StdError + 'static)> {
match self {
Error::FromHex(error) => Some(error),
Error::FromBase64(error) => Some(error),
Error::AsymmetricKey(_) | Error::SignatureError | Error::System(_) => None,
}
}
}
#[cfg(any(feature = "std", feature = "testing", test))]
#[derive(Debug, Error)]
#[non_exhaustive]
pub enum ErrorExt {
#[error("crypto error: {0:?}")]
CryptoError(#[from] Error),
#[cfg(any(feature = "std-fs-io", test))]
#[error("secret key load failed: {0}")]
SecretKeyLoad(ReadFileError),
#[cfg(any(feature = "std-fs-io", test))]
#[error("public key load failed: {0}")]
PublicKeyLoad(ReadFileError),
#[cfg(any(feature = "std-fs-io", test))]
#[error("secret key save failed: {0}")]
SecretKeySave(WriteFileError),
#[cfg(any(feature = "std-fs-io", test))]
#[error("public key save failed: {0}")]
PublicKeySave(WriteFileError),
#[error("pem error: {0}")]
FromPem(String),
#[error("der error: {0}")]
FromDer(#[from] derp::Error),
#[error("failed to get random bytes: {0}")]
GetRandomBytes(#[from] getrandom::Error),
}
#[cfg(any(feature = "std", test))]
impl From<PemError> for ErrorExt {
fn from(error: PemError) -> Self {
ErrorExt::FromPem(error.to_string())
}
}
#[allow(clippy::enum_variant_names)]
mod serde_helpers {
use serde::Serialize;
#[derive(Serialize)]
#[serde(remote = "base16::DecodeError")]
pub(super) enum Base16DecodeError {
InvalidByte { index: usize, byte: u8 },
InvalidLength { length: usize },
}
#[derive(Serialize)]
#[serde(remote = "base64::DecodeError")]
pub(super) enum Base64DecodeError {
#[allow(dead_code)]
InvalidByte(usize, u8),
InvalidLength,
#[allow(dead_code)]
InvalidLastSymbol(usize, u8),
}
}