Apache-AuthPAM
view release on metacpan or search on metacpan
our @EXPORT = qw(
);
our $VERSION = '0.01';
our $MODNAME = 'Apache::AuthPAM';
#
# I use this global to pass user info to the conversation function
# if you know a better way to do it, please tell me and/or fix it.
#
our %pw;
# Preloaded methods go here.
sub handler {
# get object request
my $r = shift;
return AUTH_REQUIRED;
}
# load apache config vars
my $service = $r->dir_config('PAMservice');
unless($service) {
$log->alert("$MODNAME: no PAM service name supplied", $r->uri);
return SERVER_ERROR;
}
# DAMN! I shouldn't use globals this way!
$pw{$$}=$pw;
# start PAM dialog
my $pamh;
my $result = pam_start($service, $username, \&my_conv_func, $pamh);
unless ($result == PAM_SUCCESS) {
$r->note_basic_auth_failure;
$log->crit("$MODNAME: <$service> not started ($result) ", $r->uri);
pam_end($pamh, 0);
Later, it calls C<pam_acct_mgmt>.
And finally it calls C<pam_end>.
If any of the PAM functions fail, Apache::AuthPAM logs an info level message and returns C<AUTH_REQUIRED>.
If all PAM functions are succesfull, Apache::AuthPAM logs an info level message and returns C<OK>.
If you are going to use your system password database, you
B<MUST> also use B<mod_ssl>.
=head1 BUGS
I'am using a global symbol.
Apache::AuthPAM is running as the same user mod_perl is running
(on RedHat Linux it is apache). It is running without privileges.
=head1 AUTHOR
Héctor Daniel Cortés González E<lt>hdcg@cie.unam.mxE<gt>
=head1 CREDITS
( run in 0.949 second using v1.01-cache-2.11-cpan-1d5ca39e368 )