NAME

Mojolicious::Plugin::Bcrypt - bcrypt your passwords!

VERSION

Version 0.03

SYNOPSIS

Provides a helper for crypting and validating passwords via bcrypt.

use Mojolicious::Plugin::Bcrypt;

sub startup {
    my $self = shift;
    $self->plugin('bcrypt', { cost => 4 });
}

...

Optional parameter cost is a non-negative integer controlling the cost of the hash function. The number of operations is proportional to 2^cost. The current default value is 6.

HELPERS

bcrypt

Crypts a password via the bcrypt algorithm.

$self->bcrypt( $password, $settings );

$settings is an optional string which encodes the algorithm parameters, as described in Crypt::Eksblowfish::Bcrypt.

sub signup {
    my $self = shift;
    my $crypted_pass = $self->bcrypt( $self->param('password') );
    ...
}

bcrypt_validate

Validates a password against a crypted copy (for example from your database).

sub login {
    my $self = shift;
    my $entered_pass = $self->param('password');
    my $crypted_pass = $self->get_password_from_db();
    if ( $self->bcrypt_validate( $entered_pass, $crypted_pass ) ) {

        # Authenticated
        ...;
    }
    else {

        # Wrong password
        ...;
    }
}

DEVELOPMENT AND REPOSITORY

Clone it on GitHub at https://github.com/naturalist/Mojolicious--Plugin--Bcrypt

SEE ALSO

Crypt::Eksblowfish::Bcrypt, Mojolicious, Mojolicious::Plugin

AUTHOR

minimalist, <minimalist at lavabit.com>

LICENSE AND COPYRIGHT

Copyright 2011 minimalist.

This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.