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=ea535cea23d8f1b60cc00a3430f94779b2fa098f;hb=d0a994096448d56122fe7f9a3b1f482e3f318a61;hpb=211c6394a0d145d3215893b827241723bb358a13 diff --git a/applications/luci-qos/luasrc/model/cbi/qos/qos.lua b/applications/luci-qos/luasrc/model/cbi/qos/qos.lua index ea535cea2..8d852e750 100644 --- a/applications/luci-qos/luasrc/model/cbi/qos/qos.lua +++ b/applications/luci-qos/luasrc/model/cbi/qos/qos.lua @@ -11,57 +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") -t:value("Express") -t:value("Normal") -t:value("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 -s:option(Value, "layer7", "Layer 7").optional = true - -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("") +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.rmempty = true +l7:value("", translate("all")) + +local pats = io.popen("find /etc/l7-protocols/ -type f -name '*.pat'") +if pats then + 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 + +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