Software /
code /
prosody
Comparison
plugins/mod_muc.lua @ 818:4dda65cd1405
MUC: Various fixes
author | Waqas Hussain <waqas20@gmail.com> |
---|---|
date | Wed, 18 Feb 2009 23:30:33 +0500 |
parent | 817:e3e3919b6c7e |
child | 820:c20545c0dc4d |
comparison
equal
deleted
inserted
replaced
817:e3e3919b6c7e | 818:4dda65cd1405 |
---|---|
114 function set_subject(current_nick, room, subject) | 114 function set_subject(current_nick, room, subject) |
115 -- TODO check nick's authority | 115 -- TODO check nick's authority |
116 if subject == "" then subject = nil; end | 116 if subject == "" then subject = nil; end |
117 rooms_info:set(room, 'subject', subject); | 117 rooms_info:set(room, 'subject', subject); |
118 save_room(); | 118 save_room(); |
119 local msg = st.message({type='groupchat', from=from}) | 119 local msg = st.message({type='groupchat', from=current_nick}) |
120 :tag('subject'):text(subject):up(); | 120 :tag('subject'):text(subject):up(); |
121 broadcast_message_stanza(room, msg, false); | 121 broadcast_message_stanza(room, msg, false); |
122 --broadcast_message(current_nick, room, subject or "", nil); | 122 --broadcast_message(current_nick, room, subject or "", nil); |
123 return true; | 123 return true; |
124 end | 124 end |
229 if stanza.name == "presence" then | 229 if stanza.name == "presence" then |
230 local pr = get_filtered_presence(stanza); | 230 local pr = get_filtered_presence(stanza); |
231 pr.attr.from = to; | 231 pr.attr.from = to; |
232 if type == "error" then -- error, kick em out! | 232 if type == "error" then -- error, kick em out! |
233 if current_nick then | 233 if current_nick then |
234 local data = rooms:get(room, to); | 234 local data = rooms:get(room, current_nick); |
235 data.role = 'none'; | 235 data.role = 'none'; |
236 local pr = st.presence({type='unavailable', from=current_nick}):tag('status'):text('This participant is kicked from the room because he sent an error presence'):up() | 236 local pr = st.presence({type='unavailable', from=current_nick}):tag('status'):text('This participant is kicked from the room because he sent an error presence'):up() |
237 :tag("x", {xmlns='http://jabber.org/protocol/muc#user'}) | 237 --:tag("x", {xmlns='http://jabber.org/protocol/muc#user'}) |
238 :tag("item", {affiliation=data.affiliation, role=data.role}):up(); | 238 --:tag("item", {affiliation=data.affiliation, role=data.role}):up(); |
239 broadcast_presence_stanza(room, pr); | 239 broadcast_presence_stanza(room, pr); |
240 --broadcast_presence('unavailable', to, room); -- TODO also add <status>This participant is kicked from the room because he sent an error presence: badformed error stanza</status> | 240 --broadcast_presence('unavailable', current_nick, room); -- TODO also add <status>This participant is kicked from the room because he sent an error presence: badformed error stanza</status> |
241 rooms:remove(room, to); | 241 rooms:remove(room, current_nick); |
242 jid_nick:remove(from, room); | 242 jid_nick:remove(from, room); |
243 end | 243 end |
244 elseif type == "unavailable" then -- unavailable | 244 elseif type == "unavailable" then -- unavailable |
245 if current_nick then | 245 if current_nick then |
246 local data = rooms:get(room, to); | 246 local data = rooms:get(room, current_nick); |
247 data.role = 'none'; | 247 data.role = 'none'; |
248 broadcast_presence_stanza(room, pr); | 248 broadcast_presence_stanza(room, pr); |
249 --broadcast_presence('unavailable', to, room); | 249 --broadcast_presence('unavailable', current_nick, room); |
250 rooms:remove(room, to); | 250 rooms:remove(room, current_nick); |
251 jid_nick:remove(from, room); | 251 jid_nick:remove(from, room); |
252 end | 252 end |
253 elseif not type then -- available | 253 elseif not type then -- available |
254 if current_nick then | 254 if current_nick then |
255 if current_nick == to then -- simple presence | 255 if current_nick == to then -- simple presence |
256 broadcast_presence_stanza(room, pr); | 256 if #pr == #stanza then |
257 -- FIXME check if something was filtered. if it was, then user may be rejoining | 257 broadcast_presence_stanza(room, pr); |
258 else -- possible rejoin | |
259 local pr_ = st.presence({type='unavailable', from=from, to=current_nick}):tag('status'):text('Replaced by new connection'); | |
260 handle_to_occupant(origin, pr_); -- send unavailable | |
261 handle_to_occupant(origin, pr); -- resend available | |
262 end | |
258 else -- change nick | 263 else -- change nick |
259 if rooms:get(room, to) then | 264 if rooms:get(room, to) then |
260 origin.send(st.error_reply(stanza, "cancel", "conflict")); | 265 origin.send(st.error_reply(stanza, "cancel", "conflict")); |
261 else | 266 else |
262 local data = rooms:get(room, current_nick); | 267 local data = rooms:get(room, current_nick); |