summaryrefslogtreecommitdiffstats
path: root/krebs/3modules/retiolum-hosts.nix
diff options
context:
space:
mode:
authorlassulus <lassulus@lassul.us>2019-01-21 16:24:43 +0100
committerlassulus <lassulus@lassul.us>2019-01-21 16:24:43 +0100
commit144e2c5571129ac01b65d44db224c233ee1ac851 (patch)
treeec8ca31f0ff61f20494a7c77c967481994e98d89 /krebs/3modules/retiolum-hosts.nix
parentbc61d4df9068fa3d63690891b3aaa8a982ceb633 (diff)
parentfabef3638584e88be50b10ec1cf3649b98752eac (diff)
Merge remote-tracking branch 'ni/master'
Diffstat (limited to 'krebs/3modules/retiolum-hosts.nix')
-rw-r--r--krebs/3modules/retiolum-hosts.nix28
1 files changed, 28 insertions, 0 deletions
diff --git a/krebs/3modules/retiolum-hosts.nix b/krebs/3modules/retiolum-hosts.nix
new file mode 100644
index 00000000..ddf85ead
--- /dev/null
+++ b/krebs/3modules/retiolum-hosts.nix
@@ -0,0 +1,28 @@
+with import <stockholm/lib>;
+{ config, ... }: let
+ # TODO dedup functions with ./hosts.nix
+ check = hostname: any (domain: hasSuffix ".${domain}" hostname) domains;
+ domains = attrNames (filterAttrs (_: eq "hosts") config.krebs.dns.providers);
+in {
+ nixpkgs.config.packageOverrides = super: {
+ retiolum-hosts =
+ super.writeText "retiolum-hosts" ''
+ ${
+ concatStringsSep
+ "\n"
+ (flatten
+ (map
+ (host: let
+ net = host.nets.retiolum;
+ aliases = longs;
+ longs = filter check net.aliases;
+ in
+ optionals
+ (aliases != [])
+ (map (addr: "${addr} ${toString aliases}") net.addrs))
+ (filter (host: hasAttr "retiolum" host.nets)
+ (attrValues config.krebs.hosts))))
+ }
+ '';
+ };
+}