zaphyra's git: nixfiles

zaphyra and void's nixfiles

1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 
51 
52 
53 
54 
55 
56 
57 
58 
59 
60 
61 
{
  inputs,
  dnsNix,
  povSelf,
  config,
  lib,
  pkgs,
  ...
}:
let
  inherit (lib) types;
  cfg = lib.getAttrFromPath povSelf config;

in
{

  options = {
    enable = {
      type = types.bool;
      default = false;
    };

    # contains dns entries defined on the local host
    zones = {
      type = types.attrsOf dnsNix.types.subzone;
      default = { };
    };

    # contains dns entries defined on the local host and on remote hosts, merged together
    allZones = {
      type = types.attrsOf dnsNix.types.zone;
      default = { };
    };

    zoneFiles = {
      type = types.attrsOf types.path;
      readOnly = true;
      default = (
        cfg.allZones
        |> lib.mapAttrs (
          name: zone:
          toString (
            pkgs.writeTextFile {
              name = "${name}.zone";
              text = dnsNix.types.zoneToString name (dnsNix.evalZone name zone);
            }
          )
        )
      );
    };
  };

  config = lib.mkIf cfg.enable {
    # serve records defined in all host configs
    dns.allZones = lib.mkMerge (
      inputs.self.nixosConfigurations
      |> lib.mapAttrsToList (hostName: hostConfig: hostConfig.config.dns.zones)
    );
  };

}