diff --git a/src/etc/rc.initial.banner b/src/etc/rc.initial.banner index 6af3122e2..babb109fa 100755 --- a/src/etc/rc.initial.banner +++ b/src/etc/rc.initial.banner @@ -44,80 +44,82 @@ print "\n*** Welcome to {$product} {$version} ({$machine}/${flavour}) on {$hostn $iflist = get_configured_interface_with_descr(false, true); if (empty($iflist)) { - printf("\n\tNo network interfaces are assigned.\n"); - return; + printf("\n\tNo network interfaces are assigned.\n"); + return; } -foreach($iflist as $ifname => $friendly) { - /* point to this interface's config */ - $ifconf = $config['interfaces'][$ifname]; - /* look for 'special cases' */ - $class = ""; - if (isset($ifconf['ipaddr'])) { - switch($ifconf['ipaddr']) { - case "dhcp": - $class = "/DHCP4"; - break; - case "pppoe": - $class = "/PPPoE"; - break; - case "pptp": - $class = "/PPTP"; - break; - case "l2tp": - $class = "/L2TP"; - break; - } - } - $class6 = null; - if (isset($ifconf['ipaddrv6'])) { - switch($ifconf['ipaddrv6']) { - case "dhcp6": - $class6 = "/DHCP6"; - break; - case "slaac": - $class6 = "/SLAAC"; - break; - case "6rd": - $class6 = "/6RD"; - break; - case "6to4": - $class6 = "/6to4"; - break; - case "track6": - $class6 = "/t6"; - break; - } - } - $ipaddr = get_interface_ip($ifname); - $subnet = get_interface_subnet($ifname); - $ipaddr6 = get_interface_ipv6($ifname); - $subnet6 = get_interface_subnetv6($ifname); - $realif = get_real_interface($ifname); - $tobanner = "{$friendly} ({$realif})"; +foreach ($iflist as $ifname => $friendly) { + /* point to this interface's config */ + $ifconf = $config['interfaces'][$ifname]; + /* look for 'special cases' */ + $class = ""; + if (isset($ifconf['ipaddr'])) { + switch ($ifconf['ipaddr']) { + case "dhcp": + $class = "/DHCP4"; + break; + case "pppoe": + $class = "/PPPoE"; + break; + case "pptp": + $class = "/PPTP"; + break; + case "l2tp": + $class = "/L2TP"; + break; + } + } + $class6 = null; + if (isset($ifconf['ipaddrv6'])) { + switch ($ifconf['ipaddrv6']) { + case "dhcp6": + $class6 = "/DHCP6"; + break; + case "slaac": + $class6 = "/SLAAC"; + break; + case "6rd": + $class6 = "/6RD"; + break; + case "6to4": + $class6 = "/6to4"; + break; + case "track6": + $class6 = "/t6"; + break; + } + } + $ipaddr = get_interface_ip($ifname); + $subnet = get_interface_subnet($ifname); + $ipaddr6 = get_interface_ipv6($ifname); + $subnet6 = get_interface_subnetv6($ifname); + $realif = get_real_interface($ifname); + $tobanner = "{$friendly} ({$realif})"; - printf("\n %-15s -> ", $tobanner); + printf("\n %-15s -> ", $tobanner); - $v6first = false; - if (!empty($ipaddr) && !empty($subnet)) { - printf("v4%s: %s/%s", - $class, - $ipaddr, - $subnet - ); - } else { - $v6first = true; - } - if (!empty($ipaddr6) && !empty($subnet6)) { - if (!$v6first) { - printf("\n%s", str_repeat(" ", 20)); - } - printf("v6%s: %s/%s", - $class6, - $ipaddr6, - $subnet6 - ); - } + $v6first = false; + if (!empty($ipaddr) && !empty($subnet)) { + printf( + "v4%s: %s/%s", + $class, + $ipaddr, + $subnet + ); + } else { + $v6first = true; + } + if (!empty($ipaddr6) && !empty($subnet6)) { + if (!$v6first) { + printf("\n%s", str_repeat(" ", 20)); + } + printf( + "v6%s: %s/%s", + $class6, + $ipaddr6, + $subnet6 + ); + } } printf("\n"); diff --git a/src/etc/rc.initial.defaults b/src/etc/rc.initial.defaults index 97a7f477a..a455432dd 100755 --- a/src/etc/rc.initial.defaults +++ b/src/etc/rc.initial.defaults @@ -43,7 +43,7 @@ Do you want to proceed {$yes_no_prompt} EOD; if (strcasecmp(chop(fgets($fp)), 'y') == 0) { - reset_factory_defaults(); + reset_factory_defaults(); } fclose($fp); diff --git a/src/etc/rc.initial.halt b/src/etc/rc.initial.halt index 3c7156c36..c3b5f4b05 100755 --- a/src/etc/rc.initial.halt +++ b/src/etc/rc.initial.halt @@ -38,7 +38,7 @@ echo "This may take a minute, depending on your hardware.\n"; echo "\nDo you want to proceed [y|n]? "; if (strcasecmp(chop(fgets($fp)), 'y') == 0) { - system_halt(true); + system_halt(true); } fclose($fp); diff --git a/src/etc/rc.initial.password b/src/etc/rc.initial.password index 5ec6ae91a..edc5fa6d0 100755 --- a/src/etc/rc.initial.password +++ b/src/etc/rc.initial.password @@ -33,49 +33,50 @@ require_once('auth.inc'); $fp = fopen('php://stdin', 'r'); printf( - gettext('The %s password will be reset to the factory default of `%s\'.'), - $g['factory_shipped_username'], - $g['factory_shipped_password'] + gettext('The %s password will be reset to the factory default of `%s\'.'), + $g['factory_shipped_username'], + $g['factory_shipped_password'] ); printf("\n\n"); printf(gettext('Do you want to proceed [y|n]? ')); if (strcasecmp(chop(fgets($fp)), 'y') == 0) { - if (isset($config['system']['webgui']['authmode']) && - $config['system']['webgui']['authmode'] != 'Local Database') { - printf("\n\n"); - printf(gettext('The User manager authentication server is set to "%s".'), $config['system']['webgui']['authmode']); - printf("\n"); - printf(gettext('Do you want to set it back to Local Database [y|n]? ')); - if (strcasecmp(chop(fgets($fp)), 'y') == 0) { - $config['system']['webgui']['authmode'] = 'Local Database'; - } - } - $admin_user =& getUserEntryByUID(0); - if (!$admin_user) { - echo "Failed to locate the admin user account! Attempting to restore access.\n"; - $admin_user = array(); - $admin_user['uid'] = 0; - if (!isset($config['system']['user'])) - $config['system']['user'] = array(); - $config['system']['user'][] = $admin_user; - } + if (isset($config['system']['webgui']['authmode']) && + $config['system']['webgui']['authmode'] != 'Local Database') { + printf("\n\n"); + printf(gettext('The User manager authentication server is set to "%s".'), $config['system']['webgui']['authmode']); + printf("\n"); + printf(gettext('Do you want to set it back to Local Database [y|n]? ')); + if (strcasecmp(chop(fgets($fp)), 'y') == 0) { + $config['system']['webgui']['authmode'] = 'Local Database'; + } + } + $admin_user =& getUserEntryByUID(0); + if (!$admin_user) { + echo "Failed to locate the admin user account! Attempting to restore access.\n"; + $admin_user = array(); + $admin_user['uid'] = 0; + if (!isset($config['system']['user'])) { + $config['system']['user'] = array(); + } + $config['system']['user'][] = $admin_user; + } - $admin_user['name'] = $g['factory_shipped_username']; - $admin_user['priv'] = array('user-shell-access'); - $admin_user['scope'] = 'system'; + $admin_user['name'] = $g['factory_shipped_username']; + $admin_user['priv'] = array('user-shell-access'); + $admin_user['scope'] = 'system'; - if (isset($admin_user['disabled'])) { - unset($admin_user['disabled']); - } + if (isset($admin_user['disabled'])) { + unset($admin_user['disabled']); + } - local_user_set_password($admin_user, $g['factory_shipped_password']); - local_user_set($admin_user); - write_config($config, gettext("password changed from console menu")); + local_user_set_password($admin_user, $g['factory_shipped_password']); + local_user_set($admin_user); + write_config($config, gettext("password changed from console menu")); - printf("\n\n"); - printf(gettext("The password has been reset.")); - printf("\n"); - printf(gettext("Please change the password as soon as you log in!")); - printf("\n\n"); + printf("\n\n"); + printf(gettext("The password has been reset.")); + printf("\n"); + printf(gettext("Please change the password as soon as you log in!")); + printf("\n\n"); } diff --git a/src/etc/rc.initial.ping b/src/etc/rc.initial.ping index ca2029714..a99b3ac50 100755 --- a/src/etc/rc.initial.ping +++ b/src/etc/rc.initial.ping @@ -37,15 +37,15 @@ echo "\nEnter a host name or IP address: "; $pinghost = chop(fgets($fp)); if (is_ipaddrv4($pinghost) || is_hostname($pinghost)) { - $command = "ping"; + $command = "ping"; } elseif (is_ipaddrv6($pinghost)) { - $command = "ping6"; + $command = "ping6"; } if ($command) { - echo "\n"; - passthru("/sbin/{$command} -c 3 -n " . escapeshellarg($pinghost)); - echo "\nPress ENTER to continue.\n"; - fgets($fp); + echo "\n"; + passthru("/sbin/{$command} -c 3 -n " . escapeshellarg($pinghost)); + echo "\nPress ENTER to continue.\n"; + fgets($fp); } fclose($fp); diff --git a/src/etc/rc.initial.reboot b/src/etc/rc.initial.reboot index 62310c504..7cc4c36b2 100755 --- a/src/etc/rc.initial.reboot +++ b/src/etc/rc.initial.reboot @@ -38,7 +38,7 @@ echo "This may take a minute, depending on your hardware.\n"; echo "\nDo you want to proceed [y|n]? "; if (strcasecmp(chop(fgets($fp)), 'y') == 0) { - system_reboot(true); + system_reboot(true); } fclose($fp); diff --git a/src/etc/rc.initial.setlanip b/src/etc/rc.initial.setlanip index c513ec84a..6aeeaba20 100755 --- a/src/etc/rc.initial.setlanip +++ b/src/etc/rc.initial.setlanip @@ -43,100 +43,106 @@ require_once("unbound.inc"); $options = getopt("hn", array("dry-run", "help")); if (isset($options["h"]) || isset($options["help"])) { - echo "usage: rc.initial.setlanip [option ...]\n"; - echo " -h, --help show this message\n"; - echo " -n, --dry-run do not make any configuration changes\n"; - exit(0); + echo "usage: rc.initial.setlanip [option ...]\n"; + echo " -h, --help show this message\n"; + echo " -n, --dry-run do not make any configuration changes\n"; + exit(0); } $dry_run = isset($options["n"]) || isset($options["dry-run"]); if ($dry_run) { - echo "DRY RUN MODE IS ON\n"; + echo "DRY RUN MODE IS ON\n"; } -function console_prompt_for_yn ($prompt_text) { - global $fp; +function console_prompt_for_yn($prompt_text) +{ + global $fp; - $good_answer = false; + $good_answer = false; - do { - echo "\n" . $prompt_text . " (y/n) "; - $yn = strtolower(chop(fgets($fp))); - if (($yn == "y") || ($yn == "yes")) { - $boolean_answer = true; - $good_answer = true; - } - if (($yn == "n") || ($yn == "no")) { - $boolean_answer = false; - $good_answer = true; - } - } while (!$good_answer); + do { + echo "\n" . $prompt_text . " (y/n) "; + $yn = strtolower(chop(fgets($fp))); + if (($yn == "y") || ($yn == "yes")) { + $boolean_answer = true; + $good_answer = true; + } + if (($yn == "n") || ($yn == "no")) { + $boolean_answer = false; + $good_answer = true; + } + } while (!$good_answer); - return $boolean_answer; + return $boolean_answer; } function console_get_interface_from_ppp($realif) { - global $config; + global $config; - if (isset($config['ppps']['ppp'])) { - foreach ($config['ppps']['ppp'] as $pppid => $ppp) { - if ($realif == $ppp['if']) { - $ifaces = explode(',', $ppp['ports']); - return $ifaces[0]; - } - } - } + if (isset($config['ppps']['ppp'])) { + foreach ($config['ppps']['ppp'] as $pppid => $ppp) { + if ($realif == $ppp['if']) { + $ifaces = explode(',', $ppp['ports']); + return $ifaces[0]; + } + } + } - return ''; + return ''; } -function prompt_for_enable_dhcp_server($version = 4) { - global $config, $fp, $interface; - if($interface == "wan") { - if($config['interfaces']['lan']) - return false; - } - /* only allow DHCP server to be enabled when static IP is +function prompt_for_enable_dhcp_server($version = 4) +{ + global $config, $fp, $interface; + if ($interface == "wan") { + if ($config['interfaces']['lan']) { + return false; + } + } + /* only allow DHCP server to be enabled when static IP is configured on this interface */ - if ($version === 6) { - $is_ipaddr = is_ipaddrv6($config['interfaces'][$interface]['ipaddrv6']); - } else { - $is_ipaddr = is_ipaddrv4($config['interfaces'][$interface]['ipaddr']); - } - if (!($is_ipaddr)) { - return false; - } + if ($version === 6) { + $is_ipaddr = is_ipaddrv6($config['interfaces'][$interface]['ipaddrv6']); + } else { + $is_ipaddr = is_ipaddrv4($config['interfaces'][$interface]['ipaddr']); + } + if (!($is_ipaddr)) { + return false; + } - $label_DHCP = ($version === 6) ? "DHCP6" : "DHCP"; - $upperifname = strtoupper($interface); - return console_prompt_for_yn (sprintf(gettext("Do you want to enable the %s server on %s?"), $label_DHCP, $upperifname)); + $label_DHCP = ($version === 6) ? "DHCP6" : "DHCP"; + $upperifname = strtoupper($interface); + return console_prompt_for_yn(sprintf(gettext("Do you want to enable the %s server on %s?"), $label_DHCP, $upperifname)); } -function get_interface_config_description($iface) { - global $config; - $c = $config['interfaces'][$iface]; - if (!$c) { return null; } - $if = $c['if']; - $result = $if; - $result2 = array(); - $ipaddr = $c['ipaddr']; - $ipaddrv6 = $c['ipaddrv6']; - if (is_ipaddr($ipaddr)) { - $result2[] = "static"; - } else if ($ipaddr == "dhcp") { - $result2[] = "dhcp"; - } - if (is_ipaddr($ipaddrv6)) { - $result2[] = "staticv6"; - } else if ($ipaddrv6 == "dhcp6") { - $result2[] = "dhcp6"; - } - if (count($result2)) { - $result .= " - " . implode(", ", $result2); - } - return $result; +function get_interface_config_description($iface) +{ + global $config; + $c = $config['interfaces'][$iface]; + if (!$c) { + return null; + } + $if = $c['if']; + $result = $if; + $result2 = array(); + $ipaddr = $c['ipaddr']; + $ipaddrv6 = $c['ipaddrv6']; + if (is_ipaddr($ipaddr)) { + $result2[] = "static"; + } elseif ($ipaddr == "dhcp") { + $result2[] = "dhcp"; + } + if (is_ipaddr($ipaddrv6)) { + $result2[] = "staticv6"; + } elseif ($ipaddrv6 == "dhcp6") { + $result2[] = "dhcp6"; + } + if (count($result2)) { + $result .= " - " . implode(", ", $result2); + } + return $result; } $fp = fopen('php://stdin', 'r'); @@ -148,211 +154,233 @@ $count = count($ifdescrs); /* grab interface that we will operate on, unless there is only one interface */ if ($count > 1) { - echo "Available interfaces:\n\n"; - $x=1; - foreach($ifdescrs as $iface => $ifdescr) { - $config_descr = get_interface_config_description($iface); - echo "{$x} - {$ifdescr} ({$config_descr})\n"; - $x++; - } - echo "\nEnter the number of the interface you wish to configure: "; - $intnum = chop(fgets($fp)); + echo "Available interfaces:\n\n"; + $x=1; + foreach ($ifdescrs as $iface => $ifdescr) { + $config_descr = get_interface_config_description($iface); + echo "{$x} - {$ifdescr} ({$config_descr})\n"; + $x++; + } + echo "\nEnter the number of the interface you wish to configure: "; + $intnum = chop(fgets($fp)); } else { - $intnum = $count; + $intnum = $count; } -if($intnum < 1) - exit; -if($intnum > $count) - exit; +if ($intnum < 1) { + exit; +} +if ($intnum > $count) { + exit; +} $index = 1; foreach ($ifdescrs as $ifname => $ifdesc) { - if ($intnum == $index) { - $interface = $ifname; - break; - } else { - $index++; - } + if ($intnum == $index) { + $interface = $ifname; + break; + } else { + $index++; + } } -if(!$interface) { - echo "Invalid interface!\n"; - exit; +if (!$interface) { + echo "Invalid interface!\n"; + exit; } $ifaceassigned = ""; -function next_unused_gateway_name($interface) { - global $g, $config; - $new_name = "GW_" . strtoupper($interface); +function next_unused_gateway_name($interface) +{ + global $g, $config; + $new_name = "GW_" . strtoupper($interface); - if (!is_array($config['gateways']['gateway_item'])) { return $new_name; } - $count = 1; - do { - $existing = false; - foreach ($config['gateways']['gateway_item'] as $item) { - if ($item['name'] === $new_name) { - $existing = true; - break; - } - } - if ($existing) { - $count += 1; - $new_name = "GW_" . strtoupper($interface) . "_" . $count; - } - } while ($existing); - return $new_name; + if (!is_array($config['gateways']['gateway_item'])) { + return $new_name; + } + $count = 1; + do { + $existing = false; + foreach ($config['gateways']['gateway_item'] as $item) { + if ($item['name'] === $new_name) { + $existing = true; + break; + } + } + if ($existing) { + $count += 1; + $new_name = "GW_" . strtoupper($interface) . "_" . $count; + } + } while ($existing); + return $new_name; } -function add_gateway_to_config($interface, $gatewayip, $inet_type) { - global $g, $config, $dry_run; - if (!is_array($config['gateways']['gateway_item'])) { - $config['gateways']['gateway_item'] = array(); - } - $a_gateways = &$config['gateways']['gateway_item']; - if ($dry_run) { - print_r($a_gateways); - } - $new_name = ''; - $is_default = true; - foreach ($a_gateways as $item) { - if ($item['ipprotocol'] === $inet_type) { - if (isset($item['defaultgw'])) - $is_default = false; - if (($item['interface'] === $interface) && ($item['gateway'] === $gatewayip)) - $new_name = $item['name']; - } - } - if ($new_name == '') { - $new_name = next_unused_gateway_name($interface); - $item = array( - "interface" => $interface, - "gateway" => $gatewayip, - "name" => $new_name, - "weight" => 1, - "ipprotocol" => $inet_type, - "interval" => true, - "descr" => "Interface $interface Gateway", - "defaultgw" => $is_default - ); - if ($dry_run) { - print_r($item); - } - $a_gateways[] = $item; - } +function add_gateway_to_config($interface, $gatewayip, $inet_type) +{ + global $g, $config, $dry_run; + if (!is_array($config['gateways']['gateway_item'])) { + $config['gateways']['gateway_item'] = array(); + } + $a_gateways = &$config['gateways']['gateway_item']; + if ($dry_run) { + print_r($a_gateways); + } + $new_name = ''; + $is_default = true; + foreach ($a_gateways as $item) { + if ($item['ipprotocol'] === $inet_type) { + if (isset($item['defaultgw'])) { + $is_default = false; + } + if (($item['interface'] === $interface) && ($item['gateway'] === $gatewayip)) { + $new_name = $item['name']; + } + } + } + if ($new_name == '') { + $new_name = next_unused_gateway_name($interface); + $item = array( + "interface" => $interface, + "gateway" => $gatewayip, + "name" => $new_name, + "weight" => 1, + "ipprotocol" => $inet_type, + "interval" => true, + "descr" => "Interface $interface Gateway", + "defaultgw" => $is_default + ); + if ($dry_run) { + print_r($item); + } + $a_gateways[] = $item; + } - return $new_name; + return $new_name; } -function console_configure_ip_address($version) { - global $g, $config, $interface, $restart_dhcpd, $ifaceassigned, $fp; +function console_configure_ip_address($version) +{ + global $g, $config, $interface, $restart_dhcpd, $ifaceassigned, $fp; - $label_IPvX = ($version === 6) ? "IPv6" : "IPv4"; - $maxbits = ($version === 6) ? 127 : 31; - $label_DHCP = ($version === 6) ? "DHCP6" : "DHCP"; + $label_IPvX = ($version === 6) ? "IPv6" : "IPv4"; + $maxbits = ($version === 6) ? 127 : 31; + $label_DHCP = ($version === 6) ? "DHCP6" : "DHCP"; - $upperifname = strtoupper($interface); + $upperifname = strtoupper($interface); - if($interface == "wan") { - if (console_prompt_for_yn (sprintf(gettext("Configure %s address %s interface via %s?"), $label_IPvX, $upperifname, $label_DHCP))) { - $ifppp = console_get_interface_from_ppp(get_real_interface("wan")); - if (!empty($ifppp)) - $ifaceassigned = $ifppp; - $intip = ($version === 6) ? "dhcp6" : "dhcp"; - $intbits = ""; - $isintdhcp = true; - $restart_dhcpd = true; - } - } + if ($interface == "wan") { + if (console_prompt_for_yn(sprintf(gettext("Configure %s address %s interface via %s?"), $label_IPvX, $upperifname, $label_DHCP))) { + $ifppp = console_get_interface_from_ppp(get_real_interface("wan")); + if (!empty($ifppp)) { + $ifaceassigned = $ifppp; + } + $intip = ($version === 6) ? "dhcp6" : "dhcp"; + $intbits = ""; + $isintdhcp = true; + $restart_dhcpd = true; + } + } - if($isintdhcp == false or $interface <> "wan") { - while(true) { - do { - echo "\n" . sprintf(gettext("Enter the new %s %s address. Press for none:"), - $upperifname, $label_IPvX) . "\n> "; - $intip = chop(fgets($fp)); - $is_ipaddr = ($version === 6) ? is_ipaddrv6($intip) : is_ipaddrv4($intip); - if ($is_ipaddr && is_ipaddr_configured($intip, $interface, true)) { - $ip_conflict = true; - echo gettext("This IP address conflicts with another interface or a VIP") . "\n"; - } else - $ip_conflict = false; - } while (($ip_conflict === true) || !($is_ipaddr || $intip == '')); - if ($intip != '') { - echo "\n" . sprintf(gettext("Subnet masks are entered as bit counts (as in CIDR notation) in %s."), - $g['product_name']) . "\n"; - if ($version === 6) { - echo "e.g. ffff:ffff:ffff:ffff:ffff:ffff:ffff:ff00 = 120\n"; - echo " ffff:ffff:ffff:ffff:ffff:ffff:ffff:0 = 112\n"; - echo " ffff:ffff:ffff:ffff:ffff:ffff:0:0 = 96\n"; - echo " ffff:ffff:ffff:ffff:ffff:0:0:0 = 80\n"; - echo " ffff:ffff:ffff:ffff:0:0:0:0 = 64\n"; - } else { - echo "e.g. 255.255.255.0 = 24\n"; - echo " 255.255.0.0 = 16\n"; - echo " 255.0.0.0 = 8\n"; - } - do { - $upperifname = strtoupper($interface); - echo "\n" . sprintf(gettext("Enter the new %s %s subnet bit count (1 to %s):"), - $upperifname, $label_IPvX, $maxbits) . "\n> "; - $intbits = chop(fgets($fp)); - $intbits_ok = is_numeric($intbits) && (($intbits >= 1) && ($intbits <= $maxbits)); - $restart_dhcpd = true; + if ($isintdhcp == false or $interface <> "wan") { + while (true) { + do { + echo "\n" . sprintf( + gettext("Enter the new %s %s address. Press for none:"), + $upperifname, + $label_IPvX + ) . "\n> "; + $intip = chop(fgets($fp)); + $is_ipaddr = ($version === 6) ? is_ipaddrv6($intip) : is_ipaddrv4($intip); + if ($is_ipaddr && is_ipaddr_configured($intip, $interface, true)) { + $ip_conflict = true; + echo gettext("This IP address conflicts with another interface or a VIP") . "\n"; + } else { + $ip_conflict = false; + } + } while (($ip_conflict === true) || !($is_ipaddr || $intip == '')); + if ($intip != '') { + echo "\n" . sprintf( + gettext("Subnet masks are entered as bit counts (as in CIDR notation) in %s."), + $g['product_name'] + ) . "\n"; + if ($version === 6) { + echo "e.g. ffff:ffff:ffff:ffff:ffff:ffff:ffff:ff00 = 120\n"; + echo " ffff:ffff:ffff:ffff:ffff:ffff:ffff:0 = 112\n"; + echo " ffff:ffff:ffff:ffff:ffff:ffff:0:0 = 96\n"; + echo " ffff:ffff:ffff:ffff:ffff:0:0:0 = 80\n"; + echo " ffff:ffff:ffff:ffff:0:0:0:0 = 64\n"; + } else { + echo "e.g. 255.255.255.0 = 24\n"; + echo " 255.255.0.0 = 16\n"; + echo " 255.0.0.0 = 8\n"; + } + do { + $upperifname = strtoupper($interface); + echo "\n" . sprintf( + gettext("Enter the new %s %s subnet bit count (1 to %s):"), + $upperifname, + $label_IPvX, + $maxbits + ) . "\n> "; + $intbits = chop(fgets($fp)); + $intbits_ok = is_numeric($intbits) && (($intbits >= 1) && ($intbits <= $maxbits)); + $restart_dhcpd = true; - if ($version === 4 && $intbits < $maxbits) { - if ($intip == gen_subnet($intip, $intbits)) { - echo gettext("You cannot set network address to an interface"); - continue 2; - $intbits_ok = false; - } else if ($intip == gen_subnet_max($intip, $intbits)) { - echo gettext("You cannot set broadcast address to an interface"); - continue 2; - $intbits_ok = false; - } - } - } while (!$intbits_ok); + if ($version === 4 && $intbits < $maxbits) { + if ($intip == gen_subnet($intip, $intbits)) { + echo gettext("You cannot set network address to an interface"); + continue 2; + $intbits_ok = false; + } elseif ($intip == gen_subnet_max($intip, $intbits)) { + echo gettext("You cannot set broadcast address to an interface"); + continue 2; + $intbits_ok = false; + } + } + } while (!$intbits_ok); - if ($version === 6) { - $subnet = gen_subnetv6($intip, $intbits); - } else { - $subnet = gen_subnet($intip, $intbits); - } - do { - echo "\n" . sprintf(gettext("For a WAN, enter the new %s %s upstream gateway address."), $upperifname, $label_IPvX) . "\n" . - gettext("For a LAN, press for none:") . "\n> "; - $gwip = chop(fgets($fp)); - $is_ipaddr = ($version === 6) ? is_ipaddrv6($gwip) : is_ipaddrv4($gwip); - $is_in_subnet = $is_ipaddr && ip_in_subnet($gwip, $subnet . "/" . $intbits); - if ($gwip != '') { - if (!$is_ipaddr) { - echo sprintf(gettext("not an %s IP address!"), $label_IPvX) . "\n"; - } else if (!$is_in_subnet) { - echo gettext("not in subnet!") . "\n"; - } - } - } while (!($gwip == '' || ($is_ipaddr && $is_in_subnet))); + if ($version === 6) { + $subnet = gen_subnetv6($intip, $intbits); + } else { + $subnet = gen_subnet($intip, $intbits); + } + do { + echo "\n" . sprintf(gettext("For a WAN, enter the new %s %s upstream gateway address."), $upperifname, $label_IPvX) . "\n" . + gettext("For a LAN, press for none:") . "\n> "; + $gwip = chop(fgets($fp)); + $is_ipaddr = ($version === 6) ? is_ipaddrv6($gwip) : is_ipaddrv4($gwip); + $is_in_subnet = $is_ipaddr && ip_in_subnet($gwip, $subnet . "/" . $intbits); + if ($gwip != '') { + if (!$is_ipaddr) { + echo sprintf(gettext("not an %s IP address!"), $label_IPvX) . "\n"; + } elseif (!$is_in_subnet) { + echo gettext("not in subnet!") . "\n"; + } + } + } while (!($gwip == '' || ($is_ipaddr && $is_in_subnet))); - if ($gwip != '') { - $inet_type = ($version === 6) ? "inet6" : "inet"; - $gwname = add_gateway_to_config($interface, $gwip, $inet_type); - } - } - $ifppp = console_get_interface_from_ppp(get_real_interface($interface)); - if (!empty($ifppp)) - $ifaceassigned = $ifppp; - break; - } - } + if ($gwip != '') { + $inet_type = ($version === 6) ? "inet6" : "inet"; + $gwname = add_gateway_to_config($interface, $gwip, $inet_type); + } + } + $ifppp = console_get_interface_from_ppp(get_real_interface($interface)); + if (!empty($ifppp)) { + $ifaceassigned = $ifppp; + } + break; + } + } - return array($intip, $intbits, $gwname); + return array($intip, $intbits, $gwname); } list($intip, $intbits, $gwname) = console_configure_ip_address(4); list($intip6, $intbits6, $gwname6) = console_configure_ip_address(6); -if (!empty($ifaceassigned)) - $config['interfaces'][$interface]['if'] = $ifaceassigned; +if (!empty($ifaceassigned)) { + $config['interfaces'][$interface]['if'] = $ifaceassigned; +} $config['interfaces'][$interface]['ipaddr'] = $intip; $config['interfaces'][$interface]['subnet'] = $intbits; $config['interfaces'][$interface]['gateway'] = $gwname; @@ -361,57 +389,60 @@ $config['interfaces'][$interface]['subnetv6'] = $intbits6; $config['interfaces'][$interface]['gatewayv6'] = $gwname6; $config['interfaces'][$interface]['enable'] = true; -function console_configure_dhcpd($version = 4) { - global $g, $config, $restart_dhcpd, $fp, $interface, $dry_run, $intip, $intbits, $intip6, $intbits6; +function console_configure_dhcpd($version = 4) +{ + global $g, $config, $restart_dhcpd, $fp, $interface, $dry_run, $intip, $intbits, $intip6, $intbits6; - $label_IPvX = ($version === 6) ? "IPv6" : "IPv4"; - $dhcpd = ($version === 6) ? "dhcpdv6" : "dhcpd"; + $label_IPvX = ($version === 6) ? "IPv6" : "IPv4"; + $dhcpd = ($version === 6) ? "dhcpdv6" : "dhcpd"; - if (prompt_for_enable_dhcp_server($version)) { - $subnet_start = ($version === 6) ? gen_subnetv6($intip6, $intbits6) : gen_subnet($intip, $intbits); - $subnet_end = ($version === 6) ? gen_subnetv6_max($intip6, $intbits6) : gen_subnet_max($intip, $intbits); - do { - do { - echo sprintf(gettext("Enter the start address of the %s client address range:"), $label_IPvX) . " "; - $dhcpstartip = chop(fgets($fp)); - if ($dhcpstartip === "") { - fclose($fp); - exit(0); - } - $is_ipaddr = ($version === 6) ? is_ipaddrv6($dhcpstartip) : is_ipaddrv4($dhcpstartip); - $is_inrange = is_inrange($dhcpstartip, $subnet_start, $subnet_end); - if (!$is_inrange) - echo gettext("This IP address must be in the interface's subnet") . "\n"; - } while (!$is_ipaddr || !$is_inrange); + if (prompt_for_enable_dhcp_server($version)) { + $subnet_start = ($version === 6) ? gen_subnetv6($intip6, $intbits6) : gen_subnet($intip, $intbits); + $subnet_end = ($version === 6) ? gen_subnetv6_max($intip6, $intbits6) : gen_subnet_max($intip, $intbits); + do { + do { + echo sprintf(gettext("Enter the start address of the %s client address range:"), $label_IPvX) . " "; + $dhcpstartip = chop(fgets($fp)); + if ($dhcpstartip === "") { + fclose($fp); + exit(0); + } + $is_ipaddr = ($version === 6) ? is_ipaddrv6($dhcpstartip) : is_ipaddrv4($dhcpstartip); + $is_inrange = is_inrange($dhcpstartip, $subnet_start, $subnet_end); + if (!$is_inrange) { + echo gettext("This IP address must be in the interface's subnet") . "\n"; + } + } while (!$is_ipaddr || !$is_inrange); - do { - echo sprintf(gettext("Enter the end address of the %s client address range:"), $label_IPvX) . " "; - $dhcpendip = chop(fgets($fp)); - if ($dhcpendip === "") { - fclose($fp); - exit(0); - } - $is_ipaddr = ($version === 6) ? is_ipaddrv6($dhcpendip) : is_ipaddrv4($dhcpendip); - $is_inrange = is_inrange($dhcpendip, $subnet_start, $subnet_end); - if (!$is_inrange) - echo gettext("This IP address must be in the interface's subnet") . "\n"; - $not_inorder = ($version === 6) ? (inet_pton($dhcpendip) < inet_pton($dhcpstartip)) : ip_less_than($dhcpendip, $dhcpstartip); - if ($not_inorder) { - echo gettext("The end address of the DHCP range must be >= the start address") . "\n"; - } - } while (!$is_ipaddr || !$is_inrange); - } while ($not_inorder); - $restart_dhcpd = true; - $config[$dhcpd][$interface]['enable'] = true; - $config[$dhcpd][$interface]['range']['from'] = $dhcpstartip; - $config[$dhcpd][$interface]['range']['to'] = $dhcpendip; - } else { - if(isset($config[$dhcpd][$interface]['enable'])) { - unset($config[$dhcpd][$interface]['enable']); - printf(gettext("Disabling %s DHCPD..."), $label_IPvX); - $restart_dhcpd = true; - } - } + do { + echo sprintf(gettext("Enter the end address of the %s client address range:"), $label_IPvX) . " "; + $dhcpendip = chop(fgets($fp)); + if ($dhcpendip === "") { + fclose($fp); + exit(0); + } + $is_ipaddr = ($version === 6) ? is_ipaddrv6($dhcpendip) : is_ipaddrv4($dhcpendip); + $is_inrange = is_inrange($dhcpendip, $subnet_start, $subnet_end); + if (!$is_inrange) { + echo gettext("This IP address must be in the interface's subnet") . "\n"; + } + $not_inorder = ($version === 6) ? (inet_pton($dhcpendip) < inet_pton($dhcpstartip)) : ip_less_than($dhcpendip, $dhcpstartip); + if ($not_inorder) { + echo gettext("The end address of the DHCP range must be >= the start address") . "\n"; + } + } while (!$is_ipaddr || !$is_inrange); + } while ($not_inorder); + $restart_dhcpd = true; + $config[$dhcpd][$interface]['enable'] = true; + $config[$dhcpd][$interface]['range']['from'] = $dhcpstartip; + $config[$dhcpd][$interface]['range']['to'] = $dhcpendip; + } else { + if (isset($config[$dhcpd][$interface]['enable'])) { + unset($config[$dhcpd][$interface]['enable']); + printf(gettext("Disabling %s DHCPD..."), $label_IPvX); + $restart_dhcpd = true; + } + } } console_configure_dhcpd(4); @@ -420,103 +451,120 @@ console_configure_dhcpd(6); //***************************************************************************** if ($config['system']['webgui']['protocol'] == "https") { - - if (console_prompt_for_yn (gettext("Do you want to revert to HTTP as the webConfigurator protocol?"))) { - $config['system']['webgui']['protocol'] = "http"; - $restart_webgui = true; - } + if (console_prompt_for_yn(gettext("Do you want to revert to HTTP as the webConfigurator protocol?"))) { + $config['system']['webgui']['protocol'] = "http"; + $restart_webgui = true; + } } if (isset($config['system']['webgui']['noantilockout'])) { - echo "\n" . sprintf(gettext("Note: the anti-lockout rule on %s has been re-enabled."), $interface) . "\n"; - unset($config['system']['webgui']['noantilockout']); + echo "\n" . sprintf(gettext("Note: the anti-lockout rule on %s has been re-enabled."), $interface) . "\n"; + unset($config['system']['webgui']['noantilockout']); } -if($config['interfaces']['lan']) { - if($config['dhcpd']) - if($config['dhcpd']['wan']) - unset($config['dhcpd']['wan']); - if($config['dhcpdv6']) - if($config['dhcpdv6']['wan']) - unset($config['dhcpdv6']['wan']); +if ($config['interfaces']['lan']) { + if ($config['dhcpd']) { + if ($config['dhcpd']['wan']) { + unset($config['dhcpd']['wan']); + } + } + if ($config['dhcpdv6']) { + if ($config['dhcpdv6']['wan']) { + unset($config['dhcpdv6']['wan']); + } + } } -if(!$config['interfaces']['lan']) { - unset($config['interfaces']['lan']); - if($config['dhcpd']['lan']) - unset($config['dhcpd']['lan']); - if($config['dhcpdv6']['lan']) - unset($config['dhcpdv6']['lan']); - unset($config['nat']); - if (!$dry_run) { - system("rm /var/dhcpd/var/db/* >/dev/null 2>/dev/null"); - $restart_dhcpd = true; - } +if (!$config['interfaces']['lan']) { + unset($config['interfaces']['lan']); + if ($config['dhcpd']['lan']) { + unset($config['dhcpd']['lan']); + } + if ($config['dhcpdv6']['lan']) { + unset($config['dhcpdv6']['lan']); + } + unset($config['nat']); + if (!$dry_run) { + system("rm /var/dhcpd/var/db/* >/dev/null 2>/dev/null"); + $restart_dhcpd = true; + } } $upperifname = strtoupper($interface); if (!$dry_run) { - echo "\nPlease wait while the changes are saved to {$upperifname}..."; - write_config(sprintf(gettext("%s IP configuration from console menu"), $interface)); - interface_reconfigure(strtolower($upperifname)); - echo "\n Reloading filter..."; - filter_configure_sync(); - if($restart_dhcpd) { - echo "\n DHCPD..."; - services_dhcpd_configure(); - } - if ($restart_webgui) { - mwexec('/usr/local/etc/rc.restart_webgui'); - } + echo "\nPlease wait while the changes are saved to {$upperifname}..."; + write_config(sprintf(gettext("%s IP configuration from console menu"), $interface)); + interface_reconfigure(strtolower($upperifname)); + echo "\n Reloading filter..."; + filter_configure_sync(); + if ($restart_dhcpd) { + echo "\n DHCPD..."; + services_dhcpd_configure(); + } + if ($restart_webgui) { + mwexec('/usr/local/etc/rc.restart_webgui'); + } } if ($intip != '') { - if (is_ipaddr($intip)) { - echo "\n\n" . sprintf(gettext("The IPv4 %s address has been set to %s"), - $upperifname, "{$intip}/{$intbits}") . "\n"; - } else { - echo "\n\n" . sprintf(gettext("The IPv4 %s address has been set to %s"), - $upperifname, $intip) . "\n"; - } + if (is_ipaddr($intip)) { + echo "\n\n" . sprintf( + gettext("The IPv4 %s address has been set to %s"), + $upperifname, + "{$intip}/{$intbits}" + ) . "\n"; + } else { + echo "\n\n" . sprintf( + gettext("The IPv4 %s address has been set to %s"), + $upperifname, + $intip + ) . "\n"; + } } if ($intip6 != '') { - if (is_ipaddr($intip6)) { - echo "\n\n" . sprintf(gettext("The IPv6 %s address has been set to %s"), - $upperifname, "${intip6}/${intbits6}") . "\n"; - } else { - echo "\n\n" . sprintf(gettext("The IPv6 %s address has been set to %s"), - $upperifname, $intip6) . "\n"; - } + if (is_ipaddr($intip6)) { + echo "\n\n" . sprintf( + gettext("The IPv6 %s address has been set to %s"), + $upperifname, + "${intip6}/${intbits6}" + ) . "\n"; + } else { + echo "\n\n" . sprintf( + gettext("The IPv6 %s address has been set to %s"), + $upperifname, + $intip6 + ) . "\n"; + } } if ($intip != '' || $intip6 != '') { - if (count($ifdescrs) == "1" or $interface == "lan") { - echo gettext('You can now access the webConfigurator by opening the following URL in your web browser:') . "\n"; - if(!empty($config['system']['webgui']['port'])) { - $webuiport = $config['system']['webgui']['port']; - if ($intip != '') { - echo " {$config['system']['webgui']['protocol']}://{$intip}:{$webuiport}/\n"; - } - if ($intip6 != '') { - if (is_ipaddr($intip6)) { - echo " {$config['system']['webgui']['protocol']}://[{$intip6}]:{$webuiport}/\n"; - } else { - echo " {$config['system']['webgui']['protocol']}://{$intip6}:{$webuiport}/\n"; - } - } - } else { - if ($intip != '') { - echo " {$config['system']['webgui']['protocol']}://{$intip}/\n"; - } - if ($intip6 != '') { - if (is_ipaddr($intip6)) { - echo " {$config['system']['webgui']['protocol']}://[{$intip6}]/\n"; - } else { - echo " {$config['system']['webgui']['protocol']}://{$intip6}/\n"; - } - } - } - } + if (count($ifdescrs) == "1" or $interface == "lan") { + echo gettext('You can now access the webConfigurator by opening the following URL in your web browser:') . "\n"; + if (!empty($config['system']['webgui']['port'])) { + $webuiport = $config['system']['webgui']['port']; + if ($intip != '') { + echo " {$config['system']['webgui']['protocol']}://{$intip}:{$webuiport}/\n"; + } + if ($intip6 != '') { + if (is_ipaddr($intip6)) { + echo " {$config['system']['webgui']['protocol']}://[{$intip6}]:{$webuiport}/\n"; + } else { + echo " {$config['system']['webgui']['protocol']}://{$intip6}:{$webuiport}/\n"; + } + } + } else { + if ($intip != '') { + echo " {$config['system']['webgui']['protocol']}://{$intip}/\n"; + } + if ($intip6 != '') { + if (is_ipaddr($intip6)) { + echo " {$config['system']['webgui']['protocol']}://[{$intip6}]/\n"; + } else { + echo " {$config['system']['webgui']['protocol']}://{$intip6}/\n"; + } + } + } + } } echo "\n" . gettext('Press to continue.'); diff --git a/src/etc/rc.initial.setports b/src/etc/rc.initial.setports index 390afa8b8..819c4938d 100755 --- a/src/etc/rc.initial.setports +++ b/src/etc/rc.initial.setports @@ -42,11 +42,11 @@ require_once("pfsense-utils.inc"); require_once("unbound.inc"); if (set_networking_interfaces_ports()) { - echo "Reloading interfaces..."; - global $config; - $config = parse_config(); - system_routing_enable(); - interfaces_configure(); - echo "done.\n"; - enable_rrd_graphing(); + echo "Reloading interfaces..."; + global $config; + $config = parse_config(); + system_routing_enable(); + interfaces_configure(); + echo "done.\n"; + enable_rrd_graphing(); }