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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
use http::{HeaderMap, Request, Response};
use url::Url;
pub use error::ClientError;
mod error;
#[cfg(any(
all(feature = "async_reqwest", feature = "blocking_reqwest"),
all(feature = "async_reqwest_rustls", feature = "blocking_reqwest"),
all(feature = "async_reqwest", feature = "blocking_reqwest_rustls"),
all(feature = "async_reqwest_rustls", feature = "blocking_reqwest_rustls"),
))]
compile_error!(r#"Enabling both async and blocking version of reqwest client is not allowed."#);
#[cfg(any(
feature = "async_reqwest",
feature = "blocking_reqwest",
feature = "async_reqwest_rustls",
feature = "blocking_reqwest_rustls"
))]
pub mod reqwest;
#[cfg(any(feature = "async_surf"))]
pub mod surf;
#[maybe_async::maybe_async]
pub trait ClientExt: Sync + Clone {
fn new<U: Into<Option<HeaderMap>>>(headers: U) -> Result<Self, ClientError>;
fn headers(&mut self) -> &mut HeaderMap;
#[inline]
async fn get<T>(&self, url: Url, text: T) -> Result<Response<String>, ClientError>
where
T: Into<String> + Send,
{
self.request(Request::get(url.to_string()).body(text.into()).unwrap())
.await
}
#[inline]
async fn post<T>(&self, url: Url, text: T) -> Result<Response<String>, ClientError>
where
T: Into<String> + Send,
{
self.request(Request::post(url.to_string()).body(text.into()).unwrap())
.await
}
#[inline]
async fn put<T>(&self, url: Url, text: T) -> Result<Response<String>, ClientError>
where
T: Into<String> + Send,
{
self.request(Request::put(url.to_string()).body(text.into()).unwrap())
.await
}
#[inline]
async fn delete<T>(&self, url: Url, text: T) -> Result<Response<String>, ClientError>
where
T: Into<String> + Send,
{
self.request(Request::delete(url.to_string()).body(text.into()).unwrap())
.await
}
#[inline]
async fn patch<T>(&self, url: Url, text: T) -> Result<Response<String>, ClientError>
where
T: Into<String> + Send,
{
self.request(Request::patch(url.to_string()).body(text.into()).unwrap())
.await
}
#[inline]
async fn connect<T>(&self, url: Url, text: T) -> Result<Response<String>, ClientError>
where
T: Into<String> + Send,
{
self.request(Request::connect(url.to_string()).body(text.into()).unwrap())
.await
}
#[inline]
async fn head<T>(&self, url: Url, text: T) -> Result<Response<String>, ClientError>
where
T: Into<String> + Send,
{
self.request(Request::head(url.to_string()).body(text.into()).unwrap())
.await
}
#[inline]
async fn options<T>(&self, url: Url, text: T) -> Result<Response<String>, ClientError>
where
T: Into<String> + Send,
{
self.request(Request::options(url.to_string()).body(text.into()).unwrap())
.await
}
#[inline]
async fn trace<T>(&self, url: Url, text: T) -> Result<Response<String>, ClientError>
where
T: Into<String> + Send,
{
self.request(Request::trace(url.to_string()).body(text.into()).unwrap())
.await
}
async fn request(&self, request: Request<String>) -> Result<Response<String>, ClientError>;
}