After upgrading my system to FreeBSD 14.0 I have decided to try WireGuard. I have never used it before and even after reading `wg(8)' I didn't really know how to make it work. After reading few articles I have found about `wg-quick(8)' that made the whole setup a bit simpler.
WireGuard is now part of the FreeBSD kernel so there is no need to install it manually. The only thing I have installed is `wireguard-tools' to get `wg-quick'.
pkg install wireguard-tools
You need to get a WireGuard INI-like config file from your provider. See the example below from the `wg(8)' man pages.
,----
| [Interface]
| PrivateKey = yAnz5TF+lXXJte14tji3zlMNq+hd2rYUIgJBgB3fBmk=
| ListenPort = 51820
|
| [Peer]
| PublicKey = xTIBA5rboUvnH4htodjb6e697QjLERt1NAB4mZqp8Dg=
| Endpoint = 192.95.5.67:1234
| AllowedIPs = 10.192.122.3/32, 10.192.124.1/24
`----
Next we need to generate public and private key for our machine. I have created `/etc/wireguard/' directory and run the following as a root user:
umask 077 wg genkey | tee private.key | wg pubkey > public.key
WireGuard protects these files by enforcing that only root should be able read them. This is why we run `umask' first.
You can move your config file to `/etc/wireguard/'. This is the default directory that `wg-quick' uses to find config files.
You can start WireGuard by providing path to the config file:
wg-quick up /etc/wireguard/sample.conf
or provide just the config name if it's inside `/etc/wireguard/'.
wg-quick up sample
You can disable it with `wg-quick down sample' and see running connections with `wg'.