NAME

SweetPea::Application::Rbac - Role-Based Access Control for SweetPea-Application.

SYNOPSIS

# Based on a common example
permissions.yml
---
roles:
  administrator:
    permissions:
      manage accounts:
        operations:
          create account
          update account
          delete account
  manager:
    permissions:
      manager accounts:
        operations:
          create account
  guests:
    permissions:

... from inside SweetPea::Application or a Controller;

# verify user access
$s->rbac->authorize($login, $password);

# change user
$s->rbac->subject($user_id);

# verify target user has permission to perform "create account" operation
$s->rbac->subject($user_id)->can('/manage accounts/create account');

# change user to default set by authenticate method
$s->rbac->subject;

# verify has the following role
$s->rbac->role('administrator');
$s->rbac->role('guests');

$s->rbac->can('/manage accounts/delete account');

METHODS

new

The new method instantiates a new SweetPea::Application::Rbac object
which uses Yaml (via SweetPea::Application::Config) to provide methods
for retrieving authenticating and verifying system access permissions.

$s->plug( 'rbac', sub { return SweetPea::Application::Rbac->new($s); });

authorize

The authorize method check whether the login and password passed to it
belong to an active system user, if not report the error.

$s->rbac->authorize($login, $password);

authorized

The authorized method check whether a user has been authenticated.

if $s->rbac->authorized;

unauthorize

The unauthorize method revokes the currently authenticated users
authentication status. (Kinda like a logout function)

override

The override method re-authenticates as another system user while retaining
the originally logged in user's credentials. Thie method is useful for
applications that need to provide a means to temporarily switch accounts.

$s->rbac->override($login, $password);

# change back to the original user
$s->rbac->override;

subject

The subject method specifies the user account permissions will be validated
against using the user id pass to it, if called with no parameters the
authenticated user's account will be used.

$s->rbac->subject($user_id);
$s->rbac->subject;

role

The role method verifies whether the subject (target user) has the role
specified.

if $s->rbac->role('administrator');

can

The "can" method verifies whether the subject (target user) has a specific
permission or has permission to perform a specific action.

# check if subject (target user) has permission generally
if $s->rbac->can('/manage accounts');

# check if subject (target user) has permission to perform a specific operation
if $s->rbac->can('/manage accounts/create account');

AUTHOR

Al Newkirk, <al.newkirk at awnstudio.com>