Skip to content

Commit

Permalink
bot, config: anti-flood configuration code style
Browse files Browse the repository at this point in the history
  • Loading branch information
kwaaak committed May 13, 2019
1 parent b8c91d0 commit e42ef1d
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 28 deletions.
40 changes: 21 additions & 19 deletions sopel/bot.py
Original file line number Diff line number Diff line change
Expand Up @@ -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 '...'
Expand All @@ -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
Expand Down
14 changes: 5 additions & 9 deletions sopel/config/core_section.py
Original file line number Diff line number Diff line change
Expand Up @@ -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."""

0 comments on commit e42ef1d

Please sign in to comment.