Software /
code /
prosody-modules
File
mod_host_status_heartbeat/mod_host_status_heartbeat.lua @ 4921:816b23e09c20
mod_rest: Improve logging of results from callback startup probe
Especially interested in logging 500 status codes and their errors, to
diagnose problems with the callback API.
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Sat, 09 Apr 2022 00:43:18 +0200 |
parent | 2220:7f955f92bbbb |
line wrap: on
line source
local st = require "util.stanza"; local time = require "socket".gettime; local heartbeat_interval = module:get_option_number("status_check_heartbeat_interval", 5); local heartbeat_mode = module:get_option_string("status_check_heartbeat_mode", "remote"); local local_heartbeats = module:shared("/*/host_status_check/heartbeats"); local heartbeat_methods = { ["local"] = function() module:log("debug", "Local heartbeat"); local_heartbeats[module.host] = time(); return heartbeat_interval; end; ["remote"] = function () module:fire_event("route/remote", { origin = prosody.hosts[module.host]; stanza = st.stanza("heartbeat", { xmlns = "xmpp:prosody.im/heartbeat" }); }); return heartbeat_interval; end; } local send_heartbeat = assert(heartbeat_methods[heartbeat_mode], "Unknown heartbeat_mode: "..heartbeat_mode); module:add_timer(0, send_heartbeat);