Need Help Setting Up Zerotier Router/Endpoint On Nixos

Zerotier Router Setup Help

Im working on a zerotier router setup for the company I work for using nixos to help manager all of the routers of a particular client and keep tools consistent between all the devices. I’ve successfully got my laptop to talk to my zerotier router but my laptop cant talk to any devices parallel to the router. My assumption is that It was not forwarding the ip packets to other devices on the network so I was trying to look into ip forwarding and didn’t find much that worked for me or that was helpful (below are the resources I’ve looked at that may be relevant incase I misunderstood) can anyone help me figure out how to do ip forwarding on nixos or if this is even the issue or if is another network issue?

I talked with nixos unofficial support and they believe that the device is configured appropriately but had very little knowlage about Zerotier and was doing their troubleshooting based on wiregaurd they kept thinking it was an issue with nat on the isp router/mobile network

TLDR: Trying to create a zerotier endpoint/router but traffic is not moving across network that router is on. Need help figuring out ip forwarding i think. Thanks!

this is how i believe the network is laid out:

Config for Reference with work stuff censored (probably not relevant to you all but thought id include it):

# Edit this configuration file to define what should be installed on
# your system. Help is available in the configuration.nix(5) man page, on
# https://search.nixos.org/options and in the NixOS manual (`nixos-help`).

{ config, lib, pkgs, ... }:

#This is a test of the sync system x2 electricboogalo#

{

  imports =
    [ # Include the results of the hardware scan.
      ./disk-config.nix
	  "${builtins.fetchTarball "https://github.com/nix-community/disko/archive/master.tar.gz"}/module.nix"
      ./hardware-configuration.nix
    ];

  # Use the systemd-boot EFI boot loader.
  boot.loader.systemd-boot.enable = true;
  boot.loader.efi.canTouchEfiVariables = true;

  networking.hostName = "nixos"; # Define your hostname.
  # networking.wireless.enable = true;  # Enables wireless support via wpa_supplicant.

  # Configure network proxy if necessary
  # networking.proxy.default = "http://user:password@proxy:port/";
  # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain";

  # Enable networking
  networking.networkmanager.enable = true;
  networking.usePredictableInterfaceNames = true;

  # Enable network manager applet
  programs.nm-applet.enable = true;

  # Set your time zone.
  time.timeZone = "America/Chicago";

  # Select internationalisation properties.
  i18n.defaultLocale = "en_US.UTF-8";

  i18n.extraLocaleSettings = {
    LC_ADDRESS = "en_US.UTF-8";
    LC_IDENTIFICATION = "en_US.UTF-8";
    LC_MEASUREMENT = "en_US.UTF-8";
    LC_MONETARY = "en_US.UTF-8";
    LC_NAME = "en_US.UTF-8";
    LC_NUMERIC = "en_US.UTF-8";
    LC_PAPER = "en_US.UTF-8";
    LC_TELEPHONE = "en_US.UTF-8";
    LC_TIME = "en_US.UTF-8";
  };

  # Enable the X11 windowing system.
  services.xserver.enable = true;

  # Enable the LXQT Desktop Environment.
  services.xserver.displayManager.lightdm.enable = true;
  services.xserver.desktopManager.lxqt.enable = true;

  # Configure keymap in X11
  services.xserver = {
    layout = "us";
    xkbVariant = "";
  };

  # Enable sound with pipewire.
  sound.enable = true;
  hardware.pulseaudio.enable = false;
  security.rtkit.enable = true;
  services.pipewire = {
    enable = true;
    alsa.enable = true;
    alsa.support32Bit = true;
    pulse.enable = true;
    # If you want to use JACK applications, uncomment this
    #jack.enable = true;

    # use the example session manager (no others are packaged yet so this is enabled by default,
    # no need to redefine it in your config for now)
    #media-session.enable = true;
  };

  # Enable touchpad support (enabled default in most desktopManager).
  # services.xserver.libinput.enable = true;

  # Define a user account. Don't forget to set a password with ‘passwd’.
  users.users.itpadmin = {
    isNormalUser = true;
    description = "itpadmin";
    extraGroups = [ "networkmanager" "wheel" ];
    initialHashedPassword = "censored";
    packages = with pkgs; [
    #  thunderbird
    ];
  };

  # Install firefox.
  programs.firefox.enable = true;

  # Allow unfree packages
  nixpkgs.config.allowUnfree = true;

  # List packages installed in system profile. To search, run:
  # $ nix search wget
  environment.systemPackages = with pkgs; [
     vim
  #  wget
     gedit
     iperf
     nettools
     corosync
     tmux
     nmap
     termshark
     zerotierone
     nixos-generators
     parted
     gptfdisk
     disko
     git
     traceroute
  ];

  #Enable zerotier
    services.zerotierone = {
    enable = true;
    joinNetworks = ["censored"];
    port = 9993;
  };

  #Enable iptable forwarding
  boot.kernel.sysctl."net.ipv4.ip_forward" = 1;


  # Some programs need SUID wrappers, can be configured further or are
  # started in user sessions.
  # programs.mtr.enable = true;
  # programs.gnupg.agent = {
  #   enable = true;
  #   enableSSHSupport = true;
  # };

  # List services that you want to enable:

  # Enable the OpenSSH daemon.
  services.openssh.enable = true;

  # Open ports in the firewall.
  # networking.firewall.allowedTCPPorts = [ ... ];
  # networking.firewall.allowedUDPPorts = [ ... ];
  # Or disable the firewall altogether.
  # networking.firewall.enable = false;
  
  # Copy the NixOS configuration file and link it from the resulting system
  # (/run/current-system/configuration.nix). This is useful in case you
  # accidentally delete configuration.nix.
  system.copySystemConfiguration = true;

  # This option defines the first version of NixOS you have installed on this particular machine,
  # and is used to maintain compatibility with application data (e.g. databases) created on older NixOS versions.
  #
  # Most users should NEVER change this value after the initial install, for any reason,
  # even if you've upgraded your system to a new NixOS release.
  #
  # This value does NOT affect the Nixpkgs version your packages and OS are pulled from,
  # so changing it will NOT upgrade your system.
  #
  # This value being lower than the current NixOS release does NOT mean your system is
  # out of date, out of support, or vulnerable.
  #
  # Do NOT change this value unless you have manually inspected all the changes it would make to your configuration,
  # and migrated your data accordingly.
  #
  # For more information, see `man configuration.nix` or https://nixos.org/manual/nixos/stable/options#opt-system.stateVersion .
  system.stateVersion = "23.11"; # Did you read the comment?

}

