Software /
code /
prosody
Comparison
plugins/mod_pubsub/mod_pubsub.lua @ 6516:ecd8d6437053
Merge 0.10->trunk
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Thu, 20 Nov 2014 09:02:23 +0000 |
parent | 6450:25d86b0f2147 |
parent | 6515:c9a72c64c3e2 |
child | 6666:42fdc8dddf04 |
comparison
equal
deleted
inserted
replaced
6514:d425fc41e59f | 6516:ecd8d6437053 |
---|---|
9 | 9 |
10 local autocreate_on_publish = module:get_option_boolean("autocreate_on_publish", false); | 10 local autocreate_on_publish = module:get_option_boolean("autocreate_on_publish", false); |
11 local autocreate_on_subscribe = module:get_option_boolean("autocreate_on_subscribe", false); | 11 local autocreate_on_subscribe = module:get_option_boolean("autocreate_on_subscribe", false); |
12 local pubsub_disco_name = module:get_option("name"); | 12 local pubsub_disco_name = module:get_option("name"); |
13 if type(pubsub_disco_name) ~= "string" then pubsub_disco_name = "Prosody PubSub Service"; end | 13 if type(pubsub_disco_name) ~= "string" then pubsub_disco_name = "Prosody PubSub Service"; end |
14 local expose_publisher = module:get_option_boolean("expose_publisher", false) | |
14 | 15 |
15 local service; | 16 local service; |
16 | 17 |
17 local lib_pubsub = module:require "pubsub"; | 18 local lib_pubsub = module:require "pubsub"; |
18 local handlers = lib_pubsub.handlers; | 19 local handlers = lib_pubsub.handlers; |
34 handler(origin, stanza, action, service); | 35 handler(origin, stanza, action, service); |
35 return true; | 36 return true; |
36 end | 37 end |
37 end | 38 end |
38 | 39 |
39 function simple_broadcast(kind, node, jids, item) | 40 function simple_broadcast(kind, node, jids, item, actor) |
40 if item then | 41 if item then |
41 item = st.clone(item); | 42 item = st.clone(item); |
42 item.attr.xmlns = nil; -- Clear the pubsub namespace | 43 item.attr.xmlns = nil; -- Clear the pubsub namespace |
44 if expose_publisher and actor then | |
45 item.attr.publisher = actor | |
46 end | |
43 end | 47 end |
44 local message = st.message({ from = module.host, type = "headline" }) | 48 local message = st.message({ from = module.host, type = "headline" }) |
45 :tag("event", { xmlns = xmlns_pubsub_event }) | 49 :tag("event", { xmlns = xmlns_pubsub_event }) |
46 :tag(kind, { node = node }) | 50 :tag(kind, { node = node }) |
47 :add_child(item); | 51 :add_child(item); |