X-Git-Url: https://git.rvb.name/weathermon.git/blobdiff_plain/67f3d398664cc319615339c1ce9c525e672c332f..7580c60d80239c3a880e124c550c2353f8153d82:/bin/weathermon?ds=sidebyside diff --git a/bin/weathermon b/bin/weathermon index cc58def..8da4696 100755 --- a/bin/weathermon +++ b/bin/weathermon @@ -1,6 +1,7 @@ #!/usr/bin/lua local json = require("json") +local signal = require("posix.signal") require "wm_util" @@ -100,12 +101,7 @@ function submitValue(type,id,param,val) url = url:gsub("//","//"..web_user..":"..web_pass.."@",1) end - local result,code = http.request ({ - url=url, create=function() - local req_sock = socket.tcp() - req_sock:settimeout(web_timeout) - return req_sock - end}) + local result,code = http.request (url) if code ~= 200 and backlog_con then printLog("writing record to backlog...") @@ -312,6 +308,19 @@ end getConfig(arg[1]) +signal.signal(signal.SIGTERM, function(signum) + + printLog("Terminating...") + local pids = get_children() + for k,v in pairs(pids) do + printLog("Terminating subprocess "..tostring(v).."...") + signal.kill(v,signal.SIGTERM) + end + printLog("Exiting...") + os.exit(0) + +end) + if backlogdb or logdb then local dbdriver = require "luasql.sqlite3" env = assert(dbdriver.sqlite3()) @@ -336,7 +345,7 @@ end if web_url then http = require("socket.http") - socket = require("socket") + http.TIMEOUT = web_timeout end if mqtt_host then