nixos-config/modules/system/services/wlan.nix

43 lines
876 B
Nix

{
config,
pkgs,
lib,
...
}:
let
cfg = config.custom.services.wlan;
in
{
options.custom.services.wlan = {
enable = lib.mkEnableOption "";
networks = lib.mkOption {
type = lib.types.listOf lib.types.nonEmptyStr;
default = config.custom.sops.secrets.iwd |> lib.attrNames;
};
};
config = lib.mkIf cfg.enable {
networking.wireless.iwd = {
enable = true;
settings = {
General.EnableNetworkConfiguration = true;
Settings.AutoConnect = true;
};
};
environment.systemPackages = [ pkgs.iwgtk ];
sops.secrets =
cfg.networks
|> lib.map (name: {
name = "iwd/${name}";
value = { };
})
|> lib.listToAttrs;
systemd.services.iwd.preStart = ''
rm --force /var/lib/iwd/*.{psk,8021x}
install -m 600 /run/secrets/iwd/* /var/lib/iwd
'';
};
}