Phoenix channels in Rust. This crate uses the Actor model to provide Socket and Channel abstractions for connecting to, receiving and sending messages in a topical fashion. The overall structure is based on the reference JavaScript client.
Warning: the results returned may include NSFW links or comments.
use serde_json::Value;
#[tokio::main]
async fn main() -> anyhow::Result<()> {
// The socket is generic over a Topic.
let mut socket = SocketBuilder::new(Url::parse("wss://furbooru.org/socket/websocket")?)
.build::<String>()
.await;
// Each channel is generic over an Event and Payload type.
// For simplicity we use serde_json::Value, but in your own code you should deserialize
// to something strongly-typed.
let (_channel, mut subscription) = socket
.channel::<String, Value, Value>(ChannelBuilder::new("firehose".to_string()))
.await?;
loop {
let v = subscription.recv().await?;
println!("{:?}", v);
}
}
TLS is not enabled by default. Enable either of the following for TLS support:
rustls-native-roots
(usesrustls-native-certs
for root certificates)rustls-webpki-roots
(useswebpki-roots
for root certificates)
License: MIT OR Apache-2.0