applications/luci-olsr-services add olsr ipv6 services
This commit is contained in:
parent
d5cd72e011
commit
31ce19743a
1 changed files with 69 additions and 21 deletions
|
@ -17,24 +17,41 @@ local utl = require "luci.util"
|
||||||
local last_update
|
local last_update
|
||||||
local i = 1
|
local i = 1
|
||||||
local rawdata
|
local rawdata
|
||||||
local services_file_empty
|
local rawdata6
|
||||||
|
local services_file_empty = true
|
||||||
local has_services = false
|
local has_services = false
|
||||||
local uci = require "luci.model.uci".cursor()
|
local uci = require "luci.model.uci".cursor()
|
||||||
|
local ip = require "luci.ip"
|
||||||
|
|
||||||
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 and fs.access(s.services_file) then
|
local services_file=s.services_file
|
||||||
|
if services_file and fs.access(services_file) then
|
||||||
has_services = true
|
has_services = true
|
||||||
rawdata = fs.readfile(s.services_file)
|
rawdata = fs.readfile(s.services_file)
|
||||||
|
|
||||||
else
|
else
|
||||||
if fs.access("/var/run/services_olsr") then
|
services_file="/var/run/services_olsr"
|
||||||
|
if fs.access(services_file) then
|
||||||
has_services = true
|
has_services = true
|
||||||
rawdata = fs.readfile("/var/run/services_olsr")
|
rawdata = fs.readfile(services_file)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if rawdata and #rawdata == 0 then
|
services_file=services_file..".ipv6"
|
||||||
services_file_empty = true
|
if services_file and fs.access(services_file) then
|
||||||
|
has_services = true
|
||||||
|
rawdata6 = fs.readfile(services_file)
|
||||||
|
else
|
||||||
|
services_file="/var/run/services_olsr.ipv6"
|
||||||
|
if fs.access(services_file) then
|
||||||
|
has_services = true
|
||||||
|
rawdata6 = fs.readfile(services_file)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if rawdata and #rawdata ~= 0 then
|
||||||
|
services_file_empty = nil
|
||||||
|
end
|
||||||
|
if rawdata6 and #rawdata6 ~= 0 then
|
||||||
|
services_file_empty = nil
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
@ -51,15 +68,31 @@ if not has_services or services_file_empty then
|
||||||
end
|
end
|
||||||
|
|
||||||
function fetch_services()
|
function fetch_services()
|
||||||
local tables = utl.split(utl.trim(rawdata), "\n", nil, true)
|
local tables = {}
|
||||||
|
if rawdata and #rawdata ~= 0 then
|
||||||
|
tables = utl.split(utl.trim(rawdata), "\n", nil, true)
|
||||||
-- remove first 3 lines
|
-- remove first 3 lines
|
||||||
for i = 1,3 do
|
for i = 1,3 do
|
||||||
table.remove(tables,1)
|
table.remove(tables,1)
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
local tables6 = {}
|
||||||
|
if rawdata6 and #rawdata6 ~= 0 then
|
||||||
|
tables6 = utl.split(utl.trim(rawdata6), "\n", nil, true)
|
||||||
|
-- remove first 3 lines
|
||||||
|
for i = 1,3 do
|
||||||
|
table.remove(tables6,1)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
-- store last line in last_update and remove it, then remove another empty line at the end
|
-- store last line in last_update and remove it, then remove another empty line at the end
|
||||||
last_update=table.remove(tables)
|
last_update=table.remove(tables)
|
||||||
table.remove(tables)
|
table.remove(tables)
|
||||||
|
last_update=table.remove(tables6)
|
||||||
|
table.remove(tables6)
|
||||||
|
for k, v in ipairs(tables6) do
|
||||||
|
table.insert(tables, v)
|
||||||
|
end
|
||||||
return tables
|
return tables
|
||||||
end
|
end
|
||||||
local services = fetch_services()
|
local services = fetch_services()
|
||||||
|
@ -68,11 +101,19 @@ if luci.http.formvalue("status") == "1" then
|
||||||
local rv = {}
|
local rv = {}
|
||||||
for k, line in ipairs(services) do
|
for k, line in ipairs(services) do
|
||||||
local field = utl.split(line, "[#|]", split, true)
|
local field = utl.split(line, "[#|]", split, true)
|
||||||
|
local origin_lnk = ip.IPv6(pcdata(field[4])) or ""
|
||||||
|
local origin_link = ""
|
||||||
|
if #origin_lnk ~= 0 and origin_lnk:is6() then
|
||||||
|
origin_link = "["..origin_lnk:string().."]"
|
||||||
|
else
|
||||||
|
origin_link = pcdata(field[4])
|
||||||
|
end
|
||||||
local url, proto, descr, origin = pcdata(field[1]), pcdata(field[2]), utl.trim(pcdata(field[3])), pcdata(field[4])
|
local url, proto, descr, origin = pcdata(field[1]), pcdata(field[2]), utl.trim(pcdata(field[3])), pcdata(field[4])
|
||||||
rv[#rv+1] = {
|
rv[#rv+1] = {
|
||||||
url = url,
|
url = url,
|
||||||
proto = proto,
|
proto = proto,
|
||||||
origin = origin,
|
origin = origin,
|
||||||
|
origin_link = origin_link,
|
||||||
descr = descr,
|
descr = descr,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
@ -100,11 +141,11 @@ end
|
||||||
var service = info[idx];
|
var service = info[idx];
|
||||||
s += String.format(
|
s += String.format(
|
||||||
'<tr class="cbi-section-table-row cbi-rowstyle-'+(1 + (idx % 2))+'">' +
|
'<tr class="cbi-section-table-row cbi-rowstyle-'+(1 + (idx % 2))+'">' +
|
||||||
'<td class="cbi-section-table-cell"><a href="%s">%s</a></td>' +
|
'<td class="cbi-section-table-titles"><a href="%s">%s</a></td>' +
|
||||||
'<td class="cbi-section-table-cell">%s</td>' +
|
'<td class="cbi-section-table-titles">%s</td>' +
|
||||||
'<td class="cbi-section-table-cell"><a href="http://%s/cgi-bin-status.html">%s</a></td>' +
|
'<td class="cbi-section-table-titles"><a href="http://%s/cgi-bin-status.html">%s</a></td>' +
|
||||||
'</tr>',
|
'</tr>',
|
||||||
service.url, service.descr, service.proto, service.origin, service.origin || '?'
|
service.url, service.descr, service.proto, service.origin_link, service.origin || '?'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
tbody.innerHTML = s;
|
tbody.innerHTML = s;
|
||||||
|
@ -135,13 +176,20 @@ end
|
||||||
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 = utl.split(line, "[#|]", split, true)
|
local field = utl.split(line, "[#|]", split, true)
|
||||||
|
local origin_lnk = ip.IPv6(pcdata(field[4])) or ""
|
||||||
|
local origin_link
|
||||||
|
if #origin_lnk ~= 0 and origin_lnk:is6() then
|
||||||
|
origin_link = "["..origin_lnk:string().."]"
|
||||||
|
else
|
||||||
|
origin_link = pcdata(field[4])
|
||||||
|
end
|
||||||
local url, proto, descr, origin = pcdata(field[1]), pcdata(field[2]), utl.trim(pcdata(field[3])), pcdata(field[4])
|
local url, proto, descr, origin = pcdata(field[1]), pcdata(field[2]), utl.trim(pcdata(field[3])), pcdata(field[4])
|
||||||
%>
|
%>
|
||||||
|
|
||||||
<tr class="cbi-section-table-row cbi-rowstyle-<%=i%>">
|
<tr class="cbi-section-table-row cbi-rowstyle-<%=i%>">
|
||||||
<td class="cbi-section-table-cell"><a href="<%=url%>"><%=descr%></a></td>
|
<td class="cbi-section-table-titles"><a href="<%=url%>"><%=descr%></a></td>
|
||||||
<td class="cbi-section-table-cell"><%=proto%></td>
|
<td class="cbi-section-table-titles"><%=proto%></td>
|
||||||
<td class="cbi-section-table-cell"><a href="http://<%=origin%>/cgi-bin-status.html"><%=origin%></a></td>
|
<td class="cbi-section-table-titles"><a href="http://<%=origin_link%>/cgi-bin-status.html"><%=origin%></a></td>
|
||||||
</tr>
|
</tr>
|
||||||
<% i = ((i % 2) + 1)
|
<% i = ((i % 2) + 1)
|
||||||
end %>
|
end %>
|
||||||
|
|
Loading…
Reference in a new issue