summaryrefslogtreecommitdiffhomepage
path: root/modules/admin-full/luasrc/model
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2010-11-15 23:00:53 +0000
committerJo-Philipp Wich <jow@openwrt.org>2010-11-15 23:00:53 +0000
commit3386d649ea5c7b98ab654e0ae9c7228615b476b2 (patch)
tree1391e2da6cd0270f661145f691c2686fc1baa1ff /modules/admin-full/luasrc/model
parent125eb141deaedbc75f9738d1aa45087ca74a6eb8 (diff)
modules/admin-full: readd atm bridge config
Diffstat (limited to 'modules/admin-full/luasrc/model')
-rw-r--r--modules/admin-full/luasrc/model/cbi/admin_network/network.lua131
1 files changed, 4 insertions, 127 deletions
diff --git a/modules/admin-full/luasrc/model/cbi/admin_network/network.lua b/modules/admin-full/luasrc/model/cbi/admin_network/network.lua
index 566b986b2c..466acb084d 100644
--- a/modules/admin-full/luasrc/model/cbi/admin_network/network.lua
+++ b/modules/admin-full/luasrc/model/cbi/admin_network/network.lua
@@ -13,135 +13,10 @@ You may obtain a copy of the License at
$Id$
]]--
-local sys = require "luci.sys"
-local wa = require "luci.tools.webadmin"
-local fs = require "nixio.fs"
+local fs = require "nixio.fs"
-local netstate = luci.model.uci.cursor_state():get_all("network")
m = Map("network", translate("Interfaces"))
-
-local created
-local netstat = sys.net.deviceinfo()
-
-s = m:section(TypedSection, "interface", "")
-s.addremove = true
-s.anonymous = false
-s.extedit = luci.dispatcher.build_url("admin", "network", "network") .. "/%s"
-s.template = "cbi/tblsection"
-s.override_scheme = true
-
-function s.filter(self, section)
- return section ~= "loopback" and section
-end
-
-function s.create(self, section)
- if TypedSection.create(self, section) then
- created = section
- else
- self.invalid_cts = true
- end
-end
-
-function s.parse(self, ...)
- TypedSection.parse(self, ...)
- if created then
- m.uci:save("network")
- luci.http.redirect(luci.dispatcher.build_url("admin", "network", "network")
- .. "/" .. created)
- end
-end
-
-up = s:option(Flag, "up")
-function up.cfgvalue(self, section)
- return netstate[section] and netstate[section].up or "0"
-end
-
-function up.write(self, section, value)
- local call
- if value == "1" then
- call = "ifup"
- elseif value == "0" then
- call = "ifdown"
- end
- os.execute(call .. " " .. section .. " >/dev/null 2>&1")
-end
-
-ifname = s:option(DummyValue, "ifname", translate("Device"))
-function ifname.cfgvalue(self, section)
- return netstate[section] and netstate[section].ifname
-end
-
-ifname.titleref = luci.dispatcher.build_url("admin", "network", "vlan")
-
-
-if luci.model.uci.cursor():load("firewall") then
- zone = s:option(DummyValue, "_zone", translate("Zone"))
- zone.titleref = luci.dispatcher.build_url("admin", "network", "firewall", "zones")
-
- function zone.cfgvalue(self, section)
- return table.concat(wa.network_get_zones(section) or { "-" }, ", ")
- end
-end
-
-hwaddr = s:option(DummyValue, "_hwaddr",
- translate("<abbr title=\"Media Access Control\">MAC</abbr>-Address"),
- translate("Hardware Address"))
-
-function hwaddr.cfgvalue(self, section)
- local ix = self.map:get(section, "ifname") or ""
- ix = (type(ix) == "table") and ix[1] or ix
-
- local mac = fs.readfile("/sys/class/net/" .. ix .. "/address")
-
- if not mac then
- mac = luci.util.exec("ifconfig " .. ix)
- mac = mac and mac:match(" ([A-F0-9:]+)%s*\n")
- end
-
- if mac and #mac > 0 then
- return mac:upper()
- end
-
- return "?"
-end
-
-
-ipaddr = s:option(DummyValue, "ipaddr",
- translate("<abbr title=\"Internet Protocol Version 4\">IPv4</abbr>" ..
- "-Address"))
-function ipaddr.cfgvalue(self, section)
- return table.concat(wa.network_get_addresses(section), ", ")
-end
-
-txrx = s:option(DummyValue, "_txrx", translate("Traffic"),
- translate("transmitted / received"))
-
-function txrx.cfgvalue(self, section)
- local ix = self.map:get(section, "ifname")
-
- local rx = netstat and netstat[ix] and netstat[ix][1]
- rx = rx and wa.byte_format(tonumber(rx)) or "-"
-
- local tx = netstat and netstat[ix] and netstat[ix][9]
- tx = tx and wa.byte_format(tonumber(tx)) or "-"
-
- return string.format("%s / %s", tx, rx)
-end
-
-errors = s:option(DummyValue, "_err", translate("Errors"),
- translate("TX / RX"))
-
-function errors.cfgvalue(self, section)
- local ix = self.map:get(section, "ifname")
-
- local rx = netstat and netstat[ix] and netstat[ix][3]
- local tx = netstat and netstat[ix] and netstat[ix][11]
-
- rx = rx and tostring(rx) or "-"
- tx = tx and tostring(tx) or "-"
-
- return string.format("%s / %s", tx, rx)
-end
+m:section(SimpleSection).template = "admin_network/iface_overview"
-- Show ATM bridge section if we have the capabilities
if fs.access("/usr/sbin/br2684ctl") then
@@ -190,6 +65,8 @@ if fs.access("/usr/sbin/br2684ctl") then
payload = atm:taboption("advanced", ListValue, "payload", translate("Forwarding mode"))
payload:value("bridged", translate("bridged"))
payload:value("routed", translate("routed"))
+else
+ m.pageaction = false
end
return m