From 06c8c28bab9975149f94397f3b7027712c0ba424 Mon Sep 17 00:00:00 2001 From: Jo-Philipp Wich Date: Wed, 21 Nov 2012 20:13:53 +0000 Subject: libs/core: introduce get_status_by_address() in luci.model.network --- libs/core/luasrc/model/network.lua | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) (limited to 'libs/core/luasrc') diff --git a/libs/core/luasrc/model/network.lua b/libs/core/luasrc/model/network.lua index cc572298c6..56f1751f81 100644 --- a/libs/core/luasrc/model/network.lua +++ b/libs/core/luasrc/model/network.lua @@ -623,6 +623,32 @@ function get_status_by_route(self, addr, mask) end end +function get_status_by_address(self, addr) + local _, object + for _, object in ipairs(_ubus:objects()) do + local net = object:match("^network%.interface%.(.+)") + if net then + local s = _ubus:call(object, "status", {}) + if s and s['ipv4-address'] then + local a + for _, a in ipairs(s['ipv4-address']) do + if a.address == addr then + return net, s + end + end + end + if s and s['ipv6-address'] then + local a + for _, a in ipairs(s['ipv6-address']) do + if a.address == addr then + return net, s + end + end + end + end + end +end + function get_wannet(self) local net = self:get_status_by_route("0.0.0.0", 0) return net and network(net) -- cgit v1.2.3