mirror of
https://github.com/LnL7/nix-darwin.git
synced 2024-12-14 11:57:34 +00:00
improve launchd activation scripts
This commit is contained in:
parent
d82c472ab0
commit
fecd4bc368
3 changed files with 16 additions and 40 deletions
|
@ -11,6 +11,7 @@ let
|
|||
./modules/system/activation-scripts.nix
|
||||
./modules/system/defaults
|
||||
./modules/system/etc.nix
|
||||
./modules/system/launchd.nix
|
||||
./modules/environment
|
||||
./modules/launchd
|
||||
./modules/programs/tmux.nix
|
||||
|
|
|
@ -7,17 +7,16 @@ let
|
|||
|
||||
cfg = config.launchd;
|
||||
|
||||
toEnvironmentText = name: value: {
|
||||
name = "${value.serviceConfig.Label}.plist";
|
||||
value.text = toPLIST value.serviceConfig;
|
||||
};
|
||||
|
||||
launchdConfig = import ./launchd.nix;
|
||||
|
||||
serviceOptions =
|
||||
{ config, name, ... }:
|
||||
{ options = {
|
||||
plist = mkOption {
|
||||
internal = true;
|
||||
type = types.path;
|
||||
description = "The generated plist.";
|
||||
};
|
||||
|
||||
serviceConfig = mkOption {
|
||||
type = types.submodule launchdConfig;
|
||||
example =
|
||||
|
@ -34,12 +33,12 @@ let
|
|||
|
||||
config = {
|
||||
serviceConfig.Label = mkDefault "org.nixos.${name}";
|
||||
|
||||
plist = pkgs.writeText "${config.serviceConfig.Label}.plist" (toPLIST config.serviceConfig);
|
||||
};
|
||||
};
|
||||
|
||||
in {
|
||||
in
|
||||
|
||||
{
|
||||
options = {
|
||||
|
||||
launchd.agents = mkOption {
|
||||
|
@ -54,35 +53,12 @@ in {
|
|||
description = "Definition of launchd daemons.";
|
||||
};
|
||||
|
||||
launchd.user.agents = mkOption {
|
||||
default = {};
|
||||
type = types.attrsOf (types.submodule serviceOptions);
|
||||
description = "Definition of launchd per-user agents.";
|
||||
};
|
||||
|
||||
};
|
||||
|
||||
config = {
|
||||
|
||||
system.build.launchd = pkgs.stdenvNoCC.mkDerivation {
|
||||
name = "launchd-library";
|
||||
preferLocalBuild = true;
|
||||
|
||||
buildCommand = ''
|
||||
mkdir -p $out/Library/LaunchDaemons
|
||||
ln -s ${cfg.daemons.nix-daemon.plist} $out/Library/LaunchDaemons/${cfg.daemons.nix-daemon.serviceConfig.Label}.plist
|
||||
'';
|
||||
};
|
||||
|
||||
system.activationScripts.launchd.text = ''
|
||||
# Set up launchd services in /Library/LaunchAgents, /Library/LaunchDaemons and ~/Library/LaunchAgents
|
||||
echo "setting up launchd services..."
|
||||
|
||||
launchctl unload '/Library/LaunchDaemons/${cfg.daemons.nix-daemon.serviceConfig.Label}.plist'
|
||||
ln -sfn '${cfg.daemons.nix-daemon.plist}' '/Library/LaunchDaemons/${cfg.daemons.nix-daemon.serviceConfig.Label}.plist'
|
||||
launchctl load '/Library/LaunchDaemons/${cfg.daemons.nix-daemon.serviceConfig.Label}.plist'
|
||||
|
||||
'';
|
||||
environment.launchAgents = mapAttrs' toEnvironmentText cfg.agents;
|
||||
environment.launchDaemons = mapAttrs' toEnvironmentText cfg.daemons;
|
||||
|
||||
};
|
||||
}
|
||||
|
|
|
@ -1,8 +1,9 @@
|
|||
{ lib, mkTextDerivation }:
|
||||
|
||||
{ config, name, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
{ config, name, ... }:
|
||||
let
|
||||
|
||||
sourceDrv = mkTextDerivation name config.text;
|
||||
|
@ -16,8 +17,8 @@ in
|
|||
type = types.bool;
|
||||
default = true;
|
||||
description = ''
|
||||
Whether this /etc file should be generated. This
|
||||
option allows specific /etc files to be disabled.
|
||||
Whether this file should be generated.
|
||||
This option allows specific files to be disabled.
|
||||
'';
|
||||
};
|
||||
|
||||
|
@ -33,9 +34,7 @@ in
|
|||
type = types.str;
|
||||
default = name;
|
||||
description = ''
|
||||
Name of symlink (relative to
|
||||
<filename>/etc</filename>). Defaults to the attribute
|
||||
name.
|
||||
Name of symlink. Defaults to the attribute name.
|
||||
'';
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in a new issue