Share OSX VPN with your Pi

I have a raspberry Pi that I wanted to connect to my office network for running a test. Rather than setting up a complete VPN connection on the Pi for just a one-off test, much better if the Pi shares the VPN connection from my MacBook.

Getting your MacBook to share its VPN connection is actually not difficult. First enable forwarding:

$ sudo sysctl -w net.inet.ip.forwarding=1

Next create a file called nat-rules with the following content:

nat on ppp0 from en0:network to any -> (ppp0)

Note that my VPN runs on device ppp0 and my MacBook is connected to my local network on device en0. Change these to suit your situation.

Now clear your MacBook’s existing firewall rules (if you have any probably create a backup first!):

$ sudo pfctl -d # disable pf
$ sudo pfctl -F all # clear all rules

Now load the new rule you created earlier:

$ sudo pfctl -f ./nat-rules -e

Now your MacBook is set up to share its VPN connection. On your Pi (or any other device you want to give access to your VPN) add the appropriate route:

$ sudo ip route add via

Here my office uses IPs in the range while my MacBook has IP on my local network.

To turn VPN sharing off, you can simply disable forwarding and flush pf as follows:

$ sudo sysctl -w net.inet.ip.forwarding=0
$ sudo pfctl -d

For more info about pf see the pf manual.



Get the Medium app

A button that says 'Download on the App Store', and if clicked it will lead you to the iOS App store
A button that says 'Get it on, Google Play', and if clicked it will lead you to the Google Play store