mod_cron: Initialize timestamp of new tasks to start of period

Makes it more generic so new periods (e.g. weekly etc) can be added
easily.
This commit is contained in:
Kim Alvefur 2021-12-03 09:01:09 +01:00
parent 914d3acbd5
commit d6070eea1f
2 changed files with 5 additions and 5 deletions

View file

@ -22,9 +22,9 @@ function module.add_host(host_module)
task.save = save_task;
module:log("debug", "%s task %s added, last run %s", task.when, task.id,
task.last and datetime.datetime(task.last) or "never");
if task.last == nil and task.when == "daily" then
if task.last == nil then
local now = os.time();
task.last = now - now % 86400;
task.last = now - now % periods[task.when];
end
return true
end

View file

@ -55,10 +55,10 @@ function module.add_host(host_module : moduleapi)
task.save = save_task;
module:log("debug", "%s task %s added, last run %s", task.when, task.id,
task.last and datetime.datetime(task.last) or "never");
if task.last == nil and task.when == "daily" then
-- initialize daily tasks to run at ~midnight UTC for now
if task.last == nil then
-- initialize new tasks so e.g. daily tasks run at ~midnight UTC for now
local now = os.time();
task.last = now - now % 86400;
task.last = now - now % periods[task.when];
end
return true;
end