From 5e264d7ec671782daf8ce2c6c2f196794bd5848b Mon Sep 17 00:00:00 2001 From: lassulus Date: Mon, 6 Apr 2015 18:03:18 +0200 Subject: [PATCH] add urxvtd service module --- modules/urxvtd.nix | 48 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 modules/urxvtd.nix diff --git a/modules/urxvtd.nix b/modules/urxvtd.nix new file mode 100644 index 000000000..ca21c6213 --- /dev/null +++ b/modules/urxvtd.nix @@ -0,0 +1,48 @@ +{ config, lib, pkgs, ... }: + +with builtins; +with lib; + +{ + options = { + services.urxvtd = { + enable = mkOption { + type = types.bool; + default = false; + description = "Enable urxvtd per user"; + }; + users = mkOption { + type = types.listOf types.string; + default = []; + description = "users to run urxvtd for"; + }; + urxvtPackage = mkOption { + type = types.package; + default = pkgs.rxvt_unicode; + description = "urxvt package to use"; + }; + }; + }; + + config = + let + cfg = config.services.urxvtd; + users = cfg.users; + urxvt = cfg.urxvtPackage; + mkService = user: { + description = "urxvt terminal daemon"; + wantedBy = [ "multi-user.target" ]; + restartIfChanged = false; + serviceConfig = { + Restart = "always"; + User = user; + Environment = "URXVT_PERL_LIB=${urxvt}/lib/urxvt/perl"; + ExecStart = "${urxvt}/bin/urxvtd"; + }; + }; + in + mkIf cfg.enable { + environment.systemPackages = [ urxvt ]; + systemd.services = listToAttrs (map (u: { name = "${u}-urxvtd"; value = mkService u; }) users); + }; +}