summaryrefslogtreecommitdiffhomepage
path: root/libs/core/luasrc
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2011-09-14 09:36:55 +0000
committerJo-Philipp Wich <jow@openwrt.org>2011-09-14 09:36:55 +0000
commit0285631f5bf4297c8dacccf77d9495db5873bf99 (patch)
tree73dd3d6902bb7d3999c02617fae29180e7ff2ade /libs/core/luasrc
parenta4ea7904b87954730929a90cc610c3da451f576f (diff)
libs/core: also enumerate not-yet-spawned vlan interfaces in network model, differentiate switch and vlan interfaces
Diffstat (limited to 'libs/core/luasrc')
-rw-r--r--libs/core/luasrc/model/network.lua24
1 files changed, 23 insertions, 1 deletions
diff --git a/libs/core/luasrc/model/network.lua b/libs/core/luasrc/model/network.lua
index 56597a285..45864719a 100644
--- a/libs/core/luasrc/model/network.lua
+++ b/libs/core/luasrc/model/network.lua
@@ -394,6 +394,24 @@ function get_interfaces(self)
end
end
+ -- find vlan interfaces
+ uci_r:foreach("network", "switch_vlan",
+ function(s)
+ local base = s.device or "-"
+ if not base:match("^eth%d") then
+ base = "eth0"
+ end
+
+ local vid = tonumber(s.vid or s.vlan)
+ if vid ~= nil and vid >= 0 and vid <= 4095 then
+ local iface = "%s.%d" %{ base, vid }
+ if not seen[iface] then
+ seen[iface] = true
+ nfs[iface] = interface(iface)
+ end
+ end
+ end)
+
for iface in utl.kspairs(nfs) do
ifaces[#ifaces+1] = nfs[iface]
end
@@ -823,7 +841,9 @@ function interface.type(self)
return "wifi"
elseif brs[self.ifname] then
return "bridge"
- elseif sws[self.ifname] or self.ifname:match("%.") then
+ elseif self.ifname:match("%.") then
+ return "vlan"
+ elseif sws[self.ifname] then
return "switch"
else
return "ethernet"
@@ -861,6 +881,8 @@ function interface.get_type_i18n(self)
return i18n.translate("Bridge")
elseif x == "switch" then
return i18n.translate("Ethernet Switch")
+ elseif x == "vlan" then
+ return i18n.translate("VLAN Interface")
else
return i18n.translate("Ethernet Adapter")
end