Authentasaurus is a generator plugin that generates a stub for restful authentication controllers, models, tests, routes and migrations.
Authentasaurus is also a group/permission authorization system, you can define permissions per controller action for each group of users.
To start using Authentasaurus follow these simple steps :
-
install authentasaurus by running the following command in your app root
script/plugin install git://github.com/cousine/Authentasaurus.git
-
to generate the necessary models, controllers and views run
script/generate authentausaurus UserModelName
replace UserModelName with the desired name for the main user model –usually called user– the generated user model contains the necessary fields for authentasaurus, feel free to customize it.
-
run the migrations to create the necessary tables
-
run “rake authentasaurus:load_defaults” to create the default groups and admin user
-
if you installed authentasaurus without –skip-validation setup your email settings in config/environment.rb
that’s it you can now test your application by running script/server in your project root directory and going to localhost:3000/login
Authentasaurus takes advantage of rails’ before_filter; it checks for the appropriate permissions before every action that requires a login, a write or read permission.
At login, authentasaurus would load the user’s group permissions into a session hash and then attempts to read that hash when it meets a require helper on a controller.
Area
-
An area is in plain english the controller’s name, so if you have a controller named “PostsController”, the corresponding area name would be “posts” (just as you type it in the generator command)
Group
-
A group is as the name suggests, each group contains a number of users, and each user inherits the group permissions, also note that at any given time, the user can only belong to one group
Permission
-
A permission is one of two, either read or write, but take care, read or write is only a naming, and though it doesn’t make sense, you could treat a read permission as a write permission and vice versa, but as i said it makes no sense !
You can use some options with the Authentasaurus generator; currently only one is available:
--skip-validation
-
Skips generating the validation files used to send activation emails
There are three main session helpers in Authentasaurus:
require_login
-
requires the user to login before accessing the actions specified
ex: Tells Authentasaurus that the action destroy requires login and that Authentasaurus shouldn’t store the request in the session (typically for logout actions)
-
:model - Specifies the model that controls user information.
-
:user_id - the session variable that holds the logged in user id
-
:login_message - flash message to display when login is required
-
:actions - actions that require the permission (list)
-
:skip_request - skips saving the original request (to redirect to after login)
require_login :model=> Masher, :actions => :destroy, :skip_request => true
-
require_write
-
requires the user to have a write permission to that area to access the actions specified
ex: Tells Authentasaurus that the actions create_user and delete_user requires login and write permission.
if you change any session variables in the session model you have to tell Authentasaurus where to find it.
-
:model - Specifies the model that controls user information.
-
:user_id - the session variable that holds the logged in user id
-
:user_permissions - the session variable that holds the user permissions
-
:guest_permissions - the session variable that holds guests’ permissions
-
:login_message - flash message to display when login is required
-
:actions - actions that require the permission (list)
-
:skip_request - skips saving the original request (to redirect to after login)
require_write :model=> Masher,:user_permissions => :perms, :guest_permissions => :guest_perms, :login_message => "Busted, login first", :actions => [:create_user, :delete_user]
-
require_read
-
requires the user to have a read permission to that area to access the actions specified
ex: Tells Authentasaurus that the action show_user requires login and read permission.
if you change any session variables in the session model you have to tell Authentasaurus where to find it.
-
:model - Specifies the model that controls user information.
-
:user_id - the session variable that holds the logged in user id
-
:user_permissions - the session variable that holds the user permissions
-
:guest_permissions - the session variable that holds guests’ permissions
-
:login_message - flash message to display when login is required
-
:actions - actions that require the permission (list)
-
:skip_request - skips saving the original request (to redirect to after login)
require_read :model=> Masher,:user_permissions => :perms, :guest_permissions => :guest_perms, :login_message => "Busted, login first", :actions => :show_user
-
Copyright © 2009 Mash, Ltd., released under the MIT license