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
|
//! Common lockchain error handling
//!
//! `Error` is a wrapper type around many different errors
//! that are provided by different parts of
//! the `lockchain-core` crate.
//!
//! It also re-exports those error types so that a user can use
//! the error handling module simply by including `lockchain_core::errors::*`
mod auth;
mod crypto;
mod data;
mod vault;
pub use self::auth::Error as AuthError;
pub use self::crypto::Error as CryptoError;
pub use self::data::Error as DataError;
pub use self::vault::Error as VaultError;
use std::error::Error as StdError;
use std::fmt::{Display, Formatter, Result};
use serde::{Serialize, Deserialize};
#[derive(Debug, Serialize, Deserialize)]
pub enum Error {
/// A common "unknown" type for errors
/// that can't be associated with a type or
/// simply need to be stubbed until more
/// information is available.
Unknown,
/// A basic vault operation error
Vault(VaultError),
/// Errors occuring during authentication
Auth(AuthError),
/// Cryptographic errors
Crypto(CryptoError),
/// Data integrity or retrieval errors
Data(DataError),
/// Make sure we don't break user code with new options
#[doc(hidden)]
__NonExhaustive,
}
impl StdError for Error {}
impl Display for Error {
fn fmt(&self, f: &mut Formatter) -> Result {
use self::Error::*;
write!(
f,
"{}",
match self {
Vault(ee) => format!("VaultError: {}", ee),
Auth(ee) => format!("AuthError: {}", ee),
Crypto(ee) => format!("CryptoError: {}", ee),
Data(ee) => format!("DataError: {}", ee),
_ => "Unknown error".into(),
}
)
}
}
|