Software /
code /
prosody
Diff
plugins/muc/muc.lib.lua @ 6478:413923bbd1a0
plugins/muc/muc.lib: Add :each_affiliation() iterator
author | daurnimator <quae@daurnimator.com> |
---|---|
date | Wed, 15 Oct 2014 17:08:19 -0400 |
parent | 6476:fb8a9873728b |
child | 6512:ad159be9e9d7 |
line wrap: on
line diff
--- a/plugins/muc/muc.lib.lua Wed Oct 15 17:07:16 2014 -0400 +++ b/plugins/muc/muc.lib.lua Wed Oct 15 17:08:19 2014 -0400 @@ -746,10 +746,8 @@ local affiliation_rank = valid_affiliations[affiliation]; if affiliation_rank >= valid_affiliations.admin and affiliation_rank >= _aff_rank then local reply = st.reply(stanza):query("http://jabber.org/protocol/muc#admin"); - for jid, affiliation in pairs(self._affiliations) do - if affiliation == _aff then - reply:tag("item", {affiliation = _aff, jid = jid}):up(); - end + for jid in self:each_affiliation(_aff or "none") do + reply:tag("item", {affiliation = _aff, jid = jid}):up(); end origin.send(reply:up()); return true; @@ -988,6 +986,21 @@ return result; end +-- Iterates over jid, affiliation pairs +function room_mt:each_affiliation(with_affiliation) + if not with_affiliation then + return pairs(self._affiliations); + else + return function(_affiliations, jid) + local affiliation; + repeat -- Iterate until we get a match + jid, affiliation = next(_affiliations, jid); + until jid == nil or affiliation == with_affiliation + return jid, affiliation; + end, self._affiliations, nil + end +end + function room_mt:set_affiliation(actor, jid, affiliation, reason) if not actor then return nil, "modify", "not-acceptable"; end; @@ -1012,7 +1025,9 @@ if jid_bare(actor) == jid then -- self change -- need at least one owner local is_last = true; - for j, aff in pairs(self._affiliations) do if j ~= jid and aff == "owner" then is_last = false; break; end end + for j in self:each_affiliation("owner") do + if j ~= jid then is_last = false; break; end + end if is_last then return nil, "cancel", "conflict"; end