2024-12-15 00:29:51 +01:00
|
|
|
{
|
|
|
|
pkgs,
|
|
|
|
lib,
|
|
|
|
config,
|
|
|
|
...
|
|
|
|
}:
|
2024-06-08 15:54:33 +02:00
|
|
|
let
|
2024-12-15 00:29:51 +01:00
|
|
|
importScript = pkgs.writers.writePython3 "install-wifi-import" {
|
|
|
|
libraries = [ pkgs.python3Packages.pyaml ];
|
|
|
|
} (builtins.readFile ./import.py);
|
2024-06-08 15:54:33 +02:00
|
|
|
applyScript = pkgs.writers.writePython3 "install-wifi-apply" { } (builtins.readFile ./apply.py);
|
|
|
|
in
|
2024-02-18 13:38:01 +01:00
|
|
|
{
|
|
|
|
environment.systemPackages = [
|
|
|
|
(pkgs.writeShellApplication {
|
|
|
|
name = "install-wifi";
|
2024-12-15 00:29:51 +01:00
|
|
|
runtimeInputs = with pkgs; [
|
|
|
|
wpa_supplicant
|
|
|
|
diffutils
|
|
|
|
];
|
2024-02-18 13:38:01 +01:00
|
|
|
text = ''
|
|
|
|
temp="$(mktemp --directory --suffix="-install-wifi")"
|
|
|
|
cd "$temp"
|
2024-06-08 15:54:33 +02:00
|
|
|
|
|
|
|
# Save config for diffing later
|
|
|
|
wpa_cli save_config > /dev/null
|
|
|
|
cat <(sudo cat /run/wpa_supplicant/wpa_supplicant.conf) > old.conf
|
|
|
|
|
|
|
|
# Export Wi-Fi config from pass
|
|
|
|
${importScript}
|
|
|
|
|
|
|
|
# Save on persistent storage for boot
|
|
|
|
sudo chown root:root wireless_networks.json
|
|
|
|
sudo chmod "u=r" wireless_networks.json
|
2024-02-18 13:38:01 +01:00
|
|
|
sudo mkdir -p /etc/keys
|
2024-06-08 15:54:33 +02:00
|
|
|
sudo mv -f wireless_networks.json /etc/keys
|
|
|
|
|
|
|
|
# Apply configuration
|
|
|
|
sudo ${applyScript}
|
|
|
|
|
|
|
|
# Diff the config
|
|
|
|
wpa_cli save_config > /dev/null
|
|
|
|
cat <(sudo cat /run/wpa_supplicant/wpa_supplicant.conf) > new.conf
|
|
|
|
diff --color=auto -U 5 old.conf new.conf
|
|
|
|
|
|
|
|
rm old.conf new.conf
|
|
|
|
cd /
|
2024-02-18 13:38:01 +01:00
|
|
|
rmdir "$temp"
|
|
|
|
'';
|
2024-06-08 15:54:33 +02:00
|
|
|
# This relies on pass password store with wifi/${name} entries,
|
|
|
|
# containing wpa_supplicant networks loosely converted to YAML
|
|
|
|
# (see import.py script)
|
2024-02-18 13:38:01 +01:00
|
|
|
})
|
|
|
|
];
|
|
|
|
# wireless support via wpa_supplicant
|
2024-12-25 15:22:07 +01:00
|
|
|
networking = {
|
|
|
|
# Tell the time synchronisation service when we got/lost the connection
|
|
|
|
dhcpcd.runHook = ''
|
|
|
|
if $if_up; then
|
|
|
|
${config.services.chrony.package}/bin/chronyc online
|
|
|
|
elif $if_down; then
|
|
|
|
${config.services.chrony.package}/bin/chronyc offline
|
|
|
|
fi
|
2024-02-18 13:38:01 +01:00
|
|
|
'';
|
2024-12-25 15:22:07 +01:00
|
|
|
|
|
|
|
wireless = {
|
|
|
|
enable = true;
|
|
|
|
extraConfig = ''
|
|
|
|
country=NL
|
|
|
|
'';
|
|
|
|
# Public wireless networks
|
|
|
|
networks = lib.genAttrs [
|
|
|
|
"EurostarTrainsWiFi"
|
|
|
|
"_SNCF gare-gratuit"
|
|
|
|
"_SNCF_WIFI_INOUI"
|
|
|
|
"Wifi in de trein"
|
|
|
|
"WiFi in de trein"
|
|
|
|
"_WIFI_LYRIA"
|
|
|
|
"WIFIonICE"
|
|
|
|
] (ssid: { });
|
|
|
|
userControlled.enable = true; # Allow some control with wpa_cli
|
|
|
|
};
|
2024-02-18 13:38:01 +01:00
|
|
|
};
|
2024-12-25 15:22:07 +01:00
|
|
|
|
|
|
|
# Wait until there's a connection to fetch time
|
2024-02-18 13:38:01 +01:00
|
|
|
services.chrony.serverOption = "offline";
|
2024-12-25 15:22:07 +01:00
|
|
|
|
2024-06-08 15:54:33 +02:00
|
|
|
systemd.services.wifi_apply = {
|
|
|
|
after = [ "wpa_supplicant.service" ];
|
2024-06-08 16:19:16 +02:00
|
|
|
wantedBy = [ "wpa_supplicant.service" ];
|
2024-06-08 15:54:33 +02:00
|
|
|
path = with pkgs; [ wpa_supplicant ];
|
2024-06-17 15:23:25 +02:00
|
|
|
script = ''
|
2024-12-15 00:29:51 +01:00
|
|
|
for i in {1..50}; do wpa_cli status &> /dev/null && break; sleep 0.1; done
|
|
|
|
${applyScript}
|
2024-06-17 15:23:25 +02:00
|
|
|
'';
|
2024-06-08 15:54:33 +02:00
|
|
|
};
|
2024-02-18 13:38:01 +01:00
|
|
|
}
|