oignon: nft: output-lan: accept HTTP(s)
[julm/julm-nix.git] / nixos / profiles / networking.nix
index e7df5464b2a142a51462b8846ad7994fdf1a6d8c..2b619d2dcc24b391947f36d46b4dc6aeb5b35f55 100644 (file)
 { config, pkgs, lib, hostName, ... }:
-let
-  wg-intra-peers = import wireguard/wg-intra/peers.nix;
-in
+with lib;
 {
-imports = [
-  networking/nftables.nix
-];
-networking = {
-  hostName = hostName;
-  domain = lib.mkDefault "localdomain";
-  #search = [ "sourcephile.fr" ];
-  firewall = {
-    enable = lib.mkDefault true;
-    allowPing = lib.mkDefault true;
+  imports = [
+    networking/nftables.nix
+  ];
+
+  boot.kernel.sysctl = {
+    # Improve MTU detection
+    # This can thaw TCP connections stalled by a host
+    # requiring a lower MTU along the path,
+    # though it would do so after a little delay
+    # so it's better to set a low MTU when possible.
+    "net/ipv4/tcp_mtu_probing" = 1;
+
+    # Use TCP BBR to significantly increase throughput
+    # and reduce latency for connections.
+    "net/ipv4/tcp_congestion_control" = mkDefault "bbr";
+
+    # BBR must be used with the fq or fq_codel qdisc with pacing enabled,
+    # since pacing is integral to the BBR design and implementation.
+    # BBR without pacing would not function properly,
+    # and may incur unnecessary high packet loss rates.
+    #
+    # See https://github.com/systemd/systemd/issues/9725#issuecomment-412287161
+    # See https://github.com/systemd/systemd/issues/9725#issuecomment-413796842
+    # > The best all-round general purpose default for linux remains fq_codel.
+    "net/core/default_qdisc" = mkDefault "fq_codel";
+
+    # Request Explicit Congestion Notification (ECN)
+    # only for incoming connections (not outgoing).
+    # See https://github.com/systemd/systemd/issues/9748#issuecomment-1261352478
+    # > My answer to the ECN situation remains - turn it on
+    # > - see if it works - don't inflict your decision on others.
+    # > $ sysctl -w net.ipv4.tcp_ecn=1
+    # > $ flent -H flent-newark.bufferbloat.net -t 'now tv hub ecn' \
+    # >         --te=download_streams=1 --socket-stats tcp_ndown # try 1,4,16
+    # > $ sysctl -w net.ipv4.tcp_ecn=2
+    # > $ flent -H flent-newark.bufferbloat.net -t 'now tv hub noecn' \
+    # >         --te=download_streams=1 --socket-stats tcp_ndown # try 1,4,16
+    # > you can then use flent-gui *.flent.gz to generate a variety of plots,
+    # > especially comparison plots.
+    "net/ipv4/tcp_ecn" = mkDefault 2;
   };
-  networkmanager = {
-    enable = lib.mkDefault config.services.xserver.enable;
-    #dhcp = "dhcpcd";
-    logLevel = lib.mkDefault "INFO";
-    wifi = {
-      #backend = "iwd";
-      #backend = "wpa_supplicant";
-      powersave = lib.mkDefault false;
+
+  networking = {
+    inherit hostName;
+    domain = mkDefault "wg";
+    #search = [ "sourcephile.fr" ];
+    firewall = {
+      enable = mkDefault true;
+      allowPing = mkDefault true;
     };
+    networkmanager = {
+      #dhcp = "dhcpcd";
+      logLevel = mkDefault "INFO";
+      wifi = {
+        #backend = "iwd";
+        #backend = "wpa_supplicant";
+        powersave = mkDefault false;
+      };
+    };
+    usePredictableInterfaceNames = true;
   };
-  usePredictableInterfaceNames = true;
-};
 
-programs.mtr.enable = true;
-programs.usbtop.enable = true;
-environment.systemPackages = [
-  pkgs.iperf
-];
+  programs.mtr.enable = true;
+  programs.traceroute.enable = mkDefault true;
+  programs.usbtop.enable = true;
 
-services.avahi = {
-  enable = lib.mkDefault true;
-  nssmdns = lib.mkDefault true;
-  openFirewall = lib.mkDefault false;
-  publish.enable = lib.mkDefault false;
-};
-networking.nftables.ruleset = lib.mkIf config.services.avahi.enable (''
-  table inet filter {
-    chain output-lan {
-      skuid root udp sport mdns udp dport mdns comment "avahi: multicast DNS"
+  services.avahi = {
+    nssmdns = mkDefault true;
+    openFirewall = mkDefault false;
+    publish.enable = mkDefault false;
+  };
+  networking.nftables.ruleset = mkIf config.services.avahi.enable (''
+    table inet filter {
+      chain output-lan {
+        skuid root udp sport mdns udp dport mdns comment "avahi: multicast DNS"
+      }
     }
-  }
-'' + lib.optionalString config.services.avahi.openFirewall ''
-  table inet filter {
-    chain input-lan {
-      udp dport mdns comment "avahi: multicast DNS"
+  '' + optionalString config.services.avahi.openFirewall ''
+    table inet filter {
+      chain input-lan {
+        udp dport mdns comment "avahi: multicast DNS"
+      }
     }
-  }
-'');
+  '');
 
-services.openssh = {
-  enable = lib.mkDefault true;
-  forwardX11 = lib.mkDefault true;
-  openFirewall = lib.mkDefault false;
-  listenAddresses = [
-    { addr = wg-intra-peers.${hostName}.ipv4; port = 22; }
-  ];
-};
+  services.openssh.enable = mkDefault true;
+
+  # Fix https://github.com/NixOS/nixpkgs/issues/180175 by removing -s (aka. --wait-for-startup)
+  systemd.services.NetworkManager-wait-online = {
+    unitConfig.StartLimitIntervalSec = 0;
+    serviceConfig = {
+      ExecStart = [ "" "${pkgs.networkmanager}/bin/nm-online -q" ];
+      Restart = "on-failure";
+      RestartSec = 1;
+    };
+  };
+  environment.etc."NetworkManager/dispatcher.d/congctl" = {
+    mode = "700";
+    source = pkgs.writeShellScript "congctl" ''
+      case $NM_DISPATCHER_ACTION in
+        up)
+          case $DEVICE_IP_IFACE in
+            # WLAN or WWAN
+            # https://en.wikipedia.org/wiki/TCP_congestion_control#TCP_Westwood+
+            wl*|ww*)
+              ip route show dev $DEVICE_IP_IFACE |
+              while read -r route; do
+                ip route change $route dev $DEVICE_IP_IFACE congctl westwood
+              done
+            ;;
+          esac
+        ;;
+      esac
+    '';
+  };
+
+  # The notion of "online" is a broken concept
+  #systemd.services.NetworkManager-wait-online.enable = false;
+  #systemd.network.wait-online.enable = false;
+
+  # Do not take down the network for too long when upgrading,
+  # This also prevents failures of services that are restarted instead of stopped.
+  # It will use `systemctl restart` rather than stopping it with `systemctl stop`
+  # followed by a delayed `systemctl start`.
+  systemd.services.systemd-networkd.stopIfChanged = false;
 
-environment.etc."NetworkManager/dispatcher.d/congctl" = {
-  mode = "700";
-  source = pkgs.writeShellScript "congctl" ''
-    case $NM_DISPATCHER_ACTION in
-      up)
-        case $DEVICE_IP_IFACE in
-          # WLAN or WWAN
-          # https://en.wikipedia.org/wiki/TCP_congestion_control#TCP_Westwood+
-          wl*|ww*)
-            ip route show dev $DEVICE_IP_IFACE |
-            while read -r route; do
-              ip route change $route dev $DEVICE_IP_IFACE congctl westwood
-            done
-            ip r >>/tmp/log
-          ;;
-        esac
-      ;;
-    esac
-  '';
-};
+  # Services that are only restarted might be not able
+  # to resolve when resolved is stopped before.
+  systemd.services.systemd-resolved.stopIfChanged = false;
 }