diff options
author | Benedikt Peetz <benedikt.peetz@b-peetz.de> | 2024-10-18 17:07:46 +0200 |
---|---|---|
committer | Benedikt Peetz <benedikt.peetz@b-peetz.de> | 2024-10-18 17:07:46 +0200 |
commit | c52c7f314ccadcc2fcd91e28c8fd1b88f6d5ce0c (patch) | |
tree | e8b947710b467b32740598ff574982097836f66c /modules/by-name/ne | |
parent | chore(pkgs/yt): 1.2.1 -> 1.3.0 (diff) | |
download | nixos-config-c52c7f314ccadcc2fcd91e28c8fd1b88f6d5ce0c.tar.gz nixos-config-c52c7f314ccadcc2fcd91e28c8fd1b88f6d5ce0c.zip |
refactor(modules): Move all system modules to `by-name`
From now on all modules should be added to the new `by-name` directory. This should help remove the (superficial and utterly useless) distinction between `home-manager` and `NixOS` modules.
Diffstat (limited to 'modules/by-name/ne')
-rw-r--r-- | modules/by-name/ne/networking/module.nix | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/modules/by-name/ne/networking/module.nix b/modules/by-name/ne/networking/module.nix new file mode 100644 index 00000000..c5f0e491 --- /dev/null +++ b/modules/by-name/ne/networking/module.nix @@ -0,0 +1,88 @@ +{ + config, + lib, + ... +}: let + cfg = config.soispha.networking; +in { + options.soispha.networking = { + enable = lib.mkEnableOption "networking"; + + mode = lib.mkOption { + type = lib.types.enum ["NetworkManager" "systemd-networkd"]; + example = "systemd-networkd"; + description = "The daemon used to setup networking."; + }; + + userName = lib.mkOption { + type = lib.types.str; + default = "soispha"; + description = '' + The name of the user to allow access to the configured network + ''; + }; + + hostName = lib.mkOption { + type = lib.types.str; + example = "apzu"; + description = "The name of the host"; + }; + }; + + config = { + networking.hostName = cfg.hostName; + + systemd.network = lib.mkIf (cfg.mode == "systemd-networkd") { + networks = { + "tap0" = { + name = "tap0"; + bridge = [ + "virbr0" + ]; + }; + "enp4s0" = { + name = "enp4s0"; + networkConfig = { + DHCP = "yes"; + DNSOverTLS = "yes"; + DNSSEC = "yes"; + }; + bridge = [ + "virbr0" + ]; + }; + }; + + netdevs = { + "tap0" = { + netdevConfig = { + Name = "tap0"; + Kind = "tap"; + }; + tapConfig = { + User = config.users.users."${cfg.userName}".uid; + Group = "libvirtd"; + }; + }; + "virbr0" = { + netdevConfig = { + Name = "br0"; + Kind = "bridge"; + }; + }; + }; + }; + + networking.networkmanager = lib.mkIf (cfg.mode == "NetworkManager") { + enable = true; + dns = "default"; + wifi = { + powersave = true; + }; + }; + + users.users."${cfg.userName}".extraGroups = lib.mkIf (cfg.mode == "NetworkManager") [ + "networkmanager" # allows to configure NetworkManager as this user + ]; + }; +} |