-
Notifications
You must be signed in to change notification settings - Fork 58
FAQ
Outset is controlled by five launchd plists:
/Library/LaunchDaemons/com.github.outset.boot.plist
/Library/LaunchDaemons/com.github.outset.cleanup.plist
/Library/LaunchDaemons/com.github.outset.login-privileged.plist
/Library/LaunchAgents/com.github.outset.login.plist
/Library/LaunchAgents/com.github.outset.on-demand.plist
For each folder of items to process, if a file type is present, it always operates on:
- packages,
- then configuration profiles,
- and finally scripts.
The boot
LaunchDaemon processes packages, profiles, and scripts during the boot sequence, and will either run once, or at every subsequent boot, depending on the directory in which the files are placed:
/usr/local/outset/boot-once/
/usr/local/outset/boot-every/
When the Mac boots, launchd will run /usr/local/outset/outset --boot
which does the following:
- Verifies that all working directories exist, and creates them if not.
- If the
network_wait
setting is set to True (which is the default setting):- disables the loginwindow process
- waits until the Mac has a valid IP address
- Processes and deletes everything in
/usr/local/outset/boot-once/
- Loads the loginwindow.
- Processes everything in
/usr/local/outset/boot-every/
- Creates the Outset preference in
/usr/local/outset/share/
if it does not exist.
The login
LaunchAgent runs any scripts or profiles during user login, and will run either once, or at every subsequent login, depending on the directory in which the files are placed:
/usr/local/outset/#-once/
/usr/local/outset/#-every/
When the user logs in, launchd will run /usr/local/outset/outset --login
which does the following:
- If the user is not in the
ignored_users
array:- Processes everything in
/usr/local/outset/#-once/
in the user context. - Logs the names of all login-once items to
~/Library/Preferences/com.github.outset.once.plist
- Processes everything in
/usr/local/outset/#-every/
in the user context.
- Processes everything in
Outset completes the login
run by checking if there are any packages, profiles, or scripts in the the following directories:
/usr/local/outset/#-privileged-once/
/usr/local/outset/#-privileged-every/
If there are any files defined in these directories, Outset triggers an additional LaunchDaemon to run /usr/local/outset --login-privileged
as root, which does the following:
- If the user is not in the
ignored_users
array:- Processes everything in
/usr/local/outset/#-privileged-once/
in the root context. - Logs the names of all login-privileged-once items to
/usr/local/outset/share/com.github.outset.once.$UID.plist
where $UID is the UID of the console user. - Processes everything in
/usr/local/outset/#-privileged-every/
in the root context.
- Processes everything in
When processing items Outset handles each type (all pkgs, then profiles, then scripts) alphanumerically, meaning a file starting with 000
will be evaluated before one that starts with 0a
, after which would be files like AAA
that start with capitalized characters, then lowercase files aaa
.
The on-demand
LaunchAgent and cleanup
LaunchDaemon, respectively, process and remove scripts or profiles from the following directory immediately, in the user context, for any currently logged in user (for those using Fast User Switching, it will only run in the current GUI session, and will not run in any background sessions):
/usr/local/outset/on-demand/
When on-demand is initiated, launchd will run /usr/local/outset/outset --on-demand
, which does the following in the current user session only:
- Processes everything in
/usr/local/outset/on-demand/
- Deletes everything in
/usr/local/outset/on-demand/
If you decide you don't want to use Outset any more, these commands should remove all traces of the tool:
sudo launchctl unload "/Library/LaunchDaemons/com.github.outset.boot.plist"
sudo rm -fv "/Library/LaunchDaemons/com.github.outset.boot.plist"
sudo launchctl unload "/Library/LaunchDaemons/com.github.outset.cleanup.plist"
sudo rm -fv "/Library/LaunchDaemons/com.github.outset.cleanup.plist"
sudo launchctl unload "/Library/LaunchAgents/com.github.outset.login.plist"
sudo rm -fv "/Library/LaunchAgents/com.github.outset.login.plist"
sudo launchctl unload "/Library/LaunchAgents/com.github.outset.on-demand.plist"
sudo rm -fv "/Library/LaunchAgents/com.github.outset.on-demand.plist"
sudo rm -rfv /usr/local/outset
sudo pkgutil --forget com.github.outset