1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
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),
}
}
}