1
0
Fork 0
mirror of https://github.com/nix-community/home-manager synced 2025-01-15 05:29:49 +01:00
home-manager/modules/programs/swaylock.nix
2024-04-10 21:26:13 +02:00

73 lines
1.9 KiB
Nix

{ pkgs, config, lib, ... }:
with lib;
let cfg = config.programs.swaylock;
in {
meta.maintainers = [ hm.maintainers.rcerc ];
options.programs.swaylock = {
enable = mkOption {
type = lib.types.bool;
default = versionOlder config.home.stateVersion "23.05"
&& (cfg.settings != { });
defaultText = literalExpression ''
true if state version < 23.05 and settings { },
false otherwise
'';
example = true;
description = ''
Whether to enable swaylock.
Note that PAM must be configured to enable swaylock to perform
authentication. The package installed through home-manager
will *not* be able to unlock the session without this
configuration.
On NixOS, this is by default enabled with the sway module, but
for other compositors it can currently be enabled using:
```nix
security.pam.services.swaylock = {};
```
'';
};
package = mkPackageOption pkgs "swaylock" { };
settings = mkOption {
type = with types; attrsOf (oneOf [ bool float int str ]);
default = { };
description = ''
Default arguments to {command}`swaylock`. An empty set
disables configuration generation.
'';
example = {
color = "808080";
font-size = 24;
indicator-idle-visible = false;
indicator-radius = 100;
line-color = "ffffff";
show-failed-attempts = true;
};
};
};
config = mkIf cfg.enable {
assertions = [
(lib.hm.assertions.assertPlatform "programs.swaylock" pkgs
lib.platforms.linux)
];
home.packages = [ cfg.package ];
xdg.configFile."swaylock/config" = mkIf (cfg.settings != { }) {
text = concatStrings (mapAttrsToList (n: v:
if v == false then
""
else
(if v == true then n else n + "=" + builtins.toString v) + "\n")
cfg.settings);
};
};
}