diff options
Diffstat (limited to 'src/etc/rc.newipsecdns')
-rwxr-xr-x | src/etc/rc.newipsecdns | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/src/etc/rc.newipsecdns b/src/etc/rc.newipsecdns new file mode 100755 index 0000000..7c5428a --- /dev/null +++ b/src/etc/rc.newipsecdns @@ -0,0 +1,61 @@ +#!/usr/local/bin/php-cgi -f +<?php +/* + rc.newipsecdns + part of m0n0wall (http://m0n0.ch/wall) + + Copyright (C) 2007 Manuel Kasper <mk@neon1.net>. + Copyright (C) 2009 Seth Mos <seth.mos@dds.nl>. + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + 1. Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + + 2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, + INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY + AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE + AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, + OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. +*/ + +/* parse the configuration and include all functions used below */ +require_once("util.inc"); +require_once("config.inc"); +require_once("gwlb.inc"); +require_once("functions.inc"); +require_once("filter.inc"); +require_once("shaper.inc"); +require_once("auth.inc"); +require_once("ipsec.inc"); +require_once("vpn.inc"); + +/* make sure to wait until the boot scripts have finished */ +if (file_exists("{$g['varrun_path']}/booting")) { + return; +} + +if (isset($config['ipsec']['enable'])) { + sleep(15); + log_error("IPSEC: One or more IPsec tunnel endpoints has changed its IP. Refreshing."); +} else { + return; +} + +$ipseclck = lock('ipsecdns', LOCK_EX); + +vpn_ipsec_configure(); + +unlock($ipseclck); +?> |