1 { pkgs, lib, config, ... }:
2 with (import ./names-and-numbers.nix);
4 inherit (config.users) users;
7 networking.nftables.ruleset = ''
10 iifname ${lteIface} jump input-net
11 iifname ${lteIface} log level warn prefix "input-net: " counter drop
14 ip daddr 10.151.0.1 tcp dport 8080 counter accept \
15 comment "mmsd: Prixtel/SFR"
18 oifname ${lteIface} jump output-net
19 oifname ${lteIface} log level warn prefix "output-net: " counter drop
21 chain forward-to-net {
23 chain forward-from-net {
25 chain forward-to-net { }
26 chain forward-from-net { }
28 iifname { ${wifiIface}, ${eth1Iface}, ${eth2Iface}, ${eth3Iface} } oifname ${lteIface} goto forward-to-net
29 iifname ${lteIface} oifname { ${wifiIface}, ${eth1Iface}, ${eth2Iface}, ${eth3Iface} } goto forward-from-net
34 iifname { ${wifiIface}, ${eth1Iface}, ${eth2Iface}, ${eth3Iface} } oifname ${lteIface} masquerade
38 services.mmsd.enable = true;
39 services.mmsd.extraArgs = [ "--debug" ];
40 systemd.services.ModemManager.serviceConfig.ExecStart = lib.mkForce [ "" "${pkgs.modemmanager}/bin/ModemManager --debug" ];
41 systemd.services.NetworkManager.wants = [ "ModemManager.service" ];
42 services.dbus.packages = [ pkgs.dconf ];
43 programs.dconf.enable = true;
44 environment.etc."NetworkManager/system-connections/Prixtel.nmconnection" = {
49 uuid=b223f550-dff1-4ba3-9755-cd4557faaa5a
63 dhcp-send-hostname=false
67 addr-gen-mode=stable-privacy
69 dhcp-send-hostname=false
74 systemd.services.watch-lte = {
75 wantedBy = [ "multi-user.target" ];
76 startAt = "*:0/5"; # every 5 min
77 path = with pkgs; [ inetutils networkmanager ];
78 unitConfig = { StartLimitIntervalSec = 0; };
81 IPAddressAllow = [ "9.9.9.9" ];
82 RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ];
83 ExecStart = pkgs.writeShellScript "watch-lte" ''
86 nmcli connection up Prixtel
88 Restart = "on-failure";
92 environment.systemPackages = [
93 pkgs.modem-manager-gui
96 pkgs.gnome.gnome-contacts
101 # https://gitlab.com/mobian1/callaudiod/-/issues/26
102 # https://gitlab.com/mobian1/callaudiod/-/issues/27