diff options
author | Jo-Philipp Wich <jow@openwrt.org> | 2014-12-03 15:17:05 +0100 |
---|---|---|
committer | Jo-Philipp Wich <jow@openwrt.org> | 2015-01-08 16:26:20 +0100 |
commit | 1bb4822dca6113f73e3bc89e2acf15935e6f8e92 (patch) | |
tree | 35e16f100466e4e00657199b38bb3d87d52bf73f /applications/luci-splash/luasrc/controller | |
parent | 9edd0e46c3f880727738ce8ca6ff1c8b85f99ef4 (diff) |
Rework LuCI build system
* Rename subdirectories to their repective OpenWrt package names
* Make each LuCI module its own standalone package
* Deploy a shared luci.mk which is used by each module Makefile
Signed-off-by: Jo-Philipp Wich <jow@openwrt.org>
Diffstat (limited to 'applications/luci-splash/luasrc/controller')
-rw-r--r-- | applications/luci-splash/luasrc/controller/splash/splash.lua | 151 |
1 files changed, 0 insertions, 151 deletions
diff --git a/applications/luci-splash/luasrc/controller/splash/splash.lua b/applications/luci-splash/luasrc/controller/splash/splash.lua deleted file mode 100644 index 97d0400822..0000000000 --- a/applications/luci-splash/luasrc/controller/splash/splash.lua +++ /dev/null @@ -1,151 +0,0 @@ -module("luci.controller.splash.splash", package.seeall) - -local uci = luci.model.uci.cursor() -local util = require "luci.util" - -function index() - entry({"admin", "services", "splash"}, cbi("splash/splash"), _("Client-Splash"), 90) - entry({"admin", "services", "splash", "splashtext" }, form("splash/splashtext"), _("Splashtext"), 10) - - local e - - e = node("splash") - e.target = call("action_dispatch") - - node("splash", "activate").target = call("action_activate") - node("splash", "splash").target = template("splash_splash/splash") - node("splash", "blocked").target = template("splash/blocked") - - entry({"admin", "status", "splash"}, call("action_status_admin"), _("Client-Splash")) - - local page = node("splash", "publicstatus") - page.target = call("action_status_public") - page.leaf = true -end - -function action_dispatch() - local uci = luci.model.uci.cursor_state() - local mac = luci.sys.net.ip4mac(luci.http.getenv("REMOTE_ADDR")) or "" - local access = false - - uci:foreach("luci_splash", "lease", function(s) - if s.mac and s.mac:lower() == mac then access = true end - end) - uci:foreach("luci_splash", "whitelist", function(s) - if s.mac and s.mac:lower() == mac then access = true end - end) - - if #mac > 0 and access then - luci.http.redirect(luci.dispatcher.build_url()) - else - luci.http.redirect(luci.dispatcher.build_url("splash", "splash")) - end -end - -function blacklist() - leased_macs = { } - uci:foreach("luci_splash", "blacklist", - function(s) leased_macs[s.mac:lower()] = true - end) - return leased_macs -end - -function action_activate() - local ip = luci.http.getenv("REMOTE_ADDR") or "127.0.0.1" - local mac = luci.sys.net.ip4mac(ip:match("^[\[::ffff:]*(%d+.%d+%.%d+%.%d+)\]*$")) - local uci_state = require "luci.model.uci".cursor_state() - local blacklisted = false - if mac and luci.http.formvalue("accept") then - uci:foreach("luci_splash", "blacklist", - function(s) if s.mac:lower() == mac or s.mac == mac then blacklisted = true end - end) - if blacklisted then - luci.http.redirect(luci.dispatcher.build_url("splash" ,"blocked")) - else - local redirect_url = uci:get("luci_splash", "general", "redirect_url") - if not redirect_url then - redirect_url = uci_state:get("luci_splash_locations", mac:gsub(':', ''):lower(), "location") - end - if not redirect_url then - redirect_url = luci.model.uci.cursor():get("freifunk", "community", "homepage") or 'http://www.freifunk.net' - end - remove_redirect(mac:gsub(':', ''):lower()) - os.execute("luci-splash lease "..mac.." >/dev/null 2>&1") - luci.http.redirect(redirect_url) - end - else - luci.http.redirect(luci.dispatcher.build_url()) - end -end - -function action_status_admin() - local uci = luci.model.uci.cursor_state() - local macs = luci.http.formvaluetable("save") - - local changes = { - whitelist = { }, - blacklist = { }, - lease = { }, - remove = { } - } - - for key, _ in pairs(macs) do - local policy = luci.http.formvalue("policy.%s" % key) - local mac = luci.http.protocol.urldecode(key) - - if policy == "whitelist" or policy == "blacklist" then - changes[policy][#changes[policy]+1] = mac - elseif policy == "normal" then - changes["lease"][#changes["lease"]+1] = mac - elseif policy == "kicked" then - changes["remove"][#changes["remove"]+1] = mac - end - end - - if #changes.whitelist > 0 then - os.execute("luci-splash whitelist %s >/dev/null" - % table.concat(changes.whitelist)) - end - - if #changes.blacklist > 0 then - os.execute("luci-splash blacklist %s >/dev/null" - % table.concat(changes.blacklist)) - end - - if #changes.lease > 0 then - os.execute("luci-splash lease %s >/dev/null" - % table.concat(changes.lease)) - end - - if #changes.remove > 0 then - os.execute("luci-splash remove %s >/dev/null" - % table.concat(changes.remove)) - end - - luci.template.render("admin_status/splash", { is_admin = true }) -end - -function action_status_public() - luci.template.render("admin_status/splash", { is_admin = false }) -end - -function remove_redirect(mac) - local mac = mac:lower() - mac = mac:gsub(":", "") - local uci = require "luci.model.uci".cursor_state() - local redirects = uci:get_all("luci_splash_locations") - --uci:load("luci_splash_locations") - uci:revert("luci_splash_locations") - -- For all redirects - for k, v in pairs(redirects) do - if v[".type"] == "redirect" then - if v[".name"] ~= mac then - -- Rewrite state - uci:section("luci_splash_locations", "redirect", v[".name"], { - location = v.location - }) - end - end - end - uci:save("luci_splash_redirects") -end |