1
0
Fork 0
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:
Daiderd Jordan 2016-12-01 23:56:20 +01:00
parent d82c472ab0
commit fecd4bc368
No known key found for this signature in database
GPG key ID: D02435D05B810C96
3 changed files with 16 additions and 40 deletions

View file

@ -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

View file

@ -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;
};
}

View file

@ -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.
'';
};