= 0) if (is_subsystem_dirty('ipsec')) clear_subsystem_dirty('ipsec'); } if ($_POST['submit']) { unset($input_errors); $pconfig = $_POST; /* input consolidation */ /* input validation */ $reqdfields = explode(" ", "user_source group_source"); $reqdfieldsn = array(gettext("User Authentication Source"),gettext("Group Authentication Source")); do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors); if ($pconfig['pool_enable']) if (!is_ipaddr($pconfig['pool_address'])) $input_errors[] = gettext("A valid IP address for 'Virtual Address Pool Network' must be specified."); if ($pconfig['dns_domain_enable']) if (!is_domain($pconfig['dns_domain'])) $input_errors[] = gettext("A valid value for 'DNS Default Domain' must be specified."); if ($pconfig['dns_split_enable']) { if (!empty($pconfig['dns_split'])) { $domain_array=preg_split("/[ ,]+/",$pconfig['dns_split']); foreach ($domain_array as $curdomain) { if (!is_domain($curdomain)) { $input_errors[] = gettext("A valid split DNS domain list must be specified."); break; } } } } if ($pconfig['dns_server_enable']) { if (!$pconfig['dns_server1'] && !$pconfig['dns_server2'] && !$pconfig['dns_server3'] && !$pconfig['dns_server4'] ) $input_errors[] = gettext("At least one DNS server must be specified to enable the DNS Server option."); if ($pconfig['dns_server1'] && !is_ipaddr($pconfig['dns_server1'])) $input_errors[] = gettext("A valid IP address for 'DNS Server #1' must be specified."); if ($pconfig['dns_server2'] && !is_ipaddr($pconfig['dns_server2'])) $input_errors[] = gettext("A valid IP address for 'DNS Server #2' must be specified."); if ($pconfig['dns_server3'] && !is_ipaddr($pconfig['dns_server3'])) $input_errors[] = gettext("A valid IP address for 'DNS Server #3' must be specified."); if ($pconfig['dns_server4'] && !is_ipaddr($pconfig['dns_server4'])) $input_errors[] = gettext("A valid IP address for 'DNS Server #4' must be specified."); } if ($pconfig['wins_server_enable']) { if (!$pconfig['wins_server1'] && !$pconfig['wins_server2']) $input_errors[] = gettext("At least one WINS server must be specified to enable the DNS Server option."); if ($pconfig['wins_server1'] && !is_ipaddr($pconfig['wins_server1'])) $input_errors[] = gettext("A valid IP address for 'WINS Server #1' must be specified."); if ($pconfig['wins_server2'] && !is_ipaddr($pconfig['wins_server2'])) $input_errors[] = gettext("A valid IP address for 'WINS Server #2' must be specified."); } if ($pconfig['login_banner_enable']) if (!strlen($pconfig['login_banner'])) $input_errors[] = gettext("A valid value for 'Login Banner' must be specified."); if (!$input_errors) { $client = array(); if ($pconfig['enable']) $client['enable'] = true; if (!empty($pconfig['user_source'])) $client['user_source'] = implode(",", $pconfig['user_source']); $client['group_source'] = $pconfig['group_source']; if ($pconfig['pool_enable']) { $client['pool_address'] = $pconfig['pool_address']; $client['pool_netbits'] = $pconfig['pool_netbits']; } if ($pconfig['net_list_enable']) $client['net_list'] = true; if ($pconfig['save_passwd_enable']) $client['save_passwd'] = true; if ($pconfig['dns_domain_enable']) $client['dns_domain'] = $pconfig['dns_domain']; if ($pconfig['dns_split_enable']) $client['dns_split'] = $pconfig['dns_split']; if ($pconfig['dns_server_enable']) { $client['dns_server1'] = $pconfig['dns_server1']; $client['dns_server2'] = $pconfig['dns_server2']; $client['dns_server3'] = $pconfig['dns_server3']; $client['dns_server4'] = $pconfig['dns_server4']; } if ($pconfig['wins_server_enable']) { $client['wins_server1'] = $pconfig['wins_server1']; $client['wins_server2'] = $pconfig['wins_server2']; } if ($pconfig['pfs_group_enable']) $client['pfs_group'] = $pconfig['pfs_group']; if ($pconfig['login_banner_enable']) $client['login_banner'] = $pconfig['login_banner']; // $echo "login banner = {$pconfig['login_banner']}"; $a_client = $client; write_config(); mark_subsystem_dirty('ipsec'); header("Location: vpn_ipsec_mobile.php"); exit; } } $pgtitle = array(gettext("VPN"),gettext("IPsec"),gettext("Mobile")); $shortcut_section = "ipsec"; include("head.inc"); ?>