From 30593350fd91f25b68bfa44cf5f948e481262258 Mon Sep 17 00:00:00 2001 From: Thibault Gagnaux Date: Sat, 29 Aug 2020 16:32:49 +0200 Subject: [PATCH] Makes it work. --- modules/services/lorri.nix | 59 +++++++++++++++----------------------- tests/services-lorri.nix | 14 +++++---- 2 files changed, 32 insertions(+), 41 deletions(-) diff --git a/modules/services/lorri.nix b/modules/services/lorri.nix index 142f5748..9e2dfd6c 100644 --- a/modules/services/lorri.nix +++ b/modules/services/lorri.nix @@ -4,56 +4,43 @@ with lib; let cfg = config.services.lorri; + home = "${builtins.getEnv "HOME"}"; in { - options = { - services.lorri.enable = mkOption { - type = types.bool; - default = false; - description = "Whether to enable the lorri service."; - }; + options = { + services.lorri = { + enable = mkOption { + type = types.bool; + default = false; + description = "Whether to enable the lorri service."; + }; - services.lorri.package = mkOption { - type = types.path; - default = pkgs.lorri; - defaultText = "pkgs.lorri"; - description = "This option specifies the lorri package to use."; - }; - - services.lorri.logFile = mkOption { - type = types.nullOr types.path; - default = "/var/tmp/lorri.log"; - example = "/var/tmp/lorri.log"; - description = '' - The logfile to use for the lorri service. Alternatively - sudo launchctl debug system/org.nixos.lorri --stderr - can be used to stream the logs to a shell after restarting the service with - sudo launchctl kickstart -k system/org.nixos.lorri. - ''; - }; - - services.lorri.tempDir = mkOption { - type = types.nullOr types.path; - default = null; - description = "The TMPDIR to use for lorri."; + logFile = mkOption { + type = types.nullOr types.path; + default = "${home}/Library/Logs/lorri.log"; + example = "${home}/Library/Logs/lorri.log"; + description = '' + The logfile to use for the lorri service. Alternatively + sudo launchctl debug system/com.target.lorri --stderr + can be used to stream the logs to a shell after restarting the service with + sudo launchctl kickstart -k system/com.target.lorri. + ''; + }; }; }; config = mkIf cfg.enable { - environment.systemPackages = [ cfg.package ]; + environment.systemPackages = [ pkgs.lorri ]; launchd.user.agents.lorri = { serviceConfig = { + Label = "com.target.lorri"; + ProgramArguments = with pkgs; ["${zsh}/bin/zsh" "-c" "${lorri}/bin/lorri daemon"]; KeepAlive = true; + RunAtLoad = true; ProcessType = "Background"; - LowPriorityIO = false; StandardOutPath = cfg.logFile; StandardErrorPath = cfg.logFile; - EnvironmentVariables = mkMerge [ - config.nix.envVars - { TMPDIR = mkIf (cfg.tempDir != null) cfg.tempDir; } - ]; }; - command = "${cfg.package}/bin/lorri daemon"; }; }; } \ No newline at end of file diff --git a/tests/services-lorri.nix b/tests/services-lorri.nix index e70eef5d..d6a9935c 100644 --- a/tests/services-lorri.nix +++ b/tests/services-lorri.nix @@ -2,17 +2,21 @@ let nix = pkgs.runCommand "nix-0.0.0" { version = "1.11.6"; } "mkdir -p $out"; - plistPath = "${config.out}/user/Library/LaunchAgents/org.nixos.lorri.plist"; + plistPath = "${config.out}/user/Library/LaunchAgents/com.target.lorri.plist"; in { services.lorri.enable = true; - nix.package = nix; + nix.package = pkgs.nix; test = '' echo checking lorri service in /Library/LaunchAgents >&2 - cat ${plistPath} grep -o "KeepAlive" ${plistPath} - grep -o "org.nixos.lorri" ${plistPath} - grep -o "exec ${pkgs.lorri}/bin/lorri daemon" ${plistPath} + grep -o "RunAtLoad" ${plistPath} + grep -o "ProcessType" ${plistPath} + grep -o "Background" ${plistPath} + grep -o "com.target.lorri" ${plistPath} + grep -o "${pkgs.zsh}/bin/zsh" ${plistPath} + grep -o "-c" ${plistPath} + grep -o "${pkgs.lorri}/bin/lorri daemon" ${plistPath} ''; }