Stop It

Stop It is a middleware for blocking requests to rake apps.

Installation

Add this line to your application's Gemfile:

gem 'stop_it'

And then execute:

$ bundle

Or install it yourself as:

$ gem install stop_it

Usage

Let's see how to use Stop It with Ruby on Rails apps. To insert Stop It into the stack of middlewares of your app open config.ru file and add line

use StopIt

right after line

require ::File.expand_path('../config/environment',  __FILE__)

so that the file contains code similar to this:

# This file is used by Rack-based servers to start the application.

require ::File.expand_path('../config/environment',  __FILE__)
use StopIt
run MyRailsApp::Application # Here should be your application class name

To configure which requests should be stopped add config/initializers/stop_it.rb file to your Ruby on Rails app with the following content:

StopIt.stop do |opts|

end

@Opts@ is a hash with the following keys: @path_info@, @remote_addr@, @query_string@, @request_method@, @http_user_agent@.

If the block in stop method returns true then the request will be blocked. If it returns false then the request will be passed to the next middleware. In the following example all requests to /forbidden will be blocked.

StopIt.stop do |opts|
  opts[:path_info] == "/forbidden"
end

Requests can be blocked by request path, remote address, query string, HTTP method, and user agent.

The block in stop method may return a rake app response like this:

StopIt.stop do |opts|
  if opts[:remote_addr] == '127.0.0.2'
    [403, { 'Content-Type' => 'text/html', 'Content-Length' => '0' }, []]
  end
end

In this case the request will be blocked and the requestor will receive the returned response.

Contributing

Your contribution is welcome.