An open API service indexing awesome lists of open source software.

https://github.com/easytier/kcp-sys

Safe bindings for KCP transport protocol.
https://github.com/easytier/kcp-sys

Last synced: 11 months ago
JSON representation

Safe bindings for KCP transport protocol.

Awesome Lists containing this project

README

          

# kcp-sys

Safe bindings to the [kcp](https://github.com/skywind3000/kcp) transport protocol library.

Also including a high level API for connection state management and data stream handling.

## Usage

1. Create the endpoint and run it.

```rust
let mut endpoint = KcpEndpoint::new();
endpoint.run().await;
```

2. forward the input and output to your transport layer, udp for example.

```rust
let (input, mut output) = (endpoint.input_sender(), endpoint.output_receiver().unwrap());

let udp_socket = Arc::new(UdpSocket::bind("0.0.0.0:54320").await.unwrap());
udp_socket.connect("127.0.0.1:54321").await.unwrap();

let udp = udp_socket.clone();
tokio::spawn(async move {
while let Some(data) = output.recv().await {
udp.send(&data.inner()).await.unwrap();
}
});

let udp = udp_socket.clone();
tokio::spawn(async move {
loop {
let mut buf = vec![0; 1024];
let (size, _) = udp.recv_from(&mut buf).await.unwrap();
input
.send(BytesMut::from(&buf[..size]).into())
.await
.unwrap();
}
});
```
4. Create a connection and send / recv data.

```rust
let conn_id = endpoint
.connect(Duration::from_secs(1), 0, 0, Bytes::new())
.await
.unwrap();

let mut kcp_stream = KcpStream::new(&endpoint, conn_id).unwrap();
kcp_stream.write_all(b"hello world").await.unwrap();

let mut buf = vec![0; 64 * 1024];
let size = kcp_stream.read(&mut buf).await.unwrap();

println!("{}", String::from_utf8_lossy(&buf[..size]));
```

## Tune the kcp parameters

You can tune the kcp parameters by set a config factory to the endpoint.

```rust
let mut endpoint = KcpEndpoint::new();
endpoint.set_kcp_config_factory(|conv| {
KcpConfig::new_turbo(conv)
});
```