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,12 +1,18 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "satr14washere"; username = "satr14washere";
email = "admin@satr14.my.id"; email = "admin@satr14.my.id";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
A = [ A = [
{ address = "203.0.113.1"; ttl = 60 * 60; } {
address = "203.0.113.1";
ttl = 60 * 60;
}
"203.0.113.2" "203.0.113.2"
(ttl (60 * 60) (a "203.0.113.3")) (ttl (60 * 60) (a "203.0.113.3"))
]; ];
@ -18,7 +24,13 @@ in with dns.lib.combinators; {
MX = mx.google; MX = mx.google;
TXT = [ TXT = [
(with spf; strict [ "a:mail.example.com" google ]) (
with spf;
strict [
"a:mail.example.com"
google
]
)
]; ];
DMARC = [ (dmarc.postmarkapp "mailto:re+abcdefghijk@dmarc.postmarkapp.com") ]; DMARC = [ (dmarc.postmarkapp "mailto:re+abcdefghijk@dmarc.postmarkapp.com") ];
@ -48,8 +60,16 @@ in with dns.lib.combinators; {
{ {
svcPriority = 1; svcPriority = 1;
targetName = "."; targetName = ".";
alpn = [ "http/1.1" "h2" "h3" ]; alpn = [
ipv4hint = [ "203.0.113.1" "203.0.113.2" "203.0.113.3" ]; "http/1.1"
"h2"
"h3"
];
ipv4hint = [
"203.0.113.1"
"203.0.113.2"
"203.0.113.3"
];
ipv6hint = [ "4321:0:1:2:3:4:567:89ab" ]; ipv6hint = [ "4321:0:1:2:3:4:567:89ab" ];
} }
]; ];

View file

@ -1,9 +1,12 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "ColinLeDev"; username = "ColinLeDev";
}; };
description = "Discord verification"; description = "Discord verification";
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
TXT = [ "dh=279643a6f8677dedb1c5c63d007fc4516149679c" ]; TXT = [ "dh=279643a6f8677dedb1c5c63d007fc4516149679c" ];
} }

View file

@ -1,10 +1,13 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "CuteDog5695"; username = "CuteDog5695";
email = "cutedog5695@gmail.com"; email = "cutedog5695@gmail.com";
repo = "https://github.com/CuteDog5695/cutedog5695.github.io"; repo = "https://github.com/CuteDog5695/cutedog5695.github.io";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
TXT = [ "dh=a7c19efb0f6bc38b97a33760f6c1ee84df4151b1" ]; TXT = [ "dh=a7c19efb0f6bc38b97a33760f6c1ee84df4151b1" ];
} }

View file

@ -1,10 +1,13 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "JustDeveloper1"; username = "JustDeveloper1";
email = "justdeveloper@juststudio.is-a.dev"; email = "justdeveloper@juststudio.is-a.dev";
repo = "https://github.com/JustDeveloper1/Website"; repo = "https://github.com/JustDeveloper1/Website";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
TXT = [ "dh=6024027bc233825451e290ac37a4b4a1f838ee70" ]; TXT = [ "dh=6024027bc233825451e290ac37a4b4a1f838ee70" ];
} }

View file

@ -1,8 +1,11 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "satr14washere"; username = "satr14washere";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
TXT = [ "dh=d509fc9014e196311ed887c2e410cdefa833436e" ]; TXT = [ "dh=d509fc9014e196311ed887c2e410cdefa833436e" ];
} }

View file

@ -1,8 +1,11 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "Roki100"; username = "Roki100";
discord = "289479495444987904"; discord = "289479495444987904";
}; };
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
TXT = [ "dh=5633078cd5bfd347a896ddb0f0de017c5423aa06" ]; TXT = [ "dh=5633078cd5bfd347a896ddb0f0de017c5423aa06" ];
} }

View file

@ -1,8 +1,11 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "shadowe1ite"; username = "shadowe1ite";
}; };
proxy = true; proxy = true;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "shadowe1ite.github.io." ]; CNAME = [ "shadowe1ite.github.io." ];
} }

View file

@ -1,9 +1,12 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "orangci"; username = "orangci";
email = "c@orangc.xyz"; email = "c@orangc.xyz";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "edge.redirect.pizza." ]; CNAME = [ "edge.redirect.pizza." ];
} }

View file

@ -1,9 +1,12 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "ColinLeDev"; username = "ColinLeDev";
}; };
description = "My personal portfolio hosted on my server"; description = "My personal portfolio hosted on my server";
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "proxy.col1n.fr." ]; CNAME = [ "proxy.col1n.fr." ];
} }

View file

@ -1,10 +1,13 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "CuteDog5695"; username = "CuteDog5695";
email = "cutedog5695@gmail.com"; email = "cutedog5695@gmail.com";
repo = "https://github.com/CuteDog5695/cutedog5695.github.io"; repo = "https://github.com/CuteDog5695/cutedog5695.github.io";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "edge.redirect.pizza." ]; CNAME = [ "edge.redirect.pizza." ];
} }

View file

@ -1,7 +1,10 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "elkhaff"; username = "elkhaff";
}; };
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "portofolio-pixel.pages.dev." ]; CNAME = [ "portofolio-pixel.pages.dev." ];
} }

View file

@ -1,10 +1,13 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "JustDeveloper1"; username = "JustDeveloper1";
email = "support@juststudio.is-a.dev"; email = "support@juststudio.is-a.dev";
repo = "https://github.com/JustStudio7/Website"; repo = "https://github.com/JustStudio7/Website";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "edge.redirect.pizza." ]; CNAME = [ "edge.redirect.pizza." ];
} }

View file

