I’m not *completely* certain that this handles user agents correctly. There is a deprecated command, `launchctl asuser`, that executes a command in the Mach bootstrap context of another user`. <https://scriptingosx.com/2020/08/running-a-command-as-another-user/> claims that this is required when loading and unloading user agents, but I haven’t tested this. Our current launchd agent logic is pretty weird and broken already anyway, so unless this actively regresses things I’d lean towards keeping it like this until we can move over entirely to `launchctl bootstrap`/`launchctl kickstart`, which aren’t deprecated and can address individual users directly. Someone should definitely test it more extensively than I have, though.
29 lines
952 B
Nix
29 lines
952 B
Nix
{ config, lib, pkgs, ... }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
spacebar = pkgs.runCommand "spacebar-0.0.0" {} "mkdir $out";
|
|
in
|
|
|
|
{
|
|
system.primaryUser = "test-spacebar-user";
|
|
|
|
services.spacebar.enable = true;
|
|
services.spacebar.package = spacebar;
|
|
services.spacebar.config = { background_color = "0xff202020"; };
|
|
services.spacebar.extraConfig = ''echo "spacebar config loaded..."'';
|
|
|
|
test = ''
|
|
echo >&2 "checking spacebar service in ~/Library/LaunchAgents"
|
|
grep "org.nixos.spacebar" ${config.out}/user/Library/LaunchAgents/org.nixos.spacebar.plist
|
|
grep "${spacebar}/bin/spacebar" ${config.out}/user/Library/LaunchAgents/org.nixos.spacebar.plist
|
|
|
|
conf=`sed -En '/<string>-c<\/string>/{n; s/\s+?<\/?string>//g; p;}' \
|
|
${config.out}/user/Library/LaunchAgents/org.nixos.spacebar.plist`
|
|
|
|
echo >&2 "checking config in $conf"
|
|
grep "spacebar -m config background_color 0xff202020" $conf
|
|
grep "spacebar config loaded..." $conf
|
|
'';
|
|
}
|