diff options
author | Kim Alvefur <zash@zash.se> | 2019-03-03 19:31:56 +0100 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2019-03-03 19:31:56 +0100 |
commit | 8562c36d070893c66bb745ac9e217ac7d2f4e29a (patch) | |
tree | 2f850f6d31956c595e9950ae016378195acadd57 /util/pubsub.lua | |
parent | cc90ec324390b214a5ab10b420acd488a901d564 (diff) | |
download | prosody-8562c36d070893c66bb745ac9e217ac7d2f4e29a.tar.gz prosody-8562c36d070893c66bb745ac9e217ac7d2f4e29a.zip |
util.pubsub: Validate node configuration on node creation (fixes #1328)
Diffstat (limited to 'util/pubsub.lua')
-rw-r--r-- | util/pubsub.lua | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/util/pubsub.lua b/util/pubsub.lua index a53e8b95..e5e0cb7c 100644 --- a/util/pubsub.lua +++ b/util/pubsub.lua @@ -436,10 +436,19 @@ function service:create(node, actor, options) --> ok, err return false, "conflict"; end + local config = setmetatable(options or {}, {__index=self.node_defaults}); + + if self.config.check_node_config then + local ok = self.config.check_node_config(node, actor, config); + if not ok then + return false, "not-acceptable"; + end + end + self.nodes[node] = { name = node; subscribers = {}; - config = setmetatable(options or {}, {__index=self.node_defaults}); + config = config; affiliations = {}; }; |