From: Jo-Philipp Wich Date: Wed, 21 Nov 2012 20:13:53 +0000 (+0000) Subject: libs/core: introduce get_status_by_address() in luci.model.network X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=06c8c28bab9975149f94397f3b7027712c0ba424;p=oweals%2Fluci.git libs/core: introduce get_status_by_address() in luci.model.network --- diff --git a/libs/core/luasrc/model/network.lua b/libs/core/luasrc/model/network.lua index cc572298c..56f1751f8 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)