diff --git a/sopel/bot.py b/sopel/bot.py index c43773f30c..a1b5b737cb 100644 --- a/sopel/bot.py +++ b/sopel/bot.py @@ -305,32 +305,34 @@ def say(self, text, recipient, max_messages=1): recipient_id = Identifier(recipient) - reciprec = self.stack.get(recipient_id) - if not reciprec: - reciprec = self.stack[recipient_id] = { - 'messages': [], - 'burst': self.config.core.bucket_burst_tokens, - } - - if not reciprec['burst']: - elapsed = time.time() - reciprec['messages'][-1][0] - reciprec['burst'] = min( - self.config.core.bucket_burst_tokens, - int(elapsed) * self.config.core.bucket_refill_rate) - - if not reciprec['burst']: - elapsed = time.time() - reciprec['messages'][-1][0] + recipient = self.stack.setdefault(recipient_id, { + 'messages': [], + 'flood_left': self.config.core.flood_burst_lines, + }) + + if not recipient['flood_left']: + elapsed = time.time() - recipient['messages'][-1][0] + recipient['flood_left'] = min( + self.config.core.flood_burst_lines, + int(elapsed) * self.config.core.flood_refill_rate) + + if not recipient['flood_left']: + elapsed = time.time() - recipient['messages'][-1][0] penalty = float(max(0, len(text) - 50)) / 70 +<<<<<<< HEAD <<<<<<< HEAD wait = self.config.core.bucket_empty_wait + penalty ======= wait = min(self.config.core.flood_empty_wait + penalty, 2) # Maximum wait time is 2 sec >>>>>>> dd3c407d... Update bot.py +======= + wait = self.config.core.flood_empty_wait + penalty +>>>>>>> 9a7bf594... bot, config: anti-flood configuration code style if elapsed < wait: time.sleep(wait - elapsed) # Loop detection - messages = [m[1] for m in reciprec['messages'][-8:]] + messages = [m[1] for m in recipient['messages'][-8:]] # If what we about to send repeated at least 5 times in the # last 2 minutes, replace with '...' @@ -341,9 +343,9 @@ def say(self, text, recipient, max_messages=1): return self.write(('PRIVMSG', recipient), text) - reciprec['burst'] = max(0, reciprec['burst'] - 1) - reciprec['messages'].append((time.time(), self.safe(text))) - reciprec['messages'] = reciprec['messages'][-10:] + recipient['flood_left'] = max(0, recipient['flood_left'] - 1) + recipient['messages'].append((time.time(), self.safe(text))) + recipient['messages'] = recipient['messages'][-10:] finally: self.sending.release() # Now that we've sent the first part, we need to send the rest. Doing diff --git a/sopel/config/core_section.py b/sopel/config/core_section.py index ec96b871f1..5e885137e3 100644 --- a/sopel/config/core_section.py +++ b/sopel/config/core_section.py @@ -217,15 +217,11 @@ def homedir(self): verify_ssl = ValidatedAttribute('verify_ssl', bool, default=True) """Whether to require a trusted SSL certificate for SSL connections.""" - bucket_burst_tokens = ValidatedAttribute('bucket_burst_tokens', int, - default=4) + flood_burst_lines = ValidatedAttribute('flood_burst_lines', int, default=4) """How many messages can be sent in burst mode.""" - bucket_refill_rate = ValidatedAttribute('bucket_refill_rate', int, - default=1) - """How many tokens/second to add to the token bucket.""" + flood_empty_wait = ValidatedAttribute('flood_empty_wait', float, default=0.7) + """How long to wait between sending messages when not in burst mode, in seconds.""" - bucket_empty_wait = ValidatedAttribute('bucket_empty_wait', float, - default=0.7) - """How long to wait before sending a messaging when not in burst - mode.""" + flood_refill_rate = ValidatedAttribute('flood_refill_rate', int, default=1) + """How quickly burst mode recovers, in messages per second."""