phyllo

Crates.iophyllo
lib.rsphyllo
version0.3.0
sourcesrc
created_at2022-07-07 09:16:28.795102
updated_at2022-07-28 18:31:51.376185
descriptionWebsocket-based client for Phoenix channels
homepage
repositoryhttps://github.com/wanderers-nft/phyllo
max_upload_size
id621071
size75,149
Emerald (the-emerald)

documentation

README

phyllo

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.

Example

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);
    }
}

Features

TLS is not enabled by default. Enable either of the following for TLS support:

License: MIT OR Apache-2.0

Commit count: 57

cargo fmt