vps/newinfra/nix/modules/dns/nilstrieb.dev.nix
2024-08-02 17:36:55 +02:00

79 lines
1.9 KiB
Nix

# https://github.com/nix-community/dns.nix
{ pkgs, lib, networkingConfig, ... }:
let
data = with pkgs.nix-dns.lib.combinators;
let
hour1 = 3600;
hostsToDns = builtins.mapAttrs
(name: { publicIPv4, publicIPv6, ... }:
lib.optionalAttrs (publicIPv4 != null) { A = [ (ttl hour1 (a publicIPv4)) ]; } //
lib.optionalAttrs (publicIPv6 != null) { AAAA = [ (ttl hour1 (aaaa publicIPv6)) ]; })
networkingConfig;
vps2 = {
A = [ "184.174.32.252" ];
};
in
with hostsToDns;
# point nilstrieb.dev to vps1
vps1 // {
SOA = {
nameServer = "ns1.nilstrieb.dev";
adminEmail = "void@noratrieb.dev";
serial = 2024072601;
};
TXT = [
"protonmail-verification=86964dcc4994261eab23dbc53dad613b10bab6de"
"v=spf1 include:_spf.protonmail.ch ~all"
];
NS = [
"ns1.nilstrieb.dev"
"ns2.nilstrieb.dev"
];
MX = with mx; [
(mx 10 "mail.protonmail.ch")
(mx 20 "mailsec.protonmail.ch")
];
subdomains = {
ns1 = dns1;
ns2 = dns2;
www = vps2;
blog = vps1;
# apps
bisect-rustc = vps2;
cors-school = vps2 // {
subdomains.api = vps2;
};
docker = vps2;
hugo-chat = vps2 // {
subdomains.api = vps2;
};
olat = vps2;
uptime = vps2;
localhost.A = [ (a "127.0.0.1") ];
# infra (legacy)
inherit vps1;
inherit vps2;
inherit dns1;
inherit dns2;
pronouns.TXT = [
"TODO"
];
newtest.TXT = [ "uwu it works" ];
bsky.subdomains.atproto.TXT = [ "did=did:plc:pqyzoyxk7gfcbxk65mjyncyl" ];
};
};
in
pkgs.writeTextFile {
name = "nilstrieb.dev.zone";
text = pkgs.nix-dns.lib.toString "nilstrieb.dev" data;
}