I found this great tutorial on how to set up a VPN Server on your Mac, in my case a Mac Mini that I have running 24/7 for Plex, without paying $20 for OS X Server.
I successfully did it running regular OS X Yosemite 10.10.5.
The tutorial was a bit short in a few areas though so I’ll elaborate a bit:
Forward these ports in your router to your Mac:
This is not really a password, but it kinda is anyway. Just run this Terminal command and replace SHARED-SECRET-PHASE with what you want. Maybe even a long sentence?
sudo security add-generic-password -a com.apple.ppp.l2tp -s com.apple.net.racoon -T /usr/sbin/racoon -p "SHARED-SECRET-PHRASE" /Library/Keychains/System.keychain
Download and save this file somewhere, and unzip. In it you will find com.apple.RemoteAccessServers.plist
, modify it:
You need to modify the following lines with your own information:
Lines 19-20 under “OfferedServerAddresses”
These two lines should be changed to the DNS domains you want your VPN clients to use. In this example, I’m providing my local router (10.0.1.1) and a Google DNS domain as a secondary (8.8.4.4).
Lines 29-30 under “DestAddressRanges”
These two lines specify the start and end IP address range that will be given to clients when they login. In this example, my clients are given an IP address between 10.0.1.250 and 10.0.1.254. Ideally, you should choose a range that is outside of the range that your router will assign so that you avoid IP address conflicts. For example, my router is configured with a DHCP range of 10.0.1.2 to 10.0.249.
After modifying the file with your settings, run these commands:
sudo chmod 644 com.apple.RemoteAccessServers.plist
sudo chown root:wheel com.apple.RemoteAccessServers.plist
sudo cp com.apple.RemoteAccessServers.plist /Library/Preferences/SystemConfiguration/com.apple.RemoteAccessServers.plist
Run sudo nano /Library/LaunchDaemons/com.apple.ppp.l2tp.plist
and paste this in:
<?xml version=”1.0″ encoding=”UTF-8″?>
<!DOCTYPE plist PUBLIC “-//Apple//DTD PLIST 1.0//EN”
“http://www.apple.com/DTDs/PropertyList-1.0.dtd“>
<plist version=”1.0″>
<dict>
<key>Label</key>
<string>com.apple.ppp.l2tp</string>
<key>ProgramArguments</key>
<array>
<string>/usr/sbin/vpnd</string>
<string>-x</string>
<string>-i</string>
<string>com.apple.ppp.l2tp</string>
</array>
<key>OnDemand</key>
<false/>
</dict>
</plist>
Hit CTRL X, Y and Enter to save.
Finally, to start it, use this command:
sudo launchctl load -w /Library/LaunchDaemons/com.apple.ppp.l2tp.plist
Note that this will also make it run on reboot.
On iPhone you will find VPN settings in Settings > General > VPN. Use these settings for new configuration:
After that, just enable it, try disconnecting from your wifi, and boom!