From fc2f0194a60071a330bd27c734f40c505b6f3ef4 Mon Sep 17 00:00:00 2001 From: Deathbybandaid Date: Wed, 3 Apr 2019 18:48:39 +0200 Subject: [PATCH] bot: fix variable name in flood prevention logic Co-Authored-By: kwaaak --- sopel/bot.py | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/sopel/bot.py b/sopel/bot.py index 98aec06485..a6d3303237 100644 --- a/sopel/bot.py +++ b/sopel/bot.py @@ -397,26 +397,26 @@ def say(self, text, recipient, max_messages=1): recipient_id = Identifier(recipient) - recipient = self.stack.setdefault(recipient_id, { + recipient_stack = 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( + if not recipient_stack['flood_left']: + elapsed = time.time() - recipient_stack['messages'][-1][0] + recipient_stack['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] + if not recipient_stack['flood_left']: + elapsed = time.time() - recipient_stack['messages'][-1][0] penalty = float(max(0, len(text) - 50)) / 70 wait = min(self.config.core.flood_empty_wait + penalty, 2) # Maximum wait time is 2 sec if elapsed < wait: time.sleep(wait - elapsed) # Loop detection - messages = [m[1] for m in recipient['messages'][-8:]] + messages = [m[1] for m in recipient_stack['messages'][-8:]] # If what we about to send repeated at least 5 times in the # last 2 minutes, replace with '...' @@ -427,9 +427,9 @@ def say(self, text, recipient, max_messages=1): return self.write(('PRIVMSG', recipient), text) - recipient['flood_left'] = max(0, recipient['flood_left'] - 1) - recipient['messages'].append((time.time(), self.safe(text))) - recipient['messages'] = recipient['messages'][-10:] + recipient_stack['flood_left'] = max(0, recipient_stack['flood_left'] - 1) + recipient_stack['messages'].append((time.time(), self.safe(text))) + recipient_stack['messages'] = recipient_stack['messages'][-10:] finally: self.sending.release() # Now that we've sent the first part, we need to send the rest. Doing