mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
MUC: Record reason for affiliation changes and return in list (fixes #1227)
This commit is contained in:
parent
c8c1482dae
commit
cb66977bd4
3 changed files with 84 additions and 4 deletions
1
CHANGES
1
CHANGES
|
@ -24,6 +24,7 @@ TRUNK
|
||||||
- Public rooms can only be created by local users (parent host) by default
|
- Public rooms can only be created by local users (parent host) by default
|
||||||
- muc_room_allow_public = false restricts to admins
|
- muc_room_allow_public = false restricts to admins
|
||||||
- Commands to show occupants and affiliations in the Shell
|
- Commands to show occupants and affiliations in the Shell
|
||||||
|
- Save 'reason' text supplied with affiliation change
|
||||||
|
|
||||||
### Security and authentication
|
### Security and authentication
|
||||||
|
|
||||||
|
|
|
@ -1079,7 +1079,10 @@ function room_mt:handle_admin_query_set_command(origin, stanza)
|
||||||
local reason = item:get_child_text("reason");
|
local reason = item:get_child_text("reason");
|
||||||
local success, errtype, err
|
local success, errtype, err
|
||||||
if item.attr.affiliation and item.attr.jid and not item.attr.role then
|
if item.attr.affiliation and item.attr.jid and not item.attr.role then
|
||||||
local registration_data;
|
local registration_data = self:get_affiliation_data(item.attr.jid) or {};
|
||||||
|
if reason then
|
||||||
|
registration_data.reason = reason;
|
||||||
|
end
|
||||||
if item.attr.nick then
|
if item.attr.nick then
|
||||||
local room_nick = self.jid.."/"..item.attr.nick;
|
local room_nick = self.jid.."/"..item.attr.nick;
|
||||||
local existing_occupant = self:get_occupant_by_nick(room_nick);
|
local existing_occupant = self:get_occupant_by_nick(room_nick);
|
||||||
|
@ -1088,7 +1091,7 @@ function room_mt:handle_admin_query_set_command(origin, stanza)
|
||||||
self:set_role(true, room_nick, nil, "This nickname is reserved");
|
self:set_role(true, room_nick, nil, "This nickname is reserved");
|
||||||
end
|
end
|
||||||
module:log("debug", "Reserving %s for %s (%s)", item.attr.nick, item.attr.jid, item.attr.affiliation);
|
module:log("debug", "Reserving %s for %s (%s)", item.attr.nick, item.attr.jid, item.attr.affiliation);
|
||||||
registration_data = { reserved_nickname = item.attr.nick };
|
registration_data.reserved_nickname = item.attr.nick;
|
||||||
end
|
end
|
||||||
success, errtype, err = self:set_affiliation(actor, item.attr.jid, item.attr.affiliation, reason, registration_data);
|
success, errtype, err = self:set_affiliation(actor, item.attr.jid, item.attr.affiliation, reason, registration_data);
|
||||||
elseif item.attr.role and item.attr.nick and not item.attr.affiliation then
|
elseif item.attr.role and item.attr.nick and not item.attr.affiliation then
|
||||||
|
@ -1119,9 +1122,13 @@ function room_mt:handle_admin_query_get_command(origin, stanza)
|
||||||
if (affiliation_rank >= valid_affiliations.admin and affiliation_rank >= _aff_rank)
|
if (affiliation_rank >= valid_affiliations.admin and affiliation_rank >= _aff_rank)
|
||||||
or (self:get_members_only() and self:get_whois() == "anyone" and affiliation_rank >= valid_affiliations.member) then
|
or (self:get_members_only() and self:get_whois() == "anyone" and affiliation_rank >= valid_affiliations.member) then
|
||||||
local reply = st.reply(stanza):query("http://jabber.org/protocol/muc#admin");
|
local reply = st.reply(stanza):query("http://jabber.org/protocol/muc#admin");
|
||||||
for jid in self:each_affiliation(_aff or "none") do
|
for jid, _, data in self:each_affiliation(_aff or "none") do
|
||||||
local nick = self:get_registered_nick(jid);
|
local nick = self:get_registered_nick(jid);
|
||||||
reply:tag("item", {affiliation = _aff, jid = jid, nick = nick }):up();
|
reply:tag("item", {affiliation = _aff, jid = jid, nick = nick });
|
||||||
|
if data and data.reason then
|
||||||
|
reply:text_tag("reason", data.reason);
|
||||||
|
end
|
||||||
|
reply:up();
|
||||||
end
|
end
|
||||||
origin.send(reply:up());
|
origin.send(reply:up());
|
||||||
return true;
|
return true;
|
||||||
|
|
72
spec/scansion/muc_outcast_reason.scs
Normal file
72
spec/scansion/muc_outcast_reason.scs
Normal file
|
@ -0,0 +1,72 @@
|
||||||
|
# Save ban reason
|
||||||
|
|
||||||
|
[Client] Romeo
|
||||||
|
password: password
|
||||||
|
jid: user@localhost
|
||||||
|
|
||||||
|
-----
|
||||||
|
|
||||||
|
Romeo connects
|
||||||
|
|
||||||
|
Romeo sends:
|
||||||
|
<presence to="muc-outcast-reason@conference.localhost/Romeo">
|
||||||
|
<x xmlns="http://jabber.org/protocol/muc"/>
|
||||||
|
</presence>
|
||||||
|
|
||||||
|
Romeo receives:
|
||||||
|
<presence from="muc-outcast-reason@conference.localhost/Romeo">
|
||||||
|
<x xmlns="http://jabber.org/protocol/muc#user">
|
||||||
|
<status code="201"/>
|
||||||
|
<item jid="${Romeo's full JID}" role="moderator" affiliation="owner"/>
|
||||||
|
<status code="110"/>
|
||||||
|
</x>
|
||||||
|
</presence>
|
||||||
|
|
||||||
|
Romeo receives:
|
||||||
|
<message type="groupchat" from="muc-outcast-reason@conference.localhost">
|
||||||
|
<subject/>
|
||||||
|
</message>
|
||||||
|
|
||||||
|
Romeo sends:
|
||||||
|
<iq id="lx5" to="muc-outcast-reason@conference.localhost" type="set">
|
||||||
|
<query xmlns="http://jabber.org/protocol/muc#admin">
|
||||||
|
<item affiliation="outcast" jid="tybalt@localhost">
|
||||||
|
<reason>Hey calm down</reason>
|
||||||
|
</item>
|
||||||
|
</query>
|
||||||
|
</iq>
|
||||||
|
|
||||||
|
Romeo receives:
|
||||||
|
<message from="muc-outcast-reason@conference.localhost">
|
||||||
|
<x xmlns="http://jabber.org/protocol/muc#user">
|
||||||
|
<status code="301"/>
|
||||||
|
<item jid="tybalt@localhost" affiliation="outcast">
|
||||||
|
<reason>Hey calm down</reason>
|
||||||
|
</item>
|
||||||
|
</x>
|
||||||
|
</message>
|
||||||
|
|
||||||
|
Romeo receives:
|
||||||
|
<iq id="lx5" type="result" from="muc-outcast-reason@conference.localhost"/>
|
||||||
|
|
||||||
|
Romeo sends:
|
||||||
|
<iq id="lx6" to="muc-outcast-reason@conference.localhost" type="get">
|
||||||
|
<query xmlns="http://jabber.org/protocol/muc#admin">
|
||||||
|
<item affiliation="outcast"/>
|
||||||
|
</query>
|
||||||
|
</iq>
|
||||||
|
|
||||||
|
Romeo receives:
|
||||||
|
<iq id="lx6" type="result" from="muc-outcast-reason@conference.localhost">
|
||||||
|
<query xmlns="http://jabber.org/protocol/muc#admin">
|
||||||
|
<item jid="tybalt@localhost" affiliation="outcast">
|
||||||
|
<reason>Hey calm down</reason>
|
||||||
|
</item>
|
||||||
|
</query>
|
||||||
|
</iq>
|
||||||
|
|
||||||
|
Romeo disconnects
|
||||||
|
|
||||||
|
Romeo sends:
|
||||||
|
<presence type='unavailable'/>
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue