7 releases (breaking)
| 0.6.0 | Jan 10, 2026 |
|---|---|
| 0.5.0 | Sep 10, 2023 |
| 0.4.0 | Sep 10, 2022 |
| 0.3.0 | Aug 24, 2022 |
| 0.1.1 | Jan 14, 2022 |
#87 in Filesystem
327,380 downloads per month
Used in 10 crates
(8 directly)
51KB
830 lines
Auto Launch
Auto launch any application or executable at startup. Supports Windows, macOS (Launch Agent, AppleScript, or SMAppService), and Linux.
How does it work? See Teamwork/node-auto-launch for details.
If you find any bugs, welcome to PR or issue.
Usage
The parameters of AutoLaunch::new are different on each platform.
See the function definition or the demo below for details.
AutoLaunchBuilder helps to eliminate the constructor difference on various platforms.
use auto_launch::*;
fn main() {
let auto = AutoLaunchBuilder::new()
.set_app_name("the-app")
.set_app_path("/path/to/the-app")
.set_macos_launch_mode(MacOSLaunchMode::LaunchAgent)
.build()
.unwrap();
auto.enable().unwrap();
auto.is_enabled().unwrap();
auto.disable().unwrap();
auto.is_enabled().unwrap();
}
Linux
Linux supports two ways to achieve auto launch:
- XDG Autostart: Uses
.desktopfiles in~/.config/autostart/(default) - systemd: Uses systemd user services in
~/.config/systemd/user/- Uses
systemctl --user enableto enable the service. - Requires
systemctlto be available in the environment.
- Uses
use auto_launch::{AutoLaunch, LinuxLaunchMode};
fn main() {
let app_name = "the-app";
let app_path = "/path/to/the-app";
// Use XDG Autostart (default method)
let auto = AutoLaunch::new(app_name, app_path, LinuxLaunchMode::XdgAutostart, &[] as &[&str]);
// Or use systemd user service
// let auto = AutoLaunch::new(app_name, app_path, LinuxLaunchMode::Systemd, &[] as &[&str]);
// enable the auto launch
auto.enable().is_ok();
auto.is_enabled().unwrap();
// disable the auto launch
auto.disable().is_ok();
auto.is_enabled().unwrap();
}
macOS
macOS supports three ways to achieve auto launch:
- Launch Agent: Uses plist files in
~/Library/LaunchAgents/(default) - AppleScript: Uses AppleScript to add login items
- SMAppService: Uses the SMAppService API (macOS 13+)
Note:
- The
app_pathshould be an absolute path and exists. Otherwise, it will cause an error whenenable. - In case using AppleScript, the
app_nameshould be same as the basename ofapp_path, or it will be corrected automatically. - In case using AppleScript, only
--hiddenand--minimizedinargsare valid, which means that hide the app on launch. - In case using SMAppService,
app_nameandapp_pathcan be empty strings because it registers the running app.
use auto_launch::{AutoLaunch, MacOSLaunchMode};
fn main() {
let app_name = "the-app";
let app_path = "/path/to/the-app.app";
// Use Launch Agent (default method)
let auto = AutoLaunch::new(app_name, app_path, MacOSLaunchMode::LaunchAgent, &[] as &[&str], &[] as &[&str], "");
// Or use AppleScript
// let auto = AutoLaunch::new(app_name, app_path, MacOSLaunchMode::AppleScript, &[] as &[&str], &[] as &[&str], "");
// Or use SMAppService (macOS 13+)
// let auto = AutoLaunch::new(app_name, app_path, MacOSLaunchMode::SMAppService, &[] as &[&str], &[] as &[&str], "");
// enable the auto launch
auto.enable().is_ok();
auto.is_enabled().unwrap();
// disable the auto launch
auto.disable().is_ok();
auto.is_enabled().unwrap();
}
Windows
On Windows, it will add registry entries under:
\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run(system)\HKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows\CurrentVersion\Run(current user)\HKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\StartupApproved\Run(Task Manager status)
It will also detect if startup is disabled inside Task Manager or the Windows settings UI, and can re-enable after being disabled in one of those.
Enable behavior is controlled by WindowsEnableMode:
Dynamic(default): try system-wide, fall back to current user on access deniedCurrentUser: write to current user onlySystem: write to system only (admin required)
use auto_launch::{AutoLaunch, WindowsEnableMode};
fn main() {
let app_name = "the-app";
let app_path = "C:\\path\\to\\the-app.exe";
let auto = AutoLaunch::new(app_name, app_path, WindowsEnableMode::Dynamic, &[] as &[&str]);
// enable the auto launch
auto.enable().is_ok();
auto.is_enabled().unwrap();
// disable the auto launch
auto.disable().is_ok();
auto.is_enabled().unwrap();
}
License
MIT License. See the License file for details.
Acknowledgement
The project is based on node-auto-launch.
Dependencies
~0.3–5MB
~96K SLoC