modules/freifunk: When olsrd was loaded but there were no neighbors then the page for services was showing an error.
This commit is contained in:
parent
4ab2d1017e
commit
5858bd3c13
1 changed files with 12 additions and 9 deletions
|
@ -1,27 +1,30 @@
|
||||||
<%+header%>
|
<%+header%>
|
||||||
|
|
||||||
<%
|
<%
|
||||||
require("luci.fs")
|
local fs = require "luci.fs"
|
||||||
require("luci.util")
|
local utl = require "luci.util"
|
||||||
|
|
||||||
-- check if nameservice plugin is enabled and where to find the services file
|
-- check if nameservice plugin is enabled and where to find the services file
|
||||||
local has_services = false
|
local has_services = false
|
||||||
|
|
||||||
local uci = require "luci.model.uci".cursor()
|
local uci = require "luci.model.uci".cursor()
|
||||||
uci:foreach("olsrd", "LoadPlugin", function(s)
|
uci:foreach("olsrd", "LoadPlugin", function(s)
|
||||||
if s.library == "olsrd_nameservice.so.0.3" then
|
if s.library == "olsrd_nameservice.so.0.3" then
|
||||||
if s.services_file then
|
if s.services_file and fs.access(s.services_file) then
|
||||||
has_services = true
|
has_services = true
|
||||||
services_file = s.services_file
|
services_file = s.services_file
|
||||||
else
|
else
|
||||||
has_services = true
|
if fs.access("/var/run/services_olsr") then
|
||||||
services_file = "/var/run/services_olsr"
|
has_services = true
|
||||||
|
services_file = "/var/run/services_olsr"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
|
||||||
function fetch_services()
|
function fetch_services()
|
||||||
local rawdata = luci.fs.readfile(services_file)
|
local rawdata = fs.readfile(services_file)
|
||||||
|
|
||||||
if #rawdata == 0 then
|
if #rawdata == 0 then
|
||||||
return nil
|
return nil
|
||||||
|
@ -29,7 +32,7 @@ function fetch_services()
|
||||||
|
|
||||||
local data = {}
|
local data = {}
|
||||||
|
|
||||||
local tables = luci.util.split(luci.util.trim(rawdata), "\n", nil, true)
|
local tables = utl.split(utl.trim(rawdata), "\n", nil, true)
|
||||||
-- remove the first 3 lines
|
-- remove the first 3 lines
|
||||||
table.remove(tables,1)
|
table.remove(tables,1)
|
||||||
table.remove(tables,1)
|
table.remove(tables,1)
|
||||||
|
@ -40,7 +43,7 @@ function fetch_services()
|
||||||
table.remove(tables)
|
table.remove(tables)
|
||||||
|
|
||||||
for i, tbl in ipairs(tables) do
|
for i, tbl in ipairs(tables) do
|
||||||
local lines = luci.util.split(tbl, "\n", nil, true)
|
local lines = utl.split(tbl, "\n", nil, true)
|
||||||
end
|
end
|
||||||
|
|
||||||
return tables
|
return tables
|
||||||
|
@ -64,7 +67,7 @@ end
|
||||||
for k, line in ipairs(table) do
|
for k, line in ipairs(table) do
|
||||||
local field = {}
|
local field = {}
|
||||||
-- split line at # and |, 1=url, 2=proto, 3=description, 4=source
|
-- split line at # and |, 1=url, 2=proto, 3=description, 4=source
|
||||||
local field = luci.util.split(line, "[#|]", split, true)
|
local field = utl.split(line, "[#|]", split, true)
|
||||||
local url,descr,origin = pcdata(field[1]),pcdata(field[3]),pcdata(field[4])
|
local url,descr,origin = pcdata(field[1]),pcdata(field[3]),pcdata(field[4])
|
||||||
%>
|
%>
|
||||||
<tr class="cbi-section-table-row cbi-rowstyle-<%=i%>">
|
<tr class="cbi-section-table-row cbi-rowstyle-<%=i%>">
|
||||||
|
|
Loading…
Reference in a new issue