mirror of
https://gitlab.steamos.cloud/holo/steamos-manager.git
synced 2025-07-06 06:30:27 -04:00
manager/user: Add ReloadConfig method
This commit is contained in:
parent
cd14f50f68
commit
0f14facac9
4 changed files with 40 additions and 7 deletions
|
@ -297,6 +297,15 @@
|
||||||
-->
|
-->
|
||||||
<property name="GpuPowerProfile" type="u" access="readwrite"/>
|
<property name="GpuPowerProfile" type="u" access="readwrite"/>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
ReloadConfig:
|
||||||
|
|
||||||
|
Reloads the configuration from disk.
|
||||||
|
|
||||||
|
Version available: 9
|
||||||
|
-->
|
||||||
|
<method name="ReloadConfig"/>
|
||||||
|
|
||||||
</interface>
|
</interface>
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
use anyhow::{bail, Result};
|
use anyhow::{bail, Result};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
|
use tokio::sync::mpsc::Sender;
|
||||||
use tracing::error;
|
use tracing::error;
|
||||||
use tracing_subscriber::prelude::*;
|
use tracing_subscriber::prelude::*;
|
||||||
use tracing_subscriber::{fmt, Registry};
|
use tracing_subscriber::{fmt, Registry};
|
||||||
|
@ -16,7 +17,7 @@ use xdg::BaseDirectories;
|
||||||
use zbus::connection::Connection;
|
use zbus::connection::Connection;
|
||||||
use zbus::ConnectionBuilder;
|
use zbus::ConnectionBuilder;
|
||||||
|
|
||||||
use crate::daemon::{channel, Daemon, DaemonContext};
|
use crate::daemon::{channel, Daemon, DaemonCommand, DaemonContext};
|
||||||
use crate::manager::user::SteamOSManager;
|
use crate::manager::user::SteamOSManager;
|
||||||
use crate::path;
|
use crate::path;
|
||||||
use crate::udev::UdevMonitor;
|
use crate::udev::UdevMonitor;
|
||||||
|
@ -98,14 +99,16 @@ impl DaemonContext for UserContext {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn create_connections() -> Result<(Connection, Connection)> {
|
pub(crate) type Command = DaemonCommand<()>;
|
||||||
|
|
||||||
|
async fn create_connections(channel: Sender<Command>) -> Result<(Connection, Connection)> {
|
||||||
let system = Connection::system().await?;
|
let system = Connection::system().await?;
|
||||||
let connection = ConnectionBuilder::session()?
|
let connection = ConnectionBuilder::session()?
|
||||||
.name("com.steampowered.SteamOSManager1")?
|
.name("com.steampowered.SteamOSManager1")?
|
||||||
.build()
|
.build()
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
let manager = SteamOSManager::new(connection.clone(), &system).await?;
|
let manager = SteamOSManager::new(connection.clone(), &system, channel).await?;
|
||||||
connection
|
connection
|
||||||
.object_server()
|
.object_server()
|
||||||
.at("/com/steampowered/SteamOSManager1", manager)
|
.at("/com/steampowered/SteamOSManager1", manager)
|
||||||
|
@ -120,9 +123,9 @@ pub async fn daemon() -> Result<()> {
|
||||||
|
|
||||||
let stdout_log = fmt::layer();
|
let stdout_log = fmt::layer();
|
||||||
let subscriber = Registry::default().with(stdout_log);
|
let subscriber = Registry::default().with(stdout_log);
|
||||||
let (_tx, rx) = channel::<UserContext>();
|
let (tx, rx) = channel::<UserContext>();
|
||||||
|
|
||||||
let (session, system) = match create_connections().await {
|
let (session, system) = match create_connections(tx).await {
|
||||||
Ok(c) => c,
|
Ok(c) => c,
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
let _guard = tracing::subscriber::set_default(subscriber);
|
let _guard = tracing::subscriber::set_default(subscriber);
|
||||||
|
|
|
@ -8,12 +8,15 @@
|
||||||
|
|
||||||
use anyhow::Result;
|
use anyhow::Result;
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
|
use tokio::sync::mpsc::Sender;
|
||||||
use tracing::error;
|
use tracing::error;
|
||||||
use zbus::proxy::Builder;
|
use zbus::proxy::Builder;
|
||||||
use zbus::zvariant::Fd;
|
use zbus::zvariant::Fd;
|
||||||
use zbus::{fdo, interface, Connection, Proxy, SignalContext};
|
use zbus::{fdo, interface, Connection, Proxy, SignalContext};
|
||||||
|
|
||||||
use crate::cec::{HdmiCecControl, HdmiCecState};
|
use crate::cec::{HdmiCecControl, HdmiCecState};
|
||||||
|
use crate::daemon::user::Command;
|
||||||
|
use crate::daemon::DaemonCommand;
|
||||||
use crate::error::{to_zbus_error, to_zbus_fdo_error, zbus_to_zbus_fdo};
|
use crate::error::{to_zbus_error, to_zbus_fdo_error, zbus_to_zbus_fdo};
|
||||||
use crate::hardware::check_support;
|
use crate::hardware::check_support;
|
||||||
use crate::power::{
|
use crate::power::{
|
||||||
|
@ -61,10 +64,11 @@ macro_rules! setter {
|
||||||
pub struct SteamOSManager {
|
pub struct SteamOSManager {
|
||||||
proxy: Proxy<'static>,
|
proxy: Proxy<'static>,
|
||||||
hdmi_cec: HdmiCecControl<'static>,
|
hdmi_cec: HdmiCecControl<'static>,
|
||||||
|
channel: Sender<Command>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SteamOSManager {
|
impl SteamOSManager {
|
||||||
pub async fn new(connection: Connection, system_conn: &Connection) -> Result<Self> {
|
pub async fn new(connection: Connection, system_conn: &Connection, channel: Sender<Command>) -> Result<Self> {
|
||||||
Ok(SteamOSManager {
|
Ok(SteamOSManager {
|
||||||
hdmi_cec: HdmiCecControl::new(&connection).await?,
|
hdmi_cec: HdmiCecControl::new(&connection).await?,
|
||||||
proxy: Builder::new(system_conn)
|
proxy: Builder::new(system_conn)
|
||||||
|
@ -74,6 +78,7 @@ impl SteamOSManager {
|
||||||
.cache_properties(zbus::CacheProperties::No)
|
.cache_properties(zbus::CacheProperties::No)
|
||||||
.build()
|
.build()
|
||||||
.await?,
|
.await?,
|
||||||
|
channel,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -308,12 +313,24 @@ impl SteamOSManager {
|
||||||
.await
|
.await
|
||||||
.map_err(to_zbus_error)
|
.map_err(to_zbus_error)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async fn reload_config(&self) -> fdo::Result<()> {
|
||||||
|
self.channel
|
||||||
|
.send(DaemonCommand::ReadConfig)
|
||||||
|
.await
|
||||||
|
.inspect_err(|message| error!("Error sending ReadConfig command: {message}"))
|
||||||
|
.map_err(to_zbus_fdo_error)?;
|
||||||
|
method!(self, "ReloadConfig")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod test {
|
mod test {
|
||||||
use super::*;
|
use super::*;
|
||||||
use crate::testing;
|
use crate::testing;
|
||||||
|
use crate::daemon::channel;
|
||||||
|
use crate::daemon::user::UserContext;
|
||||||
|
|
||||||
use std::collections::{HashMap, HashSet};
|
use std::collections::{HashMap, HashSet};
|
||||||
use std::iter::zip;
|
use std::iter::zip;
|
||||||
use tokio::fs::read;
|
use tokio::fs::read;
|
||||||
|
@ -327,8 +344,9 @@ mod test {
|
||||||
|
|
||||||
async fn start() -> Result<TestHandle> {
|
async fn start() -> Result<TestHandle> {
|
||||||
let handle = testing::start();
|
let handle = testing::start();
|
||||||
|
let (tx, _rx) = channel::<UserContext>();
|
||||||
let connection = ConnectionBuilder::session()?.build().await?;
|
let connection = ConnectionBuilder::session()?.build().await?;
|
||||||
let manager = SteamOSManager::new(connection.clone(), &connection).await?;
|
let manager = SteamOSManager::new(connection.clone(), &connection, tx).await?;
|
||||||
connection
|
connection
|
||||||
.object_server()
|
.object_server()
|
||||||
.at("/com/steampowered/SteamOSManager1", manager)
|
.at("/com/steampowered/SteamOSManager1", manager)
|
||||||
|
|
|
@ -46,6 +46,9 @@ trait Manager {
|
||||||
/// UpdateDock method
|
/// UpdateDock method
|
||||||
fn update_dock(&self) -> zbus::Result<zbus::zvariant::OwnedObjectPath>;
|
fn update_dock(&self) -> zbus::Result<zbus::zvariant::OwnedObjectPath>;
|
||||||
|
|
||||||
|
/// ReloadConfig method
|
||||||
|
fn reload_config(&self) -> zbus::Result<()>;
|
||||||
|
|
||||||
/// AlsCalibrationGain property
|
/// AlsCalibrationGain property
|
||||||
#[zbus(property)]
|
#[zbus(property)]
|
||||||
fn als_calibration_gain(&self) -> zbus::Result<f64>;
|
fn als_calibration_gain(&self) -> zbus::Result<f64>;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue