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
use http::header::InvalidHeaderValue;
use {bytes, http, hyper, hyper_tls, serde_json};

/// Error that can occur when creating a client.
#[derive(Fail, Debug)]
pub enum StartupError {
    /// Error starting TLS connector
    #[fail(display = "tls error: {}", _0)]
    Tls(hyper_tls::Error),
    /// Token provided was invalid
    #[fail(display = "invalid token: {} (token: {:?})", _0, _1)]
    InvalidToken(InvalidHeaderValue, String),
}

/// Error that can occur when running a request.
#[derive(Fail, Debug)]
pub enum RequestError {
    /// Error creating request.
    #[fail(display = "request error: {}", _0)]
    Http(http::Error),
    /// Hyper error.
    #[fail(display = "hyper error: {}", _0)]
    Hyper(hyper::Error),
    /// Generic server error.
    #[fail(display = "server error: {}: {:?}", status, bytes)]
    Status {
        /// The failed server status.
        status: http::StatusCode,
        /// The response included with this status.
        bytes: bytes::Bytes,
    },
    /// Invalid JSON in response.
    #[fail(display = "invalid response json: {}. data: {:?}", error, bytes)]
    Json {
        /// Inner error
        error: serde_json::Error,
        /// Bytes which could not be decoded
        bytes: bytes::Bytes,
    },
    /// Server error.
    #[fail(display = "server error: {}: {}", code, message)]
    Server {
        /// Error code string
        code: String,
        /// Human readable error message
        message: String,
    },
}

impl From<hyper::Error> for RequestError {
    fn from(e: hyper::Error) -> Self {
        RequestError::Hyper(e)
    }
}

impl From<http::Error> for RequestError {
    fn from(e: http::Error) -> Self {
        RequestError::Http(e)
    }
}