-
Minimal and Efficient : minimal codebase to provide efficient, memory-safe WebSocket handling.
-
Multi Environment :
tokio
,async-std
,smol
,nio
,glommio
are supported as async runtime ( by feature flagsrt_{name}
).
MEWS is NOT WebSocket server, just protocol implementation. So :
-
Tend to be used by web libraries internally, not by end-developers.
-
Doesn't builtins
wss://
support.
[dependencies]
mews = { version = "0.1", features = ["rt_tokio"] }
tokio = { version = "1", features = ["rt"] }
# ...
( with pseudo Request & Response )
/* server */
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| 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 */
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| 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 ).