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
use reqwest::StatusCode;
use trading::types::Error as TradingApiError;
#[derive(Fail, Debug)]
pub enum EbayError {
#[fail(
display = "request error: path = '{}', status = '{}', body = '{}'",
path, status, body
)]
Request {
path: String,
status: StatusCode,
body: String,
},
#[fail(display = "deserialize body error: msg = '{}', body = '{}'", msg, body)]
Deserialize { msg: String, body: String },
#[fail(display = "url error: {}", _0)]
Url(::url::ParseError),
#[fail(display = "http error: {}", _0)]
Http(::reqwest::Error),
#[fail(display = "json error: {}", _0)]
Json(::serde_json::Error),
#[fail(display = "{}", _0)]
Msg(String),
#[fail(display = "xml error: {}", _0)]
Xml(::xmltree::Error),
#[fail(display = "utf8 error: {}", _0)]
Utf8(::std::str::Utf8Error),
#[fail(display = "trading api response error: {:?}", _0)]
TradingApiResponseError(Vec<TradingApiError>),
}
impl EbayError {
pub fn should_try_again(&self) -> bool {
match *self {
EbayError::Request { status, .. } => {
let code = status.as_u16();
code == 429 || code == 500 || code == 503
}
_ => false,
}
}
}
pub type EbayResult<T> = ::std::result::Result<T, EbayError>;
macro_rules! impl_from {
($v:ident($t:ty)) => {
impl From<$t> for EbayError {
fn from(e: $t) -> Self {
EbayError::$v(e)
}
}
};
}
impl_from!(Url(::url::ParseError));
impl_from!(Http(::reqwest::Error));
impl_from!(Json(::serde_json::Error));
impl_from!(Msg(String));
impl_from!(Xml(::xmltree::Error));
impl_from!(Utf8(::std::str::Utf8Error));