local iface="$2"
local link="dslite-$cfg"
- local mtu ttl peeraddr ip6addr tunlink zone
- json_get_vars mtu ttl peeraddr ip6addr tunlink zone
+ local mtu ttl peeraddr ip6addr tunlink zone weakif
+ json_get_vars mtu ttl peeraddr ip6addr tunlink zone weakif
[ -z "$peeraddr" ] && {
proto_notify_error "$cfg" "MISSING_ADDRESS"
( proto_add_host_dependency "$cfg" "::" "$tunlink" )
+ peeraddr=$(resolveip -6 $peeraddr)
+ if [ -z "$peeraddr" ]; then
+ sleep 3
+ peeraddr=$(resolveip -6 $peeraddr)
+ if [ -z "$peeraddr" ]; then
+ proto_notify_error "$cfg" "AFTR_DNS_FAIL"
+ return
+ fi
+ fi
+ peeraddr="${peeraddr%% *}"
+
[ -z "$ip6addr" ] && {
local wanif="$tunlink"
if [ -z "$wanif" ] && ! network_find_wan6 wanif; then
fi
if ! network_get_ipaddr6 ip6addr "$wanif"; then
- proto_notify_error "$cfg" "NO_WAN_LINK"
- return
+ [ -z "$weakif" ] && weakif="lan"
+ if ! network_get_ipaddr6 ip6addr "$weakif"; then
+ proto_notify_error "$cfg" "NO_WAN_LINK"
+ return
+ fi
fi
}
proto_add_data
[ -n "$zone" ] && json_add_string zone "$zone"
+
+ json_add_array firewall
+ json_add_object ""
+ json_add_string type nat
+ json_add_string target ACCEPT
+ json_close_object
+ json_close_array
proto_close_data
proto_send_update "$cfg"
proto_config_add_int "mtu"
proto_config_add_int "ttl"
proto_config_add_string "zone"
+ proto_config_add_string "weakif"
}
[ -n "$INCLUDE_ONLY" ] || {