nixos/bind: refactor zones from a list to attrset

This commit uses coercedTo to make zones a attrset instead of list.
Makes it easier to access/change zones in multiple places.
This commit is contained in:
eyjhb 2021-04-29 17:47:43 +02:00
parent 2bd34a98af
commit 757a455dde
No known key found for this signature in database
GPG Key ID: 740FAE1502523BD8
1 changed files with 42 additions and 36 deletions

View File

@ -8,32 +8,37 @@ let
bindUser = "named"; bindUser = "named";
bindZoneOptions = { bindZoneCoerce = list: builtins.listToAttrs (lib.forEach list (zone: { name = zone.name; value = zone; }));
name = mkOption {
type = types.str; bindZoneOptions = { name, config, ... }: {
description = "Name of the zone."; options = {
}; name = mkOption {
master = mkOption { type = types.str;
description = "Master=false means slave server"; default = name;
type = types.bool; description = "Name of the zone.";
}; };
file = mkOption { master = mkOption {
type = types.either types.str types.path; description = "Master=false means slave server";
description = "Zone file resource records contain columns of data, separated by whitespace, that define the record."; type = types.bool;
}; };
masters = mkOption { file = mkOption {
type = types.listOf types.str; type = types.either types.str types.path;
description = "List of servers for inclusion in stub and secondary zones."; description = "Zone file resource records contain columns of data, separated by whitespace, that define the record.";
}; };
slaves = mkOption { masters = mkOption {
type = types.listOf types.str; type = types.listOf types.str;
description = "Addresses who may request zone transfers."; description = "List of servers for inclusion in stub and secondary zones.";
default = []; };
}; slaves = mkOption {
extraConfig = mkOption { type = types.listOf types.str;
type = types.str; description = "Addresses who may request zone transfers.";
description = "Extra zone config to be appended at the end of the zone section."; default = [];
default = ""; };
extraConfig = mkOption {
type = types.str;
description = "Extra zone config to be appended at the end of the zone section.";
default = "";
};
}; };
}; };
@ -84,7 +89,7 @@ let
${extraConfig} ${extraConfig}
}; };
'') '')
cfg.zones } (attrValues cfg.zones) }
''; '';
in in
@ -153,18 +158,19 @@ in
zones = mkOption { zones = mkOption {
default = []; default = [];
type = types.listOf (types.submodule [ { options = bindZoneOptions; } ]); type = with types; coercedTo (listOf attrs) bindZoneCoerce (attrsOf (types.submodule bindZoneOptions));
description = " description = "
List of zones we claim authority over. List of zones we claim authority over.
"; ";
example = [{ example = {
name = "example.com"; "example.com" = {
master = false; master = false;
file = "/var/dns/example.com"; file = "/var/dns/example.com";
masters = ["192.168.0.1"]; masters = ["192.168.0.1"];
slaves = []; slaves = [];
extraConfig = ""; extraConfig = "";
}]; };
};
}; };
extraConfig = mkOption { extraConfig = mkOption {