NAME
    Dancer::Plugin::Auth::Htpasswd - Basic HTTP authentication with htpasswd
    files in Dancer apps

VERSION
    Version 0.01

SYNOPSIS
    Dancer::Plugin::Auth::Htpasswd allows you to use Apache-style htpasswd
    files to implement basic HTTP authentication in Dancer web applications.

    Add the plugin to your application:

        use Dancer::Plugin::Auth::Htpasswd;

    In the configuration file, list the paths that you want to protect and
    the htpasswd files to use:

        plugins:
          "Auth::Htpasswd":
            paths:
              "/restricted": /path/to/htpasswd
              "/secret/documents":
                realm: "Top Secret Documents"
                passwd_file: /different/path/to/htpasswd

    You can also enable authentication by calling the `auth_htpasswd'
    function in a before filter:

        before sub {
            auth_htpasswd realm => 'Secret Files',
                          passwd_file => '/path/to/htpasswd';
        };

    or in a route handler:

        get '/restricted' => sub {
            auth_htpasswd '/path/to/htpasswd';
        
            # Authenticated
            ...
        };

DESCRIPTION
    Dancer::Plugin::Auth::Htpasswd provides a simple way to implement basic
    HTTP authentication in Dancer web applications using Apache-style
    htpasswd files.

CONFIGURATION
    To configure the plugin, add its options in the `plugins' section of
    your application's configuration file. The supported options are listed
    below.

  paths
    Defines one or more paths that will be protected, including sub-paths
    (so if the path is `"/restricted"', then
    `"/restricted/secret/file.html"' will also be protected). Each path can
    have the following parameters:

    * `passwd_file'
        Location of the htpasswd file.

    * `realm'
        Realm name that will be displayed in the authentication dialog.
        Default: `"Restricted area"'

    Example:

        plugins:
          "Auth::Htpasswd":
            paths:
              "/classified":
                realm: "Classified Files"
                passwd_file: /path/to/htpasswd
            
    If you don't need to set the realm, you can use the simplified syntax
    with just the location of the htpasswd file:

        plugins:
          "Auth::Htpasswd":
            paths:
              "/secret/documents": /path/to/htpasswd
              "/restricted": /another/path/to/htpasswd

SUBROUTINES
  auth_htpasswd
    Call this function in a before filter or at the beginning of a route
    handler. It checks the specified htpasswd file to verify if the client
    is authorized to access the requested path -- if not, it immediately
    returns a 401 Unauthorized response to prompt the user to authenticate.

    You can call this function with a single parameter, which is the
    location of the htpasswd file to use:

        auth_htpasswd '/path/to/htpasswd';
    
    or, with a hash of parameters:

        auth_htpasswd realm => 'Authorized personnel only',
                      passwd_file => '/path/to/htpasswd';

    Parameters:

    * `passwd_file'
        Location of the htpasswd file.

    * `realm'
        Realm name that will be displayed in the authentication dialog.
        Default: `"Restricted area"'

AUTHOR
    Michal Wojciechowski, `<odyniec at cpan.org>'

BUGS
    Please report any bugs or feature requests to
    `bug-dancer-plugin-auth-htpasswd at rt.cpan.org', or through the web
    interface at
    http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Dancer-Plugin-Auth-Htpass
    wd. I will be notified, and then you'll automatically be notified of
    progress on your bug as I make changes.

SUPPORT
    You can find documentation for this module with the perldoc command.

        perldoc Dancer::Plugin::Auth::Htpasswd

    You can also look for information at:

    * RT: CPAN's request tracker
        http://rt.cpan.org/NoAuth/Bugs.html?Dist=Dancer-Plugin-Auth-Htpasswd

    * AnnoCPAN: Annotated CPAN documentation
        http://annocpan.org/dist/Dancer-Plugin-Auth-Htpasswd

    * CPAN Ratings
        http://cpanratings.perl.org/d/Dancer-Plugin-Auth-Htpasswd

    * Search CPAN
        http://search.cpan.org/dist/Dancer-Plugin-Auth-Htpasswd/

ACKNOWLEDGEMENTS
    The plugin uses the Authen::Htpasswd module, written by David Kamholz
    and Yuval Kogman.

LICENSE AND COPYRIGHT
    Copyright 2011 Michal Wojciechowski.

    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.