aboutsummaryrefslogtreecommitdiff
path: root/nixpkgs/nixos/modules/programs/xss-lock.nix
diff options
context:
space:
mode:
Diffstat (limited to 'nixpkgs/nixos/modules/programs/xss-lock.nix')
-rw-r--r--nixpkgs/nixos/modules/programs/xss-lock.nix44
1 files changed, 44 insertions, 0 deletions
diff --git a/nixpkgs/nixos/modules/programs/xss-lock.nix b/nixpkgs/nixos/modules/programs/xss-lock.nix
new file mode 100644
index 00000000000..a7ad9b89db4
--- /dev/null
+++ b/nixpkgs/nixos/modules/programs/xss-lock.nix
@@ -0,0 +1,44 @@
+{ config, pkgs, lib, ... }:
+
+with lib;
+
+let
+ cfg = config.programs.xss-lock;
+in
+{
+ options.programs.xss-lock = {
+ enable = mkEnableOption "xss-lock";
+
+ lockerCommand = mkOption {
+ default = "${pkgs.i3lock}/bin/i3lock";
+ example = literalExample ''''${pkgs.i3lock-fancy}/bin/i3lock-fancy'';
+ type = types.separatedString " ";
+ description = "Locker to be used with xsslock";
+ };
+
+ extraOptions = mkOption {
+ default = [ ];
+ example = [ "--ignore-sleep" ];
+ type = types.listOf types.str;
+ description = ''
+ Additional command-line arguments to pass to
+ <command>xss-lock</command>.
+ '';
+ };
+ };
+
+ config = mkIf cfg.enable {
+ systemd.user.services.xss-lock = {
+ description = "XSS Lock Daemon";
+ wantedBy = [ "graphical-session.target" ];
+ partOf = [ "graphical-session.target" ];
+ serviceConfig.ExecStart = with lib;
+ strings.concatStringsSep " " ([
+ "${pkgs.xss-lock}/bin/xss-lock"
+ ] ++ (map escapeShellArg cfg.extraOptions) ++ [
+ "--"
+ cfg.lockerCommand
+ ]);
+ };
+ };
+}