use std::env;
use std::time::Duration;
use futures::StreamExt;
use motorcortex_rust::core::{Missed, Request, Subscribe};
use motorcortex_rust::{ConnectionOptions, Result, parse_url};
#[tokio::main]
async fn main() -> Result<()> {
let mut args = env::args().skip(1);
let url = args.next().unwrap_or_else(|| "wss://127.0.0.1:5568:5567".into());
let cert = args.next().unwrap_or_else(|| "tests/mcx.cert.crt".into());
let user = args.next().unwrap_or_else(|| "root".into());
let pass = args.next().unwrap_or_default();
let path = args
.next()
.unwrap_or_else(|| "root/Control/dummyDouble".into());
let (req_url, sub_url) = parse_url(&url)?;
let opts = ConnectionOptions::new(cert, 5_000, 5_000);
let req = Request::connect_to(&req_url, opts.clone()).await?;
req.login(&user, &pass).await?;
req.request_parameter_tree().await?;
let sub = Subscribe::connect_to(&sub_url, opts).await?;
let subscription = sub.subscribe(&req, [&path[..]], "example-stream", 10).await?;
let mut stream = Box::pin(subscription.stream::<f64>(256));
let deadline = tokio::time::Instant::now() + Duration::from_secs(5);
let mut seen = 0;
while seen < 20 {
match tokio::time::timeout_at(deadline, stream.next()).await {
Ok(Some(Ok((_ts, v)))) => {
println!("{path} = {v}");
seen += 1;
}
Ok(Some(Err(Missed(n)))) => eprintln!("lagged, dropped {n} samples"),
Ok(None) | Err(_) => break,
}
}
sub.unsubscribe(&req, subscription).await?;
sub.disconnect().await?;
req.disconnect().await?;
Ok(())
}