aboutsummaryrefslogtreecommitdiffstats
path: root/package
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2012-06-29 19:04:11 +0000
committerJo-Philipp Wich <jow@openwrt.org>2012-06-29 19:04:11 +0000
commitb2e5c5f82e2c0340649d514bfb3bb6382ae39041 (patch)
treec52ab8e39cdef81c3119a2ca71db278ef3269ca4 /package
parent5c49ad209642f108f25854da86b6d2e99e4b6bee (diff)
downloadupstream-b2e5c5f82e2c0340649d514bfb3bb6382ae39041.tar.gz
upstream-b2e5c5f82e2c0340649d514bfb3bb6382ae39041.tar.bz2
upstream-b2e5c5f82e2c0340649d514bfb3bb6382ae39041.zip
base-files: implement network_get_dnsserver() and network_get_dnssearch() in /lib/functions/network.sh
SVN-Revision: 32531
Diffstat (limited to 'package')
-rw-r--r--package/base-files/files/lib/functions/network.sh31
1 files changed, 31 insertions, 0 deletions
diff --git a/package/base-files/files/lib/functions/network.sh b/package/base-files/files/lib/functions/network.sh
index c6b98e6e1c..d2d4aae0d9 100644
--- a/package/base-files/files/lib/functions/network.sh
+++ b/package/base-files/files/lib/functions/network.sh
@@ -82,6 +82,37 @@ network_get_gateway() { __network_gateway "$1" "$2" 4; }
network_get_gateway6() { __network_gateway "$1" "$2" 6; }
+__network_dns() {
+ local __var="$1"
+ local __iface="$2"
+ local __field="$3"
+
+ local __tmp="$(ubus call network.interface."$__iface" status 2>/dev/null)"
+ local __dns=""
+ local __idx=1
+
+ json_load "${__tmp:-{}}"
+
+ if json_get_type __tmp "$__field" && [ "$__tmp" = array ]; then
+
+ json_select "$__field"
+
+ while json_get_type __tmp "$__idx" && [ "$__tmp" = string ]; do
+
+ json_get_var __tmp "$((__idx++))"
+ __dns="${__dns:+$__dns }$__tmp"
+
+ done
+ fi
+
+ eval "export -- \"$__var=$__dns\""
+ [ -n "$__dns" ]
+}
+
+network_get_dnsserver() { __network_dns "$1" "$2" dns_server; }
+network_get_dnssearch() { __network_dns "$1" "$2" dns_search; }
+
+
__network_wan() {
local __var="$1"
local __family="$2"