X-Git-Url: https://piware.de/gitweb/?p=learn-rust.git;a=blobdiff_plain;f=axum-server%2Fsrc%2Fmain.rs;fp=axum-server%2Fsrc%2Fmain.rs;h=31c0a4f619576870762aebe5ab0ca3a7619b169c;hp=3212d3f250962e2f422419951e1ce0fd0d355b13;hb=ac5838f9b78c6894751cfacaf2f238e09a4a7f51;hpb=cccafbeb9771b16338becafc0d389f5d1ae8e99f diff --git a/axum-server/src/main.rs b/axum-server/src/main.rs index 3212d3f..31c0a4f 100644 --- a/axum-server/src/main.rs +++ b/axum-server/src/main.rs @@ -2,7 +2,7 @@ use std::io; use axum::{ routing::{get, get_service}, - extract::{Path, TypedHeader}, + extract::{Path, TypedHeader, ws}, http::{StatusCode}, response, Router}; @@ -15,6 +15,33 @@ async fn hello(Path(name): Path, user_agent: Option ws::Message::Text(t), + ws::Message::Binary(b) => ws::Message::Binary(b), + // axum handles Ping/Pong by itself + ws::Message::Ping(_) => { continue }, + ws::Message::Pong(_) => { continue }, + ws::Message::Close(_) => { break } + }; + + if socket.send(reply).await + .is_err() { + tracing::info!("websocket client disconnected"); + break; + } + } + else { + tracing::info!("websocket client disconnected"); + break; + } + } +} + #[tokio::main] async fn main() { tracing_subscriber::fmt::init(); @@ -26,6 +53,7 @@ async fn main() { (StatusCode::INTERNAL_SERVER_ERROR, format!("Unhandled internal error: {}", e)) }) ) + .route("/ws-echo", get(|ws: ws::WebSocketUpgrade| async {ws.on_upgrade(ws_echo)})) .layer( tower::ServiceBuilder::new() .layer(