2021-12-23 20:09:06 +01:00
|
|
|
{ config, pkgs, ... }: let {
|
2021-12-23 01:10:22 +01:00
|
|
|
lib = import ../../lib;
|
|
|
|
|
|
|
|
body.options.krebs.systemd.services = lib.mkOption {
|
|
|
|
default = {};
|
2021-12-23 20:09:06 +01:00
|
|
|
type = lib.types.attrsOf (lib.types.submodule {
|
|
|
|
options = {
|
2021-12-29 16:52:23 +01:00
|
|
|
restartIfCredentialsChange = lib.mkOption {
|
2022-12-29 13:44:45 +01:00
|
|
|
default = false;
|
2021-12-23 20:16:34 +01:00
|
|
|
description = ''
|
2021-12-29 16:52:23 +01:00
|
|
|
Whether to restart the service whenever any of its credentials
|
|
|
|
change. Only credentials with an absolute path in LoadCredential=
|
|
|
|
are supported.
|
2021-12-23 20:16:34 +01:00
|
|
|
'';
|
2021-12-29 16:52:23 +01:00
|
|
|
type = lib.types.bool;
|
2021-12-23 20:16:34 +01:00
|
|
|
};
|
2021-12-23 20:09:06 +01:00
|
|
|
};
|
|
|
|
});
|
2021-12-23 01:10:22 +01:00
|
|
|
};
|
|
|
|
|
2021-12-23 23:42:59 +01:00
|
|
|
body.config = {
|
|
|
|
systemd.paths = lib.mapAttrs' (serviceName: _:
|
|
|
|
lib.nameValuePair "trigger-${lib.systemd.encodeName serviceName}" {
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
pathConfig.PathChanged =
|
|
|
|
lib.filter
|
|
|
|
lib.types.absolute-pathname.check
|
|
|
|
(map
|
|
|
|
(lib.compose [ lib.maybeHead (lib.match "[^:]*:(.*)") ])
|
2021-12-24 00:49:30 +01:00
|
|
|
(lib.toList
|
|
|
|
config.systemd.services.${serviceName}.serviceConfig.LoadCredential));
|
2021-12-23 23:42:59 +01:00
|
|
|
}
|
|
|
|
) config.krebs.systemd.services;
|
|
|
|
|
|
|
|
systemd.services = lib.mapAttrs' (serviceName: cfg:
|
|
|
|
lib.nameValuePair "trigger-${lib.systemd.encodeName serviceName}" {
|
|
|
|
serviceConfig = {
|
|
|
|
Type = "oneshot";
|
2021-12-29 16:52:23 +01:00
|
|
|
ExecStart = "${pkgs.systemd}/bin/systemctl restart ${lib.shell.escape serviceName}";
|
2021-12-23 23:42:59 +01:00
|
|
|
};
|
|
|
|
}
|
|
|
|
) config.krebs.systemd.services;
|
|
|
|
};
|
2021-12-23 01:10:22 +01:00
|
|
|
}
|