Mercurial > prosody-modules
view mod_support_contact/mod_support_contact.lua @ 5285:8e1f1eb00b58
mod_sasl2_fast: Fix harmless off-by-one error (invalidates existing tokens!)
Problem:
This was causing the key to become "<token>--cur" instead of the expected
"<token>-cur". As the same key was used by the code to both set and get, it
still worked.
Rationale for change:
Although it worked, it's unintended, inconsistent and messy. It increases the
chances of future bugs due to the unexpected format.
Side-effects of change:
Existing '--cur' entries will not be checked after this change, and therefore
existing FAST clients will fail to authenticate until they attempt password
auth and obtain a new FAST token.
Existing '--cur' entries in storage will not be cleaned up by this commit, but
this is considered a minor issue, and okay for the relatively few FAST
deployments.
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Wed, 29 Mar 2023 16:12:15 +0100 |
parents | 7dbde05b48a9 |
children |
line wrap: on
line source
-- mod_support_contact.lua -- -- Config options: -- support_contact = "support@hostname"; -- a JID -- support_contact_nick = "Support!"; -- roster nick -- support_contact_group = "Users being supported!"; -- the roster group in the support contact's roster local host = module:get_host(); local support_contact = module:get_option_string("support_contact", "support@"..host); local support_contact_nick = module:get_option_string("support_contact_nick", "Support"); local support_contact_group = module:get_option_string("support_contact_group", "Users"); if not(support_contact and support_contact_nick) then return; end local rostermanager = require "core.rostermanager"; local jid_split = require "util.jid".split; local st = require "util.stanza"; module:hook("user-registered", function(event) module:log("debug", "Adding support contact"); local groups = support_contact_group and {[support_contact_group] = true;} or {}; local node, host = event.username, event.host; local jid = node and (node..'@'..host) or host; local roster; roster = rostermanager.load_roster(node, host); if hosts[host] then roster[support_contact] = {subscription = "both", name = support_contact_nick, groups = {}}; else roster[support_contact] = {subscription = "from", ask = "subscribe", name = support_contact_nick, groups = {}}; end rostermanager.save_roster(node, host, roster); node, host = jid_split(support_contact); if hosts[host] then roster = rostermanager.load_roster(node, host); roster[jid] = {subscription = "both", groups = groups}; rostermanager.save_roster(node, host, roster); rostermanager.roster_push(node, host, jid); else module:send(st.presence({from=jid, to=support_contact, type="subscribe"})); end end);