IPSec configuration for EdgeOS. Handles dynamic updating
After updating to EdgeOS 1.9.x we noticed that our IPSec tunnels were no longer working. After
troubleshooting we discovered that using hostnames in the site-to-site ipsec tunnel configuration
was resulting in a no shared key found
error as it could not match the PSK with the remote as the id came back as (null)
4[IKE] no shared key found for 'xxxxx.yyy.zzz'[1.1.1.1] - '(null)'[2.2.2.2]
The following script + cron job will automatically monitor your ipsec configuration and keep it in sync with DNS hsotnames as things change.
Combined with the DynDNS service built into EdgeOS you can automatically reconfigure things if you encoutner an IP change
- strongswan_setup_cli.sh: uses internal CLI commands to tear down and re-setup tunnels
- strongswan_setup_files.sh: manually generates ipsec configuration files
- strongswan_setup.sh: path that is executed by cron job. Should sym link to _cli.sh or _files.sh
strongswan_cron.sh will install a cron job at boot that will execute the strongswan_setup.sh command every minute and log to /var/log/strongswan_setup.log
If changes are detected the ipsec configuration will be updated and the service restarted
- Copy the contents of this repo to /config/scripts/ on your EdgeOS installation. Hierarchy should look like:
-
/config/scripts/post-config.d/strongswan_cron.sh
-
/config/scripts/strongswan/strongswan_setup_cli.sh
-
...
-
Edit the strongswan_setup.conf file to input your local and remote info
-
Execute the following to initially kick things off and persist through reboots
# install the cron job to start executing strongswan_setup.sh
cd /config/scripts/post-config.d/strongswan_cron.sh