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
use crate::raw::DefaultRawBody;
use bytes::Bytes;
use http_body::Body;
use hyper::{HeaderMap, StatusCode};
use std::error;
use std::io::{self, BufRead, Read};
use std::pin::Pin;
use tokio::io::AsyncBufReadExt;
use tokio::io::{AsyncBufRead, AsyncReadExt};
use tokio::runtime::Handle;
pub struct Response<B = DefaultRawBody> {
inner: crate::Response<B>,
handle: Handle,
}
impl<B> Response<B> {
pub(crate) fn new(inner: crate::Response<B>, handle: Handle) -> Response<B> {
Response { inner, handle }
}
pub fn status(&self) -> StatusCode {
self.inner.status()
}
pub fn headers(&self) -> &HeaderMap {
self.inner.headers()
}
pub fn into_body(self) -> ResponseBody<B> {
ResponseBody {
inner: Box::pin(self.inner.into_body()),
handle: self.handle,
}
}
}
pub struct ResponseBody<B = DefaultRawBody> {
inner: Pin<Box<crate::ResponseBody<B>>>,
handle: Handle,
}
impl<B> ResponseBody<B>
where
B: Body<Data = Bytes>,
B::Error: Into<Box<dyn error::Error + Sync + Send>>,
{
pub fn read_bytes(&mut self) -> io::Result<Option<Bytes>> {
self.handle.block_on(self.inner.as_mut().read_bytes())
}
}
impl<B> Read for ResponseBody<B>
where
B: Body<Data = Bytes>,
B::Error: Into<Box<dyn error::Error + Sync + Send>>,
{
fn read(&mut self, buf: &mut [u8]) -> io::Result<usize> {
self.handle.block_on(self.inner.as_mut().read(buf))
}
}
impl<B> BufRead for ResponseBody<B>
where
B: Body<Data = Bytes>,
B::Error: Into<Box<dyn error::Error + Sync + Send>>,
{
fn fill_buf(&mut self) -> io::Result<&[u8]> {
self.handle.block_on(self.inner.as_mut().fill_buf())?;
Ok(self.inner.buffer())
}
fn consume(&mut self, n: usize) {
self.inner.as_mut().consume(n)
}
}