mirror of
https://github.com/RGBCube/superfreq
synced 2025-07-27 17:07:44 +00:00
battery: perform permission checks upfront
This commit is contained in:
parent
705fc6c46d
commit
b11bad74d5
1 changed files with 29 additions and 0 deletions
|
@ -82,6 +82,14 @@ pub fn set_battery_charge_thresholds(start_threshold: u8, stop_threshold: u8) ->
|
|||
));
|
||||
}
|
||||
|
||||
// Check if the power supply directory is writable
|
||||
// This helps identify permission issues in containerized environments early
|
||||
if !is_path_writable(power_supply_path) {
|
||||
return Err(ControlError::PermissionDenied(
|
||||
"Power supply path exists but is not writable. This may occur in containerized environments.".to_string(),
|
||||
));
|
||||
}
|
||||
|
||||
let supported_batteries = find_supported_batteries(power_supply_path)?;
|
||||
if supported_batteries.is_empty() {
|
||||
return Err(ControlError::NotSupported(
|
||||
|
@ -240,3 +248,24 @@ fn is_battery(path: &Path) -> Result<bool> {
|
|||
|
||||
Ok(ps_type == "Battery")
|
||||
}
|
||||
|
||||
/// Check if a directory is writable by attempting to open a temporary file for writing
|
||||
fn is_path_writable(path: &Path) -> bool {
|
||||
use std::fs::OpenOptions;
|
||||
|
||||
// Try to create a temporary file to check write permissions
|
||||
// If we're in a container with a read-only mount, this will fail
|
||||
let temp_file_path = path.join(".superfreq_write_test");
|
||||
let result = OpenOptions::new()
|
||||
.write(true)
|
||||
.create(true)
|
||||
.open(&temp_file_path);
|
||||
|
||||
// Clean up the temporary file if we created it
|
||||
if result.is_ok() {
|
||||
let _ = fs::remove_file(temp_file_path);
|
||||
true
|
||||
} else {
|
||||
false
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue