2023-06-01 12:23:12 -04:00
|
|
|
use super::{NetworkManagerEvent, NetworkManagerState};
|
|
|
|
|
use cosmic::iced::{self, subscription};
|
|
|
|
|
use cosmic_dbus_networkmanager::nm::NetworkManager;
|
2023-07-10 18:17:32 -04:00
|
|
|
use futures::{SinkExt, StreamExt};
|
2023-06-01 12:23:12 -04:00
|
|
|
use log::error;
|
|
|
|
|
use std::fmt::Debug;
|
|
|
|
|
use std::hash::Hash;
|
|
|
|
|
use zbus::Connection;
|
|
|
|
|
|
|
|
|
|
pub fn active_conns_subscription<I: 'static + Hash + Copy + Send + Sync + Debug>(
|
|
|
|
|
id: I,
|
|
|
|
|
conn: Connection,
|
2023-07-10 18:17:32 -04:00
|
|
|
) -> iced::Subscription<NetworkManagerEvent> {
|
|
|
|
|
let initial = State::Continue(conn.clone());
|
|
|
|
|
subscription::channel(id, 50, move |mut output| {
|
|
|
|
|
let mut state = initial.clone();
|
|
|
|
|
|
|
|
|
|
async move {
|
|
|
|
|
loop {
|
|
|
|
|
state = start_listening(state, &mut output).await;
|
2023-08-08 16:18:12 -04:00
|
|
|
_ = tokio::time::sleep(tokio::time::Duration::from_secs(2)).await;
|
2023-06-01 12:23:12 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[derive(Debug, Clone)]
|
|
|
|
|
pub enum State {
|
|
|
|
|
Continue(Connection),
|
|
|
|
|
Error,
|
|
|
|
|
}
|
|
|
|
|
|
2023-07-10 18:17:32 -04:00
|
|
|
async fn start_listening(
|
2023-06-01 12:23:12 -04:00
|
|
|
state: State,
|
2023-07-10 18:17:32 -04:00
|
|
|
output: &mut futures::channel::mpsc::Sender<NetworkManagerEvent>,
|
|
|
|
|
) -> State {
|
2023-06-01 12:23:12 -04:00
|
|
|
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(e) => {
|
|
|
|
|
error!("Failed to connect to NetworkManager: {}", e);
|
2023-07-10 18:17:32 -04:00
|
|
|
return State::Error;
|
2023-06-01 12:23:12 -04:00
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
let mut active_conns_changed = network_manager.receive_active_connections_changed().await;
|
|
|
|
|
active_conns_changed.next().await;
|
|
|
|
|
|
|
|
|
|
let new_state = NetworkManagerState::new(&conn).await.unwrap_or_default();
|
|
|
|
|
|
2023-07-10 18:17:32 -04:00
|
|
|
_ = output
|
|
|
|
|
.send(NetworkManagerEvent::ActiveConns(new_state))
|
|
|
|
|
.await;
|
|
|
|
|
State::Continue(conn)
|
2023-06-01 12:23:12 -04:00
|
|
|
}
|