summaryrefslogtreecommitdiffhomepage
path: root/applications/luci-splash/luasrc/model/cbi/splash/splash.lua
blob: e9d000f0dd48c67f27d6f142abf595fb0550e683 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
-- ToDo: Translate, Add descriptions and help texts
require("luci.model.uci")

m = Map("luci_splash", "Client-Splash", [[Client-Splash ist das Freifunk Hotspot-Authentifizierungs-System.]])

s = m:section(NamedSection, "general", "core", "Allgemein")
s:option(Value, "leasetime", "Freigabezeit", "h")

s:option(Value, "limit_up", "Upload-Limitierung", "Kilobyte/s - limitiert die Upload-Geschwindigkeit von Clients")
s:option(Value, "limit_down", "Download-Limitierung", "Kilobyte/s - limitiert die Download-Geschwindigkeit von Clients")

s:option(DummyValue, "_tmp", "",
	"Bandbreitenlimitierung für Clients wird aktiviert wenn sowohl Up- als auch " ..
	"Download-Geschwindigkeit angegeben werden. Auf 0 setzen um die Limitierung zu deaktivieren. " ..
	"Clients in der Whitelist werden nicht limitiert.")

s = m:section(TypedSection, "iface", "Schnittstellen",
	"Bestimmt die Schnittstellen auf denen Splashing aktiviert werden soll. " ..
	"Diese Einstellungen müssen normalerweise nicht angepasst werden.")

s.template = "cbi/tblsection"
s.addremove = true
s.anonymous = true

local uci = luci.model.uci.cursor()

zone = s:option(ListValue, "zone", "Firewallzone",
	"Splash-Regeln in der angegebenen Zone eingliedern")

uci:foreach("firewall", "zone",
	function (section)
		zone:value(section.name)
	end)
	
iface = s:option(ListValue, "network", "Netzwerk",
	"Client-Verkehr auf der angegebenen Schnittstelle abfangen")

uci:foreach("network", "interface",
	function (section)
		if section[".name"] ~= "loopback" then
			iface:value(section[".name"])
		end
	end)
	
uci:foreach("network", "alias",
	function (section)
		iface:value(section[".name"])
	end)


s = m:section(TypedSection, "whitelist", "Whitelist",
	"MAC-Adressen in dieser Liste werden automatisch freigegeben und unterliegen " ..
	"keiner Bandbreitenlimitierung.")

s.template = "cbi/tblsection"
s.addremove = true
s.anonymous = true
s:option(Value, "mac", "MAC-Adresse")


s = m:section(TypedSection, "blacklist", "Blacklist",
	"MAC-Adressen in dieser Liste werden automatisch gesperrt. Verkehr von diesen " ..
	"Adressen wird komplett verworfen und es wird kein Verbindungsaufbau via WLAN " ..
	"zugelassen.")

s.template = "cbi/tblsection"
s.addremove = true
s.anonymous = true
s:option(Value, "mac", "MAC-Adresse")

s = m:section(TypedSection, "subnet", "Freigegebene Subnetze",
	"Hier eingetragene Subnetze oder Host-Adressen sind vom Splash-Vorgang ausgenommen.")

s.template = "cbi/tblsection"
s.addremove = true
s.anonymous = true
s:option(Value, "ipaddr", "IP-Adresse")
s:option(Value, "netmask", "Netzmaske", "optional bei Host-Adressen").rmempty = true

	
return m