NAME
    Authen::SASL::Authd - Client authentication via Cyrus saslauthd or
    Dovecot authentication daemon.

SYNOPSIS
        use Authen::SASL::Authd qw(auth_cyrus auth_dovecot);

        # authenticate user against Cyrus saslauthd
        auth_cyrus('login', 'passwd') or die "saslauthd: FAIL";

        # authenticate user against Dovecot authentication daemon
        auth_dovecot('login', 'passwd') or die "dovecot-auth: FAIL";

        # check user existance
        my $user_attr = user_dovecot('login', timeout => 3) or die "dovecot-auth: NO SUCH USER";
        print "user home: $user_attr->{home}\n";

DESCRIPTION
    The "Authen::SASL::Authd" package implements LOGIN authentication
    protocol used by Cyrus saslauthd and PLAIN authentication protocol
    supported by Dovecot authentication daemon. It can be used to process
    authentication requests against configured SASL mechanism implemented by
    Cyrus or Dovecot SASL libraries. It can also be used to check if a
    particular user exists according to the Dovecot authentication daemon.

METHODS
    auth_cyrus( 'LOGIN', 'PASSWD', [ service_name => 'SERVICE_NAME', ] [
    timeout => 'TIMEOUT (sec)', ] [ sock_file => '/SOCK/FILE/NAME', ] )
    Check supplied user name and password against Cyrus saslauthd. Return
    true if authentication succeeded. Die in case of a likely configuration
    problem.

    auth_dovecot( 'LOGIN', 'PASSWD', [ service_name => 'SERVICE_NAME', ] [
    timeout => 'TIMEOUT (sec)', ] [ sock_file => '/SOCK/FILE/NAME', ] )
    Check supplied user name and password against Dovecot authentication
    daemon. Return true if authentication succeeded. Die in case of a likely
    configuration problem.

    user_dovecot( 'LOGIN', [ service_name => 'SERVICE_NAME', ] [ timeout =>
    'TIMEOUT (sec)', ] [ sock_file => '/SOCK/FILE/NAME', ] )
    Check if supplied user name exists according to the Dovecot
    authentication daemon. Return a reference to the hashtable with optional
    user attributes if the user exists, undef otherwise. The hashtable can
    contain such attributes as 'home', 'gid', 'uid', etc defined by the
    Dovecot SASL implementation. Die in case of a likely configuration
    problem.

AUTHOR
    Alex Protasenko <aprotasenko@bkmks.com>

COPYRIGHT and LICENSE
    Copyright 2007 by Alex Protasenko.

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