diff options
author | Jo-Philipp Wich <jow@openwrt.org> | 2009-07-10 19:11:37 +0000 |
---|---|---|
committer | Jo-Philipp Wich <jow@openwrt.org> | 2009-07-10 19:11:37 +0000 |
commit | 6940edbdce86a6fec722b93875bf46d14b00c475 (patch) | |
tree | 8bccc06b106b3cbd8e60e492d210779c6a226af3 /modules/admin-full | |
parent | 60613ef05cd3ca9086c5e5c9ac292f5630f3f533 (diff) |
modules/admin-full: speedup route status page by reimplementing it as template
Diffstat (limited to 'modules/admin-full')
3 files changed, 90 insertions, 80 deletions
diff --git a/modules/admin-full/luasrc/controller/admin/status.lua b/modules/admin-full/luasrc/controller/admin/status.lua index d8fa9e9f6..57496be92 100644 --- a/modules/admin-full/luasrc/controller/admin/status.lua +++ b/modules/admin-full/luasrc/controller/admin/status.lua @@ -21,7 +21,7 @@ function index() entry({"admin", "status", "interfaces"}, template("admin_status/interfaces"), i18n("interfaces", "Interfaces"), 1) entry({"admin", "status", "iptables"}, call("action_iptables"), i18n("a_s_ipt", "Firewall"), 2) entry({"admin", "status", "conntrack"}, form("admin_status/conntrack"), i18n("a_n_conntrack"), 3) - entry({"admin", "status", "routes"}, form("admin_status/routes"), i18n("a_n_routes"), 4) + entry({"admin", "status", "routes"}, template("admin_status/routes"), i18n("a_n_routes"), 4) entry({"admin", "status", "syslog"}, call("action_syslog"), i18n("syslog", "System Log"), 5) entry({"admin", "status", "dmesg"}, call("action_dmesg"), i18n("dmesg", "Kernel Log"), 6) diff --git a/modules/admin-full/luasrc/model/cbi/admin_status/routes.lua b/modules/admin-full/luasrc/model/cbi/admin_status/routes.lua deleted file mode 100644 index 5b147eff7..000000000 --- a/modules/admin-full/luasrc/model/cbi/admin_status/routes.lua +++ /dev/null @@ -1,79 +0,0 @@ ---[[ -LuCI - Lua Configuration Interface - -Copyright 2008 Steven Barth <steven@midlink.org> - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -$Id$ -]]-- - -require("luci.tools.webadmin") -m = Map("network", translate("a_n_routes"), translate("a_n_routes1")) - -local routes = luci.sys.net.routes() -local routes6 = luci.sys.net.routes6() -local bit = require "bit" - -v = m:section(Table, routes, translate("a_n_routes_kernel4")) - -net = v:option(DummyValue, "iface", translate("network")) -function net.cfgvalue(self, section) - return luci.tools.webadmin.iface_get_network(routes[section].device) - or routes[section].device -end - -target = v:option(DummyValue, "target", translate("target")) -function target.cfgvalue(self, section) - return routes[section].dest:network():string() -end - -netmask = v:option(DummyValue, "netmask", translate("netmask")) -function netmask.cfgvalue(self, section) - return routes[section].dest:mask():string() -end - -gateway = v:option(DummyValue, "gateway", translate("gateway")) -function gateway.cfgvalue(self, section) - return routes[section].gateway:string() -end - -metric = v:option(DummyValue, "metric", translate("metric")) -function metric.cfgvalue(self, section) - return routes[section].metric -end - -if routes6 then - v = m:section(Table, routes6, translate("a_n_routes_kernel6")) - - net = v:option(DummyValue, "iface", translate("network")) - function net.cfgvalue(self, section) - return luci.tools.webadmin.iface_get_network(routes6[section].device) - or routes6[section].device - end - - target = v:option(DummyValue, "target", translate("target")) - function target.cfgvalue(self, section) - return routes6[section].dest:string() - end - - gateway = v:option(DummyValue, "gateway", translate("gateway6")) - function gateway.cfgvalue(self, section) - return routes6[section].source:string() - end - - metric = v:option(DummyValue, "metric", translate("metric")) - function metric.cfgvalue(self, section) - local metr = routes6[section].metric - local lower = bit.band(metr, 0xffff) - local higher = bit.rshift(bit.band(metr, 0xffff0000), 16) - return "%04X%04X" % {higher, lower} - end -end - - -return m diff --git a/modules/admin-full/luasrc/view/admin_status/routes.htm b/modules/admin-full/luasrc/view/admin_status/routes.htm new file mode 100644 index 000000000..7bde82b17 --- /dev/null +++ b/modules/admin-full/luasrc/view/admin_status/routes.htm @@ -0,0 +1,89 @@ +<%# +LuCI - Lua Configuration Interface +Copyright 2008-2009 Steven Barth <steven@midlink.org> +Copyright 2008-2009 Jo-Philipp Wich <xm@subsignal.org> + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +$Id$ + +-%> + +<%- + require "bit" + require "luci.fs" + require "luci.sys" + require "luci.tools.webadmin" + + local style = true +-%> + +<%+header%> + +<div class="cbi-map" id="cbi-network"> + <h2><a id="content" name="content"><%:a_n_routes%></a></h2> + <div class="cbi-map-descr"><%:a_n_routes1%></div> + + <fieldset class="cbi-section" id="cbi-table-table"> + <legend><%:a_n_routes_kernel4%></legend> + + <div class="cbi-section-node"> + <table class="cbi-section-table"> + <tr class="cbi-section-table-titles"> + <th class="cbi-section-table-cell"><%:network%></th> + <th class="cbi-section-table-cell"><%:target%></th> + <th class="cbi-section-table-cell"><%:netmask%></th> + <th class="cbi-section-table-cell"><%:gateway%></th> + <th class="cbi-section-table-cell"><%:metric%></th> + </tr> + <% luci.sys.net.routes(function(rt) %> + <tr class="cbi-section-table-row cbi-rowstyle-<%=(style and 1 or 2)%>"> + <td class="cbi-value-field"><%=luci.tools.webadmin.iface_get_network(rt.device) or rt.device%></td> + <td class="cbi-value-field"><%=rt.dest:network():string()%></td> + <td class="cbi-value-field"><%=rt.dest:mask():string()%></td> + <td class="cbi-value-field"><%=rt.gateway:string()%></td> + <td class="cbi-value-field"><%=rt.metric%></td> + </tr> + <% style = not style; end) %> + </table> + </div> + </fieldset> + <br /> + + <% if luci.fs.access("/proc/net/ipv6_route") then style = true %> + <fieldset class="cbi-section" id="cbi-table-table"> + <legend><%:a_n_routes_kernel6%></legend> + + <div class="cbi-section-node"> + <table class="cbi-section-table"> + <tr class="cbi-section-table-titles"> + <th class="cbi-section-table-cell"><%:network%></th> + <th class="cbi-section-table-cell"><%:target%></th> + <th class="cbi-section-table-cell"><%:gateway6%></th> + <th class="cbi-section-table-cell"><%:metric%></th> + </tr> + <% luci.sys.net.routes6(function(rt) %> + <tr class="cbi-section-table-row cbi-rowstyle-<%=(style and 1 or 2)%>"> + <td class="cbi-value-field"><%=luci.tools.webadmin.iface_get_network(rt.device) or rt.device%></td> + <td class="cbi-value-field"><%=rt.dest:string()%></td> + <td class="cbi-value-field"><%=rt.source:string()%></td> + <td class="cbi-value-field"><%- + local metr = rt.metric + local lower = bit.band(metr, 0xffff) + local higher = bit.rshift(bit.band(metr, 0xffff0000), 16) + write(string.format("%04X%04X", higher, lower)) + -%></td> + </tr> + <% style = not style; end) %> + </table> + </div> + </fieldset> + <br /> + <% end %> +</div> + +<%+footer%> |