-
Minimal and Efficient : minimal codebase to provide efficient, memory-safe WebSocket handling.
-
Multi-Environment : works with any async runtimes with
tokio::io
orfutures::io
interface (for example:tokio
ornio
usetokio::io
interface, andsmol
orglommio
usefutures::io
interface).
Feature flagsio_tokio
orio_futures
enables integration for respective IO interface.
io_tokio
or io_futures
must be activated to integrate with async IO interfaces.
Here specifying io_tokio
to use with tokio
:
[dependencies]
mews = { version = "0.5", features = ["io_tokio"] }
tokio = { version = "1", features = ["full"] }
# ...
( with pseudo Request & Response )
/* server */
use tokio::net::TcpStream;
use mews::{WebSocketContext, Connection, Message};
async fn handle_websocket(
req: &Request/* upgrade request */,
tcp: TcpStream
) {
let ctx = WebSocketContext::new(
&req.headers["Sec-WebSocket-Key"]
);
let (sign, ws) = ctx.on_upgrade(
|mut conn: Connection<TcpStream>| async move {
while let Ok(Some(Message::Text(text))) = conn.recv().await {
conn.send(text).await
.expect("failed to send message");
sleep(Duration::from_secs(1)).await;
}
}
);
send(Response::SwitchingProtocol()
.with(Connection, "Upgrade")
.with(Upgrade, "websocket")
.with(SecWebSocketAccept, sign),
&mut tcp
).await.expect("failed to send handshake response");
ws.manage(tcp);
}
/* client */
use tokio::net::TcpStream;
async fn start_websocket(
mut tcp: TcpStream
) {
let websocket_key = "my-sec-websocket-key";
let ctx = WebSocketContext::new(
websocket_key
);
let (sign, ws) = ctx.on_upgrade(
|mut conn: Connection<TcpStream>| async move {
conn.send("Hello!").await.expect("failed to send message");
while let Ok(Some(Message::Text(text))) = conn.recv().await {
println!("got: `{text}`")
}
}
);
let res = send(Request::GET("/ws")
.with(Host, "localhost:3000")
.with(Connection, Upgrade)
.with(Upgrade, "websocket")
.with(SecWebSocketVersion, "13")
.with(SecWebSocketKey, websocket_key),
&mut tcp
).await.expect("failed to send handshake request");
assert!(res.header(SecWebSocketAccept), Some(sign));
ws.manage(tcp);
}
MEWS is licensed under MIT LICENSE ( LICENSE or https://opensource.org/licenses/MIT ).