diff options
author | jow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2012-05-28 03:15:02 +0000 |
---|---|---|
committer | jow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2012-05-28 03:15:02 +0000 |
commit | 41d413b29cf9461f501c280e1ede2280f7932557 (patch) | |
tree | 2285dee3f9444194b299c1b34d07b95076fde9f3 /package/base-files | |
parent | 0f299fab073954b94f4804784b39b1fcb5bef8d9 (diff) |
[package] base-files: introduce /lib/functions/network.sh
This file will contain common procedures to deal with network interfaces.
Initially provides network_get_ipaddr(), network_get_ipaddr6(),
network_get_subnet() and network_get_subnet6() to determine the
primary IP addresses or subnets of a given logical interface.
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@31935 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/base-files')
-rw-r--r-- | package/base-files/Makefile | 2 | ||||
-rw-r--r-- | package/base-files/files/lib/functions/network.sh | 41 |
2 files changed, 42 insertions, 1 deletions
diff --git a/package/base-files/Makefile b/package/base-files/Makefile index ae96ab54b..4e9b41f0e 100644 --- a/package/base-files/Makefile +++ b/package/base-files/Makefile @@ -11,7 +11,7 @@ include $(INCLUDE_DIR)/kernel.mk include $(INCLUDE_DIR)/version.mk PKG_NAME:=base-files -PKG_RELEASE:=107 +PKG_RELEASE:=108 PKG_FILE_DEPENDS:=$(PLATFORM_DIR)/ $(GENERIC_PLATFORM_DIR)/base-files/ PKG_BUILD_DEPENDS:=opkg/host diff --git a/package/base-files/files/lib/functions/network.sh b/package/base-files/files/lib/functions/network.sh new file mode 100644 index 000000000..1b42133ba --- /dev/null +++ b/package/base-files/files/lib/functions/network.sh @@ -0,0 +1,41 @@ +. /usr/share/libubox/jshn.sh + +__network_ipaddr() +{ + local __var="$1" + local __iface="$2" + local __family="$3" + local __prefix="${4:-0}" + + local __tmp="$(ubus call network.interface."$__iface" status 2>/dev/null)" + + json_load "${__tmp:-{}}" + json_get_type __tmp "ipv${__family}_address" + + if [ "$__tmp" = array ]; then + + json_select "ipv${__family}_address" + json_get_type __tmp 1 + + if [ "$__tmp" = object ]; then + + json_select 1 + json_get_var $__var address + + [ $__prefix -gt 0 ] && { + json_get_var __tmp mask + eval "export -- \"$__var=\${$__var}/$__tmp\"" + } + + return 0 + fi + fi + + return 1 +} + +network_get_ipaddr() { __network_ipaddr "$1" "$2" 4 0; } +network_get_ipaddr6() { __network_ipaddr "$1" "$2" 6 0; } + +network_get_subnet() { __network_ipaddr "$1" "$2" 4 1; } +network_get_subnet6() { __network_ipaddr "$1" "$2" 6 1; } |