# Tcp-Handler
[](https://crates.io/crates/tcp-handler)
[](https://github.com/xuxiaocheng0201/tcp-handler/commits/master)
[](https://github.com/xuxiaocheng0201/tcp-handler/issues)
[](https://github.com/xuxiaocheng0201/tcp-handler/pulls)
[](https://github.com/xuxiaocheng0201/tcp-handler/blob/master/LICENSE)
**Read this in other languages: [English](README.md), [简体中文](README_zh.md).**
# Description
Conveniently transfer data in chunk through tokio TCP stream.
# Features
* Based on [tokio](https://crates.io/crates/tokio) and [bytes](https://crates.io/crates/bytes).
* Support `ReadHalf` and `WriteHalf` of `tokio::net::TcpStream`.
* Support encryption ([rsa](https://crates.io/crates/rsa) and [aes](https://crates.io/crates/aes-gcm)).
# Usage
Add this to your `Cargo.toml`:
```toml
[dependencies]
tcp-handler = "*"
```
# Example
Directly transfer data. Without encryption:
```rust
use anyhow::Result;
use bytes::{Buf, BufMut, BytesMut};
use tokio::net::{TcpListener, TcpStream};
use tcp_handler::packet::{recv, send};
use tcp_handler::starter::{client_init, client_start, server_init, server_start};
use variable_len_reader::{VariableReadable, VariableWritable};
#[tokio::main]
async fn main() -> Result<()> {
// Create tcp stream.
let addr = "localhost:25564";
let server = TcpListener::bind(addr).await?;
let mut client = TcpStream::connect(addr).await?;
let (mut server, _) = server.accept().await?;
// Prepare the protocol of tcp-handler.
let client_init = client_init(&mut client, &"test", &"0.0.0").await;
let server_init = server_init(&mut server, &"test", |v| v == "0.0.0").await;
server_start(&mut server, server_init).await?;
client_start(&mut client, client_init).await?;
// Send message.
let mut writer = BytesMut::new().writer();
writer.write_string("hello server.")?;
send(&mut client, &writer.into_inner()).await?;
// Receive message.
let mut reader = recv(&mut server).await?.reader();
let message = reader.read_string()?;
assert_eq!("hello server.", message);
Ok(())
}
```
Transfer message with encrypted protocol:
```rust
use anyhow::Result;
use bytes::{Buf, BufMut, BytesMut};
use tcp_handler::packet::{client_recv_with_dynamic_encrypt, client_send_with_dynamic_encrypt, server_recv_with_dynamic_encrypt, server_send_with_dynamic_encrypt};
use tcp_handler::starter::{client_init_with_encrypt, client_start_with_encrypt, server_init_with_encrypt, server_start_with_encrypt};
use variable_len_reader::{VariableReadable, VariableWritable};
#[tokio::main]
async fn main() -> Result<()> {
// Create tcp stream.
let addr = "localhost:25564";
let server = TcpListener::bind(addr).await?;
let mut client = TcpStream::connect(addr).await?;
let (mut server, _) = server.accept().await?;
// Prepare the protocol of tcp-handler and the ciphers.
let client_init = client_init_with_encrypt(&mut client, &"test", &"0.0.0").await;
let server_init = server_init_with_encrypt(&mut server, &"test", |v| v == "0.0.0").await;
let server_cipher = server_start_with_encrypt(&mut server, server_init).await?;
let client_cipher = client_start_with_encrypt(&mut client, client_init).await?;
// Send message in client side.
let mut writer = BytesMut::new().writer();
writer.write_string("hello server.")?;
let client_cipher = client_send_with_dynamic_encrypt(&mut client, &writer.into_inner(), client_cipher).await?;
// Receive message in server side.
let (reader, server_cipher) = server_recv_with_dynamic_encrypt(&mut server, server_cipher).await?;
let message = reader.reader().read_string()?;
assert_eq!("hello server.", message);
// Send message in server side.
let mut writer = BytesMut::new().writer();
writer.write_string("hello client.")?;
let _server_cipher = server_send_with_dynamic_encrypt(&mut client, &writer.into_inner(), server_cipher).await?;
// Receive message in client side.
let (reader, _client_cipher) = client_recv_with_dynamic_encrypt(&mut server, client_cipher).await?;
let message = reader.reader().read_string()?;
assert_eq!("hello client.", message);
Ok(())
}
```