diff options
author | Manuel Munz <freifunk@somakoma.de> | 2011-03-14 19:34:23 +0000 |
---|---|---|
committer | Manuel Munz <freifunk@somakoma.de> | 2011-03-14 19:34:23 +0000 |
commit | daadcb9ea2edc6d6c99b379b40ea9f8a56864a04 (patch) | |
tree | e810ad54254f42e99cb06743b1ab04c228c0d579 /applications/luci-freifunk-policyrouting/luasrc/model | |
parent | f5bfd8b75be995e7e7d106343475172a38f4802f (diff) |
Add freifunk-policyrouting and luci-app-freifunk-policyrouting
Diffstat (limited to 'applications/luci-freifunk-policyrouting/luasrc/model')
-rw-r--r-- | applications/luci-freifunk-policyrouting/luasrc/model/cbi/freifunk/policyrouting.lua | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/applications/luci-freifunk-policyrouting/luasrc/model/cbi/freifunk/policyrouting.lua b/applications/luci-freifunk-policyrouting/luasrc/model/cbi/freifunk/policyrouting.lua new file mode 100644 index 0000000000..b3cac9a10a --- /dev/null +++ b/applications/luci-freifunk-policyrouting/luasrc/model/cbi/freifunk/policyrouting.lua @@ -0,0 +1,40 @@ +--[[ +LuCI - Lua Configuration Interface + +Copyright 2011 Manuel Munz <freifunk at somakoma de> + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 +]]-- + +luci.i18n.loadc("freifunk") +local uci = require "luci.model.uci".cursor() + +m = Map("freifunk-policyrouting", translate("Policy Routing"), translate("These pages can be used to setup policy routing for certain firewall zones. ".. + "This is useful if you need to use your own internet connection for yourself but you don't want to share it with others (thats why it can also be ".. + "called 'Ego Mode'). Your own traffic is then sent via your internet connection while traffic originating from the mesh will use another gateway in the mesh. ")) +m:chain("network") + +c = m:section(NamedSection, "pr", "settings", "") + +local pr = c:option(Flag, "enable", translate("Enable Policy Routing")) +pr.rmempty = false + +local strict = c:option(Flag, "strict", translate("Strict Filtering"), translate("If no default route is received from the mesh network then traffic which belongs to ".. + "the selected firewall zones is routed via your internet connection as a fallback. If you do not want this and instead block that traffic then you should ".. + "select this option.")) +strict.rmempty = false + +local zones = c:option(MultiValue, "zones", translate("Firewall zones"), translate("All traffic from interfaces belonging to these zones will be sent via ".. + "a gateway in the mesh network.")) +uci:foreach("firewall", "zone", function(section) + local name = section.name + if not (name == "wan") then + zones:value(name) + end +end) + +return m |