use std::result;
use base64::DecodeError;
use hex::FromHexError;
use pem::PemError;
use thiserror::Error;
use crate::utils::{ReadFileError, WriteFileError};
use casper_types::crypto;
pub type Result<T> = result::Result<T, Error>;
#[derive(Debug, Error)]
pub enum Error {
#[error("asymmetric key error: {0}")]
AsymmetricKey(String),
#[error("parsing from hex: {0}")]
FromHex(#[from] FromHexError),
#[error("secret key load failed: {0}")]
SecretKeyLoad(ReadFileError),
#[error("public key load failed: {0}")]
PublicKeyLoad(ReadFileError),
#[error("decoding error: {0}")]
FromBase64(#[from] DecodeError),
#[error("pem error: {0}")]
FromPem(String),
#[error("der error: {0}")]
FromDer(#[from] derp::Error),
#[error("secret key save failed: {0}")]
SecretKeySave(WriteFileError),
#[error("public key save failed: {0}")]
PublicKeySave(WriteFileError),
#[error("invalid operation on system key: {0}")]
System(String),
}
impl From<PemError> for Error {
fn from(error: PemError) -> Self {
Error::FromPem(error.to_string())
}
}
impl From<crypto::Error> for Error {
fn from(error: crypto::Error) -> Self {
match error {
crypto::Error::AsymmetricKey(string) => Error::AsymmetricKey(string),
crypto::Error::FromHex(error) => Error::FromHex(error),
crypto::Error::FromBase64(error) => Error::FromBase64(error),
}
}
}