diff options
author | Jo-Philipp Wich <jow@openwrt.org> | 2010-11-07 19:30:55 +0000 |
---|---|---|
committer | Jo-Philipp Wich <jow@openwrt.org> | 2010-11-07 19:30:55 +0000 |
commit | b8f810092b585e0e21e6c6a2e6a6e8e27b335b66 (patch) | |
tree | 2523d8feaf95c9904240b39c8e630df83bb77d7f /applications/luci-upnp/luasrc/controller/upnp.lua | |
parent | 9663c7cf2e56c59db2888caae25098d32ef91bcd (diff) |
applications/luci-upnp: enable/disable service, live status, allow removing single forwards
Diffstat (limited to 'applications/luci-upnp/luasrc/controller/upnp.lua')
-rw-r--r-- | applications/luci-upnp/luasrc/controller/upnp.lua | 64 |
1 files changed, 58 insertions, 6 deletions
diff --git a/applications/luci-upnp/luasrc/controller/upnp.lua b/applications/luci-upnp/luasrc/controller/upnp.lua index fd3175553c..fe9d3d8f5b 100644 --- a/applications/luci-upnp/luasrc/controller/upnp.lua +++ b/applications/luci-upnp/luasrc/controller/upnp.lua @@ -18,13 +18,65 @@ function index() if not nixio.fs.access("/etc/config/upnpd") then return end - - local page = entry({"admin", "services", "upnp"}, cbi("upnp/upnp"), "UPNP") + + local page + + page = entry({"admin", "services", "upnp"}, cbi("upnp/upnp"), "UPNP") page.i18n = "upnp" page.dependent = true - - - local page = entry({"mini", "network", "upnp"}, cbi("upnp/upnpmini", {autoapply=true}), "UPNP") + + page = entry({"mini", "network", "upnp"}, cbi("upnp/upnpmini", {autoapply=true}), "UPNP") page.i18n = "upnp" page.dependent = true -end
\ No newline at end of file + + entry({"admin", "services", "upnp", "status"}, call("act_status")).leaf = true + entry({"admin", "services", "upnp", "delete"}, call("act_delete")).leaf = true +end + +function act_status() + local ipt = io.popen("iptables --line-numbers -t nat -xnvL MINIUPNPD") + if ipt then + local fwd = { } + while true do + local ln = ipt:read("*l") + if not ln then + break + elseif ln:match("^%d+") then + local num, proto, extport, intaddr, intport = + ln:match("^(%d+).-([a-z]+).-dpt:(%d+) to:(%S-):(%d+)") + + if num and proto and extport and intaddr and intport then + num = tonumber(num) + extport = tonumber(extport) + intport = tonumber(intport) + + fwd[#fwd+1] = { + num = num, + proto = proto:upper(), + extport = extport, + intaddr = intaddr, + intport = intport + } + end + end + end + + ipt:close() + + luci.http.prepare_content("application/json") + luci.http.write_json(fwd) + end +end + +function act_delete() + local path = luci.dispatcher.context.requestpath + local idx = tonumber(path[#path]) + + if idx and idx > 0 then + luci.sys.call("iptables -t filter -D MINIUPNPD %d 2>/dev/null" % idx) + luci.sys.call("iptables -t nat -D MINIUPNPD %d 2>/dev/null" % idx) + return + end + + luci.http.status(400, "Bad request") +end |