mirror of
https://github.com/billz/raspap-webgui.git
synced 2023-10-10 13:37:24 +02:00
Fixup dhcp cfg save/update
This commit is contained in:
parent
827f37385f
commit
5045cbfd33
@ -71,7 +71,7 @@ function SaveDHCPConfig($status)
|
|||||||
if (($_POST['dhcp-iface'] == "1")) {
|
if (($_POST['dhcp-iface'] == "1")) {
|
||||||
$errors = ValidateDHCPInput();
|
$errors = ValidateDHCPInput();
|
||||||
if (empty($errors)) {
|
if (empty($errors)) {
|
||||||
$return = UpdateDnsmasqCfg($iface,$status);
|
$return = UpdateDHCPConfig($iface,$status);
|
||||||
} else {
|
} else {
|
||||||
$status->addMessage($errors, 'danger');
|
$status->addMessage($errors, 'danger');
|
||||||
}
|
}
|
||||||
@ -79,12 +79,12 @@ function SaveDHCPConfig($status)
|
|||||||
$status->addMessage('Dnsmasq configuration failed to be updated.', 'danger');
|
$status->addMessage('Dnsmasq configuration failed to be updated.', 'danger');
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$return = UpdateDHCPCfg($iface,$status);
|
$return = UpdateDnsmasqConfig($iface,$status);
|
||||||
|
|
||||||
// process disable dhcp option
|
// process disable dhcp option
|
||||||
} elseif (($_POST['dhcp-iface'] == "0") && file_exists(RASPI_DNSMASQ_PREFIX.$iface.'.conf')) {
|
} elseif (($_POST['dhcp-iface'] == "0") && file_exists(RASPI_DNSMASQ_PREFIX.$iface.'.conf')) {
|
||||||
// remove dhcp conf for selected interface
|
// remove dhcp conf for selected interface
|
||||||
$return = RemoveDHCPCfg($iface,$status);
|
$return = RemoveDHCPConfig($iface,$status);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($return == 0) {
|
if ($return == 0) {
|
||||||
@ -105,14 +105,16 @@ function ValidateDHCPInput()
|
|||||||
) {
|
) {
|
||||||
$errors .= _('Invalid interface name.').'<br />'.PHP_EOL;
|
$errors .= _('Invalid interface name.').'<br />'.PHP_EOL;
|
||||||
}
|
}
|
||||||
if (!preg_match('/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\z/', $_POST['RangeStart'])
|
if (!filter_var($_POST['StaticIP'], FILTER_VALIDATE_IP) && !empty($_POST['StaticIP'])) {
|
||||||
&& !empty($_POST['RangeStart'])
|
$errors .= _('Invalid static IP address.').'<br />'.PHP_EOL;
|
||||||
) { // allow ''/null ?
|
}
|
||||||
|
if (!filter_var($_POST['DefaultGateway'], FILTER_VALIDATE_IP)) {
|
||||||
|
$errors .= _('Invalid default gateway.').'<br />'.PHP_EOL;
|
||||||
|
}
|
||||||
|
if (!filter_var($_POST['RangeStart'], FILTER_VALIDATE_IP) && !empty($_POST['RangeStart'])) {
|
||||||
$errors .= _('Invalid DHCP range start.').'<br />'.PHP_EOL;
|
$errors .= _('Invalid DHCP range start.').'<br />'.PHP_EOL;
|
||||||
}
|
}
|
||||||
if (!preg_match('/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\z/', $_POST['RangeEnd'])
|
if (!filter_var($_POST['RangeEnd'], FILTER_VALIDATE_IP) && !empty($_POST['RangeEnd'])) {
|
||||||
&& !empty($_POST['RangeEnd'])
|
|
||||||
) { // allow ''/null ?
|
|
||||||
$errors .= _('Invalid DHCP range end.').'<br />'.PHP_EOL;
|
$errors .= _('Invalid DHCP range end.').'<br />'.PHP_EOL;
|
||||||
}
|
}
|
||||||
if (!ctype_digit($_POST['RangeLeaseTime']) && $_POST['RangeLeaseTimeUnits'] !== 'infinite') {
|
if (!ctype_digit($_POST['RangeLeaseTime']) && $_POST['RangeLeaseTimeUnits'] !== 'infinite') {
|
||||||
@ -121,10 +123,13 @@ function ValidateDHCPInput()
|
|||||||
if (!in_array($_POST['RangeLeaseTimeUnits'], array('m', 'h', 'd', 'infinite'))) {
|
if (!in_array($_POST['RangeLeaseTimeUnits'], array('m', 'h', 'd', 'infinite'))) {
|
||||||
$errors .= _('Unknown DHCP lease time unit.').'<br />'.PHP_EOL;
|
$errors .= _('Unknown DHCP lease time unit.').'<br />'.PHP_EOL;
|
||||||
}
|
}
|
||||||
|
if ($_POST['Metric'] !== '' && !ctype_digit($_POST['Metric'])) {
|
||||||
|
$errors .= _('Invalid metric value, not a number.').'<br />'.PHP_EOL;
|
||||||
|
}
|
||||||
return $errors;
|
return $errors;
|
||||||
}
|
}
|
||||||
|
|
||||||
function UpdateDnsmasqCfg($iface,$status)
|
function UpdateDnsmasqConfig($iface,$status)
|
||||||
{
|
{
|
||||||
$config = 'interface='.$iface.PHP_EOL.
|
$config = 'interface='.$iface.PHP_EOL.
|
||||||
'dhcp-range='.$_POST['RangeStart'].','.$_POST['RangeEnd'].
|
'dhcp-range='.$_POST['RangeStart'].','.$_POST['RangeEnd'].
|
||||||
@ -173,45 +178,46 @@ function UpdateDnsmasqCfg($iface,$status)
|
|||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
function UpdateDHCPCfg($iface,$status)
|
function UpdateDHCPConfig($iface,$status)
|
||||||
{
|
{
|
||||||
$net_cfg = RASPI_CONFIG_NETWORKING.'/'.$iface.'.ini';
|
|
||||||
if (!file_exists($net_cfg) || filesize($net_cfg) ==0 ) {
|
|
||||||
$status->addMessage('Static IP address for '.$iface.' not found.', 'danger');
|
|
||||||
$status->addMessage('Configure this interface in Networking > '.$iface.'.', 'danger');
|
|
||||||
$return = 1;
|
|
||||||
} else {
|
|
||||||
$dhcp_cfg = file_get_contents(RASPI_DHCPCD_CONFIG);
|
|
||||||
if (!preg_match('/^interface\s'.$iface.'$/m', $dhcp_cfg)) {
|
|
||||||
// set dhcp values from ini
|
|
||||||
$iface_cfg = parse_ini_file($net_cfg, false, INI_SCANNER_RAW);
|
|
||||||
$ip_address = $iface_cfg['ip_address'];
|
|
||||||
$domain_name_server = ($iface_cfg['domain_name_server'] =='') ? '1.1.1.1 8.8.8.8' : $iface_cfg['domain_name_server'];
|
|
||||||
|
|
||||||
// append interface config to dhcpcd.conf
|
|
||||||
$cfg = $dhcp_conf;
|
|
||||||
$cfg[] = '# RaspAP '.$iface.' configuration';
|
$cfg[] = '# RaspAP '.$iface.' configuration';
|
||||||
$cfg[] = 'interface '.$iface;
|
$cfg[] = 'interface '.$iface;
|
||||||
$cfg[] = 'static ip_address='.$ip_address;
|
$cfg[] = 'static ip_address='.$_POST['StaticIP'];
|
||||||
$cfg[] = 'static domain_name_server='.$domain_name_server;
|
if (isset($_POST['DefaultGateway'])) {
|
||||||
|
$cfg[] = 'static routers='.$_POST['DefaultGateway'];
|
||||||
|
}
|
||||||
|
if ($_POST['DNS1'] !== '' || $_POST['DNS2'] !== '') {
|
||||||
|
$cfg[] = 'static domain_name_server='.$_POST['DNS1'].' '.$_POST['DNS2'];
|
||||||
|
}
|
||||||
|
if ($_POST['Metric'] !== '') {
|
||||||
|
$cfg[] = 'metric '.$_POST['Metric'];
|
||||||
|
}
|
||||||
|
if ($_POST['Fallback'] == 1) {
|
||||||
|
$cfg[] = 'fallback static_'.$iface;
|
||||||
|
}
|
||||||
$cfg[] = PHP_EOL;
|
$cfg[] = PHP_EOL;
|
||||||
$cfg = join(PHP_EOL, $cfg);
|
$cfg = join(PHP_EOL, $cfg);
|
||||||
|
|
||||||
|
$dhcp_cfg = file_get_contents(RASPI_DHCPCD_CONFIG);
|
||||||
|
|
||||||
|
if (!preg_match('/^interface\s'.$iface.'$/m', $dhcp_cfg)) {
|
||||||
$dhcp_cfg .= $cfg;
|
$dhcp_cfg .= $cfg;
|
||||||
file_put_contents("/tmp/dhcpddata", $dhcp_cfg);
|
file_put_contents("/tmp/dhcpddata", $dhcp_cfg);
|
||||||
system('sudo cp /tmp/dhcpddata '.RASPI_DHCPCD_CONFIG, $result);
|
system('sudo cp /tmp/dhcpddata '.RASPI_DHCPCD_CONFIG, $result);
|
||||||
$status->addMessage('DHCP configuration for '.$iface.' added.', 'success');
|
$status->addMessage('DHCP configuration for '.$iface.' added.', 'success');
|
||||||
} else {
|
} else {
|
||||||
$status->addMessage('DHCP for '.$iface.' already enabled.', 'success');
|
$dhcp_cfg = preg_replace('/^#\sRaspAP\s'.$iface.'\s.*?(?=\s*^\s*$)/ms', $cfg, $dhcp_cfg, 1);
|
||||||
}
|
file_put_contents("/tmp/dhcpddata", rtrim($dhcp_cfg).PHP_EOL);
|
||||||
|
$status->addMessage('DHCP configuration for '.$iface.' updated.', 'success');
|
||||||
}
|
}
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
function RemoveDHCPCfg($iface,$status)
|
function RemoveDHCPConfig($iface,$status)
|
||||||
{
|
{
|
||||||
$dhcp_cfg = file_get_contents(RASPI_DHCPCD_CONFIG);
|
$dhcp_cfg = file_get_contents(RASPI_DHCPCD_CONFIG);
|
||||||
$dhcp_cfg = preg_replace('/^#\sRaspAP\s'.$iface.'.*\n(.*\n){3}/m', '', $dhcp_cfg);
|
$dhcp_cfg = preg_replace('/^#\sRaspAP\s'.$iface.'\s.*?(?=\s*^\s*$)/ms', '', $dhcp_cfg, 1);
|
||||||
file_put_contents("/tmp/dhcpddata", rtrim($dhcp_cfg).PHP_EOL);
|
file_put_contents("/tmp/dhcpddata", rtrim($dhcp_cfg).PHP_EOL.PHP_EOL);
|
||||||
system('sudo cp /tmp/dhcpddata '.RASPI_DHCPCD_CONFIG, $result);
|
system('sudo cp /tmp/dhcpddata '.RASPI_DHCPCD_CONFIG, $result);
|
||||||
if ($result == 0) {
|
if ($result == 0) {
|
||||||
$status->addMessage('DHCP configuration for '.$iface.' removed.', 'success');
|
$status->addMessage('DHCP configuration for '.$iface.' removed.', 'success');
|
||||||
@ -219,7 +225,7 @@ function RemoveDHCPCfg($iface,$status)
|
|||||||
$status->addMessage('Failed to remove DHCP configuration for '.$iface.'.', 'danger');
|
$status->addMessage('Failed to remove DHCP configuration for '.$iface.'.', 'danger');
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
// remove dnsmasq eth0 conf
|
// remove dnsmasq conf
|
||||||
system('sudo rm '.RASPI_DNSMASQ_PREFIX.$iface.'.conf', $result);
|
system('sudo rm '.RASPI_DNSMASQ_PREFIX.$iface.'.conf', $result);
|
||||||
if ($result == 0) {
|
if ($result == 0) {
|
||||||
$status->addMessage('Dnsmasq configuration for '.$iface.' removed.', 'success');
|
$status->addMessage('Dnsmasq configuration for '.$iface.' removed.', 'success');
|
||||||
@ -229,3 +235,4 @@ function RemoveDHCPCfg($iface,$status)
|
|||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user