You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
82 lines
1.9 KiB
82 lines
1.9 KiB
## @file
|
|
# UserDB OpenID module
|
|
|
|
## @class
|
|
# UserDB OpenID module
|
|
package Lemonldap::NG::Portal::UserDBOpenID;
|
|
|
|
use strict;
|
|
use Lemonldap::NG::Portal::Simple;
|
|
use Lemonldap::NG::Common::Regexp;
|
|
|
|
our $VERSION = '1.4.0';
|
|
|
|
## @apmethod int userDBInit()
|
|
# Check if authentication module is OpenID
|
|
# @return Lemonldap::NG::Portal error code
|
|
sub userDBInit {
|
|
my $self = shift;
|
|
|
|
unless ( $self->get_module('auth') =~ /^OpenID/ ) {
|
|
$self->lmLog(
|
|
'UserDBOpenID isn\'t useable unless authentication module is set to OpenID',
|
|
'error'
|
|
);
|
|
return PE_ERROR;
|
|
}
|
|
PE_OK;
|
|
}
|
|
|
|
## @apmethod int getUser()
|
|
# Does nothing
|
|
# @return Lemonldap::NG::Portal error code
|
|
sub getUser {
|
|
PE_OK;
|
|
}
|
|
|
|
## @apmethod int setSessionInfo()
|
|
# Check if there are some exportedVars in OpenID response.
|
|
# See http://openid.net/specs/openid-simple-registration-extension-1_0.html
|
|
# for more
|
|
# @return Lemonldap::NG::Portal error code
|
|
sub setSessionInfo {
|
|
my $self = shift;
|
|
|
|
my %vars = ( %{ $self->{exportedVars} }, %{ $self->{openIdExportedVars} } );
|
|
while ( my ( $k, $v ) = each %vars ) {
|
|
my $attr = $k;
|
|
my $required = ( $attr =~ s/^!// );
|
|
if ( $v =~ Lemonldap::NG::Common::Regexp::OPENIDSREGATTR() ) {
|
|
$self->{sessionInfo}->{$attr} = $self->param("openid.sreg.$v");
|
|
}
|
|
else {
|
|
$self->lmLog(
|
|
'Ignoring attribute '
|
|
. $v
|
|
. ' which is not a valid OpenID SREG attribute',
|
|
'warn'
|
|
);
|
|
}
|
|
|
|
if ( $required and not defined( $self->{sessionInfo}->{$attr} ) ) {
|
|
$self->lmLog(
|
|
"Required parameter $attr is not provided by OpenID server, aborted",
|
|
'warn'
|
|
);
|
|
|
|
$self->{mustRedirect} = 0;
|
|
return PE_MISSINGREQATTR;
|
|
}
|
|
}
|
|
PE_OK;
|
|
}
|
|
|
|
## @apmethod int setGroups()
|
|
# Does nothing
|
|
# @return Lemonldap::NG::Portal error code
|
|
sub setGroups {
|
|
PE_OK;
|
|
}
|
|
|
|
1;
|
|
|
|
|