gluon-mesh-vpn-tunneldigger add watchdog script
The logic is based on the previously used shell script implementation. Co-Authored-By: Robin Weiligmann <admin@robwei.me>
This commit is contained in:
parent
80b6e7f18f
commit
8e176354f8
46
package/gluon-mesh-vpn-tunneldigger/files/usr/bin/tunneldigger-watchdog
Executable file
46
package/gluon-mesh-vpn-tunneldigger/files/usr/bin/tunneldigger-watchdog
Executable file
@ -0,0 +1,46 @@
|
|||||||
|
#!/usr/bin/lua
|
||||||
|
|
||||||
|
local uci = require('simple-uci').cursor()
|
||||||
|
|
||||||
|
function restart_tunneldigger()
|
||||||
|
os.execute('logger -t tunneldigger-watchdog "Restarting Tunneldigger."')
|
||||||
|
os.execute('/etc/init.d/tunneldigger restart')
|
||||||
|
end
|
||||||
|
|
||||||
|
function read_pid_file()
|
||||||
|
local pid_file = io.open('/var/run/tunneldigger.mesh-vpn.pid', 'r')
|
||||||
|
if not pid_file then
|
||||||
|
return nil
|
||||||
|
end
|
||||||
|
local pid = pid_file:read('*l')
|
||||||
|
pid_file:close()
|
||||||
|
return pid
|
||||||
|
end
|
||||||
|
|
||||||
|
function has_mesh_vpn_neighbours()
|
||||||
|
local handle = io.popen('batctl o', 'r')
|
||||||
|
if not handle then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
for line in handle:lines() do
|
||||||
|
if line:find('mesh%-vpn') then
|
||||||
|
handle:close()
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
handle:close()
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
if uci:get_bool('tunneldigger', 'mesh_vpn', 'enabled') then
|
||||||
|
if io.popen('pgrep tunneldigger'):read('*l') ~= read_pid_file() then
|
||||||
|
os.execute('logger -t tunneldigger-watchdog "Process-Pid does not match with pid-File."')
|
||||||
|
restart_tunneldigger()
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if not has_mesh_vpn_neighbours() then
|
||||||
|
os.execute('logger -t tunneldigger-watchdog "No vpn-mesh neighbours found."')
|
||||||
|
restart_tunneldigger()
|
||||||
|
return
|
||||||
|
end
|
||||||
|
end
|
@ -0,0 +1 @@
|
|||||||
|
*/5 * * * * /usr/bin/tunneldigger-watchdog
|
Loading…
Reference in New Issue
Block a user