mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-06-11 20:25:32 +03:00

Without this fix, if `config.services.vault.package` is set to e.g. `vault-bin` (instead of the `vault` default), then `ExecStart` gets improperly generated without the `agent` positional argument because `vault-bin` did not match `vault`, and the command for the `consul` flavor gets generated instead. To fix this, we can look at the `flavor` argument instead of the package name.
172 lines
5.1 KiB
Nix
172 lines
5.1 KiB
Nix
{
|
|
config,
|
|
lib,
|
|
pkgs,
|
|
...
|
|
}:
|
|
let
|
|
format = pkgs.formats.json { };
|
|
commonOptions =
|
|
{
|
|
pkgName,
|
|
flavour ? pkgName,
|
|
}:
|
|
lib.mkOption {
|
|
default = { };
|
|
description = ''
|
|
Attribute set of ${flavour} instances.
|
|
Creates independent `${flavour}-''${name}.service` systemd units for each instance defined here.
|
|
'';
|
|
type =
|
|
with lib.types;
|
|
attrsOf (
|
|
submodule (
|
|
{ name, ... }:
|
|
{
|
|
options = {
|
|
enable = lib.mkEnableOption "this ${flavour} instance" // {
|
|
default = true;
|
|
};
|
|
|
|
package = lib.mkPackageOption pkgs pkgName { };
|
|
|
|
user = lib.mkOption {
|
|
type = types.str;
|
|
default = "root";
|
|
description = ''
|
|
User under which this instance runs.
|
|
'';
|
|
};
|
|
|
|
group = lib.mkOption {
|
|
type = types.str;
|
|
default = "root";
|
|
description = ''
|
|
Group under which this instance runs.
|
|
'';
|
|
};
|
|
|
|
settings = lib.mkOption {
|
|
type = types.submodule {
|
|
freeformType = format.type;
|
|
|
|
options = {
|
|
pid_file = lib.mkOption {
|
|
default = "/run/${flavour}/${name}.pid";
|
|
type = types.str;
|
|
description = ''
|
|
Path to use for the pid file.
|
|
'';
|
|
};
|
|
|
|
template = lib.mkOption {
|
|
default = null;
|
|
type = with types; nullOr (listOf (attrsOf anything));
|
|
description =
|
|
let
|
|
upstreamDocs =
|
|
if flavour == "vault-agent" then
|
|
"https://developer.hashicorp.com/vault/docs/agent/template"
|
|
else
|
|
"https://github.com/hashicorp/consul-template/blob/main/docs/configuration.md#templates";
|
|
in
|
|
''
|
|
Template section of ${flavour}.
|
|
Refer to <${upstreamDocs}> for supported values.
|
|
'';
|
|
};
|
|
};
|
|
};
|
|
|
|
default = { };
|
|
|
|
description =
|
|
let
|
|
upstreamDocs =
|
|
if flavour == "vault-agent" then
|
|
"https://developer.hashicorp.com/vault/docs/agent#configuration-file-options"
|
|
else
|
|
"https://github.com/hashicorp/consul-template/blob/main/docs/configuration.md#configuration-file";
|
|
in
|
|
''
|
|
Free-form settings written directly to the `config.json` file.
|
|
Refer to <${upstreamDocs}> for supported values.
|
|
|
|
::: {.note}
|
|
Resulting format is JSON not HCL.
|
|
Refer to <https://www.hcl2json.com/> if you are unsure how to convert HCL options to JSON.
|
|
:::
|
|
'';
|
|
};
|
|
};
|
|
}
|
|
)
|
|
);
|
|
};
|
|
|
|
createAgentInstance =
|
|
{
|
|
instance,
|
|
name,
|
|
flavour,
|
|
}:
|
|
let
|
|
configFile = format.generate "${name}.json" instance.settings;
|
|
in
|
|
lib.mkIf (instance.enable) {
|
|
description = "${flavour} daemon - ${name}";
|
|
wantedBy = [ "multi-user.target" ];
|
|
after = [ "network.target" ];
|
|
path = [ pkgs.getent ];
|
|
startLimitIntervalSec = 60;
|
|
startLimitBurst = 3;
|
|
serviceConfig = {
|
|
User = instance.user;
|
|
Group = instance.group;
|
|
RuntimeDirectory = flavour;
|
|
ExecStart = "${lib.getExe instance.package} ${
|
|
lib.optionalString (flavour == "vault-agent") "agent"
|
|
} -config ${configFile}";
|
|
ExecReload = "${pkgs.coreutils}/bin/kill -SIGHUP $MAINPID";
|
|
KillSignal = "SIGINT";
|
|
TimeoutStopSec = "30s";
|
|
Restart = "on-failure";
|
|
};
|
|
};
|
|
in
|
|
{
|
|
options = {
|
|
services.consul-template.instances = commonOptions { pkgName = "consul-template"; };
|
|
services.vault-agent.instances = commonOptions {
|
|
pkgName = "vault";
|
|
flavour = "vault-agent";
|
|
};
|
|
};
|
|
|
|
config = lib.mkMerge (
|
|
map
|
|
(
|
|
flavour:
|
|
let
|
|
cfg = config.services.${flavour};
|
|
in
|
|
lib.mkIf (cfg.instances != { }) {
|
|
systemd.services = lib.mapAttrs' (
|
|
name: instance:
|
|
lib.nameValuePair "${flavour}-${name}" (createAgentInstance {
|
|
inherit name instance flavour;
|
|
})
|
|
) cfg.instances;
|
|
}
|
|
)
|
|
[
|
|
"consul-template"
|
|
"vault-agent"
|
|
]
|
|
);
|
|
|
|
meta.maintainers = with lib.maintainers; [
|
|
emilylange
|
|
tcheronneau
|
|
];
|
|
}
|