Skip to content

yez/passages

Repository files navigation

Passages

Build Status

Purpose

This Rails Engine adds the ability to search over different attributes of Ruby on Rails routes within an application.

For example, an internal (or very permissive external) API can now expose a single page that will answer simple questions like: "What was the HTTP verb for the /users/clear_password route?" or "Does a v2 or v3 version for this route exist?".

Demo

Demo

Install

In your Gemfile

source 'https://rubygems.org'
gem 'passages'

bundle install

By default, the Passages Engine must be mounted in your routes.rb file.

Example:

routes.rb

Rails.application.routes.draw do
  mount Passages::Engine, at: '/passages'
end

Alternatively, an initializer can be created that will allow the Passages Engine to mount itself.

Create a new file: initializers/passages.rb and add the following:

Passages.configure do |config|
  config.automount = true
end

With the Engine mounted at /passages, the rendered page will display a search box and list of all known routes within the application.

Rails 5 and Above

Rails 5 apps should use version 2.0 of this gem, everyone below should use 1.5.2

Authorization

Since there are no environment dependent checks, the /passages page uses configurable http basic authentication.

To set a username and password in the Passages Engine, add an ENV variable for each value.

ENV['passages_username'] should be the desired username and ENV['passages_password'] should be the desired password

By default these values are:

username: username

password: password

ENV variables can prefix a Ruby server command from the command line interface, set with a helper .ENV file for systems like foreman or set through a web interface on platforms like heroku.

To disable authentication, create or add to the initializers/passages.rb file:

Passages.configure do |config|
  config.no_auth = true
end

Contributing

Please feel free to fork and contribute your own changes to the Passages project. Single commits are preferred with a description of why the contribution is useful.