contrib/package: /etc/functions.sh => /lib/functions.sh
[project/luci.git] / contrib / package / meshwizard / files / usr / bin / meshwizard / helpers / setup_network.sh
index 4f03d22..e62cb5a 100755 (executable)
@@ -1,32 +1,38 @@
 # setup entry in /etc/config/network for a interface
 # Argument $1: network interface
-
 net="$1"
-. /etc/functions.sh
+. /lib/functions.sh
 . $dir/functions.sh
 
-# Delete the network interface section for $net
-if [ "$cleanup" == 1 ]; then
-       section_cleanup network.$netrenamed
-fi
-
 # Setup a (new) interface section for $net
 
 ipaddr=$(uci get meshwizard.netconfig.$net\_ip4addr)
 [ -z "$ipaddr" ] && msg_missing_value meshwizard $net\_ip4addr
 
-[ -z "$interface_netmask" ] && interface netmask="255.255.0.0"
+netmask=$(uci -q get meshwizard.netconfig.$net\_netmask)
+[ -z "$netmask" ] && netmask="$interface_netmask"
+[ -z "$netmask" ] && netmask="255.255.0.0"
+
+uci set network.$netrenamed="interface"
+set_defaults "interface_" network.$netrenamed
 
 uci batch << EOF
-set network.$netrenamed="interface"
-set network.$netrenamed.proto="static"
-set network.$netrenamed.ipaddr="$ipaddr"
-set network.$netrenamed.netmask="$interface_netmask"
-set network.$netrenamed.dns="$interface_dns"
+       set network.$netrenamed.proto="static"
+       set network.$netrenamed.ipaddr="$ipaddr"
+       set network.$netrenamed.netmask="$netmask"
 EOF
 
-echo "    IP address: $ipaddr"
-echo "    Netmask   : $interface_netmask"
+# Setup IPv6 for the interface
+local ip6addr
+if [ "$profile_ipv6" = 1 ]; then
+       if [ "$profile_ipv6_config" = "auto-ipv6-dhcpv6" ]; then
+               ip6addr="$($dir/helpers/gen_auto-ipv6-dhcpv6-ip.sh $netrenamed)"
+               uci set network.$netrenamed.ip6addr="${ip6addr}/112"
+       fi
+fi
+
+uci_commitverbose "Setup interface $netrenamed" network
 
 # setup dhcp alias/interface
 
@@ -38,16 +44,12 @@ if [ "$net_dhcp" == 1 ]; then
        interface_ip="$(uci -q get meshwizard.netconfig.${net}_ip4addr)"
        vap=$(uci -q get meshwizard.netconfig.${net}_vap)
 
-       # Clean/rename config
+       # Rename config
        handle_dhcpalias() {
                        config_get interface "$1" interface
                        if [ "$interface" == "$netrenamed" ]; then
-                               if [ "$cleanup" == 1 ]; then
-                                       section_cleanup network.$1
-                               else
-                                       if [ -z "${1/cfg[0-9a-fA-F]*/}" ]; then
-                                               section_rename network $1 ${netrenamed}dhcp
-                                       fi
+                               if [ -z "${1/cfg[0-9a-fA-F]*/}" ]; then
+                                       section_rename network $1 ${netrenamed}dhcp
                                fi
                        fi
        }
@@ -68,24 +70,17 @@ if [ "$net_dhcp" == 1 ]; then
        # Setup alias for $net
 
        if [ "$vap" == 1 ]; then
-               echo "    + Setup interface ${netrenamed}dhcp."
                uci set network.${netrenamed}dhcp=interface
        else
-               echo "    + Setup alias interface ${netrenamed}dhcp."
                uci set network.${netrenamed}dhcp=alias
                uci set network.${netrenamed}dhcp.interface="$netrenamed"
        fi
 
-       uci batch << EOF
-set network.${netrenamed}dhcp.proto=static
-set network.${netrenamed}dhcp.ipaddr="$START"
-set network.${netrenamed}dhcp.netmask="$NETMASK"
-EOF
-
-       echo "    interface: $net
-    ipaddr: $START
-    netmask: $NETMASK"
+       uci batch <<- EOF
+               set network.${netrenamed}dhcp.proto=static
+               set network.${netrenamed}dhcp.ipaddr="$START"
+               set network.${netrenamed}dhcp.netmask="$NETMASK"
+       EOF
+       uci_commitverbose  "Setup interface for ${netrenamed}dhcp" network
 
 fi
-
-uci commit