2022-02-26 16:53:26 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
let
|
|
|
|
nncpCfgFile = "/run/nncp.hjson";
|
|
|
|
programCfg = config.programs.nncp;
|
|
|
|
settingsFormat = pkgs.formats.json { };
|
|
|
|
jsonCfgFile = settingsFormat.generate "nncp.json" programCfg.settings;
|
|
|
|
pkg = programCfg.package;
|
|
|
|
in {
|
|
|
|
options.programs.nncp = {
|
|
|
|
|
|
|
|
enable =
|
2024-04-17 11:37:58 +00:00
|
|
|
lib.mkEnableOption "NNCP (Node to Node copy) utilities and configuration";
|
2022-02-26 16:53:26 +00:00
|
|
|
|
2024-04-17 11:37:58 +00:00
|
|
|
group = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
2022-02-26 16:53:26 +00:00
|
|
|
default = "uucp";
|
2024-04-13 12:54:15 +00:00
|
|
|
description = ''
|
2022-02-26 16:53:26 +00:00
|
|
|
The group under which NNCP files shall be owned.
|
|
|
|
Any member of this group may access the secret keys
|
|
|
|
of this NNCP node.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-04-17 11:37:58 +00:00
|
|
|
package = lib.mkPackageOption pkgs "nncp" { };
|
2022-02-26 16:53:26 +00:00
|
|
|
|
2024-04-17 11:37:58 +00:00
|
|
|
secrets = lib.mkOption {
|
|
|
|
type = with lib.types; listOf str;
|
2022-02-26 16:53:26 +00:00
|
|
|
example = [ "/run/keys/nncp.hjson" ];
|
2024-04-13 12:54:15 +00:00
|
|
|
description = ''
|
2022-02-26 16:53:26 +00:00
|
|
|
A list of paths to NNCP configuration files that should not be
|
|
|
|
in the Nix store. These files are layered on top of the values at
|
|
|
|
[](#opt-programs.nncp.settings).
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-04-17 11:37:58 +00:00
|
|
|
settings = lib.mkOption {
|
2022-02-26 16:53:26 +00:00
|
|
|
type = settingsFormat.type;
|
2024-04-13 12:54:15 +00:00
|
|
|
description = ''
|
2022-02-26 16:53:26 +00:00
|
|
|
NNCP configuration, see
|
|
|
|
<http://www.nncpgo.org/Configuration.html>.
|
|
|
|
At runtime these settings will be overlayed by the contents of
|
|
|
|
[](#opt-programs.nncp.secrets) into the file
|
|
|
|
`${nncpCfgFile}`. Node keypairs go in
|
|
|
|
`secrets`, do not specify them in
|
|
|
|
`settings` as they will be leaked into
|
|
|
|
`/nix/store`!
|
|
|
|
'';
|
|
|
|
default = { };
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2024-04-17 11:37:58 +00:00
|
|
|
config = lib.mkIf programCfg.enable {
|
2022-02-26 16:53:26 +00:00
|
|
|
|
|
|
|
environment = {
|
|
|
|
systemPackages = [ pkg ];
|
|
|
|
etc."nncp.hjson".source = nncpCfgFile;
|
|
|
|
};
|
|
|
|
|
|
|
|
programs.nncp.settings = {
|
2024-04-17 11:37:58 +00:00
|
|
|
spool = lib.mkDefault "/var/spool/nncp";
|
|
|
|
log = lib.mkDefault "/var/spool/nncp/log";
|
2022-02-26 16:53:26 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
systemd.tmpfiles.rules = [
|
|
|
|
"d ${programCfg.settings.spool} 0770 root ${programCfg.group}"
|
|
|
|
"f ${programCfg.settings.log} 0770 root ${programCfg.group}"
|
|
|
|
];
|
|
|
|
|
|
|
|
systemd.services.nncp-config = {
|
|
|
|
path = [ pkg ];
|
|
|
|
description = "Generate NNCP configuration";
|
|
|
|
wantedBy = [ "basic.target" ];
|
|
|
|
serviceConfig.Type = "oneshot";
|
|
|
|
script = ''
|
|
|
|
umask u=rw
|
|
|
|
nncpCfgDir=$(mktemp --directory nncp.XXX)
|
2024-04-17 11:37:58 +00:00
|
|
|
for f in ${jsonCfgFile} ${builtins.toString config.programs.nncp.secrets}; do
|
2022-02-26 16:53:26 +00:00
|
|
|
tmpdir=$(mktemp --directory nncp.XXX)
|
|
|
|
nncp-cfgdir -cfg $f -dump $tmpdir
|
|
|
|
find $tmpdir -size 1c -delete
|
|
|
|
cp -a $tmpdir/* $nncpCfgDir/
|
|
|
|
rm -rf $tmpdir
|
|
|
|
done
|
|
|
|
nncp-cfgdir -load $nncpCfgDir > ${nncpCfgFile}
|
|
|
|
rm -rf $nncpCfgDir
|
|
|
|
chgrp ${programCfg.group} ${nncpCfgFile}
|
|
|
|
chmod g+r ${nncpCfgFile}
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
meta.maintainers = with lib.maintainers; [ ehmry ];
|
|
|
|
}
|