Comparison

plugins/mod_pep.lua @ 7456:76a8456cf1e2

Merge 0.10->trunk
author Kim Alvefur <zash@zash.se>
date Sun, 12 Jun 2016 20:06:30 +0200
parent 7454:d10b4bfb20c5
child 7871:09aa0453bdcc
comparison
equal deleted inserted replaced
7452:d916703d5e18 7456:76a8456cf1e2
45 local username, host = jid_split(user_bare); 45 local username, host = jid_split(user_bare);
46 return is_contact_subscribed(username, host, recipient_bare); 46 return is_contact_subscribed(username, host, recipient_bare);
47 end 47 end
48 48
49 module:hook("pep-publish-item", function (event) 49 module:hook("pep-publish-item", function (event)
50 local session, node, id, item = event.session, event.node, event.id, event.item; 50 local session, bare, node, id, item = event.session, event.user, event.node, event.id, event.item;
51 item.attr.xmlns = nil; 51 item.attr.xmlns = nil;
52 local disable = #item.tags ~= 1 or #item.tags[1] == 0; 52 local disable = #item.tags ~= 1 or #item.tags[1] == 0;
53 if #item.tags == 0 then item.name = "retract"; end 53 if #item.tags == 0 then item.name = "retract"; end
54 local bare = session.username..'@'..session.host;
55 local stanza = st.message({from=bare, type='headline'}) 54 local stanza = st.message({from=bare, type='headline'})
56 :tag('event', {xmlns='http://jabber.org/protocol/pubsub#event'}) 55 :tag('event', {xmlns='http://jabber.org/protocol/pubsub#event'})
57 :tag('items', {node=node}) 56 :tag('items', {node=node})
58 :add_child(item) 57 :add_child(item)
59 :up() 58 :up()
181 if payload and payload.name == "item" then -- <item> 180 if payload and payload.name == "item" then -- <item>
182 local id = payload.attr.id or "1"; 181 local id = payload.attr.id or "1";
183 payload.attr.id = id; 182 payload.attr.id = id;
184 session.send(st.reply(stanza)); 183 session.send(st.reply(stanza));
185 module:fire_event("pep-publish-item", { 184 module:fire_event("pep-publish-item", {
186 node = node, actor = session.jid, id = id, session = session, item = st.clone(payload); 185 node = node, user = jid_bare(session.full_jid), actor = session.jid, id = id, session = session, item = st.clone(payload);
187 }); 186 });
188 return true; 187 return true;
189 end 188 end
190 end 189 end
191 elseif stanza.attr.type == 'get' then 190 elseif stanza.attr.type == 'get' then