No commit activity in last 3 years
No release in over 3 years
Allows request throttling on a per-action basis
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.16
~> 10.0
~> 3.0
~> 0.9

Runtime

 Project Readme

Action throttling

Usage

gem 'rails-action_throtling'

Configure your bucket. There are no default values for this, since we can't know your application specific implementation, so this step is mandatory.

ActionThrottling.configure do |config|
  # The bucket_key is evaluated inside your application context
  config.bucket_key = Proc.new { current_user.id }

  # Set the interval in which the user is throttled if running out of credits in
  # the bucket.
  config.timeout = Proc.new { current_user.timeout }

  # Sets the number of tokens to be put back into the bucket
  config.regenerate_amount = Proc.new { current_user.regenerate_amount }

  # (optional) If you're not running on a completely vanilla redis connection,
  # you can supply your own redis instance here.
  config.redis = Redis.new 'http://redis-server.com'
end

Then call the cost method on your actions that you want to protect:

def show
  # Every call will cost one credit
  # Based on the configuration above, this will allow the user to call this
  # endpoint 100 times every minute.
  #
  # This will call the `deduct(1)` method on the configured `config.bucket_key` (see
  # above)
  cost 1
  # ...
end

If you have something like a create method, or some complex method that's costly on the server side, you can set the cost appropriately:

def complex_method
  # This will call `deduct(25)` on the `config.bucket_key` (see above)
  cost 25
  # ...
end