4 stable releases
1.1.2 | Jan 4, 2024 |
---|---|
1.1.1 | Jan 3, 2024 |
1.1.0 | Jan 2, 2024 |
1.0.0 | Jan 2, 2024 |
#2 in #elevated
590 downloads per month
Used in 2 crates
(via geph5-client)
35KB
278 lines
elevated-command
Run command using sudo
, prompting the user with a graphical OS dialog if necessary. Useful for background rust applications or native Tauri apps that need sudo
.
Cross-Platform
elevated-command
provides a native OS dialog prompt on Windows, Linux and MacOS.
Example
Add the following to your Cargo.toml:
[dependencies]
elevated-command = "1.1"
In your main.rs
:
use elevated_command::Command;
use std::process::Command as StdCommand;
fn main() {
let is_elevated = Command::is_elevated();
let mut cmd = StdCommand::new("path to the application");
cmd.arg("some arg");
let output = if is_elevated {
cmd.output().unwrap()
} else {
let elevated_cmd = Command::new(cmd);
elevated_cmd.output().unwrap()
};
}
Note: The application should not be sudo
.
To get started using elevated-command
, please see the API reference (docs.rs).
Behavior
On Windows, elevated-command
will elevate your command using User Account Control (UAC).
On Linux, elevated-command
will use pkexec
to show the password prompt and run your command.
On MacOS, elevated-command
should behave just like the sudo
command in the shell.
Reference
- jorangreef/sudo-prompt
- https://stackoverflow.com/questions/8046097/how-to-check-if-a-process-has-the-administrative-rights/8196291#8196291
- https://fix.moe/post/macos-app-authorization
License
Licensed under the MIT license.
Dependencies
~0.2–35MB
~527K SLoC