aboutsummaryrefslogtreecommitdiffstats
path: root/util
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2019-03-03 19:31:56 +0100
committerKim Alvefur <zash@zash.se>2019-03-03 19:31:56 +0100
commit8562c36d070893c66bb745ac9e217ac7d2f4e29a (patch)
tree2f850f6d31956c595e9950ae016378195acadd57 /util
parentcc90ec324390b214a5ab10b420acd488a901d564 (diff)
downloadprosody-8562c36d070893c66bb745ac9e217ac7d2f4e29a.tar.gz
prosody-8562c36d070893c66bb745ac9e217ac7d2f4e29a.zip
util.pubsub: Validate node configuration on node creation (fixes #1328)
Diffstat (limited to 'util')
-rw-r--r--util/pubsub.lua11
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 = {};
};