2020-08-04 22:22:43 +02:00
|
|
|
with import <stockholm/lib>;
|
|
|
|
{ config, lib, pkgs, ... }: let
|
2016-02-21 05:27:37 +01:00
|
|
|
cfg = config.krebs.secret;
|
|
|
|
in {
|
|
|
|
options.krebs.secret = {
|
2020-10-14 12:18:59 +02:00
|
|
|
directory = mkOption {
|
|
|
|
default = toString <secrets>;
|
|
|
|
type = types.absolute-pathname;
|
|
|
|
};
|
|
|
|
file = mkOption {
|
|
|
|
default = relpath: "${cfg.directory}/${relpath}";
|
|
|
|
readOnly = true;
|
|
|
|
};
|
2016-02-21 05:27:37 +01:00
|
|
|
files = mkOption {
|
|
|
|
type = with types; attrsOf secret-file;
|
|
|
|
default = {};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
config = lib.mkIf (cfg.files != {}) {
|
2020-08-04 22:22:43 +02:00
|
|
|
systemd.paths =
|
|
|
|
mapAttrs'
|
|
|
|
(name: file: nameValuePair "secret-trigger-${systemd.encodeName name}" {
|
|
|
|
wantedBy = ["multi-user.target"];
|
|
|
|
pathConfig.PathChanged = file.source-path;
|
|
|
|
})
|
|
|
|
cfg.files;
|
|
|
|
systemd.services =
|
|
|
|
mapAttrs'
|
|
|
|
(name: file: nameValuePair "secret-trigger-${systemd.encodeName name}" {
|
|
|
|
serviceConfig = {
|
|
|
|
Type = "oneshot";
|
2020-08-11 20:56:01 +02:00
|
|
|
ExecStart = "${pkgs.systemd}/bin/systemctl restart ${shell.escape file.service}";
|
2020-08-04 22:22:43 +02:00
|
|
|
};
|
|
|
|
})
|
|
|
|
cfg.files
|
|
|
|
//
|
|
|
|
mapAttrs'
|
|
|
|
(name: file: nameValuePair "secret-${systemd.encodeName name}" {
|
|
|
|
wantedBy = ["multi-user.target"];
|
|
|
|
serviceConfig = {
|
|
|
|
Type = "oneshot";
|
|
|
|
RemainAfterExit = "yes";
|
|
|
|
ExecStart = toString [
|
|
|
|
"${pkgs.coreutils}/bin/install"
|
|
|
|
"-D"
|
|
|
|
"--compare"
|
|
|
|
"--verbose"
|
|
|
|
"--mode=${file.mode}"
|
|
|
|
"--owner=${file.owner.name}"
|
|
|
|
"--group=${file.group-name}"
|
|
|
|
file.source-path
|
|
|
|
file.path
|
|
|
|
];
|
|
|
|
};
|
|
|
|
})
|
|
|
|
cfg.files;
|
2016-02-21 05:27:37 +01:00
|
|
|
};
|
|
|
|
}
|