7 releases

0.1.6 Jun 14, 2023
0.1.5 Feb 7, 2023
0.1.4 Nov 9, 2021
0.1.3 Oct 26, 2021
0.1.1 Mar 11, 2021

#64 in WebSocket

Download history 75/week @ 2024-01-06 52/week @ 2024-01-13 53/week @ 2024-01-20 31/week @ 2024-01-27 20/week @ 2024-02-03 107/week @ 2024-02-10 62/week @ 2024-02-17 89/week @ 2024-02-24 62/week @ 2024-03-02 220/week @ 2024-03-09 86/week @ 2024-03-16 115/week @ 2024-03-23 143/week @ 2024-03-30 43/week @ 2024-04-06 60/week @ 2024-04-13 53/week @ 2024-04-20

309 downloads per month
Used in 2 crates

MIT license

15KB
176 lines

simple-websockets

An easy-to-use WebSocket server.

MIT licensed Docs Crates.io

Example

Echo server:

use simple_websockets::{Event, Responder};
use std::collections::HashMap;

fn main() {
    // listen for WebSockets on port 8080:
    let event_hub = simple_websockets::launch(8080)
        .expect("failed to listen on port 8080");
    // map between client ids and the client's `Responder`:
    let mut clients: HashMap<u64, Responder> = HashMap::new();

    loop {
        match event_hub.poll_event() {
            Event::Connect(client_id, responder) => {
                println!("A client connected with id #{}", client_id);
                // add their Responder to our `clients` map:
                clients.insert(client_id, responder);
            },
            Event::Disconnect(client_id) => {
                println!("Client #{} disconnected.", client_id);
                // remove the disconnected client from the clients map:
                clients.remove(&client_id);
            },
            Event::Message(client_id, message) => {
                println!("Received a message from client #{}: {:?}", client_id, message);
                // retrieve this client's `Responder`:
                let responder = clients.get(&client_id).unwrap();
                // echo the message back:
                responder.send(message);
            },
        }
    }
}

Dependencies

~4–11MB
~109K SLoC