X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/87897e1c5939928756eef0b6e93fc56e201b7aea..5d526120bd7580668a774447d4644164be767b58:/package/dnsmasq/files/dnsmasq.init?ds=sidebyside diff --git a/package/dnsmasq/files/dnsmasq.init b/package/dnsmasq/files/dnsmasq.init index 9797490c4..442550450 100644 --- a/package/dnsmasq/files/dnsmasq.init +++ b/package/dnsmasq/files/dnsmasq.init @@ -23,7 +23,7 @@ append_bool() { local value="$3" local _loctmp config_get_bool _loctmp "$section" "$option" - [ "$_loctmp" -gt 0 ] && append args "$3" + [ "$_loctmp" -gt 0 ] && append args "$value" } append_parm() { @@ -144,6 +144,8 @@ dhcp_host_add() { config_get mac "$cfg" mac [ -n "$mac" ] || return 0 + config_get ip "$cfg" ip + [ -n "$ip" ] || return 0 append args "--dhcp-host=$mac,$ip" @@ -186,7 +188,8 @@ dhcp_add() { [ static = "$proto" ] || return 0 config_get ipaddr "$net" ipaddr - config_get netmask "$net" netmask + config_get netmask "$cfg" netmask + [ -n "$netmask" ] || config_get netmask "$net" netmask #check for an already active dhcp server on the interface, unless 'force' is set config_get_bool force "$cfg" force 0 @@ -198,11 +201,13 @@ dhcp_add() { config_get limit "$cfg" limit config_get leasetime "$cfg" leasetime config_get options "$cfg" options + config_get_bool dynamicdhcp "$cfg" dynamicdhcp 1 leasetime="${leasetime:-12h}" start="$(dhcp_calc "${start:-100}")" limit="$((${limit:-150} + 1))" eval "$(ipcalc.sh $ipaddr $netmask $start $limit)" + if [ "$dynamicdhcp" = "0" ]; then END="static"; fi append args "--dhcp-range=$name,$START,$END,$NETMASK,$leasetime${options:+ $options}" dhcp_option_add "$cfg" "$name"