feat(nix): recursively import domain files via mapping

This commit is contained in:
orangc 2026-03-21 17:12:28 +03:00
commit 4ca3912135
31 changed files with 216 additions and 93 deletions

View file

@ -1,33 +1,49 @@
{
description = "Zone File Generator";
inputs.dns.url = "github:nix-community/dns.nix";
outputs = { dns, ... }: let
email = "admin@satr14.my.id";
domains."0" = {
domain = "part-of.my.id";
nameservers = [
"adele.ns.cloudflare.com"
"fattouche.ns.cloudflare.com"
];
};
in {
packages.x86_64-linux = builtins.mapAttrs (_: domain:
dns.util.x86_64-linux.writeZone domain.domain (
with dns.lib.combinators; {
SOA = {
adminEmail = email;
nameServer = builtins.head domain.nameservers;
serial = builtins.currentTime;
};
NS = domain.nameservers;
# note: Cloudflare ignores SOA and NS records uploaded via Zone File, they are included just so that dns.nix builds a valid zone file.
#subdomains = ;
# ^^ todo: implement file imports from ./domains
outputs =
{ dns, ... }:
let
email = "admin@satr14.my.id";
domains."0" = {
domain = "part-of.my.id";
nameservers = [
"adele.ns.cloudflare.com"
"fattouche.ns.cloudflare.com"
];
};
inherit (import <nixpkgs> { }) lib;
domainsFolder = builtins.readDir ./domains;
domainFiles = lib.filterAttrs (
name: type: type == "regular" && builtins.match ".*\\.nix" name != null
) domainsFolder;
subdomains = lib.mapAttrs' (
name: _:
let
key = builtins.replaceStrings [ ".nix" ] [ "" ] name;
in
{
name = key;
value = import (./domains + "/${name}") { inherit dns; };
}
)
) domains;
};
}
) domainFiles;
in
{
packages.x86_64-linux = builtins.mapAttrs (
_: domain:
dns.util.x86_64-linux.writeZone domain.domain (
with dns.lib.combinators;
{
SOA = {
adminEmail = email;
nameServer = builtins.head domain.nameservers;
serial = builtins.currentTime;
};
NS = domain.nameservers;
# note: Cloudflare ignores SOA and NS records uploaded via Zone File, they are included just so that dns.nix builds a valid zone file.
inherit subdomains;
}
)
) domains;
};
}