Trust me Authifer, I'm not half as think as you drunk I am!
One obstacles to chiseling away a monolithic application architecture is managing user authentication on several smaller apps.
Authifer abstracts authentication into it's own application so you can focus your attention on adding useful features for your customers instead of managing user identities.
A fully working implementation of authifer is Make Headspaces Auth website - source
Feel free to reference the code for inspiration.
require 'sinatra'
Authifer.configure do |config|
config.database_url = 'sqlite3://db/auth_provider.sqlite3'
end
use Authifer::App
helpers do
include Authifer::AuthenticationHelper
include Authifer::Paths
end
get '/' do
if logged_in?
"<a href='#{ delete_session_path }'>log out</a>"
else
"<a href='#{ new_session_path }'>log in</a>" +
" or " +
"<a href='#{ new_user_path }'>register</a>"
end
end
The configure
block allows you to set several options:
views_path
- optional - The absolute path to your authifer templates. Defaults to the views inside the authifer gemdatabase_url
- required - The full url to your database. Make sure you've included the proper gem for your database! We use the ActiveRecord ORM under the covers.enforce_ssl
- optional - Whether you want to raise errors on requests that don't come in over HTTPS. Defaults to true.
An example development configuration:
Authifer.configure do |config|
config.enforce_ssl = false
config.views_path = File.join(File.path(File.expand_path(__FILE__)),'views', 'authifer')
config.database_url = 'sqlite3://db/auth_provider.sqlite3'
end
Check out these sample views.
We love pull requests and issues!
Create an issue or pull request with:
- A good name
- Tests where applicable
Create an issue with:
- Reproduction steps
- Stack trace if applicable
- Proposed fix if applicable