X-Git-Url: https://git.enpas.org/?a=blobdiff_plain;f=plugins%2Fmod_motd.lua;h=39b74de98ef4af57e95bb635aa0016a1fe427b68;hb=cbab66b3d2ed46fdcf5c579957ca75272d5d1d4b;hp=f323e606e50af903220d0fb105d83e415035ccfb;hpb=825f4ed9deaad75573eea381f1c4cd123b51524c;p=prosody.git diff --git a/plugins/mod_motd.lua b/plugins/mod_motd.lua index f323e606..39b74de9 100644 --- a/plugins/mod_motd.lua +++ b/plugins/mod_motd.lua @@ -8,18 +8,23 @@ -- local host = module:get_host(); -local motd_text = module:get_option("motd_text") or "MOTD: (blank)"; -local motd_jid = module:get_option("motd_jid") or host; +local motd_text = module:get_option_string("motd_text"); +local motd_jid = module:get_option_string("motd_jid", host); +if not motd_text then return; end + +local jid_join = require "util.jid".join; local st = require "util.stanza"; -module:hook("resource-bind", - function (event) - local session = event.session; - local motd_stanza = - st.message({ to = session.username..'@'..session.host, from = motd_jid }) - :tag("body"):text(motd_text); - core_route_stanza(hosts[host], motd_stanza); - module:log("debug", "MOTD send to user %s@%s", session.username, session.host); +motd_text = motd_text:gsub("^%s*(.-)%s*$", "%1"):gsub("\n%s+", "\n"); -- Strip indentation from the config -end); +module:hook("presence/bare", function (event) + local session, stanza = event.origin, event.stanza; + if not session.presence and not stanza.attr.type then + local motd_stanza = + st.message({ to = session.full_jid, from = motd_jid }) + :tag("body"):text(motd_text); + core_route_stanza(hosts[host], motd_stanza); + module:log("debug", "MOTD send to user %s", session.full_jid); + end +end, 1);