summaryrefslogtreecommitdiff
path: root/pages/about-us
diff options
context:
space:
mode:
Diffstat (limited to 'pages/about-us')
-rw-r--r--pages/about-us/news/2020/wireguard.md95
1 files changed, 48 insertions, 47 deletions
diff --git a/pages/about-us/news/2020/wireguard.md b/pages/about-us/news/2020/wireguard.md
index 6aee166..4fb0b8d 100644
--- a/pages/about-us/news/2020/wireguard.md
+++ b/pages/about-us/news/2020/wireguard.md
@@ -4,69 +4,70 @@
@more = true
@preview_image = '/img/pages/wireguard.png'
-Our VPN is built on top of [OpenVPN](https://openvpn.net/), a well tested and
-widely used technology that has been around for almost two decades. As most
-software with enough history it has grown with a lot of features and code
-complexity. This is great as it has everything that we need to provide a stable
-service, but at the same time it brings now and then security issues. The
+Our VPN is built on top of [OpenVPN](https://openvpn.net/), a well tested and
+widely used technology that has been around for almost two decades. As most
+software with enough history it has grown with a lot of features and code
+complexity. This is great as it has everything that we need to provide a stable
+service, but at the same time it brings now and then security issues. The
OpenVPN team has been really good at handling them in a timely manner and in
-LEAP we've been lucky to have designed our VPN in a way that prevented us from
+LEAP we've been lucky to have designed our VPN in a way that prevented us from
being affected by most of the ones that have appeared in the last years.
-Since a few years there is a newcomer to the free software VPNs:
-[WireGuard](https://wireguard.com/). WireGuard uses nice modern cryptography
-primitives, a pretty simple protocol and has a small code base. This makes it a very
-fast VPN and probably less prone to security issues.
+Since a few years there is a newcomer to the free software VPNs:
+[WireGuard](https://wireguard.com/). WireGuard uses nice modern cryptography
+primitives, a pretty simple protocol and has a small code base. This makes it a
+very fast VPN and probably less prone to security issues.
-If WireGuard is so great why don't we ditch OpenVPN and use WireGuard instead?
-WireGuard is great, but (yes, there is always a "but") it wasn't designed for
+If WireGuard is so great why don't we ditch OpenVPN and use WireGuard instead?
+WireGuard is great, but (yes, there is always a "but") it wasn't designed for
our use cases and it is not trivial to make it work for us.
-WireGuard uses UDP, which is great for speed. But many of our users are in
-networks that don't allow UDP traffic and for them to be able to connect we need
-the VPN to support TCP. We are currently using OpenVPN on TCP mode, but our plan
-for the future is to dynamically use UDP if available and if not to fall back to
-TCP.
+WireGuard uses UDP, which is great for speed. But many of our users are in
+networks that don't allow UDP traffic and for them to be able to connect we
+need the VPN to support TCP. We are currently using OpenVPN on TCP mode, but
+our plan for the future is to dynamically use UDP if available and if not to
+fall back to TCP.
-Some time ago there was a discussion about [TCP support in the wireguard mailing
-list](https://lists.zx2c4.com/pipermail/wireguard/2018-March/002496.html), with
-proposed solutions like using
-[ssf](https://github.com/securesocketfunneling/ssf),
-[socat](http://www.dest-unreach.org/socat/) or
+Some time ago there was a discussion about [TCP support in the wireguard
+mailing
+list](https://lists.zx2c4.com/pipermail/wireguard/2018-March/002496.html), with
+proposed solutions like using
+[ssf](https://github.com/securesocketfunneling/ssf),
+[socat](http://www.dest-unreach.org/socat/) or
[udptunnel](http://www1.cs.columbia.edu/~lennox/udptunnel/). All of them sound
a bit hacky, one extra moving piece that can break.
-Another problem is that WireGuard doesn't provide dynamic IP allocation. We
-don't know in advance who will be connected to assign static IPs to each client.
-We rely on OpenVPN to do it dynamically each time a client connects. In WireGuard
-we would need to build some tooling around to do all this IP assignment without
-the service operators getting the possibility to correlate users and clients to
-IPs.
+Another problem is that WireGuard doesn't provide dynamic IP allocation. We
+don't know in advance who will be connected to assign static IPs to each
+client. We rely on OpenVPN to do it dynamically each time a client connects.
+In WireGuard we would need to build some tooling around to do all this IP
+assignment without the service operators getting the possibility to correlate
+users and clients to IPs.
-Besides all these technical issues there is a security issue, the authentication
-protocol of WireGuard is not Forward Secret. That means an observer recording
-all conversations only need to wait until the server long term secret key gets
-compromised to be able to figure out which client produced each connection. Let
-me remark, this doesn't mean that the attacker can decrypt the traffic, they
-only see the authentication key, so they can pinpoint a client being the same in
-different connections.
+Besides all these technical issues there is a security issue, the
+authentication protocol of WireGuard is not Forward Secret. That means an
+observer recording all conversations only need to wait until the server long
+term secret key gets compromised to be able to figure out which client produced
+each connection. Let me remark, this doesn't mean that the attacker can decrypt
+the traffic, they only see the authentication key, so they can pinpoint a
+client being the same in different connections.
-While this is a flaw, it is clearly an improvement over TLS 1.2 with client
-certificates, which we are currently using with OpenVPN. Previously to TLS 1.3
-(the latest version) if you authenticate the clients using a cert, which we use
-to avoid having a list of users, the cert is sent unencrypted. That means that
-currently an observer does not even need a compromised server private key to
-track the users. We do minimize that by rotating the cert frequently and we are
-preparing a migration to TLS 1.3, that solves this problem by transferring the
+While this is a flaw, it is clearly an improvement over TLS 1.2 with client
+certificates, which we are currently using with OpenVPN. Previously to TLS 1.3
+(the latest version) if you authenticate the clients using a cert, which we use
+to avoid having a list of users, the cert is sent unencrypted. That means that
+currently an observer does not even need a compromised server private key to
+track the users. We do minimize that by rotating the cert frequently and we are
+preparing a migration to TLS 1.3, that solves this problem by transferring the
cert over a forward secret channel.
-The dynamic IP allocation and the lack of forward secrecy for client identifiers
-are being worked on in a separate tool named
-[wg-dynamic](https://git.zx2c4.com/wg-dynamic/about/docs/idea.md) which
-does handle the IP allocation and rotates the client identifier. So maybe in the
+The dynamic IP allocation and the lack of forward secrecy for client
+identifiers are being worked on in a separate tool named
+[wg-dynamic](https://git.zx2c4.com/wg-dynamic/about/docs/idea.md) which does
+handle the IP allocation and rotates the client identifier. So maybe in the
future those will be solved when wg-dynamic becomes more mature.
Right now for us adopting WireGuard would require a lot of development work to
-get around those issues and to get a new technology stable enough to be used in
+get around those issues and to get a new technology stable enough to be used in
production. We already have our hands full maintaining the existing service and
prefer to prioritize our energies on providing a more stable and smooth VPN.