NAME

Catalyst::Plugin::SimpleAuth - Simple authentication for Catalyst

SYNOPSIS

# in your Catalyst application:
use Catalyst qw(SimpleAuth);

__PACKAGE__->config(
    simpleauth => { class => 'Users' },
);

# in your sign up code

unless( $c->sign_up(
          {   username => $email,
              password => $password,
          }
      ) ) {
      # sign up failed, user exists
}
my $user = $c->user;
...

# in your sign in code

my $user = $c->user; 
if ($c->sign_in(
        {   username => $email,
            password => $password,
        }
    )
    )
{
    my $user = $c->user;
    ...
} else {
    # sign in failed
}

# in your sign out code

$c->sign_out;

DESCRIPTION

This module is a replacement module for Catalyst::Authentication::* which does one thing and does it well. This module assumes that you have a model for the users you wish to authenticate - this will typically be a DBIx::Class module.

You set the name of the model to authenticate in the configuration as above. 'sign_up' creates the instance for you. 'sign_in' signs a person in, 'sign_out' signs a person out. You can access the user object either as $c->user in the code or as the 'user' variable in the stash.

This module saves SHA1 digests of the passwords instead of the password.

The model will generally have a database structure along the lines of:

CREATE TABLE `users` (
  `username` text NOT NULL,
  `password` char(40) NOT NULL,
  `first_name` text,
  `last_name` text
);

Note that the password will be 40 characters long.

This module requires either Catalyst::Plugin::Session or Catalyst::Plugin::CookiedSession.

AUTHOR

Leon Brocard <acme@astray.com>.

COPYRIGHT

Copyright (C) 2008, Leon Brocard

This module is free software; you can redistribute it or modify it under the same terms as Perl itself.