|
| 1 | +use std::{ |
| 2 | + error::Error, |
| 3 | + fmt, |
| 4 | + fmt::{Display, Formatter}, |
| 5 | +}; |
| 6 | + |
1 | 7 | use thiserror::Error;
|
2 |
| -use crate::schema::types::jsonwebkey::JsonWebKeyError; |
3 | 8 |
|
4 |
| -use crate::schema::types::multibase::MultibaseWrapperError; |
| 9 | +use crate::schema::types::{jsonwebkey::JsonWebKeyError, multibase::MultibaseWrapperError}; |
5 | 10 |
|
6 | 11 | #[derive(Debug, Error)]
|
7 |
| -pub enum KeyDecodingError { |
8 |
| - #[error("Json decoding error: ${0}")] |
9 |
| - JsonError(serde_json::Error), |
10 |
| - #[error("Pem decoding error: ${0}")] |
11 |
| - PemError(pem::PemError), |
12 |
| - #[error("Unsupported key error: ${0}")] |
13 |
| - UnsupportedPublicKeyField(&'static str), |
14 |
| - #[error("Base 58 decoding error: ${0}")] |
15 |
| - Base58DecodeError(bs58::decode::Error), |
16 |
| - #[error("Base 64 decoding error: ${0}")] |
17 |
| - Base64DecodeError(base64::DecodeError), |
18 |
| - #[error("Hex decoding error: ${0}")] |
19 |
| - HexDecodeError(hex::FromHexError), |
20 |
| - #[error("Jwk decoding error: ${0}")] |
21 |
| - JwkDecodeError(JsonWebKeyError), |
22 |
| - #[error("Multibase decoding error ${0}")] |
23 |
| - MultibaseError(MultibaseWrapperError), |
| 12 | +pub struct KeyDecodingError { |
| 13 | + reason: &'static str, |
| 14 | + #[source] |
| 15 | + source: Option<Box<dyn Error + Sync + Send>>, |
| 16 | +} |
| 17 | + |
| 18 | +impl KeyDecodingError { |
| 19 | + pub fn new(reason: &'static str) -> Self { |
| 20 | + KeyDecodingError { |
| 21 | + reason, |
| 22 | + source: None, |
| 23 | + } |
| 24 | + } |
| 25 | +} |
| 26 | + |
| 27 | +impl Display for KeyDecodingError { |
| 28 | + fn fmt(&self, f: &mut Formatter<'_>) -> fmt::Result { |
| 29 | + match &self.source { |
| 30 | + Some(source) => write!( |
| 31 | + f, |
| 32 | + "KeyDecodingError, reason: {}, source: {}", |
| 33 | + self.reason, source |
| 34 | + ), |
| 35 | + None => write!(f, "KeyDecodingError, reason: {}", self.reason), |
| 36 | + } |
| 37 | + } |
24 | 38 | }
|
25 | 39 |
|
26 | 40 | impl From<pem::PemError> for KeyDecodingError {
|
27 | 41 | fn from(error: pem::PemError) -> Self {
|
28 |
| - KeyDecodingError::PemError(error) |
| 42 | + KeyDecodingError { |
| 43 | + reason: "Failed to decode PEM", |
| 44 | + source: Some(Box::new(error)), |
| 45 | + } |
29 | 46 | }
|
30 | 47 | }
|
31 | 48 |
|
32 | 49 | impl From<bs58::decode::Error> for KeyDecodingError {
|
33 | 50 | fn from(error: bs58::decode::Error) -> Self {
|
34 |
| - KeyDecodingError::Base58DecodeError(error) |
| 51 | + KeyDecodingError { |
| 52 | + reason: "Failed to decode base58", |
| 53 | + source: Some(Box::new(error)), |
| 54 | + } |
35 | 55 | }
|
36 | 56 | }
|
37 | 57 |
|
38 | 58 | impl From<base64::DecodeError> for KeyDecodingError {
|
39 | 59 | fn from(error: base64::DecodeError) -> Self {
|
40 |
| - KeyDecodingError::Base64DecodeError(error) |
| 60 | + KeyDecodingError { |
| 61 | + reason: "Failed to decode base64", |
| 62 | + source: Some(Box::new(error)), |
| 63 | + } |
41 | 64 | }
|
42 | 65 | }
|
43 | 66 |
|
44 | 67 | impl From<hex::FromHexError> for KeyDecodingError {
|
45 | 68 | fn from(error: hex::FromHexError) -> Self {
|
46 |
| - KeyDecodingError::HexDecodeError(error) |
| 69 | + KeyDecodingError { |
| 70 | + reason: "Failed to decode hex value", |
| 71 | + source: Some(Box::new(error)), |
| 72 | + } |
| 73 | + } |
| 74 | +} |
| 75 | + |
| 76 | +impl From<MultibaseWrapperError> for KeyDecodingError { |
| 77 | + fn from(error: MultibaseWrapperError) -> Self { |
| 78 | + KeyDecodingError { |
| 79 | + reason: "Failed to decode multibase value", |
| 80 | + source: Some(Box::new(error)), |
| 81 | + } |
| 82 | + } |
| 83 | +} |
| 84 | + |
| 85 | +impl From<JsonWebKeyError> for KeyDecodingError { |
| 86 | + fn from(error: JsonWebKeyError) -> Self { |
| 87 | + KeyDecodingError { |
| 88 | + reason: "Failed to decode JWK", |
| 89 | + source: Some(Box::new(error)), |
| 90 | + } |
47 | 91 | }
|
48 | 92 | }
|
0 commit comments