Software /
code /
prosody
Comparison
plugins/muc/muc.lib.lua @ 6223:2a7ce69844ca
plugins/muc/muc.lib: Refactor subject logic; fix bug of mixed up subject/author
author | daurnimator <quae@daurnimator.com> |
---|---|
date | Tue, 15 Apr 2014 18:20:56 -0400 |
parent | 6222:355b29881117 |
child | 6224:2a9aff163545 |
comparison
equal
deleted
inserted
replaced
6222:355b29881117 | 6223:2a7ce69844ca |
---|---|
295 end | 295 end |
296 return reply; | 296 return reply; |
297 end | 297 end |
298 | 298 |
299 function room_mt:get_subject() | 299 function room_mt:get_subject() |
300 return self._data['subject'], self._data['subject_from'] | 300 return self._data.subject_from, self._data.subject; |
301 end | 301 end |
302 local function create_subject_message(from, subject) | 302 local function create_subject_message(from, subject) |
303 return st.message({from = from; type = "groupchat"}) | 303 return st.message({from = from; type = "groupchat"}) |
304 :tag('subject'):text(subject):up(); | 304 :tag('subject'):text(subject):up(); |
305 end | 305 end |
876 origin.send(st.error_reply(stanza, "cancel", "service-unavailable")); | 876 origin.send(st.error_reply(stanza, "cancel", "service-unavailable")); |
877 return true; | 877 return true; |
878 end | 878 end |
879 end | 879 end |
880 | 880 |
881 module:hook("muc-subject-change", function(event) | |
882 local room, stanza = event.room, event.stanza; | |
883 local occupant = room:get_occupant_by_real_jid(stanza.attr.from); | |
884 if occupant.role == "moderator" or | |
885 ( occupant.role == "participant" and room:get_changesubject() ) then -- and participant | |
886 local subject = stanza:get_child_text("subject"); | |
887 room:set_subject(occupant.nick, subject); | |
888 else | |
889 event.origin.send(st.error_reply(stanza, "auth", "forbidden")); | |
890 end | |
891 return true; | |
892 end); | |
893 | |
881 function room_mt:handle_groupchat_to_room(origin, stanza) | 894 function room_mt:handle_groupchat_to_room(origin, stanza) |
895 -- Prosody has made the decision that messages with <subject/> are exclusively subject changes | |
896 -- e.g. body will be ignored; even if the subject change was not allowed | |
897 if stanza:get_child("subject") then | |
898 return module:fire_event("muc-subject-change", {room = self, origin = origin, stanza = stanza}); | |
899 end | |
882 local from = stanza.attr.from; | 900 local from = stanza.attr.from; |
883 local occupant = self:get_occupant_by_real_jid(from); | 901 local occupant = self:get_occupant_by_real_jid(from); |
884 if not occupant then -- not in room | 902 if not occupant then -- not in room |
885 origin.send(st.error_reply(stanza, "cancel", "not-acceptable")); | 903 origin.send(st.error_reply(stanza, "cancel", "not-acceptable")); |
886 return true; | 904 return true; |
887 elseif occupant.role == "visitor" then | 905 elseif occupant.role == "visitor" then |
888 origin.send(st.error_reply(stanza, "auth", "forbidden")); | 906 origin.send(st.error_reply(stanza, "auth", "forbidden")); |
889 return true; | 907 return true; |
890 else | 908 end |
891 local from = stanza.attr.from; | 909 stanza.attr.from = occupant.nick; |
892 stanza.attr.from = occupant.nick; | 910 self:broadcast_message(stanza); |
893 local subject = stanza:get_child_text("subject"); | 911 stanza.attr.from = from; |
894 if subject then | 912 return true; |
895 if occupant.role == "moderator" or | |
896 ( self:get_changesubject() and occupant.role == "participant" ) then -- and participant | |
897 self:set_subject(occupant.nick, subject); | |
898 else | |
899 stanza.attr.from = from; | |
900 origin.send(st.error_reply(stanza, "auth", "forbidden")); | |
901 end | |
902 else | |
903 self:broadcast_message(stanza); | |
904 end | |
905 stanza.attr.from = from; | |
906 return true; | |
907 end | |
908 end | 913 end |
909 | 914 |
910 -- hack - some buggy clients send presence updates to the room rather than their nick | 915 -- hack - some buggy clients send presence updates to the room rather than their nick |
911 function room_mt:handle_presence_to_room(origin, stanza) | 916 function room_mt:handle_presence_to_room(origin, stanza) |
912 local current_nick = self:get_occupant_jid(stanza.attr.from); | 917 local current_nick = self:get_occupant_jid(stanza.attr.from); |