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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
|
//! Representations of various client errors
use hyper::{self, http, StatusCode};
use serde_json::Error as SerdeError;
use std::{error::Error as StdError, fmt, string::FromUtf8Error};
use futures_util::io::Error as IoError;
/// Represents the result of all docker operations
pub type Result<T> = std::result::Result<T, Error>;
#[derive(Debug)]
pub enum Error {
SerdeJsonError(SerdeError),
Hyper(hyper::Error),
Http(hyper::http::Error),
IO(IoError),
Encoding(FromUtf8Error),
InvalidResponse(String),
Fault { code: StatusCode, message: String },
ConnectionNotUpgraded,
}
impl From<SerdeError> for Error {
fn from(error: SerdeError) -> Error {
Error::SerdeJsonError(error)
}
}
impl From<hyper::Error> for Error {
fn from(error: hyper::Error) -> Error {
Error::Hyper(error)
}
}
impl From<hyper::http::Error> for Error {
fn from(error: hyper::http::Error) -> Error {
Error::Http(error)
}
}
impl From<http::uri::InvalidUri> for Error {
fn from(error: http::uri::InvalidUri) -> Self {
let http_error: http::Error = error.into();
http_error.into()
}
}
impl From<IoError> for Error {
fn from(error: IoError) -> Error {
Error::IO(error)
}
}
impl From<FromUtf8Error> for Error {
fn from(error: FromUtf8Error) -> Error {
Error::Encoding(error)
}
}
impl fmt::Display for Error {
fn fmt(
&self,
f: &mut fmt::Formatter,
) -> fmt::Result {
write!(f, "Docker Error: ")?;
match self {
Error::SerdeJsonError(ref err) => err.fmt(f),
Error::Http(ref err) => err.fmt(f),
Error::Hyper(ref err) => err.fmt(f),
Error::IO(ref err) => err.fmt(f),
Error::Encoding(ref err) => err.fmt(f),
Error::InvalidResponse(ref cause) => {
write!(f, "Response doesn't have the expected format: {}", cause)
}
Error::Fault { code, .. } => write!(f, "{}", code),
Error::ConnectionNotUpgraded => write!(
f,
"expected the docker host to upgrade the HTTP connection but it did not"
),
}
}
}
impl StdError for Error {
fn source(&self) -> Option<&(dyn StdError + 'static)> {
match self {
Error::SerdeJsonError(ref err) => Some(err),
Error::Http(ref err) => Some(err),
Error::IO(ref err) => Some(err),
Error::Encoding(e) => Some(e),
_ => None,
}
}
}
|