mirror of
https://github.com/Doodle3D/doodle3d-firmware.git
synced 2024-12-31 15:03:48 +01:00
Improve logger; set encryption config when creating network from scan info; fix reconfiguration marking; add logging to init script; show encryption in web interface; fixes toward client mode setup; other minor fixes/improvements.
This commit is contained in:
parent
1f39bf6434
commit
8b4d81a7e7
@ -46,6 +46,7 @@ function parseNetLine(line) {
|
|||||||
r.bssid = line[1];
|
r.bssid = line[1];
|
||||||
r.channel = line[2];
|
r.channel = line[2];
|
||||||
r.mode = line[3];
|
r.mode = line[3];
|
||||||
|
r.encryption = line[4];
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -76,7 +77,7 @@ function fetchAvailableNetworks() {
|
|||||||
if (value != "") {
|
if (value != "") {
|
||||||
var netinf = parseNetLine(value);
|
var netinf = parseNetLine(value);
|
||||||
var ssid = netinf.ssid;
|
var ssid = netinf.ssid;
|
||||||
options.append($("<option />").val(ssid).text(ssid + " - " + netinf.mode + " mode"));
|
options.append($("<option />").val(ssid).text(ssid + " - " + netinf.mode + " mode" + "(encryption: " + netinf.encryption + ")"));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
$("#wlan_btn_connect").prop('disabled', false);
|
$("#wlan_btn_connect").prop('disabled', false);
|
||||||
@ -113,7 +114,7 @@ function connectBtnHandler() {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$.get(cgiBase + "?op=assoc&ssid=" + ssid + "&passphrase=" + phrase, function(data) {
|
$.get(cgiBase + "?op=assoc&ssid=" + ssid + "&phrase=" + phrase, function(data) {
|
||||||
data = parseResponse(data);
|
data = parseResponse(data);
|
||||||
if (data.status == "ERR") {
|
if (data.status == "ERR") {
|
||||||
setResult(data.msg, true);
|
setResult(data.msg, true);
|
||||||
|
@ -66,13 +66,15 @@ function main()
|
|||||||
|
|
||||||
--TODO:
|
--TODO:
|
||||||
-- - extend reconf interface to support function arguments (as tables) so wifihelper functionality can be integrated
|
-- - extend reconf interface to support function arguments (as tables) so wifihelper functionality can be integrated
|
||||||
-- but how? idea: pass x_args={arg1="a",arg2="2342"} with component 'x'
|
-- but how? idea: pass x_args={arg1="a",arg2="2342"} for component 'x'
|
||||||
|
-- or: allow alternative for x="y" --> x={action="y", arg1="a", arg2="2342"}
|
||||||
|
-- in any case, arguments should be put in a new table to pass to the function (since order is undefined it must be an assoc array)
|
||||||
if sr and #sr > 0 then
|
if sr and #sr > 0 then
|
||||||
u.printWithSuccess(#sr .. " network(s) found");
|
u.printWithSuccess(#sr .. " network(s) found");
|
||||||
for _, se in ipairs(sr) do
|
for _, se in ipairs(sr) do
|
||||||
print("[[ " .. u.dump(se) .. " ]]") --TEMP
|
--print("[[ " .. u.dump(se) .. " ]]") --TEMP
|
||||||
if se.mode ~= "ap" then
|
if se.mode ~= "ap" and se.ssid ~= wifi.AP_SSID then
|
||||||
print(se.ssid .. "," .. se.bssid .. "," .. se.channel .. "," .. wifi.mapDeviceMode(se.mode))
|
print(se.ssid .. "," .. se.bssid .. "," .. se.channel .. "," .. wifi.mapDeviceMode(se.mode) .. "," .. wifi.mapEncryptionType(se.encryption))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
@ -110,15 +112,15 @@ function main()
|
|||||||
if cfg == nil or argRecreate ~= nil then
|
if cfg == nil or argRecreate ~= nil then
|
||||||
local scanResult = wifi.getScanInfo(argSsid)
|
local scanResult = wifi.getScanInfo(argSsid)
|
||||||
if scanResult ~= nil then
|
if scanResult ~= nil then
|
||||||
wifi.createConfigFromScanInfo(scanResult)
|
wifi.createConfigFromScanInfo(scanResult, argPhrase)
|
||||||
else
|
else
|
||||||
--check for error
|
--check for error
|
||||||
u.exitWithError("No wireless network with SSID '" .. argSsid .. "' is available")
|
u.exitWithError("No wireless network with SSID '" .. argSsid .. "' is available")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
wifi.activateConfig(argSsid)
|
wifi.activateConfig(argSsid)
|
||||||
local rv = wifi.restart()
|
reconf.switchConfiguration{ wifiiface="add", apnet="rm", staticaddr="rm", dhcppool="rm", wwwredir="rm", dnsredir="rm", wwwcaptive="rm", wireless="reload" }
|
||||||
u.exitWithSuccess("Wlan associated with network "..argSsid.."! [$?=" .. rv .. "]")
|
u.exitWithSuccess("Wlan associated with network " .. argSsid .. "!")
|
||||||
|
|
||||||
elseif argOperation == "disassoc" then
|
elseif argOperation == "disassoc" then
|
||||||
wifi.activateConfig()
|
wifi.activateConfig()
|
||||||
@ -129,7 +131,7 @@ function main()
|
|||||||
--add AP net, activate it, deactivate all others, reload network/wireless config, add all dhcp and captive settings and reload as needed
|
--add AP net, activate it, deactivate all others, reload network/wireless config, add all dhcp and captive settings and reload as needed
|
||||||
reconf.switchConfiguration{apnet="add_noreload"}
|
reconf.switchConfiguration{apnet="add_noreload"}
|
||||||
wifi.activateConfig(wifi.AP_SSID)
|
wifi.activateConfig(wifi.AP_SSID)
|
||||||
reconf.switchConfiguration{ network="reload", staticaddr="add", dhcppool="add", wwwredir="add", dnsredir="add", wwwcaptive="add", natreflect="add" }
|
reconf.switchConfiguration{ wifiiface="add", network="reload", staticaddr="add", dhcppool="add", wwwredir="add", dnsredir="add", wwwcaptive="add" }
|
||||||
u.exitWithSuccess("Switched to AP mode (SSID: '" .. wifi.AP_SSID .. "')")
|
u.exitWithSuccess("Switched to AP mode (SSID: '" .. wifi.AP_SSID .. "')")
|
||||||
|
|
||||||
elseif argOperation == "rm" then
|
elseif argOperation == "rm" then
|
||||||
@ -141,7 +143,8 @@ function main()
|
|||||||
end
|
end
|
||||||
|
|
||||||
elseif argOperation == "test" then
|
elseif argOperation == "test" then
|
||||||
reconf.switchConfiguration{ apnet="rm", staticaddr="rm", dhcppool="rm", wwwredir="rm", dnsredir="rm", wwwcaptive="rm", natreflect="rm" }
|
--invert actions performed by openap operation
|
||||||
|
reconf.switchConfiguration{ apnet="rm", staticaddr="rm", dhcppool="rm", wwwredir="rm", dnsredir="rm", wwwcaptive="rm" }
|
||||||
-- reconf.switchConfiguration{dnsredir="add"}
|
-- reconf.switchConfiguration{dnsredir="add"}
|
||||||
u.exitWithSuccess("nop")
|
u.exitWithSuccess("nop")
|
||||||
|
|
||||||
|
@ -1,12 +1,17 @@
|
|||||||
#!/bin/sh /etc/rc.common
|
#!/bin/sh /etc/rc.common
|
||||||
|
|
||||||
START=19
|
START=19
|
||||||
|
LOGGER="logger -s -t autowifi -p 6"
|
||||||
|
|
||||||
start() {
|
boot() {
|
||||||
echo "dummy auto wifi init"
|
$LOGGER "dummy boot"
|
||||||
#/www/cgi-bin/wfcf op=auto
|
#/www/cgi-bin/wfcf op=auto
|
||||||
}
|
}
|
||||||
|
|
||||||
stop() {
|
start() {
|
||||||
echo "dummy auto wifi deinit"
|
$LOGGER "dummy start"
|
||||||
|
}
|
||||||
|
|
||||||
|
stop() {
|
||||||
|
$LOGGER "dummy stop"
|
||||||
}
|
}
|
||||||
|
113
src/reconf.lua
113
src/reconf.lua
@ -10,6 +10,20 @@ M.WWW_CAPTIVE_PATH = "/usr/share/lua/autowifi/ext/www"
|
|||||||
M.WWW_CAPTIVE_INDICATOR = "/www/.autowifi-inplace"
|
M.WWW_CAPTIVE_INDICATOR = "/www/.autowifi-inplace"
|
||||||
M.WWW_RENAME_NAME = "/www-regular"
|
M.WWW_RENAME_NAME = "/www-regular"
|
||||||
|
|
||||||
|
local function reloadBit(dlist, itemname)
|
||||||
|
if dlist[itemname] == nil then dlist[itemname] = "" end
|
||||||
|
if dlist[itemname] == "" then dlist[itemname] = "r"
|
||||||
|
elseif dlist[itemname] == "c" then dlist[itemname] = "b"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local function commitBit(dlist, itemname)
|
||||||
|
if dlist[itemname] == nil then dlist[itemname] = "" end
|
||||||
|
if dlist[itemname] == "" then dlist[itemname] = "c"
|
||||||
|
elseif dlist[itemname] == "r" then dlist[itemname] = "b"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local function bothBits(dlist, itemname) dlist[itemname] = "b" end
|
||||||
|
|
||||||
function M.init(wifiInstance, reloadSilent)
|
function M.init(wifiInstance, reloadSilent)
|
||||||
wifi = wifiInstance
|
wifi = wifiInstance
|
||||||
silent = reloadSilent or false
|
silent = reloadSilent or false
|
||||||
@ -60,12 +74,16 @@ end
|
|||||||
|
|
||||||
|
|
||||||
--[[ Issue '/etc/init.d/network reload' command ]]
|
--[[ Issue '/etc/init.d/network reload' command ]]
|
||||||
function reconf.network_reload(dirtyList) dirtyList.network = "r" end
|
function reconf.network_reload(dirtyList) reloadBit(dirtyList, "network") end
|
||||||
|
|
||||||
|
--[[ Issue '/etc/init.d/wireless reload' command ]]
|
||||||
|
function reconf.wireless_reload(dirtyList) reloadBit(dirtyList, "wireless") end
|
||||||
|
|
||||||
--[[ Add wlan interface declaration to /etc/config/network ]]
|
--[[ Add wlan interface declaration to /etc/config/network ]]
|
||||||
function reconf.wifiiface_add(dirtyList)
|
function reconf.wifiiface_add(dirtyList)
|
||||||
uci:set("network", wifi.NET, "interface")
|
uci:set("network", wifi.NET, "interface")
|
||||||
dirtyList.network = "c";
|
-- uci:set("network", wifi.NET, "proto", "dhcp")
|
||||||
|
commitBit(dirtyList, "network")
|
||||||
end
|
end
|
||||||
|
|
||||||
--[[ Add/remove access point network ]]
|
--[[ Add/remove access point network ]]
|
||||||
@ -85,118 +103,97 @@ function reconf.apnet_add(dirtyList, noReload)
|
|||||||
mode = "ap",
|
mode = "ap",
|
||||||
})
|
})
|
||||||
|
|
||||||
dirtyList.wireless = "c"
|
commitBit(dirtyList, "wireless")
|
||||||
if noReload == nil or noReload == false then dirtyList.network = "r" end
|
if noReload == nil or noReload == false then reloadBit(dirtyList, "network") end
|
||||||
end
|
end
|
||||||
function reconf.apnet_rm(dirtyList)
|
function reconf.apnet_rm(dirtyList)
|
||||||
local sname = nil
|
local sname = nil
|
||||||
uci:foreach("wireless", "wifi-iface", function(s)
|
uci:foreach("wireless", "wifi-iface", function(s)
|
||||||
if s.ssid == wifi.AP_SSID then sname = s[".name"]; return false end
|
if s.ssid == wifi.AP_SSID then sname = s[".name"]; return false end
|
||||||
end)
|
end)
|
||||||
if sname == nil then
|
if sname == nil then return u:loginfo("AP network configuration does not exist, nothing to remove") end
|
||||||
u:loginfo("AP network configuration does not exist, nothing to remove")
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
uci:delete("wireless", sname)
|
uci:delete("wireless", sname)
|
||||||
dirtyList.network = "r"; dirtyList.wireless = "c"
|
reloadBit(dirtyList, "network"); commitBit(dirtyList, "wireless")
|
||||||
end
|
end
|
||||||
|
|
||||||
--[[ Switch between wireless static IP and DHCP ]]
|
--[[ Switch between wireless static IP and DHCP ]]
|
||||||
function reconf.staticaddr_add(dirtyList)
|
function reconf.staticaddr_add(dirtyList)
|
||||||
-- M.uciTableSet("network", wifi.NET, {
|
uci:set("network", wifi.NET, "interface")
|
||||||
-- proto = "static",
|
M.uciTableSet("network", wifi.NET, {
|
||||||
-- ipaddr = wifi.AP_ADDRESS,
|
proto = "static",
|
||||||
-- netmask = wifi.AP_NETMASK,
|
ipaddr = wifi.AP_ADDRESS,
|
||||||
-- type = "bridge",
|
netmask = wifi.AP_NETMASK,
|
||||||
-- })
|
type = "bridge",
|
||||||
uci:set("network", wifi.NET, "proto", "static")
|
})
|
||||||
uci:set("network", wifi.NET, "ipaddr", wifi.AP_ADDRESS)
|
bothBits(dirtyList, "network")
|
||||||
uci:set("network", wifi.NET, "netmask", wifi.AP_NETMASK)
|
|
||||||
uci:set("network", wifi.NET, "type", "bridge")
|
|
||||||
dirtyList.network = "b"
|
|
||||||
end
|
end
|
||||||
--TODO: replace repeated deletes by M.uciTableDelete
|
--TODO: replace repeated deletes by M.uciTableDelete
|
||||||
function reconf.staticaddr_rm(dirtyList)
|
function reconf.staticaddr_rm(dirtyList)
|
||||||
|
uci:set("network", wifi.NET, "interface")
|
||||||
uci:set("network", wifi.NET, "proto", "dhcp")
|
uci:set("network", wifi.NET, "proto", "dhcp")
|
||||||
uci:delete("network", wifi.NET, "ipaddr")
|
uci:delete("network", wifi.NET, "ipaddr")
|
||||||
uci:delete("network", wifi.NET, "netmask")
|
uci:delete("network", wifi.NET, "netmask")
|
||||||
uci:delete("network", wifi.NET, "type")
|
uci:delete("network", wifi.NET, "type")
|
||||||
dirtyList.network = "b"
|
bothBits(dirtyList, "network")
|
||||||
end
|
end
|
||||||
|
|
||||||
--[[ Add/remove DHCP pool for wireless net ]]
|
--[[ Add/remove DHCP pool for wireless net ]]
|
||||||
function reconf.dhcppool_add(dirtyList)
|
function reconf.dhcppool_add(dirtyList)
|
||||||
-- M.uciTableSet("dhcp", wifi.NET, {
|
uci:set("dhcp", wifi.NET, "dhcp") --create section
|
||||||
-- interface = wifi.NET,
|
M.uciTableSet("dhcp", wifi.NET, {
|
||||||
-- start = "100",
|
interface = wifi.NET,
|
||||||
-- limit = "150",
|
start = "100",
|
||||||
-- leasetime = "12h",
|
limit = "150",
|
||||||
-- })
|
leasetime = "12h",
|
||||||
uci:set("dhcp", wifi.NET, "dhcp") --create section??? TODO: what was this again
|
})
|
||||||
uci:set("dhcp", wifi.NET, "interface", wifi.NET)
|
commitBit(dirtyList, "dhcp"); reloadBit(dirtyList, "dnsmasq")
|
||||||
uci:set("dhcp", wifi.NET, "start", "100")
|
|
||||||
uci:set("dhcp", wifi.NET, "limit", "150")
|
|
||||||
uci:set("dhcp", wifi.NET, "leasetime", "12h")
|
|
||||||
dirtyList.dhcp = "c"; dirtyList.dnsmasq = "r"
|
|
||||||
end
|
end
|
||||||
function reconf.dhcppool_rm(dirtyList)
|
function reconf.dhcppool_rm(dirtyList)
|
||||||
uci:delete("dhcp", wifi.NET)
|
uci:delete("dhcp", wifi.NET)
|
||||||
dirtyList.dhcp = "c"; dirtyList.dnsmasq = "r"
|
commitBit(dirtyList, "dhcp"); reloadBit(dirtyList, "dnsmasq")
|
||||||
end
|
end
|
||||||
|
|
||||||
--[[ Add/remove webserver 404 redirection and denial of dirlisting ]]
|
--[[ Add/remove webserver 404 redirection and denial of dirlisting ]]
|
||||||
function reconf.wwwredir_add(dirtyList)
|
function reconf.wwwredir_add(dirtyList)
|
||||||
uci:set("uhttpd", "main", "error_page", "/admin/autowifi.html")
|
uci:set("uhttpd", "main", "error_page", "/admin/autowifi.html")
|
||||||
uci:set("uhttpd", "main", "no_dirlist", "1")
|
uci:set("uhttpd", "main", "no_dirlist", "1")
|
||||||
dirtyList.uhttpd = "b"
|
bothBits(dirtyList, "uhttpd")
|
||||||
end
|
end
|
||||||
function reconf.wwwredir_rm(dirtyList)
|
function reconf.wwwredir_rm(dirtyList)
|
||||||
uci:delete("uhttpd", "main", "error_page")
|
uci:delete("uhttpd", "main", "error_page")
|
||||||
uci:delete("uhttpd", "main", "no_dirlist")
|
uci:delete("uhttpd", "main", "no_dirlist")
|
||||||
dirtyList.uhttpd = "b"
|
bothBits(dirtyList, "uhttpd")
|
||||||
end
|
end
|
||||||
|
|
||||||
--[[ Add/remove redirecton of all DNS requests to self ]]
|
--[[ Add/remove redirecton of all DNS requests to self ]]
|
||||||
function reconf.dnsredir_add(dirtyList)
|
function reconf.dnsredir_add(dirtyList)
|
||||||
local redirText = "/#/" .. wifi.AP_ADDRESS
|
local redirText = "/#/" .. wifi.AP_ADDRESS
|
||||||
local sname = u.getUciSectionName("dhcp", "dnsmasq")
|
local sname = u.getUciSectionName("dhcp", "dnsmasq")
|
||||||
if sname == nil then
|
if sname == nil then return u:logerror("dhcp config does not contain a dnsmasq section") end
|
||||||
u:logerror("dhcp config does not contain a dnsmasq section")
|
if uci:get("dhcp", sname, "address") ~= nil then return u:logdebug("DNS address redirection already in place, not re-adding", false) end
|
||||||
return false
|
|
||||||
end
|
|
||||||
if uci:get("dhcp", sname, "address") ~= nil then
|
|
||||||
u:logdebug("DNS address redirection already in place, not re-adding")
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
|
|
||||||
uci:set("dhcp", sname, "address", {redirText})
|
uci:set("dhcp", sname, "address", {redirText})
|
||||||
dirtyList.dhcp = "c"; dirtyList.dnsmasq = "r"
|
commitBit(dirtyList, "dhcp"); reloadBit(dirtyList, "dnsmasq")
|
||||||
end
|
end
|
||||||
function reconf.dnsredir_rm(dirtyList)
|
function reconf.dnsredir_rm(dirtyList)
|
||||||
local sname = u.getUciSectionName("dhcp", "dnsmasq")
|
local sname = u.getUciSectionName("dhcp", "dnsmasq")
|
||||||
if sname == nil then
|
if sname == nil then return u:logerror("dhcp config does not contain a dnsmasq section") end
|
||||||
u:logerror("dhcp config does not contain a dnsmasq section")
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
uci:delete("dhcp", sname, "address")
|
uci:delete("dhcp", sname, "address")
|
||||||
dirtyList.dhcp = "c"; dirtyList.dnsmasq = "r"
|
commitBit(dirtyList, "dhcp"); reloadBit(dirtyList, "dnsmasq")
|
||||||
end
|
end
|
||||||
|
|
||||||
--TODO: handle os.rename() return values (nil+msg on error)
|
--TODO: handle os.rename() return values (nil+msg on error)
|
||||||
function reconf.wwwcaptive_add(dirtyList)
|
function reconf.wwwcaptive_add(dirtyList)
|
||||||
if u.exists(M.WWW_CAPTIVE_INDICATOR) then
|
if u.exists(M.WWW_CAPTIVE_INDICATOR) then
|
||||||
u:logdebug("WWW captive directory already in place, not redoing")
|
return u:logdebug("WWW captive directory already in place, not redoing", false)
|
||||||
return true
|
|
||||||
end
|
end
|
||||||
os.rename("/www", M.WWW_RENAME_NAME)
|
os.rename("/www", M.WWW_RENAME_NAME)
|
||||||
u.symlink(M.WWW_CAPTIVE_PATH, "/www")
|
u.symlink(M.WWW_CAPTIVE_PATH, "/www")
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
function reconf.wwwcaptive_rm(dirtyList)
|
function reconf.wwwcaptive_rm(dirtyList)
|
||||||
if not u.exists(M.WWW_CAPTIVE_INDICATOR) then
|
if not u.exists(M.WWW_CAPTIVE_INDICATOR) then return u:logdebug("WWW captive directory not in place, not undoing", false) end
|
||||||
u:logdebug("WWW captive directory not in place, not undoing")
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
os.remove("/www")
|
os.remove("/www")
|
||||||
return os.rename(M.WWW_RENAME_NAME, "/www")
|
return os.rename(M.WWW_RENAME_NAME, "/www")
|
||||||
end
|
end
|
||||||
@ -212,11 +209,11 @@ function reconf.natreflect_add(dirtyList)
|
|||||||
dest_ip = wifi.AP_ADDRESS,
|
dest_ip = wifi.AP_ADDRESS,
|
||||||
target = "DNAT"
|
target = "DNAT"
|
||||||
})
|
})
|
||||||
dirtyList.firewall = "b"
|
bothBits(dirtyList, "firewall")
|
||||||
end
|
end
|
||||||
function reconf.natreflect_rm(dirtyList)
|
function reconf.natreflect_rm(dirtyList)
|
||||||
uci:delete("firewall", "portalreflect")
|
uci:delete("firewall", "portalreflect")
|
||||||
dirtyList.firewall = "b"
|
bothBits(dirtyList, "firewall")
|
||||||
end
|
end
|
||||||
|
|
||||||
return M
|
return M
|
||||||
|
17
src/util.lua
17
src/util.lua
@ -68,16 +68,19 @@ local function log(level, msg, verbose)
|
|||||||
if level >= logLevel then
|
if level >= logLevel then
|
||||||
local now = os.date("%m-%d %H:%M:%S")
|
local now = os.date("%m-%d %H:%M:%S")
|
||||||
local i = debug.getinfo(3)
|
local i = debug.getinfo(3)
|
||||||
local v = verbose ~= nil and verbose or logVerbose
|
local v = verbose
|
||||||
if v then logStream:write(now .. " (" .. level .. ") \t" .. msg .. " [" .. i.name .. "@" .. i.short_src .. ":" .. i.linedefined .. "]\n")
|
if v == nil then v = logVerbose end
|
||||||
|
local name = i.name or "(nil)"
|
||||||
|
local vVal = "nil"
|
||||||
|
if v then logStream:write(now .. " (" .. level .. ") \t" .. msg .. " [" .. name .. "@" .. i.short_src .. ":" .. i.linedefined .. "]\n")
|
||||||
else logStream:write(now .. " (" .. level .. ") \t" .. msg .. "\n") end
|
else logStream:write(now .. " (" .. level .. ") \t" .. msg .. "\n") end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function M:logdebug(msg, verbose) log(M.LOG_LEVEL.debug, msg, verbose) end
|
function M:logdebug(msg, verbose) log(M.LOG_LEVEL.debug, msg, verbose); return true end
|
||||||
function M:loginfo(msg, verbose) log(M.LOG_LEVEL.info, msg, verbose) end
|
function M:loginfo(msg, verbose) log(M.LOG_LEVEL.info, msg, verbose); return true end
|
||||||
function M:logwarn(msg, verbose) log(M.LOG_LEVEL.warn, msg, verbose) end
|
function M:logwarn(msg, verbose) log(M.LOG_LEVEL.warn, msg, verbose); return true end
|
||||||
function M:logerror(msg, verbose) log(M.LOG_LEVEL.error, msg, verbose) end
|
function M:logerror(msg, verbose) log(M.LOG_LEVEL.error, msg, verbose); return false end
|
||||||
function M:logfatal(msg, verbose) log(M.LOG_LEVEL.fatal, msg, verbose) end
|
function M:logfatal(msg, verbose) log(M.LOG_LEVEL.fatal, msg, verbose); return false end
|
||||||
|
|
||||||
return M
|
return M
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
local reconf = require("reconf")
|
local reconf = require("reconf")
|
||||||
|
local util = require("util")
|
||||||
local uci = require("uci").cursor()
|
local uci = require("uci").cursor()
|
||||||
local iwinfo = require("iwinfo")
|
local iwinfo = require("iwinfo")
|
||||||
|
|
||||||
@ -26,6 +27,19 @@ function M.mapDeviceMode(mode, masterIsAp)
|
|||||||
return modeMap[mode] or mode
|
return modeMap[mode] or mode
|
||||||
end
|
end
|
||||||
|
|
||||||
|
--[[
|
||||||
|
- TODO: several modes need to be tested (wep, psk2, mixed-psk)
|
||||||
|
- See: http://wiki.openwrt.org/doc/uci/wireless#wpa.modes
|
||||||
|
]]
|
||||||
|
function M.mapEncryptionType(scanEncrTbl)
|
||||||
|
local wpaModeMap = { [1] = "psk", [2] = "psk2", [3] = "mixed-psk" }
|
||||||
|
|
||||||
|
if scanEncrTbl.enabled == false then return "none" end
|
||||||
|
if scanEncrTbl.wep == true then return "wep" end
|
||||||
|
|
||||||
|
return wpaModeMap[scanEncrTbl.wpa] or scanEncrTbl.description
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
--- Initialize WiFi helper library
|
--- Initialize WiFi helper library
|
||||||
-- @param device wireless device to operate on (optional, defaults to DFL_DEVICE)
|
-- @param device wireless device to operate on (optional, defaults to DFL_DEVICE)
|
||||||
@ -111,7 +125,7 @@ end
|
|||||||
|
|
||||||
--- Create a new UCI network from the given iwinfo data
|
--- Create a new UCI network from the given iwinfo data
|
||||||
-- http://luci.subsignal.org/trac/browser/luci/trunk/libs/iwinfo/src/iwinfo_wext.c?rev=5645 (outdated?)
|
-- http://luci.subsignal.org/trac/browser/luci/trunk/libs/iwinfo/src/iwinfo_wext.c?rev=5645 (outdated?)
|
||||||
-- TODO: configure encryption correctly (how?)
|
-- TODO: delete previous network if exists (match on MAC-address)
|
||||||
-- @param info iwinfo data to create a network from
|
-- @param info iwinfo data to create a network from
|
||||||
-- @param passphrase passphrase to use (optional)
|
-- @param passphrase passphrase to use (optional)
|
||||||
-- @param disabled immediately disable the network (optional)
|
-- @param disabled immediately disable the network (optional)
|
||||||
@ -123,7 +137,7 @@ function M.createConfigFromScanInfo(info, passphrase, disabled)
|
|||||||
device = "radio0",
|
device = "radio0",
|
||||||
ssid = info.ssid,
|
ssid = info.ssid,
|
||||||
bssid = info.bssid,
|
bssid = info.bssid,
|
||||||
--encryption = "none",
|
encryption = M.mapEncryptionType(info.encryption),
|
||||||
mode = mode,
|
mode = mode,
|
||||||
}
|
}
|
||||||
if passphrase ~= nil then apconfig.key = passphrase end
|
if passphrase ~= nil then apconfig.key = passphrase end
|
||||||
|
Loading…
Reference in New Issue
Block a user