2014-04-14 07:26:48 -07:00
|
|
|
{ config, lib, pkgs, ... }:
|
2012-11-21 23:07:25 -08:00
|
|
|
|
2014-04-14 07:26:48 -07:00
|
|
|
with lib;
|
2012-11-21 23:07:25 -08:00
|
|
|
|
2019-05-05 23:43:35 -07:00
|
|
|
let
|
|
|
|
cfg = config.security.rngd;
|
|
|
|
in
|
2012-11-21 23:07:25 -08:00
|
|
|
{
|
|
|
|
options = {
|
2019-05-05 23:43:35 -07:00
|
|
|
security.rngd = {
|
|
|
|
enable = mkOption {
|
|
|
|
type = types.bool;
|
2020-08-23 06:12:13 -07:00
|
|
|
default = false;
|
2019-05-05 23:43:35 -07:00
|
|
|
description = ''
|
2020-08-23 06:12:13 -07:00
|
|
|
Whether to enable the rng daemon. Devices that the kernel recognises
|
|
|
|
as entropy sources are handled automatically by krngd.
|
2019-05-05 23:43:35 -07:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
debug = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
description = "Whether to enable debug output (-d).";
|
|
|
|
};
|
2012-11-21 23:07:25 -08:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2019-05-05 23:43:35 -07:00
|
|
|
config = mkIf cfg.enable {
|
2013-01-16 03:33:18 -08:00
|
|
|
systemd.services.rngd = {
|
2012-11-26 05:45:23 -08:00
|
|
|
bindsTo = [ "dev-random.device" ];
|
|
|
|
|
|
|
|
after = [ "dev-random.device" ];
|
2012-11-21 23:07:25 -08:00
|
|
|
|
2020-02-23 15:53:52 -08:00
|
|
|
# Clean shutdown without DefaultDependencies
|
|
|
|
conflicts = [ "shutdown.target" ];
|
|
|
|
before = [
|
|
|
|
"sysinit.target"
|
|
|
|
"shutdown.target"
|
|
|
|
];
|
|
|
|
|
2012-11-21 23:07:25 -08:00
|
|
|
description = "Hardware RNG Entropy Gatherer Daemon";
|
|
|
|
|
2019-10-17 15:30:11 -07:00
|
|
|
# rngd may have to start early to avoid entropy starvation during boot with encrypted swap
|
|
|
|
unitConfig.DefaultDependencies = false;
|
2019-05-05 23:43:35 -07:00
|
|
|
serviceConfig = {
|
|
|
|
ExecStart = "${pkgs.rng-tools}/sbin/rngd -f"
|
|
|
|
+ optionalString cfg.debug " -d";
|
2019-10-17 15:30:11 -07:00
|
|
|
# PrivateTmp would introduce a circular dependency if /tmp is on tmpfs and swap is encrypted,
|
|
|
|
# thus depending on rngd before swap, while swap depends on rngd to avoid entropy starvation.
|
2019-05-07 20:53:09 -07:00
|
|
|
NoNewPrivileges = true;
|
|
|
|
PrivateNetwork = true;
|
|
|
|
ProtectSystem = "full";
|
|
|
|
ProtectHome = true;
|
2019-05-05 23:43:35 -07:00
|
|
|
};
|
2012-11-21 23:07:25 -08:00
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|