Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
43 lines
1.0 KiB
Nix
43 lines
1.0 KiB
Nix
{
|
|
config,
|
|
lib,
|
|
pkgs,
|
|
...
|
|
}:
|
|
|
|
let
|
|
cfg = config.services.xscreensaver;
|
|
in
|
|
{
|
|
options.services.xscreensaver = {
|
|
enable = lib.mkEnableOption "xscreensaver user service";
|
|
|
|
package = lib.mkPackageOption pkgs "xscreensaver" { };
|
|
};
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
# Make xscreensaver-auth setuid root so that it can (try to) prevent the OOM
|
|
# killer from unlocking the screen.
|
|
security.wrappers.xscreensaver-auth = {
|
|
setuid = true;
|
|
owner = "root";
|
|
group = "root";
|
|
source = "${pkgs.xscreensaver}/libexec/xscreensaver/xscreensaver-auth";
|
|
};
|
|
|
|
systemd.user.services.xscreensaver = {
|
|
enable = true;
|
|
description = "XScreenSaver";
|
|
after = [ "graphical-session-pre.target" ];
|
|
partOf = [ "graphical-session.target" ];
|
|
wantedBy = [ "graphical-session.target" ];
|
|
path = [ cfg.package ];
|
|
serviceConfig.ExecStart = "${cfg.package}/bin/xscreensaver -no-splash";
|
|
};
|
|
};
|
|
|
|
meta.maintainers = with lib.maintainers; [
|
|
vancluever
|
|
];
|
|
}
|