/raunch

A safe wrapper around launchd launch_activate_socket

Primary LanguageRust

Raunch

A safe wrapper around launchd launch_activate_socket.

#[cfg(target_os = "macos")]
let descriptors = raunch::activate_socket("socket-name").expect("activation to work");

The name of the socket (here socket-name) needs to match the socket name in the plist file:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
	<key>Label</key>
	<string>com.example.agent</string>
	<key>OnDemand</key>
	<true/>
	<key>ProgramArguments</key>
	<array>
		<string>example-agent</string>
	</array>
	<key>RunAtLoad</key>
	<true/>
	<key>Sockets</key>
	<dict>
		<key>socket-name</key>
		<dict>
			<key>SockPathName</key>
			<string>/Users/test/.openpgp-card-ssh-agent</string>
			<key>SockFamily</key>
			<string>Unix</string>
		</dict>
	</dict>
</dict>
</plist>

The file can be placed in ~/Library/LaunchAgents and loaded via launchctl load ~/Library/LaunchAgents/com.example.agent.plist.