2018-06-06 17:00:02 +02:00
|
|
|
use Test::More;
|
|
|
|
use strict;
|
|
|
|
use IO::String;
|
|
|
|
use LWP::UserAgent;
|
|
|
|
use inc::LWP::Protocol::PSGI;
|
|
|
|
|
|
|
|
use Lemonldap::NG::Portal::Main::Constants qw(
|
|
|
|
PE_FIRSTACCESS
|
|
|
|
);
|
|
|
|
|
|
|
|
require 't/test-lib.pm';
|
|
|
|
|
|
|
|
my $res;
|
|
|
|
my $maintests = 8;
|
|
|
|
my $debug = 'error';
|
|
|
|
my %handlerOR = ( portal => [], app => [] );
|
|
|
|
my $client;
|
|
|
|
|
|
|
|
# Redefine LWP methods for tests
|
|
|
|
LWP::Protocol::PSGI->register(
|
|
|
|
sub {
|
|
|
|
my $req = Plack::Request->new(@_);
|
2018-06-21 21:35:16 +02:00
|
|
|
ok( $req->uri =~ m#http://auth.example.com(.*?)(?:\?(.*))?$#,
|
|
|
|
" @ REST REQUEST @" );
|
2018-06-06 17:00:02 +02:00
|
|
|
count(1);
|
2018-06-21 21:35:16 +02:00
|
|
|
my $url = $1;
|
2018-06-06 17:00:02 +02:00
|
|
|
my $query = $2;
|
|
|
|
my $res;
|
|
|
|
switch ('portal');
|
|
|
|
if ( $req->method =~ /^(post|put)$/i ) {
|
|
|
|
my $mth = '_' . lc($1);
|
|
|
|
my $s = $req->content;
|
|
|
|
ok(
|
|
|
|
$res = $client->$mth(
|
2018-06-21 21:35:16 +02:00
|
|
|
$url,
|
|
|
|
IO::String->new($s),
|
|
|
|
length => length($s),
|
|
|
|
type => $req->header('Content-Type'),
|
2018-06-06 17:00:02 +02:00
|
|
|
),
|
|
|
|
' Post request'
|
|
|
|
);
|
|
|
|
count(1);
|
|
|
|
expectOK($res);
|
|
|
|
}
|
|
|
|
elsif ( $req->method =~ /^(get|delete)$/i ) {
|
|
|
|
my $mth = '_' . lc($1);
|
|
|
|
ok(
|
|
|
|
$res = $client->$mth(
|
2018-06-21 21:35:16 +02:00
|
|
|
$url,
|
|
|
|
accept => $req->header('Accept'),
|
|
|
|
cookie => $req->header('Cookie'),
|
|
|
|
query => $query,
|
2018-06-06 17:00:02 +02:00
|
|
|
),
|
|
|
|
' Execute request'
|
|
|
|
);
|
|
|
|
ok( ( $res->[0] == 200 or $res->[0] == 400 ),
|
|
|
|
' Response is 200 or 400' )
|
|
|
|
or explain( $res->[0], '200 or 400' );
|
|
|
|
count(2);
|
|
|
|
}
|
|
|
|
pass(' @ END OF REST REQUEST @');
|
|
|
|
count(1);
|
|
|
|
switch ('app');
|
|
|
|
return $res;
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2018-06-21 21:35:16 +02:00
|
|
|
$client = LLNG::Manager::Test->new(
|
|
|
|
{
|
|
|
|
ini => {
|
|
|
|
logLevel => $debug,
|
|
|
|
useSafeJail => 1,
|
|
|
|
cda => 1,
|
|
|
|
restSessionServer => 1,
|
|
|
|
logger => 'Lemonldap::NG::Common::Logger::Std',
|
2018-06-06 17:00:02 +02:00
|
|
|
}
|
2018-06-21 21:35:16 +02:00
|
|
|
}
|
|
|
|
);
|
|
|
|
$handlerOR{portal} = \@Lemonldap::NG::Handler::Main::_onReload;
|
2018-06-06 17:00:02 +02:00
|
|
|
|
2018-06-21 21:35:16 +02:00
|
|
|
# CDA with unauthentified user
|
|
|
|
ok(
|
|
|
|
$res = $client->_get(
|
|
|
|
'/',
|
|
|
|
query => 'url=aHR0cDovL3Rlc3QuZXhhbXBsZS5vcmcv',
|
|
|
|
accept => 'text/html',
|
|
|
|
),
|
|
|
|
'Unauth CDA request'
|
|
|
|
);
|
|
|
|
my ( $host, $url, $query ) = expectForm( $res, undef, undef, 'url' );
|
|
|
|
ok( $query =~ /\burl=aHR0cDovL3Rlc3QuZXhhbXBsZS5vcmcv\b/, ' check url value' );
|
2018-06-06 17:00:02 +02:00
|
|
|
|
2018-06-21 21:35:16 +02:00
|
|
|
# Authentification
|
|
|
|
$query .= '&user=dwho&password=dwho';
|
|
|
|
ok(
|
|
|
|
$res = $client->_post(
|
|
|
|
'/' => IO::String->new($query),
|
|
|
|
length => length($query),
|
|
|
|
accept => 'text/html',
|
|
|
|
),
|
|
|
|
'Post credentials'
|
|
|
|
);
|
2018-06-06 17:00:02 +02:00
|
|
|
|
2018-06-21 21:35:16 +02:00
|
|
|
($query) =
|
|
|
|
expectRedirection( $res, qr#^http://test.example.org/\?(lemonldapcda=.*)$# );
|
2018-06-06 17:00:02 +02:00
|
|
|
|
2018-06-21 21:35:16 +02:00
|
|
|
# Handler part
|
|
|
|
use_ok('Lemonldap::NG::Handler::Server');
|
|
|
|
use_ok('Lemonldap::NG::Common::PSGI::Cli::Lib');
|
2018-06-06 17:00:02 +02:00
|
|
|
|
2018-06-21 21:35:16 +02:00
|
|
|
my ( $cli, $app );
|
|
|
|
&Lemonldap::NG::Handler::Main::cfgNum( 0, 0 );
|
|
|
|
switch ('app');
|
|
|
|
ok(
|
|
|
|
$app = Lemonldap::NG::Handler::Server->run(
|
|
|
|
{
|
|
|
|
%{ $client->ini },
|
|
|
|
globalStorage => 'Lemonldap::NG::Common::Apache::Session::REST',
|
|
|
|
globalStorageOptions =>
|
|
|
|
{ baseUrl => 'http://auth.example.com/sessions/global/' },
|
|
|
|
localSessionStorage => undef,
|
|
|
|
}
|
|
|
|
),
|
|
|
|
'App'
|
|
|
|
);
|
2018-06-06 17:00:02 +02:00
|
|
|
|
2018-06-21 21:35:16 +02:00
|
|
|
ok(
|
|
|
|
$res = $app->(
|
|
|
|
{
|
|
|
|
'HTTP_ACCEPT' => 'text/html',
|
|
|
|
'SCRIPT_NAME' => '/',
|
|
|
|
'SERVER_NAME' => '127.0.0.1',
|
|
|
|
'QUERY_STRING' => $query,
|
|
|
|
'HTTP_CACHE_CONTROL' => 'max-age=0',
|
|
|
|
'HTTP_ACCEPT_LANGUAGE' => 'fr,fr-FR;q=0.8,en-US;q=0.5,en;q=0.3',
|
|
|
|
'PATH_INFO' => '/',
|
|
|
|
'REQUEST_METHOD' => 'GET',
|
|
|
|
'REQUEST_URI' => "/?$query",
|
|
|
|
'X_ORIGINAL_URI' => "/?$query",
|
|
|
|
'SERVER_PORT' => '80',
|
|
|
|
'SERVER_PROTOCOL' => 'HTTP/1.1',
|
|
|
|
'HTTP_USER_AGENT' =>
|
|
|
|
'Mozilla/5.0 (VAX-4000; rv:36.0) Gecko/20350101 Firefox',
|
|
|
|
'REMOTE_ADDR' => '127.0.0.1',
|
|
|
|
'HTTP_HOST' => 'test.example.org',
|
|
|
|
'VHOSTTYPE' => 'CDA',
|
|
|
|
}
|
|
|
|
),
|
|
|
|
'Push cda cookie'
|
|
|
|
);
|
|
|
|
expectRedirection( $res, 'http://test.example.org/' );
|
|
|
|
my $cid = expectCookie($res);
|
2018-06-06 17:00:02 +02:00
|
|
|
|
2018-06-21 21:35:16 +02:00
|
|
|
ok(
|
|
|
|
$res = $app->(
|
|
|
|
{
|
|
|
|
'HTTP_ACCEPT' => 'text/html',
|
|
|
|
'SCRIPT_NAME' => '/',
|
|
|
|
'SERVER_NAME' => '127.0.0.1',
|
|
|
|
'HTTP_COOKIE' => "lemonldap=$cid",
|
|
|
|
'HTTP_CACHE_CONTROL' => 'max-age=0',
|
|
|
|
'HTTP_ACCEPT_LANGUAGE' => 'fr,fr-FR;q=0.8,en-US;q=0.5,en;q=0.3',
|
|
|
|
'PATH_INFO' => '/',
|
|
|
|
'REQUEST_METHOD' => 'GET',
|
|
|
|
'REQUEST_URI' => "/",
|
|
|
|
'X_ORIGINAL_URI' => "/",
|
|
|
|
'SERVER_PORT' => '80',
|
|
|
|
'SERVER_PROTOCOL' => 'HTTP/1.1',
|
|
|
|
'HTTP_USER_AGENT' =>
|
|
|
|
'Mozilla/5.0 (VAX-4000; rv:36.0) Gecko/20350101 Firefox',
|
|
|
|
'REMOTE_ADDR' => '127.0.0.1',
|
|
|
|
'HTTP_HOST' => 'test.example.org',
|
|
|
|
'VHOSTTYPE' => 'CDA',
|
|
|
|
}
|
|
|
|
),
|
|
|
|
'Authenticated query'
|
|
|
|
);
|
|
|
|
expectOK($res);
|
|
|
|
expectAuthenticatedAs( $res, 'dwho' );
|
2018-06-06 17:00:02 +02:00
|
|
|
|
|
|
|
clean_sessions();
|
|
|
|
|
|
|
|
done_testing( count($maintests) );
|
|
|
|
|
|
|
|
sub switch {
|
|
|
|
my $type = shift;
|
|
|
|
@Lemonldap::NG::Handler::Main::_onReload = @{
|
|
|
|
$handlerOR{$type};
|
|
|
|
};
|
|
|
|
}
|