Cloudflare WARP-to-WARP is an overlay network just like ZeroTier and Tailscale but instead of peer-to-peer, you connect to the nearest Cloudflare PoP using WireGuard.
Because Cloudflare WARP uses WireGuard, we can run Cloudflare WARP on MikroTik and port forward on our virtual network at Cloudflare.
Cloudflare Zero Trust settings
Cloudflare WARP-to-WARP
- Go to Settings, and Network.
- Enable Proxy.
- Check UDP and ICMP.
- Enable WARP to WARP.
Let Cloudflare assign the WARP-to-WARP IPv4 range to devices
Instead of getting the same IP address of 172.16.0.2
to every device, we instead enable “Override local interface IP” so that devices get their own unique IP from 100.96.0.0/12
.
- Go to Settings, and WARP Client.
- Enable Override local interface IP.
Configure Split Tunneling
This allows Cloudflare WARP-to-WARP traffic to pass though the WireGuard instead of getting handled as local traffic.
- Go to Settings, and WARP Client.
- Click Default profile, and configure.
- Make sure split tunnels is set to Exclude IPs and domains.
- Click “Manage” on Split Tunnels.
- Remove IP range
100.64.0.0/10
andfd00::/8
.
Generate Cloudflare Zero Trust WireGuard configuration
- Download wgcf-teams.
- Open wgcf-teams.
wgcf-teams
- On your browser, open
https://<YOUR_ORGANIZATION>.cloudflareaccess.com/warp
. - Login to Cloudflare Zero Trust on your browser.
- After logging in to Cloudflare Zero Trust, get your JWT token using this guide.
- Paste the JWT token on the command prompt that is opened by wgcf-teams and press enter.
The program will output a WireGuard configuration like this:
|
|
Setup MikroTik Cloudflare WARP WireGuard
- Add a new WireGuard interface.
/interface wireguard add mtu=1420 name=Cloudflare-WARP private-key="your_private_key"
- Add WireGuard peer to connect to Cloudflare WARP. For Zero Trust,
162.159.193.1
should be the endpoint.1 Persistent keepalive is enabled so that the tunnel will not timeout when not in use./interface wireguard peers add allowed-address=0.0.0.0/0,::/0 endpoint-address=162.159.193.1 endpoint-port=2408 interface=Cloudflare-WARP persistent-keepalive=2m public-key="bmXOC+F1FxEMF9dyiK2H5/1SUtzH0JuVo51h2wPfgyo="
Setup IPv4
- Add Cloudflare WARP’s IPv4 address to the WireGuard interface. Replace
/32
subnet to/12
so that a dynamic IPv4 route will automatically be created./ip address add address=100.96.0.1/12 interface=Cloudflare-WARP
- Enable NAT44. The
to-address
should be set to the IPv4 address of the WireGuard interface./ip firewall nat add action=src-nat chain=srcnat out-interface=Cloudflare-WARP to-addresses=100.96.0.1
IPv4 port forwarding example
The dst-address
should be set to the IPv4 address of the WireGuard interface.
To port forward TCP port 8080
of 192.168.1.2
:
|
|
Setup IPv6
If you already have native IPv6, you probably don’t need to set this up. If you don’t have native IPv6, this allows you to get IPv6 connectivity to your devices.
It is recommended to just set a static IPv6 address to every device that needs IPv6 port forwarding instead of relying on SLAAC so that the IPv6 address for port forwarding does not change.
- Add Cloudflare WARP’s IPv6 address to the WireGuard interface.
/ipv6 address add address=2606:4700:110:8ced:11b5:d064:abc:ee89/128 interface=Cloudflare-WARP
- Add IPv6 ULA to your LAN interface. Make sure the prefix you chose does not conflict with the Cloudflare WARP-to-WARP IPv6 range.
/ipv6 address add address=fd00:1234:5678:9abc::/64 advertise=no interface=bridge
- Enable NAT66. Yes, I know NAT is bad, awful when we are talking about IPv6, but since Cloudflare WARP only provides a single IPv6 address, it’s necessary to use NAT in IPv6. The
to-address
should be set to the IPv6 address of the WireGuard interface./ipv6 firewall nat add action=src-nat chain=srcnat out-interface=Cloudflare-WARP to-address=2606:4700:110:8b7b:2edb:5201:dddd:19fd/128
- Add an IPv6 route. If you have native IPv6 connectivity, use Cloudflare WARP-to-WARP IPv6 range
fd00::/8
, if you don’t have native IPv6, use::/0
./ipv6 route add dst-address=::/0 gateway=Cloudflare-WARP
- Allow the IPv6 firewall to accept packets that are port forwarded. (Optional if you want to port forward on IPv6.)
/ipv6 firewall filter set [find action=drop chain=forward in-interface-list="!LAN"] comment="defconf: drop everything else not coming from LAN not DSTNATed" connection-nat-state=!dstnat
IPv6 port forwarding example
The dst-address
should be set to the IPv6 address of the WireGuard interface.
To port forward TCP port 8080
of fd00:1234:5678:9abc::1
:
|
|
Test port forwarding
Check your MikroTik router’s IP address on the Cloudflare virtual network
- Go to My Team, and Devices.
- Select the device name besides the email that you used for your MikroTik router.
For this example, the IP addresses are 100.96.0.1
and fd10:ec7e:5e94::1
On your device outside of your LAN
- Download Cloudflare WARP on your device.
- Login to Cloudflare Zero Trust.
- Turn on Cloudflare Zero Trust.
- Try to ping and access the server that is port forwarded at
100.96.0.1
andfd10:ec7e:5e94::1
.
DNS hostnames
If you own a domain name, you can use a subdomain that is pointed at 100.96.0.1
and fd10:ec7e:5e94::1
since the IP allocation on the Cloudflare virtual network is static.