An implementation of a socket.io client written in the Rust programming language. This implementation currently supports revision 5 of the socket.io protocol and therefore revision 4 of the engine.io protocol.
use rust_socketio::Socket;
use serde_json::json;
use tokio::time::sleep;
fn main() {
let mut socket = Socket::new(String::from("http://localhost:80"), Some("/admin"));
// callback for the "foo" event
socket.on("foo", |message| println!("{}", message)).unwrap();
// connect to the server
socket.connect().expect("Connection failed");
// emit to the "foo" event
let payload = json!({"token": 123});
socket.emit("foo", payload.to_string()).expect("Server unreachable");
// emit with an ack
let ack = socket.emit_with_ack("foo", payload.to_string(), Duration::from_secs(2)).unwrap();
sleep(Duration::from_secs(2));
// check if ack is present and read the data
if ack.read().expect("Server panicked anyway").acked {
println!("{}", ack.read().expect("Server panicked anyway").data.as_ref().unwrap());
}
}
Documentation of this crate can be found up on docs.rs.
This is the first released version of the client, so it still lacks some features that the normal client would provide. First of all the underlying engine.io protocol still uses long-polling instead of websockets. This will be resolved as soon as both the reqwest libary as well as tungstenite-websockets will bump their tokio version to 1.0.0. At the moment only reqwest is used for long polling. In general the full engine-io protocol is implemented and most of the features concerning the 'normal' socket.io protocol work as well.
Here's an overview of possible use-cases:
- connecting to a server.
- register callbacks for the following event types:
- open
- close
- error
- message
- custom events like "foo", "on_payment", etc.
- send json-data to the server (recommended to use serde_json as it provides safe handling of json data).
- send json-data to the server and receive an ack with a possible message.
What's currently missing is the emitting of binary data - I aim to implement this as soon as possible.
The whole crate is written in rust and it's necessary to use tokio, or other executors with this libary to resolve the futures.
This repository contains a rust implementation of the socket.io protocol as well as the underlying engine.io protocol.
The details about the engine.io protocol can be found here:
The specification for the socket.io protocol here:
Looking at the component chart, the following parts are implemented (Source: https://socket.io/images/dependencies.jpg):
MIT