X-Git-Url: https://git.archive.openwrt.org/?p=project%2Fluci.git;a=blobdiff_plain;f=applications%2Fluci-qos%2Fluasrc%2Fmodel%2Fcbi%2Fqos%2Fqos.lua;h=8d852e75083ca0638fd6a44fdd34031256f7775a;hp=0bb559edebed5991b7ebb1871c381b093a89e1eb;hb=d0a994096448d56122fe7f9a3b1f482e3f318a61;hpb=52d49762ed28033d82e5ab1e0ccf65ad74a4b593 diff --git a/applications/luci-qos/luasrc/model/cbi/qos/qos.lua b/applications/luci-qos/luasrc/model/cbi/qos/qos.lua index 0bb559ede..8d852e750 100644 --- a/applications/luci-qos/luasrc/model/cbi/qos/qos.lua +++ b/applications/luci-qos/luasrc/model/cbi/qos/qos.lua @@ -11,68 +11,86 @@ You may obtain a copy of the License at $Id$ ]]-- -m = Map("qos") -s = m:section(TypedSection, "interface", translate("interfaces")) +local wa = require "luci.tools.webadmin" +local fs = require "nixio.fs" + +m = Map("qos", translate("Quality of Service"), + translate("With QoS you " .. + "can prioritize network traffic selected by addresses, " .. + "ports or services.")) + +s = m:section(TypedSection, "interface", translate("Interfaces")) s.addremove = true +s.anonymous = false -s:option(Flag, "enabled", translate("enable")) +e = s:option(Flag, "enabled", translate("Enable")) +e.rmempty = false -c = s:option(ListValue, "classgroup") -c:value("Default", "standard") +c = s:option(ListValue, "classgroup", translate("Classification group")) +c:value("Default", translate("default")) c.default = "Default" -s:option(Flag, "overhead") +s:option(Flag, "overhead", translate("Calculate overhead")) -s:option(Value, "download", nil, "kb/s") +s:option(Flag, "halfduplex", translate("Half-duplex")) -s:option(Value, "upload", nil, "kb/s") +s:option(Value, "download", translate("Download speed (kbit/s)")) -s = m:section(TypedSection, "classify") +s:option(Value, "upload", translate("Upload speed (kbit/s)")) +s = m:section(TypedSection, "classify", translate("Classification Rules")) +s.template = "cbi/tblsection" s.anonymous = true s.addremove = true -t = s:option(ListValue, "target") -t:value("Priority", translate("qos_priority")) -t:value("Express", translate("qos_express")) -t:value("Normal", translate("qos_normal")) -t:value("Bulk", translate("qos_bulk")) +t = s:option(ListValue, "target", translate("Target")) +t:value("Priority", translate("priority")) +t:value("Express", translate("express")) +t:value("Normal", translate("normal")) +t:value("Bulk", translate("low")) t.default = "Normal" -s:option(Value, "srchost").optional = true -s:option(Value, "dsthost").optional = true +srch = s:option(Value, "srchost", translate("Source host")) +srch.rmempty = true +srch:value("", translate("all")) +wa.cbi_add_knownips(srch) + +dsth = s:option(Value, "dsthost", translate("Destination host")) +dsth.rmempty = true +dsth:value("", translate("all")) +wa.cbi_add_knownips(dsth) -l7 = s:option(ListValue, "layer7", translate("service")) -l7.optional = true -l7:value("") -local pats = luci.fs.dir("/etc/l7-protocols") +l7 = s:option(ListValue, "layer7", translate("Service")) +l7.rmempty = true +l7:value("", translate("all")) + +local pats = io.popen("find /etc/l7-protocols/ -type f -name '*.pat'") if pats then - for i,f in ipairs(pats) do - if f:sub(-4) == ".pat" then - l7:value(f:sub(1, #f-4)) + local l + while true do + l = pats:read("*l") + if not l then break end + + l = l:match("([^/]+)%.pat$") + if l then + l7:value(l) end end + pats:close() end -p2p = s:option(ListValue, "ipp2p", "P2P") -p2p:value("") -p2p:value("all", translate("all")) -p2p:value("bit", "BitTorrent") -p2p:value("dc", "DirectConnect") -p2p:value("edk", "eDonkey") -p2p:value("gnu", "Gnutella") -p2p:value("kazaa", "Kazaa") -p2p.optional = true - -p = s:option(ListValue, "proto", translate("protocol")) -p:value("") +p = s:option(Value, "proto", translate("Protocol")) +p:value("", translate("all")) p:value("tcp", "TCP") p:value("udp", "UDP") p:value("icmp", "ICMP") -p.optional = true +p.rmempty = true + +ports = s:option(Value, "ports", translate("Ports")) +ports.rmempty = true +ports:value("", translate("all")) -s:option(Value, "ports", translate("port")).optional = true -s:option(Value, "portrange").optional = true +bytes = s:option(Value, "connbytes", translate("Number of bytes")) -return m \ No newline at end of file +return m