@ -1,8 +1,11 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "jacobrdale"; username = "jacobrdale";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "hexon404.onrender.com." ]; CNAME = [ "hexon404.onrender.com." ];
} }

View file

@ -1,10 +1,13 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "JustDeveloper1"; username = "JustDeveloper1";
email = "justdeveloper@juststudio.is-a.dev"; email = "justdeveloper@juststudio.is-a.dev";
repo = "https://github.com/JustDeveloper1/Website"; repo = "https://github.com/JustDeveloper1/Website";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "edge.redirect.pizza." ]; CNAME = [ "edge.redirect.pizza." ];
} }

View file

@ -1,8 +1,11 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "FWEEaaaa1"; username = "FWEEaaaa1";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
A = [ "128.204.223.115" ]; A = [ "128.204.223.115" ];
} }

View file

@ -1,10 +1,13 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "joestr"; username = "joestr";
email = "strasser999@gmail.com"; email = "strasser999@gmail.com";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
A = [ "142.132.173.34" ]; A = [ "142.132.173.34" ];
AAAA = [ "2a01:4f8:1c0c:6cc0::1" ]; AAAA = [ "2a01:4f8:1c0c:6cc0::1" ];
MX = [ MX = [

View file

@ -1,10 +1,13 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "JustDeveloper1"; username = "JustDeveloper1";
email = "support@juststudio.is-a.dev"; email = "support@juststudio.is-a.dev";
repo = "https://github.com/JustStudio7/Website"; repo = "https://github.com/JustStudio7/Website";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "edge.redirect.pizza." ]; CNAME = [ "edge.redirect.pizza." ];
} }

View file

@ -1,10 +1,13 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "JustDeveloper1"; username = "JustDeveloper1";
email = "justdeveloper@juststudio.is-a.dev"; email = "justdeveloper@juststudio.is-a.dev";
repo = "https://github.com/JustDeveloper1/Website"; repo = "https://github.com/JustDeveloper1/Website";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "edge.redirect.pizza." ]; CNAME = [ "edge.redirect.pizza." ];
} }

View file

@ -1,10 +1,13 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "JustDeveloper1"; username = "JustDeveloper1";
email = "justdeveloper@juststudio.is-a.dev"; email = "justdeveloper@juststudio.is-a.dev";
repo = "https://github.com/JustDeveloper1/Website"; repo = "https://github.com/JustDeveloper1/Website";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "edge.redirect.pizza." ]; CNAME = [ "edge.redirect.pizza." ];
} }

View file

@ -1,10 +1,13 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "JustDeveloper1"; username = "JustDeveloper1";
email = "justdeveloper@juststudio.is-a.dev"; email = "justdeveloper@juststudio.is-a.dev";
repo = "https://github.com/JustDeveloper1/Website"; repo = "https://github.com/JustDeveloper1/Website";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "edge.redirect.pizza." ]; CNAME = [ "edge.redirect.pizza." ];
} }

View file

@ -1,10 +1,13 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "JustDeveloper1"; username = "JustDeveloper1";
email = "support@juststudio.is-a.dev"; email = "support@juststudio.is-a.dev";
repo = "https://github.com/JustStudio7/Website"; repo = "https://github.com/JustStudio7/Website";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "edge.redirect.pizza." ]; CNAME = [ "edge.redirect.pizza." ];
} }

View file

@ -1,8 +1,11 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "Bananalolok"; username = "Bananalolok";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
A = [ "69.197.135.205" ]; A = [ "69.197.135.205" ];
} }

View file

@ -1,9 +1,12 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "EducatedSuddenBucket"; username = "EducatedSuddenBucket";
email = "me@esb.is-a.dev"; email = "me@esb.is-a.dev";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "educatedsuddenbucket-github-io.onrender.com." ]; CNAME = [ "educatedsuddenbucket-github-io.onrender.com." ];
} }

View file

@ -1,8 +1,11 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "heypxl"; username = "heypxl";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "heypxl.github.io." ]; CNAME = [ "heypxl.github.io." ];
} }

View file

@ -1,8 +1,11 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "vortexprime24"; username = "vortexprime24";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "fire.hackclub.app." ]; CNAME = [ "fire.hackclub.app." ];
} }

View file

@ -1,9 +1,12 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "Roki100"; username = "Roki100";
discord = "289479495444987904"; discord = "289479495444987904";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "edge.redirect.pizza." ]; CNAME = [ "edge.redirect.pizza." ];
} }

View file

@ -1,7 +1,10 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "satr14washere"; username = "satr14washere";
}; };
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "5th-site.pages.dev." ]; CNAME = [ "5th-site.pages.dev." ];
} }

View file

@ -1,9 +1,12 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "Stef-00012"; username = "Stef-00012";
email = "admin@stefdp.lol"; email = "admin@stefdp.lol";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "proxy.stefdp.lol." ]; CNAME = [ "proxy.stefdp.lol." ];
} }

View file

@ -1,10 +1,13 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "ukriu"; username = "ukriu";
email = "partofmyid@ukriu.com"; email = "partofmyid@ukriu.com";
}; };
description = "my website"; description = "my website";
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "ukriu.pages.dev." ]; CNAME = [ "ukriu.pages.dev." ];
} }

View file

@ -1,9 +1,12 @@
{ dns, ... }: let { dns, ... }:
let
owner = { owner = {
username = "Stef-00012"; username = "Stef-00012";
email = "admin@stefdp.com"; email = "admin@stefdp.com";
}; };
proxy = false; proxy = false;
in with dns.lib.combinators; { in
with dns.lib.combinators;
{
CNAME = [ "proxy.stefdp.com." ]; CNAME = [ "proxy.stefdp.com." ];
} }

View file

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