lesavka/client/src/main.rs

46 lines
1.5 KiB
Rust
Raw Normal View History

2025-06-01 16:04:00 -05:00
//! navka-client forward keyboard/mouse HID reports to navka-server
#![forbid(unsafe_code)]
use anyhow::Result;
2025-06-06 00:21:20 -05:00
use navka_common::navka::{relay_client::RelayClient, HidReport};
2025-06-01 16:04:00 -05:00
use tokio::{sync::mpsc, time::sleep};
use tokio_stream::wrappers::ReceiverStream;
2025-06-01 16:04:00 -05:00
use tonic::{transport::Channel, Request};
2025-06-01 13:31:22 -05:00
#[tokio::main]
async fn main() -> Result<()> {
2025-06-06 00:21:20 -05:00
tracing_subscriber::fmt::init();
2025-06-01 21:16:26 -05:00
// -- server address comes from CLI arg, env or falls back to localhost
let addr = std::env::args()
.nth(1)
2025-06-06 00:21:20 -05:00
.or_else(|| std::env::var("NAVKA_SERVER_ADDR").ok())
2025-06-01 21:16:26 -05:00
.unwrap_or_else(|| "http://127.0.0.1:50051".to_owned());
let channel: Channel = Channel::from_shared(addr)?
2025-06-01 16:04:00 -05:00
.connect()
.await?;
2025-06-01 21:16:26 -05:00
// mpsc -> ReceiverStream -> bidirectional gRPC
2025-06-01 16:04:00 -05:00
let (tx, rx) = mpsc::channel::<HidReport>(32);
let outbound = ReceiverStream::new(rx);
let mut inbound = RelayClient::new(channel)
.stream(Request::new(outbound))
.await?
.into_inner();
2025-06-01 21:16:26 -05:00
// demo: press & release a
tokio::spawn(async move {
2025-06-01 21:16:26 -05:00
let press_a = HidReport { data: vec![0, 0, 0x04, 0, 0, 0, 0, 0] };
2025-06-01 16:04:00 -05:00
let release = HidReport { data: vec![0; 8] };
tx.send(press_a).await.ok();
sleep(std::time::Duration::from_millis(100)).await;
tx.send(release).await.ok();
});
2025-06-01 13:31:22 -05:00
2025-06-01 16:04:00 -05:00
while let Some(report) = inbound.message().await? {
2025-06-06 00:21:20 -05:00
tracing::info!(bytes=?report.data, "echo from server");
2025-06-01 13:31:22 -05:00
}
Ok(())
2025-06-01 13:31:22 -05:00
}