From b16b84abbf1a43af7b19501a16fa92ff78c4a50f Mon Sep 17 00:00:00 2001 From: Piotr Limanowski Date: Fri, 17 Mar 2017 21:34:10 +0100 Subject: [PATCH] Adds mopidy service with media keys support --- default.nix | 1 + modules/services/mopidy.nix | 61 +++++++++++++++++++++++++++++++++++++ 2 files changed, 62 insertions(+) create mode 100644 modules/services/mopidy.nix diff --git a/default.nix b/default.nix index 4da081f..f8fb692 100644 --- a/default.nix +++ b/default.nix @@ -39,6 +39,7 @@ let ./modules/services/khd.nix ./modules/services/kwm.nix ./modules/services/emacs.nix + ./modules/services/mopidy.nix ./modules/services/nix-daemon.nix ./modules/services/nix-gc.nix ./modules/programs/bash.nix diff --git a/modules/services/mopidy.nix b/modules/services/mopidy.nix new file mode 100644 index 0000000..c22f1d1 --- /dev/null +++ b/modules/services/mopidy.nix @@ -0,0 +1,61 @@ +{ config, lib, pkgs, ... }: + +with lib; + +let + + cfg = config.services.mopidy; + +in + +{ + options = { + services.mopidy = { + + enable = mkOption { + type = types.bool; + default = false; + description = "Whether to enable the Mopidy Daemon."; + }; + + package = mkOption { + type = types.path; + default = pkgs.mopidy; + description = "This option specifies the mopidy package to use."; + }; + + mediakeys = { + enable = mkOption { + type = types.bool; + default = false; + description = "Whether to enable the Mopidy OSX Media Keys support daemon."; + }; + package = mkOption { + type = types.path; + default = pkgs.pythonPackages.osxmpdkeys; + description = "This option specifies the mediakeys package to use."; + }; + }; + + }; + }; + + config = mkMerge [ + (mkIf cfg.enable { + launchd.user.agents.mopidy = { + serviceConfig.Program = "${cfg.package}/bin/mopidy"; + serviceConfig.RunAtLoad = true; + serviceConfig.KeepAlive = true; + serviceConfig.ProcessType = "Adaptive"; + }; + }) + (mkIf cfg.mediakeys.enable { + launchd.user.agents.mopidymediakeys = { + serviceConfig.Program = "${cfg.package}/bin/mpdkeys"; + serviceConfig.RunAtLoad = true; + serviceConfig.KeepAlive = true; + serviceConfig.ProcessType = "Interactive"; + }; + }) + ]; +}