PKG_NAME:=gre
PKG_VERSION:=1
-PKG_RELEASE:=3
+PKG_RELEASE:=4
PKG_LICENSE:=GPL-2.0
include $(INCLUDE_DIR)/package.mk
define Package/grev4
$(call Package/gre/Default)
TITLE:=Generic Routing Encapsulation (IPv4) config support
- DEPENDS:=@(PACKAGE_gre) +kmod-gre
+ DEPENDS:=@(PACKAGE_gre) +kmod-gre +resolveip
endef
define Package/grev4/description
define Package/grev6
$(call Package/gre/Default)
TITLE:=Generic Routing Encapsulation (IPv6) config support
- DEPENDS:=@(PACKAGE_gre) @IPV6 +kmod-gre6
+ DEPENDS:=@(PACKAGE_gre) @IPV6 +kmod-gre6 +resolveip
endef
define Package/grev6/description
gre_setup() {
local cfg="$1"
local mode="$2"
+ local remoteip
local ipaddr peeraddr
json_get_vars df ipaddr peeraddr tunlink
[ -z "$peeraddr" ] && {
- proto_notify_error "$cfg" "MISSING_ADDRESS"
+ proto_notify_error "$cfg" "MISSING_PEER_ADDRESS"
proto_block_restart "$cfg"
exit
}
+ remoteip=$(resolveip -t 10 -4 "$peeraddr")
+
+ if [ -z "$remoteip" ]; then
+ proto_notify_error "$cfg" "PEER_RESOLVE_FAIL"
+ exit
+ fi
+
+ for ip in $remoteip; do
+ peeraddr=$ip
+ break
+ done
+
( proto_add_host_dependency "$cfg" "$peeraddr" "$tunlink" )
[ -z "$ipaddr" ] && {
grev6_setup() {
local cfg="$1"
local mode="$2"
+ local remoteip6
local ip6addr peer6addr weakif
json_get_vars ip6addr peer6addr tunlink weakif
[ -z "$peer6addr" ] && {
- proto_notify_error "$cfg" "MISSING_ADDRESS"
+ proto_notify_error "$cfg" "MISSING_PEER_ADDRESS"
proto_block_restart "$cfg"
exit
}
+ remoteip6=$(resolveip -t 10 -6 "$peer6addr")
+
+ if [ -z "$remoteip6" ]; then
+ proto_notify_error "$cfg" "PEER_RESOLVE_FAIL"
+ exit
+ fi
+
+ for ip6 in $remoteip6; do
+ peer6addr=$ip6
+ break
+ done
+
( proto_add_host_dependency "$cfg" "$peer6addr" "$tunlink" )
[ -z "$ip6addr" ] && {