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
use ntex_bytes::BufMut;
use crate::frame::{Frame, FrameError, Head, Kind, Reason, StreamId};
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
pub struct Reset {
stream_id: StreamId,
error_code: Reason,
}
impl Reset {
pub fn new(stream_id: StreamId, error: Reason) -> Reset {
Reset {
stream_id,
error_code: error,
}
}
pub fn set_reason(mut self, error_code: Reason) -> Self {
self.error_code = error_code;
self
}
pub fn stream_id(&self) -> StreamId {
self.stream_id
}
pub fn reason(&self) -> Reason {
self.error_code
}
pub fn load(head: Head, payload: &[u8]) -> Result<Reset, FrameError> {
if payload.len() != 4 {
return Err(FrameError::InvalidPayloadLength);
}
let error_code = unpack_octets_4!(payload, 0, u32);
Ok(Reset {
stream_id: head.stream_id(),
error_code: error_code.into(),
})
}
pub fn encode<B: BufMut>(&self, dst: &mut B) {
log::trace!(
"encoding RESET; id={:?} code={:?}",
self.stream_id,
self.error_code
);
let head = Head::new(Kind::Reset, 0, self.stream_id);
head.encode(4, dst);
dst.put_u32(self.error_code.into());
}
}
impl From<Reset> for Frame {
fn from(src: Reset) -> Self {
Frame::Reset(src)
}
}