REST Backend (#1976)
This commit is contained in:
parent
5e8effcddd
commit
b075082970
|
@ -2,7 +2,7 @@ package Lemonldap::NG::Portal::UserDB::REST;
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use Mouse;
|
use Mouse;
|
||||||
use JSON;
|
use JSON qw(from_json to_json);
|
||||||
use Lemonldap::NG::Portal::Main::Constants qw(
|
use Lemonldap::NG::Portal::Main::Constants qw(
|
||||||
PE_ERROR
|
PE_ERROR
|
||||||
PE_OK
|
PE_OK
|
||||||
|
@ -57,28 +57,61 @@ sub getUser {
|
||||||
|
|
||||||
sub findUser {
|
sub findUser {
|
||||||
my ( $self, $req, %args ) = @_;
|
my ( $self, $req, %args ) = @_;
|
||||||
my $res;
|
my $plugin =
|
||||||
# $res = eval {
|
$self->p->loadedModules->{"Lemonldap::NG::Portal::Plugins::FindUser"};
|
||||||
# $self->restCall(
|
my ( $searching, $excluding ) = $plugin->retreiveFindUserParams($req);
|
||||||
# $self->conf->{restUserDBUrl},
|
eval { $self->p->_authentication->setSecurity($req) };
|
||||||
# {
|
return PE_OK unless scalar @$searching;
|
||||||
# ( $args{useMail} ? 'mail' : 'user' ) => $req->user,
|
|
||||||
# 'useMail' => ( $args{useMail} ? JSON::true : JSON::false ),
|
my $res;
|
||||||
|
$searching = [
|
||||||
|
map {
|
||||||
|
{ $_->{key} => $_->{value} }
|
||||||
|
} @$searching
|
||||||
|
];
|
||||||
|
$excluding = [
|
||||||
|
map {
|
||||||
|
{ $_->{key} => $_->{value} }
|
||||||
|
} @$excluding
|
||||||
|
];
|
||||||
|
$res = eval {
|
||||||
|
$self->restCall(
|
||||||
|
$self->conf->{restUserDBUrl},
|
||||||
|
{
|
||||||
|
searchingAttributes => to_json($searching),
|
||||||
|
(
|
||||||
|
scalar @$excluding
|
||||||
|
? excludingAttributes => to_json($excluding)
|
||||||
|
: ()
|
||||||
|
)
|
||||||
|
}
|
||||||
|
);
|
||||||
|
};
|
||||||
|
if ($@) {
|
||||||
|
$self->logger->error("UserDB REST error: $@");
|
||||||
|
return PE_ERROR;
|
||||||
|
}
|
||||||
|
unless ( $res->{result} ) {
|
||||||
|
$self->userLogger->info('FindUser: no user found from REST UserDB');
|
||||||
|
return PE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
my $results = eval { from_json( $res->user, { allow_nonref => 1 } ) };
|
||||||
|
if ($@) {
|
||||||
|
$self->logger->error(
|
||||||
|
"FindUser: received invalid JSON from REST UserDB $@");
|
||||||
|
return PE_ERROR;
|
||||||
|
}
|
||||||
|
$self->logger->debug(
|
||||||
|
'REST UserDB number of result(s): ' . scalar @$results );
|
||||||
|
if ( scalar @$results ) {
|
||||||
|
my $rank = rand( scalar @$results );
|
||||||
|
$self->logger->debug("REST UserDB random rank: $rank");
|
||||||
|
$self->userLogger->info(
|
||||||
|
"FindUser: REST UserDB returns $results->[$rank]");
|
||||||
|
$req->data->{findUser} = $results->[$rank];
|
||||||
|
}
|
||||||
|
|
||||||
# }
|
|
||||||
# );
|
|
||||||
# };
|
|
||||||
# if ($@) {
|
|
||||||
# $self->logger->error("UserDB REST error: $@");
|
|
||||||
# eval { $self->p->_authentication->setSecurity($req) };
|
|
||||||
# return PE_ERROR;
|
|
||||||
# }
|
|
||||||
# unless ( $res->{result} ) {
|
|
||||||
# $self->userLogger->warn( 'User ' . $req->user . ' not found' );
|
|
||||||
# eval { $self->p->_authentication->setSecurity($req) };
|
|
||||||
# return PE_BADCREDENTIALS;
|
|
||||||
# }
|
|
||||||
# $req->data->{restUserDBInfo} = $res->{info} || {};
|
|
||||||
return PE_OK;
|
return PE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user