modules/consul-service-registry: init
This commit is contained in:
parent
8be69d13ad
commit
674fde3617
2 changed files with 49 additions and 0 deletions
47
modules/consul-service-registry/default.nix
Normal file
47
modules/consul-service-registry/default.nix
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
{ config, lib, ... }:
|
||||||
|
|
||||||
|
with lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
cfg = config.consul;
|
||||||
|
|
||||||
|
consul = "${config.services.consul.package}/bin/consul";
|
||||||
|
|
||||||
|
consulServiceDefinition = submodule ({ name, ... }: {
|
||||||
|
unit = mkOption {
|
||||||
|
description = "Which systemd service to attach to.";
|
||||||
|
default = name;
|
||||||
|
type = types.str;
|
||||||
|
};
|
||||||
|
definition = mkOption {
|
||||||
|
description = "Consul service definition.";
|
||||||
|
type = types.attrs;
|
||||||
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
attachToService = name: conf: let
|
||||||
|
serviceJson = pkgs.writeText "consul-service-${name}.json" (builtins.toJSON conf.definition);
|
||||||
|
in {
|
||||||
|
name = conf.unit;
|
||||||
|
value = {
|
||||||
|
serviceConfig = {
|
||||||
|
ExecStartPost = "${consul} services register ${serviceJson}";
|
||||||
|
ExecStopPre = "${consul} services deregister ${serviceJson}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
in
|
||||||
|
|
||||||
|
{
|
||||||
|
options.consul = {
|
||||||
|
services = mkOption {
|
||||||
|
type = with types; attrsOf consulServiceDefinition;
|
||||||
|
default = {};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkIf (cfg.services != {}) {
|
||||||
|
systemd.services = mapAttrs' attachToService cfg.services;
|
||||||
|
warnings = optional (!config.services.consul.enable) "Consul service registrations found, but Consul agent is not enabled on this machine.";
|
||||||
|
};
|
||||||
|
}
|
|
@ -3,6 +3,7 @@ with builtins;
|
||||||
let
|
let
|
||||||
aspects = {
|
aspects = {
|
||||||
autopatch = import ./autopatch;
|
autopatch = import ./autopatch;
|
||||||
|
consul-service-registry = import ./consul-service-registry;
|
||||||
deploy-rs-receiver = import ./deploy-rs-receiver;
|
deploy-rs-receiver = import ./deploy-rs-receiver;
|
||||||
enterprise = import ./enterprise;
|
enterprise = import ./enterprise;
|
||||||
fail2ban = import ./fail2ban;
|
fail2ban = import ./fail2ban;
|
||||||
|
@ -41,6 +42,7 @@ in rec {
|
||||||
];
|
];
|
||||||
|
|
||||||
server = [
|
server = [
|
||||||
|
consul-service-registry
|
||||||
deploy-rs-receiver
|
deploy-rs-receiver
|
||||||
fail2ban
|
fail2ban
|
||||||
motd
|
motd
|
||||||
|
|
Loading…
Add table
Reference in a new issue