cosmic-applets/cosmic-applet-network/src/network_manager/active_conns.rs

67 lines
1.8 KiB
Rust
Raw Normal View History

use super::{NetworkManagerEvent, NetworkManagerState};
2024-10-30 22:51:08 -04:00
use cosmic::{
iced::{self, Subscription},
iced_futures::stream,
};
use cosmic_dbus_networkmanager::nm::NetworkManager;
use futures::{SinkExt, StreamExt};
2024-07-09 15:17:44 +02:00
use std::{fmt::Debug, hash::Hash};
use zbus::Connection;
pub fn active_conns_subscription<I: 'static + Hash + Copy + Send + Sync + Debug>(
id: I,
conn: Connection,
) -> iced::Subscription<NetworkManagerEvent> {
2023-11-16 18:24:47 +00:00
let initial = State::Continue(conn);
2024-10-30 22:51:08 -04:00
Subscription::run_with_id(
id,
stream::channel(50, move |mut output| {
let mut state = initial;
2024-10-30 22:51:08 -04:00
async move {
loop {
state = start_listening(state, &mut output).await;
}
}
2024-10-30 22:51:08 -04:00
}),
)
}
#[derive(Debug, Clone)]
pub enum State {
Continue(Connection),
Error,
}
async fn start_listening(
state: State,
output: &mut futures::channel::mpsc::Sender<NetworkManagerEvent>,
) -> State {
let conn = match state {
State::Continue(conn) => conn,
State::Error => iced::futures::future::pending().await,
};
let network_manager = match NetworkManager::new(&conn).await {
Ok(n) => n,
Err(why) => {
tracing::error!(why = why.to_string(), "Failed to connect to NetworkManager");
return State::Error;
}
};
let mut active_conns_changed = network_manager.receive_active_connections_changed().await;
active_conns_changed.next().await;
while let (Some(_change), ()) = tokio::join!(
active_conns_changed.next(),
tokio::time::sleep(tokio::time::Duration::from_secs(1))
) {
let new_state = NetworkManagerState::new(&conn).await.unwrap_or_default();
_ = output
.send(NetworkManagerEvent::ActiveConns(new_state))
.await;
}
State::Continue(conn)
}