NAME
Net::Radius::Server::PAM - Authenticate users using the Linux-PAM framework
SYNOPSIS
use Net::Radius::Server::PAM;
my $pam = new Net::Radius::Server({@args});
# As match-method factory
$pam->fmatch();
# As set-method factory
$pam->fset();
DESCRIPTION
Net::Radius::Server::PAM
uses the PAM framework to authenticate and populate a RADIUS response within the Net::Radius::Server framework. The interface with the PAM infraestructure is provided by Authen::PAM(3).
The following methods are supported:
->fmatch
-
Equivalent to invoking
->mk
on a Net::Radius::Server::Match(3) - derived class. This will return a sub providing match functionality to Net::Server::Radius(3). ->fset
-
Equivalent to invoking
->mk
on a Net::Radius::Server::Set(3) - derived class. This will return a sub providing set functionality to Net::Server::Radius(3).
The match method will attempt authentication via username and password against the PAM framework. Succesful authentication causes the match method to return NRS_MATCH_OK. Failure, as expected, causes the return of NRS_MATCH_FAIL.
The Authen::PAM
object is left in the shared invocation hash at the specified key.
The set method attempts to fetch the environment provided by the PAM framework, translating any environment variables matching an attribute in the current dictionary into RADIUS attribute/value pairs within the response.
The set method will only perform its task if the account can be authenticated by PAM. Otherwise, a NRS_SET_CONTINUE will be returned, causing the execution of the rules to continue.
The following properties or arguments can be specified to either the constructor or any factory:
- auto
-
Causes the RADIUS identifier and authenticator from the request to be copied into the response.
- code
-
Sets the code of the RADIUS response. Defaults to 'Access-Accept'.
- result
-
What value to return when a succesful authentication occurs.
- description
-
Description of this rule, used for logging purposes.
- store_result
-
Specifies which key in the shared invocation hashref will be used to store the
Authen::PAM
object. Defaults to _pamh. - service
-
Defines the PAM service that must be used to authenticate. This attribute defaults to login.
Note that this class inherits from Net::Radius::Server::Set::Simple(3), so all its attributes are available as well.
EXPORT
None by default.
HISTORY
$Log: PAM.pm,v $
Revision 1.6 2006/12/14 16:33:17 lem
Rules and methods will only report failures in log level 3 and
above. Level 4 report success and failure, for deeper debugging
Revision 1.5 2006/11/15 05:54:04 lem
NRS::PAM now inherits from NRS::Set::Simple to increase functionality.
Revision 1.4 2006/11/15 05:39:15 lem
Corrected invocation of the factories
Revision 1.2 2006/11/15 05:23:57 lem
service now can be left unspecified. Defaults to 'login'
Revision 1.1 2006/11/15 05:14:54 lem
NRS::PAM has basic functionality.
SEE ALSO
Perl(1), Net::Radius::Server(3), Net::Radius::Server::Match(3), Net::Radius::Server::Set(3), Net::Radius::Server::Set::Simple(3), Authen::PAM(3).
AUTHOR
Luis E. Muñoz, <luismunoz@cpan.org>
COPYRIGHT AND LICENSE
Copyright (C) 2006 by Luis E. Muñoz
This library is free software; you can redistribute it and/or modify it under the same terms as Perl 5.8.6 itself.
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 275:
Non-ASCII character seen before =encoding in 'Muñoz,'. Assuming CP1252