Wireguard command line tools for Android

boerner at t-online.de boerner at t-online.de
Tue Aug 6 09:17:55 CEST 2019


Hi David,
Thanks for your elaborate answer!

Yes, your assumption is right - my clients connect to a URL that resolves to an internal address when inside my local LAN. The idea was to keep traffic internal whenever possible. 
I have now followed your suggestion and have my VPN URL always resolved to the external IP address so the address won't change when leaving/entering  the local network.
For me, this solves a part of my issue but not all of it. 
My router is assigned a new external address (both IPv4 and IPv6) every 24 h, and obviously this invalidates the public IP adresses known by the server and the client simultaneously, as they are identical for the clients connected to the local network. That makes the handshake fail, and "wg" on the server shows that it is still looking for its endpoints at the old address. The same is true for the clients.
Disconnecting/reconnecting the clients fixes the tunnel until the next address change, because then Wireguard looks for the DNS record instead of using its stored address information. I think it would be a good feature if Wireguard could refresh its endpoint addresses automatically when an endpoint is not reachable anymore.

How does it work on your side? Have you a constant external IP address?

Thomas


Am Montag, 5. August 2019, 23:28:41 CEST schrieb David Kerr:


I assume you have set the client configs to connect to something like "vpn.example.com[1]:<port>" . How does DNS resolve this when inside your local LAN?  Does it resolve to the same public IP address that your DSL router is connected to, or does it resolve to an internal address like 192.168.1.1?


The way I have this working is to ensure that my VPN URL always resolves to the external IP address, even when I am inside my home network.  To do that I had to update my DNS server configuration to make sure that my VPN URL is always resolved by an external DNS provider... I have my own custom network gateway/router and set dnsmasq.static to include the line...


server=/vpn.example.com/8.8.8.8[2]



Now this works for me because my wireguard server is running on my custom gateway/router... no NAT forwarding to an internal host running wireguard.  If you are running wireguard on an internal server then you also need to make sure that your firewall rules don't block connections to your external interface from your local LAN and do the right NATing -- which is probably not permitted by default.  I forget how to do this, but I'm sure google will find some instructions.


David









On Mon, Aug 5, 2019 at 2:57 PM <boerner at t-online.de[3]> wrote:


Hey all,

I've recently set up my private VPN with Wireguard. I am running my local server behind a DSL router with a variable public IP address, accessible via dyndns and NAT, and several mobile clients (Android, Notebooks). Everything is working fine so far, except of one issue that I would like discuss here: Roaming doesn't work reliably when a device leaves or re-enters the home LAN, nor when the public IP address is changed by my ISP. The reason seems clear to me: In these cases both peers change their IP address simultaneously whereas the Wireguard protocol relies on only one address changing at a time.

My approach would be to shut down Wireguard on the clients as long as they are connected to their home network locally and to bring up the tunnel only when they leave the home network. Besides the roaming issue it  would be desirable to use the local connection when it is available rather than to take the detour over the internet. And it  should be done automatically so users need not remember to switch on/off VPN all the time.My idea was to use Tasker to perform something like wg-quick up|down tun1 accordingly, but the Wireguard command line tools wg and wg-quick don't seem to be available (anymore). In older forum posts I've seen that you can install them from the app settings, but in my version (v0.0.20190708) this option is not available.

Does anybody know about another solution? Or, as a question to the developers, would it be a big deal to bring back the command line feature?

Thanks, Tom




_______________________________________________WireGuard mailing list

WireGuard at lists.zx2c4.com[4]
https://lists.zx2c4.com/mailman/listinfo/wireguard[5]




--------
[1] http://vpn.example.com
[2] http://vpn.example.com/8.8.8.8
[3] mailto:boerner at t-online.de
[4] mailto:WireGuard at lists.zx2c4.com
[5] https://lists.zx2c4.com/mailman/listinfo/wireguard
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.zx2c4.com/pipermail/wireguard/attachments/20190806/e15abe0c/attachment-0001.html>


More information about the WireGuard mailing list