Changeset

2324:1424aa8877f0

mod_throttle_unsolicited: Add support for throttling unsolicited messages on incoming s2s connections
author Kim Alvefur <zash@zash.se>
date Tue, 04 Oct 2016 16:18:06 +0200 (2016-10-04)
parents 2323:35ae59a8196d
children 2325:557dc366838e
files mod_throttle_unsolicited/README.markdown mod_throttle_unsolicited/mod_throttle_unsolicited.lua
diffstat 2 files changed, 52 insertions(+), 4 deletions(-) [+]
line wrap: on
line diff
--- a/mod_throttle_unsolicited/README.markdown	Sat Oct 01 20:34:43 2016 +0200
+++ b/mod_throttle_unsolicited/README.markdown	Tue Oct 04 16:18:06 2016 +0200
@@ -2,14 +2,15 @@
 depends:
 - 'mod\_track\_muc\_joins'
 summary: Limit rate of outgoing unsolicited messages
-...
+---
 
 Introduction
 ============
 
-This module limits the rate of outgoing unsolicited messages. A message
-counts as "unsolicited" if the receiving user hasn't added the sending
-user to their roster.
+This module limits the rate of outgoing unsolicited messages from local
+clients. Optionally, unsolicited messages coming in from remote servers
+may be limited per s2s conneciton. A message counts as "unsolicited" if
+the receiving user hasn't added the sending user to their roster.
 
 The module depends on [mod\_track\_muc\_joins] in order to allow sent
 messages to joined MUC rooms.
@@ -17,6 +18,14 @@
 Configuration
 =============
 
+To set a limit on messages from local sessions:
+
 ``` {.lua}
 unsolicited_messages_per_minute = 10
 ```
+
+To enable limits on unsolicited messages from s2s connections:
+
+``` {.lua}
+unsolicited_s2s_messages_per_minute = 100
+```
--- a/mod_throttle_unsolicited/mod_throttle_unsolicited.lua	Sat Oct 01 20:34:43 2016 +0200
+++ b/mod_throttle_unsolicited/mod_throttle_unsolicited.lua	Tue Oct 04 16:18:06 2016 +0200
@@ -6,6 +6,7 @@
 local gettime = require "socket".gettime;
 
 local max = module:get_option_number("unsolicited_messages_per_minute", 10);
+local s2s_max = module:get_option_number("unsolicited_s2s_messages_per_minute");
 local multiplier = module:get_option_number("throttle_unsolicited_burst", 1);
 
 function check_subscribed(event)
@@ -51,4 +52,42 @@
 module:hook("pre-message/bare", check_subscribed, 200);
 module:hook("pre-message/full", check_subscribed, 200);
 
+local full_sessions = prosody.full_sessions;
+
+-- Rooms and throttle creation will differ for s2s
+function check_subscribed_s2s(event)
+	local stanza, origin = event.stanza, event.origin;
+	local log = origin.log or module._log;
+
+	if origin.type ~= "s2sin" then return end
+
+	local to_orig = stanza.attr.to;
+	local from_orig = stanza.attr.from;
+	local from_bare = jid_bare(from_orig);
+
+	local target = full_sessions[to_orig];
+	if target then
+		local rooms = target.rooms_joined;
+		if rooms and rooms[from_bare] then
+			log("debug", "Message to joined room, no limit");
+			return
+		end
+	end
+
+	-- Retrieve or create throttle object
+	local lim = origin.throttle_unsolicited;
+	if not lim then
+		log("debug", "New s2s throttle");
+		lim = throttle.create(s2s_max * multiplier, 60 * multiplier);
+		origin.throttle_unsolicited = lim;
+	end
+
+	return check_subscribed(event);
+end
+
+if s2s_max then
+	module:hook("message/bare", check_subscribed_s2s, 200);
+	module:hook("message/full", check_subscribed_s2s, 200);
+end
+
 module:depends("track_muc_joins");