aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2020-05-31 22:39:34 +0200
committerKim Alvefur <zash@zash.se>2020-05-31 22:39:34 +0200
commit04ce7240a776b9b9a98cf189058ecbaf3d9f5f24 (patch)
tree2bd65e32f758ac9506a77b413b95faac81e22a3b
parent75a555dea1f6fd0c8d455693c5b838b7f52ac35a (diff)
downloadprosody-04ce7240a776b9b9a98cf189058ecbaf3d9f5f24.tar.gz
prosody-04ce7240a776b9b9a98cf189058ecbaf3d9f5f24.zip
mod_c2s,mod_s2s: Make stanza size limits configurable
-rw-r--r--plugins/mod_c2s.lua3
-rw-r--r--plugins/mod_s2s/mod_s2s.lua3
2 files changed, 4 insertions, 2 deletions
diff --git a/plugins/mod_c2s.lua b/plugins/mod_c2s.lua
index 15d3a9be..c648850f 100644
--- a/plugins/mod_c2s.lua
+++ b/plugins/mod_c2s.lua
@@ -26,6 +26,7 @@ local log = module._log;
local c2s_timeout = module:get_option_number("c2s_timeout", 300);
local stream_close_timeout = module:get_option_number("c2s_close_timeout", 5);
local opt_keepalives = module:get_option_boolean("c2s_tcp_keepalives", module:get_option_boolean("tcp_keepalives", true));
+local stanza_size_limit = module:get_option_number("c2s_stanza_size_limit"); -- TODO come up with a sensible default (util.xmppstream defaults to 10M)
local measure_connections = module:measure("connections", "amount");
local measure_ipv6 = module:measure("ipv6", "amount");
@@ -262,7 +263,7 @@ function listener.onconnect(conn)
session.close = session_close;
- local stream = new_xmpp_stream(session, stream_callbacks);
+ local stream = new_xmpp_stream(session, stream_callbacks, stanza_size_limit);
session.stream = stream;
session.notopen = true;
diff --git a/plugins/mod_s2s/mod_s2s.lua b/plugins/mod_s2s/mod_s2s.lua
index 3f56b953..5439aa96 100644
--- a/plugins/mod_s2s/mod_s2s.lua
+++ b/plugins/mod_s2s/mod_s2s.lua
@@ -37,6 +37,7 @@ local secure_auth = module:get_option_boolean("s2s_secure_auth", false); -- One
local secure_domains, insecure_domains =
module:get_option_set("s2s_secure_domains", {})._items, module:get_option_set("s2s_insecure_domains", {})._items;
local require_encryption = module:get_option_boolean("s2s_require_encryption", false);
+local stanza_size_limit = module:get_option_number("s2s_stanza_size_limit"); -- TODO come up with a sensible default (util.xmppstream defaults to 10M)
local measure_connections = module:measure("connections", "amount");
local measure_ipv6 = module:measure("ipv6", "amount");
@@ -550,7 +551,7 @@ end
-- Session initialization logic shared by incoming and outgoing
local function initialize_session(session)
- local stream = new_xmpp_stream(session, stream_callbacks);
+ local stream = new_xmpp_stream(session, stream_callbacks, stanza_size_limit);
session.thread = runner(function (stanza)
if stanza.name == nil then