Project

stop_it

0.0
No commit activity in last 3 years
No release in over 3 years
Middleware for blocking requests to rake apps based on user agent, remote IP, and other environment variables.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

>= 2.6.1, ~> 2.6
>= 0
~> 0.30
 Project Readme

Stop It

Build Status Code Climate Test Coverage

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.