NAME

Dancer::Plugin::Authen::Simple - Easy Authentication for Dancer applications via Authen::Simple

VERSION

version 0.130490

SYNOPSIS

use Dancer;
use Dancer::Plugins::Authen::Simple;

# calling the authen keyword will get you a Authen::Simple object
# e.g. authen->authenticate( $user, $pass)

hook 'before' => sub {
    if ( !session('user') && request->path_info !~ m{^/login} )
    {
        var requested_path => request->path_info;
        request->path_info('/login');
    }
};
get '/login' => sub {
    template 'login', { path => vars->{requested_path} };
};
post '/login' => sub {
    if ( authen->authenticate( params->{user}, params->{pass} ) )
    {
        debug "Password correct";

        # Logged in successfully
        session user => $user;
        redirect params->{path} || '/';
    }
    else
    {
        debug("Login failed - password incorrect for " . params->{user});
        redirect '/login?failed=1';
    }
};

CONFIGURATION

Configuration details will be taken from your Dancer application config file. Each sub-key of Authen::Simple will add an additional Authen::Simple:* module to the parent Authen::Simple object.

See Authen::Simple for details on configuration options for each module.

Example configuration for Authen::Simple::Kerberos, Authen::Simple::SMB and Authen::Simple::LDAP:

plugins:
    "Authen::Simple":
        Kerberos:
            realm: 'REALM.EXAMPLE.COM'
        SMB:
            domain: 'DOMAIN'
            pdc:    'PDC'
        LDAP
            host: 'ldap.example.com'
            binddn: 'example_user'
            bindpw: 'example_password'
            basedn: 'ou=People,dc=example,dc=com'
            filter: '(sAMAccountName=%s)'

This is functionally equivalent to:

use Authen::Simple;
use Authen::Simple::Kerberos;
use Authen::Simple::SMB;
use Authen::Simple::LDAP;

my $authen = Authen::Simple->new(
    Authen::Simple::Kerberos->new(realm => 'REALM.EXAMPLE.COM'),
    Authen::Simple::SMB->new(domain => 'DOMAIN', pdc => 'PDC'),
    Authen::Simple::LDAP->new(host => 'ldap.example.com', ... )
);

SEE ALSO

Dancer

Authen::Simple

AUTHOR

Andrew Grangaard <spazm@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2013 by Andrew Grangaard.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.