1 { pkgs, lib, config, ... }:
2 # NOTE: list explicitely the modules loaded by defaults.nix,
3 # its clearer, safer and more flexible if not quicker.
5 modules/services/mail/dovecot.nix
6 modules/services/mail/rspamd/dkim.nix
7 modules/services/networking/domains.nix
8 modules/services/networking/shorewall.nix
9 modules/services/networking/shorewall6.nix
10 modules/services/networking/shorewall6.nix
11 modules/services/databases/openldap.nix
16 # NOTE: this modules.nix file is put in the imports of the configuration.nix,
17 # but using the lib.findFiles defined in the nixpkgs.overlays leads to an infinite recursion,
18 # hence it is redefined here:
19 let findFiles = pattern:
22 let dir = readDir curr; in
23 let files = lib.filterAttrs (name: type:
25 match pattern name != null) dir; in
26 let dirs = lib.filterAttrs (name: type: type == "directory") dir; in
27 map (name: "${curr}/${name}") (attrNames files) ++
28 lib.concatMap (name: go "${curr}/${name}") (attrNames dirs)
30 in root: go (toPath root);
33 imports = findFiles ".*\\.nix" ./modules;