I’m trying to get networkd to connect to a wireguard endpoint, specifically ProtonVPN, in case it matters. I just can’t get it to connect. Has anyone had success with that? Specifically without using wg-quick.

  • blurry
    link
    fedilink
    English
    arrow-up
    13
    ·
    edit-2
    5 months ago

    Yes I use wireguard only with systemd-networkd (as server and as client).

    I followed the arch wiki and you need to ensure that the file permissions are correct, otherwise systemd will ignore them.

    Copied from the wiki:

    # chown root:systemd-network /etc/systemd/network/99-*.netdev # chmod 0640 /etc/systemd/network/99-*.netdev 
    
      • blurry
        link
        fedilink
        English
        arrow-up
        1
        ·
        edit-2
        5 months ago

        Have you tried to reduce your config to a minimum (like in the wiki) and add additional parts step by step? F.e. the link and route parts? So you can maybe identify the block/line which breaks your config.

        Edit: I have never seen ActivationPolicy before. Is it NixOS specific? An additional idea how are your files named? systemd-networkd uses the name of the file as indicator for the initialization order (alphanumeric order is applied here). Which means that wireguard.network will be used xx.network. I mean the lower w is near the end of the ascii table, but the devil is in the details and maybe your ethernet or wifi connection will be established after wireguard and therefore wireguard will not be able to connect. F.e. wlan.network for example will come up after wireguard.network. (As I remember that would not be the case using wg-quick, because its unit file depends network-online.target.)

        • Chais@sh.itjust.worksOP
          link
          fedilink
          English
          arrow-up
          1
          ·
          5 months ago

          The ActivationPolicy I added in an attempt to replicate what wg-quick produces, as I recall.

          • blurry
            link
            fedilink
            English
            arrow-up
            1
            ·
            5 months ago

            Do you have a link where it is documented in systemd-networkd content?

      • 2xsaiko@discuss.tchncs.de
        link
        fedilink
        English
        arrow-up
        1
        ·
        5 months ago

        Seems fine to me except for all the firewall and special routing stuff, I’m not familiar with that. Does the wg command show received or only sent data? For the record, this is my config:

        spoiler
        # /etc/systemd/network/mullvad.netdev
        [NetDev]
        Description=Mullvad
        Kind=wireguard
        Name=mullvad
        
        [WireGuard]
        PrivateKeyFile=/var/keys/mullvad/pk
        
        [WireGuardPeer]
        AllowedIPs=::/0
        AllowedIPs=0.0.0.0/0
        Endpoint=146.70.126.194:51820
        PublicKey=ApOUMLFcpTpj/sDAMub0SvASFdsSWtsy+vvw/nWvEmY=
        
        # /etc/systemd/network/mullvad.network
        [Match]
        Name=mullvad
        
        [Network]
        Address=10.64.130.96/32
        Address=fc00:bbbb:bbbb:bb01::1:825f/128
        
        [Route]
        Destination=::/0
        Metric=16384
        
        [Route]
        Destination=0.0.0.0/0
        Metric=16384