2017-11-11 11:52:17 +01:00
|
|
|
{lib, pkgs}:
|
|
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
|
|
rec {
|
|
|
|
|
mkAllDefault = value: priority:
|
|
|
|
|
if isAttrs value
|
|
|
|
|
then mapAttrs (n: v: mkAllDefault v priority) value
|
|
|
|
|
|
|
|
|
|
else if isList value
|
|
|
|
|
then map (v: mkAllDefault v priority) value
|
|
|
|
|
|
|
|
|
|
else mkOverride priority value;
|
|
|
|
|
|
|
|
|
|
moduleToAttrs = value:
|
|
|
|
|
if isAttrs value
|
|
|
|
|
then mapAttrs (n: v: moduleToAttrs v) (filterAttrs (n: v: !(hasPrefix "_" n) && v != null) value)
|
|
|
|
|
|
|
|
|
|
else if isList value
|
|
|
|
|
then map (v: moduleToAttrs v) value
|
|
|
|
|
|
|
|
|
|
else value;
|
|
|
|
|
|
|
|
|
|
loadJSON = path: mkAllDefault (builtins.fromJSON (builtins.readFile path)) 1000;
|
|
|
|
|
|
|
|
|
|
loadYAML = path: loadJSON (pkgs.runCommand "yaml-to-json" {
|
|
|
|
|
} "${pkgs.remarshal}/bin/remarshal -i ${path} -if yaml -of json > $out");
|
|
|
|
|
|
|
|
|
|
toBase64 = value:
|
|
|
|
|
builtins.readFile
|
|
|
|
|
(pkgs.runCommand "value-to-b64" {} "echo '${value}' | ${pkgs.coreutils}/bin/base64 -w0 > $out");
|
2017-11-11 13:42:15 +01:00
|
|
|
|
|
|
|
|
mkValueOrSecretOption = {...}@options: mkOption ({
|
2017-11-28 12:45:30 +01:00
|
|
|
type = types.nullOr (types.either types.str (types.submodule {
|
2017-11-11 13:42:15 +01:00
|
|
|
options.secret = mkOption {
|
|
|
|
|
description = "Name of the secret where password is stored";
|
|
|
|
|
type = types.str;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
options.key = mkOption {
|
|
|
|
|
description = "Name of the key where password is stored";
|
|
|
|
|
type = types.str;
|
|
|
|
|
default = "password";
|
|
|
|
|
};
|
2017-11-28 12:45:30 +01:00
|
|
|
}));
|
2017-11-11 13:42:15 +01:00
|
|
|
|
|
|
|
|
apply = value:
|
|
|
|
|
if isAttrs value
|
|
|
|
|
then {
|
|
|
|
|
valueFrom.secretKeyRef = {
|
|
|
|
|
name = value.secret;
|
|
|
|
|
key = value.key;
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
else {inherit value;};
|
|
|
|
|
} // options);
|
2017-11-11 11:52:17 +01:00
|
|
|
}
|