Files
bft-crdt-experiment/side-node/src/websocket.rs

49 lines
1.5 KiB
Rust
Raw Normal View History

2024-06-06 19:32:29 +01:00
use async_trait::async_trait;
use bft_json_crdt::json_crdt::SignedOp;
2024-06-06 19:32:29 +01:00
use ezsockets::ClientConfig;
use tokio::sync::mpsc;
2024-06-06 19:32:29 +01:00
pub(crate) struct WebSocketClient {
incoming_sender: mpsc::Sender<SignedOp>,
}
impl WebSocketClient {
/// Start the websocket client
2024-06-10 16:43:45 +01:00
pub(crate) async fn start(
incoming_sender: mpsc::Sender<SignedOp>,
) -> ezsockets::Client<WebSocketClient> {
tracing_subscriber::fmt::init();
let config = ClientConfig::new("ws://localhost:8080/websocket");
let (handle, future) =
ezsockets::connect(|_client| WebSocketClient { incoming_sender }, config).await;
tokio::spawn(async move {
future.await.unwrap();
});
loop {}
handle
}
}
2024-06-06 19:32:29 +01:00
#[async_trait]
impl ezsockets::ClientExt for WebSocketClient {
2024-06-06 19:32:29 +01:00
type Call = ();
async fn on_text(&mut self, text: String) -> Result<(), ezsockets::Error> {
tracing::info!("received message: {text}");
let incoming: bft_json_crdt::json_crdt::SignedOp = serde_json::from_str(&text).unwrap();
tracing::info!("received signed op: {incoming:?}");
self.incoming_sender.send(incoming).await.unwrap();
2024-06-06 19:32:29 +01:00
Ok(())
}
async fn on_binary(&mut self, bytes: Vec<u8>) -> Result<(), ezsockets::Error> {
tracing::info!("received bytes: {bytes:?}");
Ok(())
}
async fn on_call(&mut self, call: Self::Call) -> Result<(), ezsockets::Error> {
let () = call;
Ok(())
}
}