module("luci.controller.splash.splash", package.seeall) luci.i18n.loadc("splash") local uci = luci.model.uci.cursor() local util = require "luci.util" function index() entry({"admin", "services", "splash"}, cbi("splash/splash"), _("Client-Splash"), 90).i18n = "freifunk" entry({"admin", "services", "splash", "splashtext" }, form("splash/splashtext"), _("Splashtext"), 10) local e e = node("splash") e.target = call("action_dispatch") e.i18n = "freifunk" 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")).i18n = "freifunk" local page = node("splash", "publicstatus") page.target = call("action_status_public") page.i18n = "freifunk" 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 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 os.execute("luci-splash lease "..mac.." >/dev/null 2>&1") luci.http.redirect(luci.model.uci.cursor():get("freifunk", "community", "homepage")) 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