Netgate Discussion Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Register
    • Login

    v21.02 Broke all ExpressVPN Gateways

    Scheduled Pinned Locked Moved OpenVPN
    44 Posts 8 Posters 10.1k Views 8 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • B Offline
      bod
      last edited by

      Spoke too soon. The Watchdog service (Action) broke it.

      No issues with throughput on AES-256-GCM. Still getting sustained 40mbps.

      1 Reply Last reply Reply Quote 0
      • T Offline
        thaddeusf
        last edited by

        This post is deleted!
        1 Reply Last reply Reply Quote 0
        • G Offline
          guido666
          last edited by guido666

          I'm having a similar/related issue. After upgrading to 2.5, my traffic does not get routed out the VPN gateway. It hits the proper firewall rule, and gets passed, but it just doesn't go out the VPN gateway and instead goes out the WAN gateway.

          The VPN gateway (in Status) shows as "Offline, Packetloss: 100%".

          If I disable Gateway monitoring (System > Routing > Gateways) for the VPN gateway, the traffic instantly starts going through the VPN gateway correctly again (matching the same firewall rule).

          If related, I also get the 3 errors mentioned previously.
          Mar 11 01:03:28 openvpn 49069 Options error: option 'route' cannot be used in this context ([PUSH-OPTIONS])
          Mar 11 01:03:28 openvpn 49069 Options error: option 'dhcp-option' cannot be used in this context ([PUSH-OPTIONS])
          Mar 11 01:03:28 openvpn 49069 Options error: option 'redirect-gateway' cannot be used in this context ([PUSH-OPTIONS])

          GertjanG 1 Reply Last reply Reply Quote 0
          • GertjanG Offline
            Gertjan @guido666
            last edited by

            @guido666

            Looks like you confirmed - see above - https://redmine.pfsense.org/issues/11448

            There is a patch already.
            Tried (try) it ?!!

            No "help me" PM's please. Use the forum, the community will thank you.
            Edit : and where are the logs ??

            G 1 Reply Last reply Reply Quote 1
            • G Offline
              guido666 @Gertjan
              last edited by

              @gertjan

              Thanks! Patch applied, and traffic seems to be routing through the VPN correctly, even with Disable Gateway Monitoring unchecked.

              I've set the patch to auto-load. Once 2.5.1 comes out, and presumably includes the fix, will I need to disable it, and remove the patch at that point? I've never used this patch system before.

              GertjanG T 2 Replies Last reply Reply Quote 0
              • GertjanG Offline
                Gertjan @guido666
                last edited by Gertjan

                @guido666 said in v21.02 Broke all ExpressVPN Gateways:

                and presumably includes the fix, will I need to disable it, and remove the patch at that point? I've never used this patch system before.

                The patcher checks the files it needs to patch, and if it can find specific lines it will change these for new lines, the patch.

                When you upgrade, and nothing was changed in the file(s) you patched, the patch still auto applies.
                If the patch is now included in the update, it can't find the same specific lines any more, as the source has changed.
                The patcher will try - and fail, which is ok, as the patch is needed any more / already there.

                It's a close "to set it and forget it system".

                No "help me" PM's please. Use the forum, the community will thank you.
                Edit : and where are the logs ??

                G 1 Reply Last reply Reply Quote 1
                • G Offline
                  guido666 @Gertjan
                  last edited by

                  @gertjan Thanks for your help.

                  1 Reply Last reply Reply Quote 0
                  • T Offline
                    thaddeusf @guido666
                    last edited by

                    @guido666

                    This patch did not fix the problem for me.

                    Will you send your custom settings?

                    Thanks.

                    G 1 Reply Last reply Reply Quote 0
                    • G Offline
                      guido666 @thaddeusf
                      last edited by

                      @thaddeusf

                      Which settings are you looking for?

                      T 1 Reply Last reply Reply Quote 0
                      • T Offline
                        thaddeusf @guido666
                        last edited by

                        @guido666
                        The original custom options from ExpressVPN are:

                        fast-io;persist-key;persist-tun;remote-random;pull;comp-lzo;tls-client;verify-x509-name Server name-prefix;remote-cert-tls server;key-direction 1;route-method exe;route-delay 2;tun-mtu 1500;fragment 1300;mssfix 1450;verb 3;sndbuf 524288;rcvbuf 524288

                        Have you changed these?

                        Also, have you changed it from AES-256-CBC?

                        Thanks

                        G 2 Replies Last reply Reply Quote 0
                        • G Offline
                          guido666 @thaddeusf
                          last edited by

                          @thaddeusf No, I did not change them from default.

                          Here's what I have...

                          fast-io;persist-key;persist-tun;remote-random;pull;comp-lzo;tls-client;verify-x509-name Server name-prefix;ns-cert-type server;key-direction 1;route-method exe;route-delay 2;tun-mtu 1500;fragment 1300;mssfix 1450;verb 3;sndbuf 524288;rcvbuf 524288

                          @gertjan The patch was working for me, however, today I had to reboot the router and now can not get traffic through again. The patch was set to auto-run at start up, and I also tried reverting and applying it again, to no avail.

                          I'm getting these errors in the OpenVPN logs again...

                          Mar 18 15:09:03 openvpn 38456 Options error: option 'route' cannot be used in this context ([PUSH-OPTIONS])
                          Mar 18 15:09:03 openvpn 38456 Options error: option 'dhcp-option' cannot be used in this context ([PUSH-OPTIONS])
                          Mar 18 15:09:03 openvpn 38456 Options error: option 'redirect-gateway' cannot be used in this context ([PUSH-OPTIONS])

                          Full log of one connection attempt...

                          Mar 18 15:10:10 openvpn 38456 MANAGEMENT: Client disconnected
                          Mar 18 15:10:10 openvpn 38456 MANAGEMENT: CMD 'status 2'
                          Mar 18 15:10:10 openvpn 38456 MANAGEMENT: CMD 'state 1'
                          Mar 18 15:10:10 openvpn 38456 MANAGEMENT: Client connected from /var/etc/openvpn/client21/sock
                          Mar 18 15:10:07 openvpn 38456 MANAGEMENT: Client disconnected
                          Mar 18 15:10:07 openvpn 38456 MANAGEMENT: CMD 'status 2'
                          Mar 18 15:10:07 openvpn 38456 MANAGEMENT: CMD 'state 1'
                          Mar 18 15:10:07 openvpn 38456 MANAGEMENT: Client connected from /var/etc/openvpn/client21/sock
                          Mar 18 15:10:07 openvpn 38456 MANAGEMENT: Client disconnected
                          Mar 18 15:10:07 openvpn 38456 MANAGEMENT: CMD 'status 2'
                          Mar 18 15:10:07 openvpn 38456 MANAGEMENT: CMD 'state 1'
                          Mar 18 15:10:07 openvpn 38456 MANAGEMENT: Client connected from /var/etc/openvpn/client21/sock
                          Mar 18 15:09:05 openvpn 38456 Initialization Sequence Completed
                          Mar 18 15:09:03 openvpn 38456 /usr/local/sbin/ovpn-linkup ovpnc21 1500 1629 <REDACTED> <REDACTED> init
                          Mar 18 15:09:03 openvpn 38456 /sbin/ifconfig ovpnc21 <REDACTED> <REDACTED> mtu 1500 netmask 255.255.255.255 up
                          Mar 18 15:09:03 openvpn 38456 TUN/TAP device /dev/tun21 opened
                          Mar 18 15:09:03 openvpn 38456 TUN/TAP device ovpnc21 exists previously, keep at program end
                          Mar 18 15:09:03 openvpn 38456 Incoming Data Channel: Using 512 bit message hash 'SHA512' for HMAC authentication
                          Mar 18 15:09:03 openvpn 38456 Incoming Data Channel: Cipher 'AES-256-CBC' initialized with 256 bit key
                          Mar 18 15:09:03 openvpn 38456 Outgoing Data Channel: Using 512 bit message hash 'SHA512' for HMAC authentication
                          Mar 18 15:09:03 openvpn 38456 Outgoing Data Channel: Cipher 'AES-256-CBC' initialized with 256 bit key
                          Mar 18 15:09:03 openvpn 38456 Using peer cipher 'AES-256-CBC'
                          Mar 18 15:09:03 openvpn 38456 OPTIONS IMPORT: adjusting link_mtu to 1629
                          Mar 18 15:09:03 openvpn 38456 OPTIONS IMPORT: peer-id set
                          Mar 18 15:09:03 openvpn 38456 OPTIONS IMPORT: --ifconfig/up options modified
                          Mar 18 15:09:03 openvpn 38456 OPTIONS IMPORT: compression parms modified
                          Mar 18 15:09:03 openvpn 38456 OPTIONS IMPORT: timers and/or timeouts modified
                          Mar 18 15:09:03 openvpn 38456 Options error: option 'route' cannot be used in this context ([PUSH-OPTIONS])
                          Mar 18 15:09:03 openvpn 38456 Options error: option 'dhcp-option' cannot be used in this context ([PUSH-OPTIONS])
                          Mar 18 15:09:03 openvpn 38456 Options error: option 'redirect-gateway' cannot be used in this context ([PUSH-OPTIONS])
                          Mar 18 15:09:03 openvpn 38456 PUSH: Received control message: 'PUSH_REPLY,redirect-gateway def1,dhcp-option DNS <REDACTED>,comp-lzo no,route <REDACTED>,topology net30,ping 10,ping-restart 60,ifconfig 10.145.0.82 10.145.0.81,peer-id 19'
                          Mar 18 15:09:03 openvpn 38456 SENT CONTROL [Server-4042-1a]: 'PUSH_REQUEST' (status=1)
                          Mar 18 15:09:02 openvpn 38456 [Server-4042-1a] Peer Connection Initiated with [AF_INET]<REDACTED>:1195
                          Mar 18 15:09:02 openvpn 38456 Control Channel: TLSv1.3, cipher TLSv1.3 TLS_AES_256_GCM_SHA384, 2048 bit RSA
                          Mar 18 15:09:02 openvpn 38456 VERIFY OK: depth=0, C=VG, ST=BVI, O=MyVPN, OU=MyVPN, CN=Server-4042-1a, emailAddress=support@<REDACTED>.com
                          Mar 18 15:09:02 openvpn 38456 VERIFY X509NAME OK: C=VG, ST=BVI, O=MyVPN, OU=MyVPN, CN=Server-4042-1a, emailAddress=support@<REDACTED>.com
                          Mar 18 15:09:02 openvpn 38456 VERIFY OK: nsCertType=SERVER
                          Mar 18 15:09:02 openvpn 38456 VERIFY OK: depth=1, C=VG, ST=BVI, O=MyVPN, OU=MyVPN, CN=MyVPN CA, emailAddress=support@<REDACTED>.com
                          Mar 18 15:09:02 openvpn 38456 VERIFY WARNING: depth=1, unable to get certificate CRL: C=VG, ST=BVI, O=MyVPN, OU=MyVPN, CN=MyVPN CA, emailAddress=support@<REDACTED>.com
                          Mar 18 15:09:02 openvpn 38456 VERIFY WARNING: depth=0, unable to get certificate CRL: C=VG, ST=BVI, O=MyVPN, OU=MyVPN, CN=Server-4042-1a, emailAddress=support@<REDACTED>.com
                          Mar 18 15:09:02 openvpn 38456 WARNING: this configuration may cache passwords in memory -- use the auth-nocache option to prevent this
                          Mar 18 15:09:02 openvpn 38456 TLS: Initial packet from [AF_INET]<REDACTED>:1195, sid=66de6eb3 9b1e2179
                          Mar 18 15:09:02 openvpn 38456 UDPv4 link remote: [AF_INET]<REDACTED>:1195
                          Mar 18 15:09:02 openvpn 38456 UDPv4 link local (bound): [AF_INET]<REDACTED>:0
                          Mar 18 15:09:02 openvpn 38456 Socket Buffers: R=[42080->524288] S=[57344->524288]
                          Mar 18 15:09:02 openvpn 38456 TCP/UDP: Preserving recently used remote address: [AF_INET]<REDACTED>:1195
                          Mar 18 15:09:02 openvpn 38456 Incoming Control Channel Authentication: Using 512 bit message hash 'SHA512' for HMAC authentication
                          Mar 18 15:09:02 openvpn 38456 Outgoing Control Channel Authentication: Using 512 bit message hash 'SHA512' for HMAC authentication
                          Mar 18 15:09:02 openvpn 38456 WARNING: experimental option --capath /var/etc/openvpn/client21/ca
                          Mar 18 15:09:02 openvpn 38456 NOTE: the current --script-security setting may allow this configuration to call user-defined scripts
                          Mar 18 15:09:02 openvpn 38456 WARNING: --ns-cert-type is DEPRECATED. Use --remote-cert-tls instead.
                          Mar 18 15:09:02 openvpn 38456 MANAGEMENT: unix domain socket listening on /var/etc/openvpn/client21/sock
                          Mar 18 15:09:02 openvpn 38326 library versions: OpenSSL 1.1.1i-freebsd 8 Dec 2020, LZO 2.10
                          Mar 18 15:09:02 openvpn 38326 OpenVPN 2.5.0 amd64-portbld-freebsd12.2 [SSL (OpenSSL)] [LZO] [LZ4] [MH/RECVDA] [AEAD] built on Feb 5 2021
                          Mar 18 15:09:02 openvpn 38326 WARNING: file '/var/etc/openvpn/client21/up' is group or others accessible
                          Mar 18 15:09:02 openvpn 38326 WARNING: Compression for receiving enabled. Compression has been used in the past to break encryption. Sent packets are not compressed unless "allow-compression yes" is also set.
                          Mar 18 15:09:02 openvpn 38326 WARNING: Compression for receiving enabled. Compression has been used in the past to break encryption. Sent packets are not compressed unless "allow-compression yes" is also set.

                          1 Reply Last reply Reply Quote 0
                          • B Offline
                            bod
                            last edited by bod

                            As I understand it... the patch is for the "No Pull" option only. OpenVPN>Tunnel Settings>Don't Pull Routes.

                            If you only want one device to access the tunnel then apply patch and ensure the box is ticked. Personally, I would never want that option disabled. I would rather specify using firewall rules which device was routed to the VPN.

                            I notice in both your configs you have PULL enabled?

                            Sorry if I'm mis-understanding this - I'm no expert on PfSense.

                            G 1 Reply Last reply Reply Quote 0
                            • G Offline
                              guido666 @bod
                              last edited by

                              @bod That's how ExpressVPN specified it. This has all been working fine for years for me, and now, after upgrading to v2.5 and without changing any other settings, it's completely broken. The gateway shows down, with 100% packet loss. Something internally isn't getting data through the tunnel.

                              I even upgraded to the v2.5.1-RC, to see if that contained more fixes similar to the patch mentioned above that might restore operation, but it doesn't. I'm no OpenVPN guru, so I'm hoping someone who is might have an idea. Thanks!

                              B 1 Reply Last reply Reply Quote 0
                              • B Offline
                                bcruze @guido666
                                last edited by

                                @guido666 said in v21.02 Broke all ExpressVPN Gateways:

                                @bod That's how ExpressVPN specified it. This has all been working fine for years for me, and now, after upgrading to v2.5 and without changing any other settings, it's completely broken. The gateway shows down, with 100% packet loss. Something internally isn't getting data through the tunnel.

                                I even upgraded to the v2.5.1-RC, to see if that contained more fixes similar to the patch mentioned above that might restore operation, but it doesn't. I'm no OpenVPN guru, so I'm hoping someone who is might have an idea. Thanks!

                                https://openvpn.net/community-downloads/

                                IMPORTANT NOTICES
                                BF-CBC CIPHER IS NO LONGER THE DEFAULT
                                Cipher handling for the data channel cipher has been significantly changed between OpenVPN 2.3/2.4 and v2.5, most notably there are no “default cipher BF-CBC” anymore because it is no longer considered a reasonable default. BF-CBC is still available, but it needs to be explicitly configured now.
                                For connections between OpenVPN 2.4 and v2.5 clients and servers, both ends will be able to negotiate a better cipher than BF-CBC. By default they will select one of the AES-GCM ciphers, but this can be influenced using the –data-ciphers setting.
                                Connections between OpenVPN 2.3 and v2.5 that have no –cipher setting in the config (= defaulting to BF-CBC and not being negotiation-capable) must be updated. Unless BF-CBC is included in –data-ciphers or there is a “–cipher BF-CBC” in the OpenVPN 2.5 config, a v2.5 client or server will refuse to talk to a v2.3 server or client, because it has no common data channel cipher and negotiating a cipher is not possible. Generally, we recommend upgrading such setups to OpenVPN 2.4 or v2.5. If upgrading is not possible we recommend adding data-ciphers AES-256-GCM:AES-128-GCM:AES-128-CBC (for v2.5+) or cipher AES-128-CBC (v2.4.x and older) to the configuration of all clients and servers.
                                If you really need to use an unsupported OpenVPN 2.3 (or even older) release and need to stay on BF-CBC (not recommended), the OpenVPN 2.5 based client will need a config file change to re-enable BF-CBC. But be warned that BF-CBC and other related weak ciphers will be removed in coming OpenVPN major releases.
                                For full details see the”Data channel cipher negotiation” section on the man page.
                                CONNECTIVITY TO SOME VPN SERVICE PROVIDER MAY BREAK
                                Connecting with an OpenVPN 2.5 client to at least one commercial VPN service that
                                implemented their own cipher negotiation method that always reports back that it is using BF-CBC to the client is broken in v2.5. This has always caused warning about mismatch ciphers. We have been in contact with some service providers and they are looking into it. This is not something the OpenVPN community can fix. If your commercial VPN does not work with a v2.5 client, complain to the VPN service provider.

                                G 1 Reply Last reply Reply Quote 0
                                • G Offline
                                  guido666 @bcruze
                                  last edited by

                                  @bcruze You can tell from something in my logs that this is the problem? Can you help me understand what's going on?

                                  B 1 Reply Last reply Reply Quote 0
                                  • B Offline
                                    bcruze @guido666
                                    last edited by

                                    @guido666 said in v21.02 Broke all ExpressVPN Gateways:

                                    @bcruze You can tell from something in my logs that this is the problem? Can you help me understand what's going on?

                                    i was having the SAME exact issue with 2 other providers. i wrote them both and told them my scenario, i had just updated to openvpn 2.5 (Pfsense 21.02)and now the tunnels do not work. i also asked them if any of their servers had open vpn2.5. one gave me 5 servers... they all immediately connected and worked even after restarting the tunnel or rebooting the Pfense router.
                                    less that 24 hours after that email this was posted on their Blog:

                                    We have upgraded all our OpenVPN servers to OpenVPN 2.5
                                    4 February 2021. ALL of my original servers worked after that!

                                    the other provider i canceled the rest of my plan as they never replied back

                                    i encourage you to write your provider and see if any of their servers are running the latest openvpn

                                    1 Reply Last reply Reply Quote 0
                                    • G Offline
                                      guido666 @thaddeusf
                                      last edited by guido666

                                      @thaddeusf I think I may have come across something. I reinstalled back to pfSense 2.4.5-P1, and restored my config from 2.5.0, because I had made some other changes I was hoping to try to keep. OpenVPN didn't work. I started looking at logs, and noticed some "cipher" errors.

                                      Long story short: I think that during the upgrade 2.4.5-P1 -> 2.5.0, pfSense changed the cipher settings for all the VPN connections!

                                      From the ExpressVPN guide (google it... these forums won't let me post a link):

                                      • Encryption Algorithm: In the text editor you opened earlier, look for the word “cipher.” Select the algorithm shown after “cipher” in the dropdown menu. For example: AES-256-CBC.
                                      • Enable NCP: Uncheck this box.
                                      • NCP Algorithms: Leave blank.

                                      Looking at my post-2.5.0 upgrade config XML, it contains these for all my OpenVPN client entries...
                                      ...
                                      <data_ciphers_fallback>AES-256-CBC</data_ciphers_fallback>
                                      ...
                                      <data_ciphers>AES-128-GCM,AES-256-CBC</data_ciphers>
                                      <ncp_enable>enabled</ncp_enable>
                                      ...

                                      So NCP is enabled now? Why? My config backups pre-2.5.0 are missing the <crypto>AES-256-CBC</crypto> line altogether. Looking at my old config backups, the v19.1 backup (17Oct2020) has the <crypto>AES-256-CBC line, but the v21.4 backup (3Mar2021) does not.

                                      When I open the entries in pfSense's however, it's incorrectly showing as AES-128-CBC in the box, and yes, NCP is enabled.

                                      pfSenseOpenVPNWrongCipher.png

                                      If I manually set the Encyption Algorithm back to AES-256-CBC, and uncheck Enable Negotiable Cryptographic Parameters again, then it connects again. I'm able to pass traffic, it seems.

                                      Strangely, even though traffic seems to be flowing through the VPN gateway (e.g. "What's my IP?" shows the VPN external IP), the Status > Gateways still shows "Offline - 100% loss".

                                      G 1 Reply Last reply Reply Quote 0
                                      • G Offline
                                        guido666 @guido666
                                        last edited by

                                        I just tried re-upgrading to 2.5.0, using the fixed VPN crypto settings, and it again changes the crypto settings to something else (that would not work). After fixing them, the VPN tunnel connects again, but I still can't pass traffic. Working on that now.

                                        Also, it keeps disabling the hardware crypto offloading, too.

                                        pfSenseOpenVPNWrongCipher2.png

                                        B 1 Reply Last reply Reply Quote 0
                                        • B Offline
                                          bcruze @guido666
                                          last edited by

                                          @guido666 said in v21.02 Broke all ExpressVPN Gateways:

                                          I just tried re-upgrading to 2.5.0, using the fixed VPN crypto settings, and it again changes the crypto settings to something else (that would not work). After fixing them, the VPN tunnel connects again, but I still can't pass traffic. Working on that now.

                                          Also, it keeps disabling the hardware crypto offloading, too.

                                          pfSenseOpenVPNWrongCipher2.png

                                          i have started to have some weird things going on.
                                          i have been manually stopping tunnels, making a change or two and clicking start and its doing the no data thing again.

                                          but try this... when do data is flowing. login to Pfense click status > then filter reload > reload filter. after 15 seconds data starts flowing for me!

                                          B 1 Reply Last reply Reply Quote 0
                                          • B Offline
                                            bcruze @bcruze
                                            last edited by bcruze

                                            i have started to have some weird things going on. i can't decided to stick with GCM or Cha1305 ultimately
                                            i have been manually stopping tunnels, making a change or two (saving)and clicking start and its doing the no data thing again.
                                            but try this... when no data is flowing. login to Pfense click status > then filter reload > reload filter. after 15 seconds data starts flowing for me!

                                            i will also note under system > misc > skip rules when gateway down IS checked

                                            GertjanG 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post
                                            Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.