diff options
author | Kim Alvefur <zash@zash.se> | 2019-06-06 17:37:15 +0200 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2019-06-06 17:37:15 +0200 |
commit | d615cd34845b4b0de21ec9659291b0ec0fb30efe (patch) | |
tree | 7fd3341308f2f9cb87bbdedf859e05e840ebc502 /util | |
parent | 17f90edfaaaaf5c40944f54622c440b9d5e51ce0 (diff) | |
download | prosody-d615cd34845b4b0de21ec9659291b0ec0fb30efe.tar.gz prosody-d615cd34845b4b0de21ec9659291b0ec0fb30efe.zip |
util.pubsub: Factor out calling of broadcaster
This will simplify doing things along with broadcasting.
Diffstat (limited to 'util')
-rw-r--r-- | util/pubsub.lua | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/util/pubsub.lua b/util/pubsub.lua index e5e0cb7c..24f1f41d 100644 --- a/util/pubsub.lua +++ b/util/pubsub.lua @@ -499,7 +499,7 @@ function service:delete(node, actor) --> ok, err end self.events.fire_event("node-deleted", { service = self, node = node, actor = actor }); - self.config.broadcaster("delete", node, node_obj.subscribers, nil, actor, node_obj, self); + self:broadcast("delete", node, node_obj.subscribers, nil, actor, node_obj); return true; end @@ -562,10 +562,14 @@ function service:publish(node, actor, id, item, requested_config) --> ok, err local event_data = { service = self, node = node, actor = actor, id = id, item = item }; self.events.fire_event("item-published/"..node, event_data); self.events.fire_event("item-published", event_data); - self.config.broadcaster("items", node, node_obj.subscribers, item, actor, node_obj, self); + self:broadcast("items", node, node_obj.subscribers, item, actor, node_obj); return true; end +function service:broadcast(event, node, subscribers, item, actor, node_obj) + return self.config.broadcaster(event, node, subscribers, item, actor, node_obj, self); +end + function service:retract(node, actor, id, retract) --> ok, err -- Access checking if not self:may(node, actor, "retract") then @@ -582,7 +586,7 @@ function service:retract(node, actor, id, retract) --> ok, err end self.events.fire_event("item-retracted", { service = self, node = node, actor = actor, id = id }); if retract then - self.config.broadcaster("retract", node, node_obj.subscribers, retract, actor, node_obj, self); + self:broadcast("retract", node, node_obj.subscribers, retract, actor, node_obj); end return true end @@ -604,7 +608,7 @@ function service:purge(node, actor, notify) --> ok, err end self.events.fire_event("node-purged", { service = self, node = node, actor = actor }); if notify then - self.config.broadcaster("purge", node, node_obj.subscribers, nil, actor, node_obj, self); + self:broadcast("purge", node, node_obj.subscribers, nil, actor, node_obj); end return true end |