2022-08-10 01:56:22 +01:00
|
|
|
use std::fmt::Display;
|
2022-11-10 03:09:05 +00:00
|
|
|
//use std::sync::{LockResult, MutexGuard};
|
2023-02-22 02:28:59 +00:00
|
|
|
//use std::fs::{Permissions, metadata};
|
|
|
|
use std::os::unix::fs::PermissionsExt;
|
2022-08-10 01:56:22 +01:00
|
|
|
|
|
|
|
pub fn unwrap_maybe_fatal<T: Sized, E: Display>(result: Result<T, E>, message: &str) -> T {
|
|
|
|
match result {
|
|
|
|
Ok(x) => x,
|
|
|
|
Err(e) => {
|
|
|
|
log::error!("{}: {}", message, e);
|
|
|
|
panic!("{}: {}", message, e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-11-10 03:09:05 +00:00
|
|
|
/*pub fn unwrap_lock<'a, T: Sized>(
|
2022-08-10 01:56:22 +01:00
|
|
|
result: LockResult<MutexGuard<'a, T>>,
|
|
|
|
lock_name: &str,
|
|
|
|
) -> MutexGuard<'a, T> {
|
|
|
|
match result {
|
|
|
|
Ok(x) => x,
|
|
|
|
Err(e) => {
|
|
|
|
log::error!("Failed to acquire {} lock: {}", lock_name, e);
|
|
|
|
panic!("Failed to acquire {} lock: {}", lock_name, e);
|
|
|
|
}
|
|
|
|
}
|
2022-11-10 03:09:05 +00:00
|
|
|
}*/
|
2022-09-01 01:18:15 +01:00
|
|
|
|
|
|
|
pub fn settings_dir() -> std::path::PathBuf {
|
|
|
|
usdpl_back::api::dirs::home()
|
2022-11-29 00:04:03 +00:00
|
|
|
.unwrap_or_else(|| "/tmp/".into())
|
2022-09-01 01:18:15 +01:00
|
|
|
.join(".config/powertools/")
|
|
|
|
}
|
2023-02-22 02:28:59 +00:00
|
|
|
|
|
|
|
pub fn chown_settings_dir() -> std::io::Result<()> {
|
|
|
|
let dir = settings_dir();
|
|
|
|
#[cfg(feature = "decky")]
|
|
|
|
let deck_user = usdpl_back::api::decky::user().map_err(|_| std::io::Error::new(std::io::ErrorKind::NotFound, "Decky missing deck user's username"))?;
|
|
|
|
#[cfg(not(feature = "decky"))]
|
|
|
|
let deck_user = "deck".to_owned();
|
|
|
|
// FIXME this shouldn't need to invoke a command
|
|
|
|
let output = std::process::Command::new("id")
|
|
|
|
.args(["-u", &deck_user])
|
|
|
|
.output()?;
|
|
|
|
let uid: u32 = String::from_utf8_lossy(&output.stdout).parse().unwrap_or(1000);
|
|
|
|
log::info!("chmod/chown ~/.config/powertools for user `{}` ({})", deck_user, uid);
|
|
|
|
let permissions = PermissionsExt::from_mode(0o655);
|
|
|
|
std::fs::set_permissions(&dir, permissions)?;
|
|
|
|
// FIXME once merged into stable https://github.com/rust-lang/rust/issues/88989
|
|
|
|
//std::os::unix::fs::chown(&dir, Some(uid), None)
|
|
|
|
std::process::Command::new("chown")
|
|
|
|
.args(["-R", &format!("{}:{}", deck_user, deck_user), &dir.to_str().unwrap_or(".")])
|
|
|
|
.output()?;
|
|
|
|
Ok(())
|
|
|
|
}
|