Add global domains list

This commit is contained in:
SebastianStork 2025-06-15 12:20:54 +02:00
parent 7a9796e02c
commit f3c3d3268c
2 changed files with 68 additions and 55 deletions

View file

@ -6,29 +6,6 @@
}: }:
let let
cfg = config.meta.domains; 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 in
{ {
options.meta.domains = { options.meta.domains = {
@ -37,17 +14,51 @@ in
default = [ ]; default = [ ];
internal = true; internal = true;
}; };
globalList = lib.mkOption {
type = lib.types.listOf lib.types.nonEmptyStr;
default =
self.nixosConfigurations
|> lib.mapAttrsToList (_: value: value.config.meta.domains.list)
|> lib.concatLists;
internal = true;
readOnly = true;
};
assertUnique = lib.mkEnableOption "" // { assertUnique = lib.mkEnableOption "" // {
default = true; default = true;
}; };
}; };
config = lib.mkIf cfg.assertUnique { config = lib.mkIf cfg.assertUnique {
assertions = [ assertions =
{ let
assertion = duplicatedDomains == { }; duplicateDomains =
message = errorMessage; 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 =
duplicateDomains
|> lib.mapAttrsToList (
domain: entries:
"Duplicate domain \"${domain}\" found in:\n"
+ lib.concatMapStrings (entry: " - ${entry.file}\n") entries
)
|> lib.concatStrings;
in
[
{
assertion = duplicateDomains == { };
message = errorMessage;
}
];
}; };
} }

View file

@ -6,26 +6,6 @@
}: }:
let let
cfg = config.meta.ports; cfg = config.meta.ports;
duplicatedPorts =
options.meta.ports.list.definitionsWithLocations
|> lib.concatMap (
entry:
map (port: {
file = entry.file;
inherit port;
}) entry.value
)
|> lib.groupBy (entry: toString entry.port)
|> lib.filterAttrs (port: entries: lib.length entries > 1);
errorMessage =
duplicatedPorts
|> lib.mapAttrsToList (
port: entries:
"Duplicate port ${port} found in:\n" + lib.concatMapStrings (entry: " - ${entry.file}\n") entries
)
|> lib.concatStrings;
in in
{ {
options.meta.ports = { options.meta.ports = {
@ -40,11 +20,33 @@ in
}; };
config = lib.mkIf cfg.assertUnique { config = lib.mkIf cfg.assertUnique {
assertions = [ assertions =
{ let
assertion = duplicatedPorts == { }; duplicatePorts =
message = errorMessage; options.meta.ports.list.definitionsWithLocations
} |> lib.concatMap (
]; entry:
map (port: {
inherit (entry) file;
inherit port;
}) entry.value
)
|> lib.groupBy (entry: toString entry.port)
|> lib.filterAttrs (port: entries: lib.length entries > 1);
errorMessage =
duplicatePorts
|> lib.mapAttrsToList (
port: entries:
"Duplicate port ${port} found in:\n" + lib.concatMapStrings (entry: " - ${entry.file}\n") entries
)
|> lib.concatStrings;
in
[
{
assertion = duplicatePorts == { };
message = errorMessage;
}
];
}; };
} }