diff options
Diffstat (limited to 'ipsec-tools-model.lua')
-rw-r--r-- | ipsec-tools-model.lua | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/ipsec-tools-model.lua b/ipsec-tools-model.lua index 3994007..ece5886 100644 --- a/ipsec-tools-model.lua +++ b/ipsec-tools-model.lua @@ -26,6 +26,35 @@ local function get_version() return cmd_output_result,cmd_output_error end +local function autostarts() + local cmd_output_result, cmd_output_error + local cmd = "/sbin/rc_status | egrep '^S' | egrep '" .. processname .."' 2>/dev/null" + local f = io.popen( cmd ) + local cmdresult = f:read("*a") + if (cmdresult) and (#cmdresult > 0) then + cmd_output_result = "Process will autostart at next boot (at sequence '" .. string.match(cmdresult,"^%a+(%d%d)") .. "')" + else + cmd_output_error = "Not programmed to autostart" + end + f:close() + return cmd_output_result,cmd_output_error + +end + +local function racoonctl(proto) + local cmd_output_result, cmd_output_error + local cmd = "/usr/sbin/racoonctl show-sa ".. proto .. " 2>/dev/null" + local f = io.popen( cmd ) + local cmdresult = f:read("*a") + if (cmdresult) and (#cmdresult > 0) then + cmd_output_result = cmdresult + else + cmd_output_error = "Not programmed to autostart" + end + f:close() + return cmd_output_result,cmd_output_error + +end function process_status_text(procname) local t = procps.pidof(procname) @@ -50,6 +79,34 @@ function getstatus() label="Program status", value=process_status_text(processname), }) + local autostart_sequense, autostart_errtxt = autostarts() + status.autostart = cfe({ name="autostart", + label="Autostart sequence", + value=autostart_sequense, + errtxt=autostart_errtxt, + }) + + local racoon_sequense, racoon_errtxt = racoonctl("isakmp") + status.show_isakmp = cfe({ name="show_isakmp", + label="racoon show-sa isakmp", + value=racoon_sequense, + errtxt=racoon_errtxt, + }) + + local racoon_sequense, racoon_errtxt = racoonctl("esp") + status.show_esp = cfe({ name="show_esp", + label="racoon show-sa esp", + value=racoon_sequense, + errtxt=racoon_errtxt, + }) + + local racoon_sequense, racoon_errtxt = racoonctl("ah") + status.show_ah = cfe({ name="show_ah", + label="racoon show-sa ah", + value=racoon_sequense, + errtxt=racoon_errtxt, + }) + return status end |