diff --git a/modules/services/screen-locker.nix b/modules/services/screen-locker.nix
index 29141656..844075ee 100644
--- a/modules/services/screen-locker.nix
+++ b/modules/services/screen-locker.nix
@@ -26,6 +26,23 @@ in {
See .
'';
};
+
+ xautolockExtraOptions = mkOption {
+ type = types.listOf types.str;
+ default = [];
+ description = ''
+ Extra command-line arguments to pass to xautolock.
+ '';
+ };
+
+ xssLockExtraOptions = mkOption {
+ type = types.listOf types.str;
+ default = [];
+ description = ''
+ Extra command-line arguments to pass to xss-lock.
+ '';
+ };
+
};
config = mkIf cfg.enable {
@@ -45,7 +62,8 @@ in {
${pkgs.xautolock}/bin/xautolock \
-detectsleep \
-time ${toString cfg.inactiveInterval} \
- -locker '${pkgs.systemd}/bin/loginctl lock-session $XDG_SESSION_ID'
+ -locker '${pkgs.systemd}/bin/loginctl lock-session $XDG_SESSION_ID' \
+ ${concatStringsSep " " cfg.xautolockExtraOptions}
'';
};
};
@@ -53,7 +71,7 @@ in {
# xss-lock will run specified screen locker when the session is locked via loginctl
# can't be started as a systemd service,
# see https://bitbucket.org/raymonad/xss-lock/issues/13/allow-operation-as-systemd-user-unit
- xsession.initExtra = "${pkgs.xss-lock}/bin/xss-lock -- ${cfg.lockCmd} &";
+ xsession.initExtra = "${pkgs.xss-lock}/bin/xss-lock ${concatStringsSep " " cfg.xssLockExtraOptions} -- ${cfg.lockCmd} &";
};
}