tcp_handler/streams/
compress.rs1use bytes::{Buf, BytesMut};
4use tokio::io::{AsyncRead, AsyncWrite};
5use crate::protocols::common::{PacketError, StarterError};
6use crate::protocols::compress::{self, send, recv};
7use crate::streams::impl_tcp_handler;
8
9#[derive(Debug)]
11pub struct TcpServerHandlerCompress<R: AsyncRead + Unpin, W: AsyncWrite + Unpin> {
12 reader: R,
13 writer: W,
14 version: String,
15}
16
17impl<R: AsyncRead + Unpin, W: AsyncWrite + Unpin> TcpServerHandlerCompress<R, W> {
18 pub async fn new<P: FnOnce(&str) -> bool>(mut reader: R, mut writer: W, identifier: &str, version_prediction: P, version: &str) -> Result<Self, StarterError> {
20 let init = compress::server_init(&mut reader, identifier, version_prediction).await;
21 let (_protocol_version, application_version) = compress::server_start(&mut writer, identifier, version, init).await?;
22 Ok(Self { reader, writer, version: application_version })
23 }
24
25 #[inline]
27 pub fn into_inner(self) -> (R, W) {
28 (self.reader, self.writer)
29 }
30
31 #[inline]
34 pub fn from_inner(reader: R, writer: W, version: String) -> Self {
35 Self { reader, writer, version }
36 }
37
38 #[inline]
40 pub async fn send<B: Buf>(&mut self, message: &mut B) -> Result<(), PacketError> {
41 send(&mut self.writer, message).await
42 }
43
44 #[inline]
46 pub async fn recv(&mut self) -> Result<BytesMut, PacketError> {
47 recv(&mut self.reader).await
48 }
49}
50
51impl_tcp_handler!(server TcpServerHandlerCompress);
52
53
54#[derive(Debug)]
56pub struct TcpClientHandlerCompress<R: AsyncRead + Unpin, W: AsyncWrite + Unpin> {
57 reader: R,
58 writer: W,
59}
60
61impl<R: AsyncRead + Unpin, W: AsyncWrite + Unpin> TcpClientHandlerCompress<R, W> {
62 pub async fn new(mut reader: R, mut writer: W, identifier: &str, version: &str) -> Result<Self, StarterError> {
64 let init = compress::client_init(&mut writer, identifier, version).await;
65 compress::client_start(&mut reader, init).await?;
66 Ok(Self { reader, writer })
67 }
68
69 #[inline]
71 pub fn into_inner(self) -> (R, W) {
72 (self.reader, self.writer)
73 }
74
75 #[inline]
78 pub fn from_inner(reader: R, writer: W) -> Self {
79 Self { reader, writer }
80 }
81
82 #[inline]
84 pub async fn send<B: Buf>(&mut self, message: &mut B) -> Result<(), PacketError> {
85 send(&mut self.writer, message).await
86 }
87
88 #[inline]
90 pub async fn recv(&mut self) -> Result<BytesMut, PacketError> {
91 recv(&mut self.reader).await
92 }
93}
94
95impl_tcp_handler!(client TcpClientHandlerCompress);
96
97
98#[cfg(test)]
99mod tests {
100 use anyhow::Result;
101 use bytes::{Buf, BufMut};
102 use tokio::{spawn, try_join};
103 use variable_len_reader::{VariableReader, VariableWriter};
104 use crate::streams::compress::{TcpClientHandlerCompress, TcpServerHandlerCompress};
105 use crate::streams::tests::{check_send_recv, create};
106
107 #[tokio::test(flavor = "multi_thread")]
108 async fn connect() -> Result<()> {
109 let (cr, cw, sr, sw) = create().await?;
110 let server = spawn(TcpServerHandlerCompress::new(sr, sw, "test", |v| v == "0", "0"));
111 let client = spawn(TcpClientHandlerCompress::new(cr, cw, "test", "0"));
112 let (server, client) = try_join!(server, client)?;
113 let (mut server, mut client) = (server?, client?);
114
115 assert_eq!("0", server.get_client_version());
116 check_send_recv!(server, client, "Hello tcp-handler compress.");
117 check_send_recv!(client, server, "Hello tcp-handler compress.");
118 Ok(())
119 }
120}