1
0
mirror of https://github.com/actix/examples synced 2024-12-18 00:13:57 +01:00
examples/websocket-chat-broker
2019-12-20 22:30:26 +06:00
..
src Fix clippy warnings (#168) 2019-09-05 00:04:57 +09:00
static WebSocket Chat example using actix-broker (#44) 2018-09-18 13:19:45 +03:00
Cargo.toml update dependencies 2019-12-20 22:30:26 +06:00
client.py Fix some issues at chat client (#71) 2018-12-31 09:28:42 +03:00
README.md WebSocket Chat example using actix-broker (#44) 2018-09-18 13:19:45 +03:00

Websocket chat broker example

This is a different implementation of the websocket chat example

Differences:

  • Chat Server Actor is a System Service that runs in the same thread as the HttpServer/WS Listener.
  • The actix-broker crate is used to facilitate the sending of some messages between the Chat Session and Server Actors where the session does not require a response.
  • The Client is not required to send Ping messages. The Chat Server Actor auto-clears dead sessions.

Possible Improvements:

  • Could the Chat Server Actor be simultaneously a System Service (accessible to the Chat Session via the System Registry) and also run in a seperate thread?

Server

Chat server listens for incoming tcp connections. Server can access several types of message:

  • /list - list all available rooms
  • /join name - join room, if room does not exist, create new one
  • /name name - set session name
  • some message - just string, send message to all peers in same room

To start server use command: cargo run

WebSocket Browser Client

Open url: http://localhost:8080/