Relevant Research that I’ve already done:

Though Wire guard setup might be similar: WireGuard - NixOS Wiki

also at the nixos options search website

Nixos Zerotier wiki is also very empty: ZeroTier One - NixOS Wiki

Assuming that the given router configuration is complete, the router must have static routes for each of the network blocks. The IP forwarding option is, alone, not enough to get the desired result.

Past that, I don’t understand what parallel devices means, and you’re using network symbology in an unusual way. For example, it seems like 172.18.125.12 is being used by the computer in the bottom-left and by the router. And 172.18.125.0/24 isn’t your Internet connection. And the rando cellphone needs an explanation.

The request would be easier to understand if you name the affected nodes and provide a concrete example of what doesn’t work. (eg: “192.168.113.246 on Laptop1 does not connect to 192.168.191.54 on Server2”.) Also provide a list of participating nodes, and the output of things like zerotier-cli listnetworks and zerotier-cli listpeers

I apologize for my lack of networking terminology feel free to correct me, Firstly what I meant by parallel was devices on the same lan as the router as i want lan traffic to be able to be routed across the Zerotier network to a different physical location so that every device does not need to be in the network to talk to resources at the other location. this needs to work both ways. I will attempt to clean up the diagram and i will try and provide as much information as i can, and get you the output of those commands. Also there is only one maybe two nodes in the network as this is a test network for experimenting with this new OS.

Here is an updated better labeled diagram:

For the laptop connected to the mobile hotspot this is the current output of those commands


image

Router output for those commands


Example of Current behavior: I am able to ping directly from my work device to the router but when trying to ping the .13 mini pc i am not able to reach the destination. Going the other way also does not prove successful. I can include a traceroute if i need to.

Expected Behavior:
I should be able to ping from my work laptop to the .13 mini pc and from the mini pc to the work laptop.

(That diagram is good.)

The screenshot of the Fortigate routing table has 192.168.254.2, which is an address that does not appear in your network diagram or other screenshots. If 192.168.254.2 is not the Managed Ethernet Switch in the network diagram, then this is a misconfiguration that must be fixed.

Do this:

  1. Remove or adjust the bogus route at 192.168.254.2.

  2. Ensure that the Managed Ethernet Switch is allowing TCPv4 traffic between 192.168.191.54/32 and 172.18.125.0/24. This kind of traffic pattern will be blocked by default by some manufacturers/models, so providing more hardware information will be helpful.

  3. Add a route for 172.18.125.0/24 at 192.168.191.54 on the Fortigate router.

For testing and troubleshooting, you can add this route on the Mini PC instead of the Fortigate router.