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=6965078edf631de85d50df3136ad70bb58c66649;hp=ac5f3b27cb7bfbdf689feb988a55704719cae52c;hb=d5ed4ae9981036d1019f36a9e89a4bb96be4fbec;hpb=f2148a5c65fa6c66d0d22fa43ec2f3e71aac9aa1 diff --git a/applications/luci-qos/luasrc/model/cbi/qos/qos.lua b/applications/luci-qos/luasrc/model/cbi/qos/qos.lua index ac5f3b27c..6965078ed 100644 --- a/applications/luci-qos/luasrc/model/cbi/qos/qos.lua +++ b/applications/luci-qos/luasrc/model/cbi/qos/qos.lua @@ -11,79 +11,91 @@ You may obtain a copy of the License at $Id$ ]]-- -require("luci.tools.webadmin") -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(Flag, "halfduplex", translate("Half-duplex")) -s:option(Value, "download", nil, "kb/s") +dl = s:option(Value, "download", translate("Download speed (kbit/s)")) +dl.datatype = "and(uinteger,min(1))" -s:option(Value, "upload", nil, "kb/s") +ul = s:option(Value, "upload", translate("Upload speed (kbit/s)")) +ul.datatype = "and(uinteger,min(1))" -s = m:section(TypedSection, "classify") +s = m:section(TypedSection, "classify", translate("Classification Rules")) s.template = "cbi/tblsection" s.anonymous = true s.addremove = true +s.sortable = 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" -srch = s:option(Value, "srchost") +srch = s:option(Value, "srchost", translate("Source host")) srch.rmempty = true srch:value("", translate("all")) -luci.tools.webadmin.cbi_add_knownips(srch) +wa.cbi_add_knownips(srch) -dsth = s:option(Value, "dsthost") +dsth = s:option(Value, "dsthost", translate("Destination host")) dsth.rmempty = true dsth:value("", translate("all")) -luci.tools.webadmin.cbi_add_knownips(dsth) +wa.cbi_add_knownips(dsth) -l7 = s:option(ListValue, "layer7", translate("service")) +l7 = s:option(ListValue, "layer7", translate("Service")) l7.rmempty = true l7:value("", translate("all")) -local pats = luci.fs.dir("/etc/l7-protocols") + +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", "BIT") -p2p:value("dc", "DC") -p2p:value("edk", "EDK") -p2p:value("gnu", "GNU") -p2p:value("kazaa", "KAZ") -p2p.rmempty = true - -p = s:option(Value, "proto", translate("protocol")) +p = s:option(Value, "proto", translate("Protocol")) p:value("", translate("all")) p:value("tcp", "TCP") p:value("udp", "UDP") p:value("icmp", "ICMP") p.rmempty = true -ports = s:option(Value, "ports", translate("ports")) +ports = s:option(Value, "ports", translate("Ports")) ports.rmempty = true -ports:value("", translate("allf", translate("all"))) +ports:value("", translate("all")) + +bytes = s:option(Value, "connbytes", translate("Number of bytes")) -bytes = s:option(Value, "connbytes", translate("qos_connbytes")) +comment = s:option(Value, "comment", translate("Comment")) return m