Rust Data Transfer Protocol
Asynchronous cross-platform networking interfaces for Rust.
The two fundamental network objects this crate provides are the server and client. When starting a server or connecting via a client, the task will not block while it performs network operations in the background. Upon instantiation, both the server and client return handles that provide a mechanism for communicating with the background task, and instructing it to provide status information or halt network operations.
Creating a server
A server can be built using the Server
implementation:
use rustdtp::{Server, ServerEvent};
#[tokio::main]
async fn main() {
let (mut server, mut server_event) = Server::<usize, String>::start(("0.0.0.0", 0)).await.unwrap();
while let Some(event) = server_event.next().await {
match event {
ServerEvent::Connect { client_id } => {
println!("Client with ID {} connected", client_id);
},
ServerEvent::Disconnect { client_id } => {
println!("Client with ID {} disconnected", client_id);
},
ServerEvent::Receive { client_id, data } => {
server.send(client_id, data.len()).await.unwrap();
},
ServerEvent::Stop => {
println!("Server closed");
},
}
}
}
Creating a client
A client can be built using the Client
implementation:
use rustdtp::{Client, ClientEvent};
#[tokio::main]
async fn main() {
let (mut client, mut client_event) = Client::<String, usize>::connect(("127.0.0.1", 29275)).await.unwrap();
let msg = "Hello, server!".to_owned();
client.send(msg.clone()).await.unwrap();
match client_event.next().await.unwrap() {
ClientEvent::Receive { data } => {
println!("Received response from server: {}", data);
assert_eq!(data, msg.len());
},
event => {
panic!("expected to receive a response from the server, instead got {:?}", event);
},
}
}
Event iteration
Note that in order to iterate over events, the EventStreamExt
extension trait needs to be in scope.
Security
Information security comes included. Every message sent over a network interface is encrypted with AES-256. Key exchanges are performed using a 2048-bit RSA key-pair.