Skip to content

An implementation of a socket.io client written in the Rust programming language.

License

Notifications You must be signed in to change notification settings

mibes404/rust-socketio

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

69 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Latest Version tests

Rust-socketio-client

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.

Example usage

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

Documentation of this crate can be found up on docs.rs.

Current features

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.

Content of this repository

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):

Licence

MIT

About

An implementation of a socket.io client written in the Rust programming language.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Rust 97.5%
  • JavaScript 1.7%
  • Makefile 0.8%