Add uniqueness check for domains

This commit is contained in:
SebastianStork 2025-06-14 01:53:24 +02:00
parent 232c9aa946
commit f160a9be33
3 changed files with 59 additions and 2 deletions

View file

@ -0,0 +1,53 @@
{
config,
self,
lib,
...
}:
let
cfg = config.meta.domains;
duplicatedDomains =
self.nixosConfigurations
|> lib.mapAttrsToList (_: value: value.options.meta.domains.list.definitionsWithLocations)
|> lib.concatLists
|> lib.concatMap (
entry:
map (domain: {
file = entry.file;
inherit domain;
}) entry.value
)
|> lib.groupBy (entry: toString entry.domain)
|> lib.filterAttrs (domain: entries: lib.length entries > 1);
errorMessage =
duplicatedDomains
|> lib.mapAttrsToList (
domain: entries:
"Duplicate domain \"${domain}\" found in:\n"
+ lib.concatMapStrings (entry: " - ${entry.file}\n") entries
)
|> lib.concatStrings;
in
{
options.meta.domains = {
list = lib.mkOption {
type = lib.types.listOf lib.types.nonEmptyStr;
default = [ ];
internal = true;
};
assertUnique = lib.mkEnableOption "" // {
default = true;
};
};
config = lib.mkIf cfg.assertUnique {
assertions = [
{
assertion = duplicatedDomains == { };
message = errorMessage;
}
];
};
}

View file

@ -13,7 +13,7 @@ let
entry:
map (port: {
file = entry.file;
port = port;
inherit port;
}) entry.value
)
|> lib.groupBy (entry: toString entry.port)

View file

@ -62,7 +62,11 @@ in
config = lib.mkIf (virtualHosts != { }) (
lib.mkMerge [
{
meta.ports.list = lib.mkIf nonTailscaleHostsExist ports;
meta = {
ports.list = lib.mkIf nonTailscaleHostsExist ports;
domains.list = lib.mapAttrsToList (_: value: value.domain) virtualHosts;
};
networking.firewall.allowedTCPPorts = lib.mkIf nonTailscaleHostsExist ports;
services.caddy = {