Software /
code /
prosody
Diff
plugins/muc/muc.lib.lua @ 8187:4d83876aac3e
MUC: Reject whitespace-only nicknames (fixes #337)
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Fri, 21 Jul 2017 00:07:34 +0200 |
parent | 8176:f07cfc9b9b36 |
child | 8191:d43012448c1f |
line wrap: on
line diff
--- a/plugins/muc/muc.lib.lua Fri Aug 04 18:52:15 2017 +0100 +++ b/plugins/muc/muc.lib.lua Fri Jul 21 00:07:34 2017 +0200 @@ -435,6 +435,13 @@ self._occupants[current_nick].sessions[from] = pr; self:broadcast_presence(pr, from); else -- change nick + -- a MUC service MUST NOT allow empty or invisible Room Nicknames + -- (i.e., Room Nicknames that consist only of one or more space characters). + if not select(3, jid_split(nick)):find("[^ ]") then -- resourceprep turns all whitespace into 0x20 + module:log("debug", "Rejecting invisible nickname"); + origin.send(st.error_reply(stanza, "cancel", "not-allowed")); + return; + end local occupant = self._occupants[current_nick]; local is_multisession = next(occupant.sessions, next(occupant.sessions)); if self._occupants[to] or is_multisession then @@ -467,6 +474,13 @@ -- self:handle_to_occupant(origin, stanza); -- resend available --end else -- enter room + -- a MUC service MUST NOT allow empty or invisible Room Nicknames + -- (i.e., Room Nicknames that consist only of one or more space characters). + if not select(3, jid_split(nick)):find("[^ ]") then -- resourceprep turns all whitespace into 0x20 + module:log("debug", "Rejecting invisible nickname"); + origin.send(st.error_reply(stanza, "cancel", "not-allowed")); + return; + end local new_nick = to; local is_merge; if self._occupants[to] then