Merge branch 'master' of gitlab.ow2.org:lemonldap-ng/lemonldap-ng

This commit is contained in:
Christophe Maudoux 2019-01-18 22:06:24 +01:00
commit 7e9aaea6bc
14 changed files with 187 additions and 139 deletions

View File

@ -70,6 +70,7 @@ describe('01 Lemonldap::NG Manager', function() {
}); });
it('General Parameters > Authn. parameters > Users modules => Should have 7 modules availabled with "Same" selected', function() { it('General Parameters > Authn. parameters > Users modules => Should have 7 modules availabled with "Same" selected', function() {
element(by.id('t-userDB')).click(); element(by.id('t-userDB')).click();
browser.sleep(1000);
expect(element(by.css('option[selected="selected"]')).getAttribute('Value')).toEqual('Same'); expect(element(by.css('option[selected="selected"]')).getAttribute('Value')).toEqual('Same');
expect(element.all(by.repeater('item in currentNode.select')).count()).toEqual(7); expect(element.all(by.repeater('item in currentNode.select')).count()).toEqual(7);
}); });

View File

@ -44,7 +44,7 @@ describe('05 Lemonldap::NG Manager', function() {
['exportedVars', 'macros', 'groups'].forEach(function(type) { ['exportedVars', 'macros', 'groups'].forEach(function(type) {
element(by.id('a-' + type)).click(); element(by.id('a-' + type)).click();
element(by.id('t-' + type)).click(); element(by.id('t-' + type)).click();
element(by.css('.glyphicon-plus-sign')).click(); element.all(by.css('.glyphicon-plus-sign')).first().click();
expect(element(by.id('t-' + type + '/n' + id)).getText()).toEqual('new'); expect(element(by.id('t-' + type + '/n' + id)).getText()).toEqual('new');
browser.sleep(3000); browser.sleep(3000);
id++; id++;

View File

@ -7,14 +7,19 @@ describe('06 Lemonldap::NG Manager', function() {
describe('Form control, part 2', function() { describe('Form control, part 2', function() {
it('should display portal skin choice', function() { it('should display portal skin choice', function() {
browser.get('/#/confs/1'); browser.get('/#!/confs/lastest');
element(by.id('a-generalParameters')).click(); element(by.id('a-generalParameters')).click();
element(by.id('a-portalParams')).click(); element(by.id('a-portalParams')).click();
element(by.id('a-portalCustomization')).click(); element(by.id('a-portalCustomization')).click();
element(by.id('t-portalSkin')).click(); element(by.id('t-portalSkin')).click();
element(by.css('[ng-click="showModal(\'portalSkinChoice.html\')"]')).click(); element(by.css('[ng-click="showModal(\'portalSkinChoice.html\')"]')).click();
browser.sleep(1000);
var skinChoice = element.all(by.repeater('b in currentNode.select')); var skinChoice = element.all(by.repeater('b in currentNode.select'));
expect(skinChoice.count()).toEqual(1); expect(skinChoice.count()).toEqual(1);
element(by.css('[trspan="cancel"]')).click();
browser.sleep(1000);
}); });
}); });
}); });

View File

@ -7,37 +7,57 @@ describe('07 Lemonldap::NG Manager', function() {
describe('Form control, part 3 - authParams', function() { describe('Form control, part 3 - authParams', function() {
it('should display auth modules chosen', function() { it('should display auth modules chosen', function() {
browser.get('/#/confs/1'); browser.get('/#!/confs/latest');
browser.sleep(2000);
element(by.id('a-generalParameters')).click(); element(by.id('a-generalParameters')).click();
browser.sleep(1000);
element(by.id('a-authParams')).click(); element(by.id('a-authParams')).click();
browser.sleep(1000);
element(by.id('t-authentication')).click(); element(by.id('t-authentication')).click();
browser.sleep(2000);
expect(element(by.id('t-demoParams')).isDisplayed()).toBeTruthy(); expect(element(by.id('t-demoParams')).isDisplayed()).toBeTruthy();
element(by.xpath("//option[@value='Apache']")).click(); element(by.xpath("//option[@value='Apache']")).click();
browser.sleep(2000);
expect(element(by.id('t-apacheParams')).isDisplayed()).toBeTruthy(); expect(element(by.id('t-apacheParams')).isDisplayed()).toBeTruthy();
}); });
it('should display auth modules chosen with authChoice', function() { it('should display auth modules chosen with authChoice', function() {
element(by.xpath("//option[@value='Choice']")).click(); element(by.xpath("//option[@value='Choice']")).click();
browser.sleep(1000);
expect(element(by.id('t-choiceParams')).isDisplayed()).toBeTruthy(); expect(element(by.id('t-choiceParams')).isDisplayed()).toBeTruthy();
element(by.id('a-choiceParams')).click(); element(by.id('a-choiceParams')).click();
browser.sleep(1000);
element(by.id('t-authChoiceModules')).click(); element(by.id('t-authChoiceModules')).click();
element(by.css('.glyphicon-plus-sign')).click(); browser.sleep(2000);
//element(by.css('.glyphicon-plus-sign')).click();
browser.sleep(2000);
element(by.id('a-authChoiceModules')).click(); element(by.id('a-authChoiceModules')).click();
browser.sleep(2000);
element.all(by.css('.glyphicon-plus-sign')).first().click();
element(by.id('t-authChoiceModules/n1')).click(); element(by.id('t-authChoiceModules/n1')).click();
element(by.xpath("//option[@value='LDAP']")).click(); browser.sleep(2000);
element.all(by.xpath("//option[@value='LDAP']")).first().click();
expect(element(by.id('t-ldapParams')).isDisplayed()).toBeTruthy(); expect(element(by.id('t-ldapParams')).isDisplayed()).toBeTruthy();
}); });
it('should display auth modules chosen with authCombination', function() { it('should display auth modules chosen with authCombination', function() {
element(by.id('t-authentication')).click(); element(by.id('t-authentication')).click();
browser.sleep(1000);
element(by.xpath("//option[@value='Combination']")).click(); element(by.xpath("//option[@value='Combination']")).click();
browser.sleep(1000);
expect(element(by.id('t-combinationParams')).isDisplayed()).toBeTruthy(); expect(element(by.id('t-combinationParams')).isDisplayed()).toBeTruthy();
element(by.id('a-combinationParams')).click(); element(by.id('a-combinationParams')).click();
browser.sleep(1000);
element(by.id('t-combModules')).click(); element(by.id('t-combModules')).click();
browser.sleep(2000);
element(by.css('.glyphicon-plus-sign')).click(); element(by.css('.glyphicon-plus-sign')).click();
element(by.xpath("//option[@value='DBI']")).click(); element(by.xpath("//option[@value='DBI']")).click();
expect(element(by.id('t-dbiParams')).isDisplayed()).toBeTruthy(); expect(element(by.id('t-dbiParams')).isDisplayed()).toBeTruthy();
element(by.xpath("//option[@value='LDAP']")).click(); element.all(by.xpath("//option[@value='LDAP']")).first().click();
expect(element(by.id('t-ldapParams')).isDisplayed()).toBeTruthy(); expect(element(by.id('t-ldapParams')).isDisplayed()).toBeTruthy();
}); });
}); });

View File

@ -7,7 +7,7 @@ describe('07u Lemonldap::NG Manager', function() {
describe('Apply mechanism', function() { describe('Apply mechanism', function() {
it('should be able to send UTF-8 chars', function() { it('should be able to send UTF-8 chars', function() {
browser.get('/#/confs/latest'); browser.get('/#!/confs/latest');
element(by.id('a-generalParameters')).click(); element(by.id('a-generalParameters')).click();
element(by.id('a-advancedParams')).click(); element(by.id('a-advancedParams')).click();
element(by.id('a-security')).click(); element(by.id('a-security')).click();
@ -18,6 +18,8 @@ describe('07u Lemonldap::NG Manager', function() {
element(by.id('save')).click(); element(by.id('save')).click();
element(by.id('longtextinput')).sendKeys('UTF-8 tests'); element(by.id('longtextinput')).sendKeys('UTF-8 tests');
element(by.id('saveok')).click(); element(by.id('saveok')).click();
browser.sleep(2000);
element(by.id('messageok')).click(); element(by.id('messageok')).click();
expect(element(by.id('cfgnum')).getText()).toEqual('2'); expect(element(by.id('cfgnum')).getText()).toEqual('2');
}); });

View File

@ -7,25 +7,38 @@ describe('08 Lemonldap::NG Manager', function() {
describe('Apply mechanism', function() { describe('Apply mechanism', function() {
it('should be able to add reload urls', function() { it('should be able to add reload urls', function() {
browser.get('/#/confs/latest'); browser.get('/#!/confs/latest');
browser.sleep(1000);
element(by.id('a-generalParameters')).click(); element(by.id('a-generalParameters')).click();
element(by.id('t-reloadParams')).click(); element(by.id('a-reloadParams')).click();
element(by.id('t-reloadUrls')).click(); element(by.id('t-reloadUrls')).click();
element(by.css('.glyphicon-plus-sign')).click();
element(by.id('a-reloadUrls')).click(); element(by.id('a-reloadUrls')).click();
browser.sleep(1000);
//element(by.id('a-reloadUrls')).click();
element(by.css('.glyphicon-plus-sign')).click();
browser.sleep(1000);
element(by.id('t-reloadUrls/n1')).click(); element(by.id('t-reloadUrls/n1')).click();
element(by.id('hashkeyinput')).clear().sendKeys('auth.example.com:19876'); browser.sleep(1000);
element(by.id('hashvalueinput')).clear().sendKeys('http://auth.example.com:19876/static/nothing'); element(by.id('hashkeyinput')).clear().sendKeys('auth.example.com');
browser.sleep(1000);
element(by.id('hashvalueinput')).clear().sendKeys('http://auth.example.com:19876/static/common/icons/ok.png');
browser.sleep(1000);
element(by.css('.glyphicon-plus-sign')).click(); element(by.css('.glyphicon-plus-sign')).click();
element(by.id('t-reloadUrls/n2')).click(); element(by.id('t-reloadUrls/n2')).click();
element(by.id('hashkeyinput')).clear().sendKeys('manager.example.com:19876'); element(by.id('hashkeyinput')).clear().sendKeys('manager.example.com');
element(by.id('hashvalueinput')).clear().sendKeys('http://auth.example.com:19876/static/js/manager.js'); element(by.id('hashvalueinput')).clear().sendKeys('http://manager.example.com:19876/static/js/manager.js');
browser.sleep(1000);
}); });
it('should save new configuration', function() { it('should save new configuration', function() {
element(by.id('save')).click(); element(by.id('save')).click();
element(by.id('longtextinput')).sendKeys('Reload URLs test'); element(by.id('longtextinput')).sendKeys('Reload URLs test');
element(by.id('saveok')).click(); element(by.id('saveok')).click();
expect(element.all(by.repeater('item in item.items')).count()).toEqual(2); expect(element.all(by.repeater('item in item.items')).count()).toEqual(2);
browser.sleep(1000);
element(by.id('messageok')).click(); element(by.id('messageok')).click();
expect(element(by.id('cfgnum')).getText()).toEqual('3'); expect(element(by.id('cfgnum')).getText()).toEqual('3');
}); });

View File

@ -9,7 +9,7 @@ describe('11 Lemonldap::NG Manager', function() {
it('should add an OIDC OP', function() { it('should add an OIDC OP', function() {
browser.get('/#/confs/latest'); browser.get('/#/confs/latest');
element(by.id('t-oidcOPMetaDataNodes')).click(); element(by.id('t-oidcOPMetaDataNodes')).click();
element(by.css('.glyphicon-plus-sign')).click(); element.all(by.css('.glyphicon-plus-sign')).first().click();
element(by.id('promptok')).click(); element(by.id('promptok')).click();
browser.sleep(500); browser.sleep(500);
element(by.id('a-oidcOPMetaDataNodes/new__op-example')).click(); element(by.id('a-oidcOPMetaDataNodes/new__op-example')).click();
@ -18,7 +18,7 @@ describe('11 Lemonldap::NG Manager', function() {
element(by.id('t-oidcOPMetaDataNodes/new__op-example/oidcOPMetaDataJWKS')).click(); element(by.id('t-oidcOPMetaDataNodes/new__op-example/oidcOPMetaDataJWKS')).click();
element(by.id('filetext')).sendKeys('{"c":"d"}'); element(by.id('filetext')).sendKeys('{"c":"d"}');
element(by.id('t-oidcOPMetaDataNodes/new__op-example/oidcOPMetaDataExportedVars')).click(); element(by.id('t-oidcOPMetaDataNodes/new__op-example/oidcOPMetaDataExportedVars')).click();
element(by.css('.glyphicon-plus-sign')).click(); element.all(by.css('.glyphicon-plus-sign')).first().click();
//element(by.id('a-oidcOPMetaDataNodes/new__op-example/oidcOPMetaDataExportedVars')).click(); //element(by.id('a-oidcOPMetaDataNodes/new__op-example/oidcOPMetaDataExportedVars')).click();
element(by.id('t-oidcOPMetaDataNodes/new__op-example/oidcOPMetaDataExportedVars/n1')).click(); element(by.id('t-oidcOPMetaDataNodes/new__op-example/oidcOPMetaDataExportedVars/n1')).click();
element(by.id('hashkeyinput')).clear().sendKeys('MyKey'); element(by.id('hashkeyinput')).clear().sendKeys('MyKey');

View File

@ -9,12 +9,12 @@ describe('12 Lemonldap::NG Manager', function() {
it('should add an OIDC RP', function() { it('should add an OIDC RP', function() {
browser.get('/#/confs/latest'); browser.get('/#/confs/latest');
element(by.id('t-oidcRPMetaDataNodes')).click(); element(by.id('t-oidcRPMetaDataNodes')).click();
element(by.css('.glyphicon-plus-sign')).click(); element.all(by.css('.glyphicon-plus-sign')).first().click();
element(by.id('promptok')).click(); element(by.id('promptok')).click();
browser.sleep(500); browser.sleep(500);
element(by.id('a-oidcRPMetaDataNodes/new__rp-example')).click(); element(by.id('a-oidcRPMetaDataNodes/new__rp-example')).click();
element(by.id('t-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataExportedVars')).click(); element(by.id('t-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataExportedVars')).click();
element(by.css('.glyphicon-plus-sign')).click(); element.all(by.css('.glyphicon-plus-sign')).first().click();
//element(by.id('a-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataExportedVars')).click(); //element(by.id('a-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataExportedVars')).click();
element(by.id('t-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataExportedVars/n1')).click(); element(by.id('t-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataExportedVars/n1')).click();
element(by.id('hashkeyinput')).clear().sendKeys('MyKey'); element(by.id('hashkeyinput')).clear().sendKeys('MyKey');
@ -24,7 +24,7 @@ describe('12 Lemonldap::NG Manager', function() {
element(by.id('t-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataOptionsClientID')).click(); element(by.id('t-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataOptionsClientID')).click();
element(by.id('textinput')).clear().sendKeys('MyClientID'); element(by.id('textinput')).clear().sendKeys('MyClientID');
element(by.id('t-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataOptionsExtraClaims')).click(); element(by.id('t-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataOptionsExtraClaims')).click();
element(by.css('.glyphicon-plus-sign')).click(); element.all(by.css('.glyphicon-plus-sign')).first().click();
//element(by.id('a-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataOptionsExtraClaims')).click(); //element(by.id('a-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataOptionsExtraClaims')).click();
element(by.id('t-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataOptionsExtraClaims/n2')).click(); element(by.id('t-oidcRPMetaDataNodes/new__rp-example/oidcRPMetaDataOptionsExtraClaims/n2')).click();
element(by.id('hashkeyinput')).clear().sendKeys('MyClaim'); element(by.id('hashkeyinput')).clear().sendKeys('MyClaim');

View File

@ -7,7 +7,9 @@ describe('36 Lemonldap::NG Manager', function() {
describe('Diff interface', function() { describe('Diff interface', function() {
it('should find key changed', function() { it('should find key changed', function() {
browser.get('/diff.html#!/6/7'); browser.get('/diff.html#!/5/6');
browser.sleep(5000);
element(by.id('t-generalParameters')).click(); element(by.id('t-generalParameters')).click();
element(by.id('t-advancedParams')).click(); element(by.id('t-advancedParams')).click();
element(by.id('t-security')).click(); element(by.id('t-security')).click();

View File

@ -6,7 +6,7 @@ describe('40 Lemonldap::NG Manager', function() {
browser.get('/'); browser.get('/');
var links = element.all(by.repeater('l in links')); var links = element.all(by.repeater('l in links'));
expect(links.count()).toEqual(4); expect(links.count()).toEqual(4);
element(by.xpath("//a[@href='sessions.html']")).click(); element.all(by.xpath("//a[@href='sessions.html']")).first().click();
}); });
}); });

View File

@ -1,10 +1,10 @@
exports.config = { exports.config = {
allScriptsTimeout: 11000, allScriptsTimeout: 300000,
// Specific test // Specific test
specs: process.env.E2E_TESTS, // specs: process.env.E2E_TESTS,
// All tests // All tests
//specs: ['handler/*.js', 'portal/*.js', 'manager/*.js' ], specs: ['portal/*.js', 'handler/*.js', 'manager/*.js' ],
capabilities: { capabilities: {
//'browserName': 'firefox' //'browserName': 'firefox'
@ -18,6 +18,6 @@ exports.config = {
framework: 'jasmine', framework: 'jasmine',
jasmineNodeOpts: { jasmineNodeOpts: {
defaultTimeoutInterval: 30000 defaultTimeoutInterval: 60000
} }
}; };

View File

@ -1,6 +1,6 @@
package Lemonldap::NG::Handler::Main::Init; package Lemonldap::NG::Handler::Main::Init;
our $VERSION = '2.0.0'; our $VERSION = '2.0.2';
package Lemonldap::NG::Handler::Main; package Lemonldap::NG::Handler::Main;
@ -66,7 +66,9 @@ sub logLevelInit {
# adapt server signature # adapt server signature
sub serverSignatureInit { sub serverSignatureInit {
my $class = shift; my $class = shift;
$class->setServerSignature("Lemonldap::NG/$VERSION"); require Lemonldap::NG::Handler;
my $version = $Lemonldap::NG::Handler::VERSION;
$class->setServerSignature("Lemonldap::NG/$version");
} }
## @ifn protected void statusInit() ## @ifn protected void statusInit()

View File

@ -30,7 +30,8 @@ sub tests {
portalIsInDomain => sub { portalIsInDomain => sub {
return ( return (
1, 1,
( index( $conf->{portal}, $conf->{domain} ) > 0 (
index( $conf->{portal}, $conf->{domain} ) > 0
? '' ? ''
: "Portal seems not to be in the domain $conf->{domain}" : "Portal seems not to be in the domain $conf->{domain}"
) )
@ -60,7 +61,8 @@ sub tests {
} }
return ( return (
1, 1,
( @pb (
@pb
? 'Virtual hosts ' ? 'Virtual hosts '
. join( ', ', @pb ) . join( ', ', @pb )
. " are not in $conf->{domain} and cross-domain-authentication is not set" . " are not in $conf->{domain} and cross-domain-authentication is not set"
@ -117,8 +119,8 @@ sub tests {
checkAttrAndMacros => sub { checkAttrAndMacros => sub {
my @tmp; my @tmp;
foreach my $k ( keys %$conf ) { foreach my $k ( keys %$conf ) {
if ( $k if ( $k =~
=~ /^(?:openIdSreg_(?:(?:(?:full|nick)nam|languag|postcod|timezon)e|country|gender|email|dob)|whatToTrace)$/ /^(?:openIdSreg_(?:(?:(?:full|nick)nam|languag|postcod|timezon)e|country|gender|email|dob)|whatToTrace)$/
) )
{ {
my $v = $conf->{$k}; my $v = $conf->{$k};
@ -136,7 +138,8 @@ sub tests {
} }
return ( return (
1, 1,
( @tmp (
@tmp
? 'Values of parameter(s) "' ? 'Values of parameter(s) "'
. join( ', ', @tmp ) . join( ', ', @tmp )
. '" are not defined in exported attributes or macros' . '" are not defined in exported attributes or macros'
@ -151,15 +154,15 @@ sub tests {
if ( $conf->{userDB} =~ /^Google$/ ) { if ( $conf->{userDB} =~ /^Google$/ ) {
foreach my $k ( keys %{ $conf->{exportedVars} } ) { foreach my $k ( keys %{ $conf->{exportedVars} } ) {
my $v = $conf->{exportedVars}->{$k}; my $v = $conf->{exportedVars}->{$k};
if ( $v !~ Lemonldap::NG::Common::Regexp::GOOGLEAXATTR() ) if ( $v !~ Lemonldap::NG::Common::Regexp::GOOGLEAXATTR() ) {
{
push @tmp, $v; push @tmp, $v;
} }
} }
} }
return ( return (
1, 1,
( @tmp (
@tmp
? 'Values of parameter(s) "' ? 'Values of parameter(s) "'
. join( ', ', @tmp ) . join( ', ', @tmp )
. '" are not exported by Google' . '" are not exported by Google'
@ -174,8 +177,7 @@ sub tests {
if ( $conf->{userDB} =~ /^OpenID$/ ) { if ( $conf->{userDB} =~ /^OpenID$/ ) {
foreach my $k ( keys %{ $conf->{exportedVars} } ) { foreach my $k ( keys %{ $conf->{exportedVars} } ) {
my $v = $conf->{exportedVars}->{$k}; my $v = $conf->{exportedVars}->{$k};
if ( $v if ( $v !~ Lemonldap::NG::Common::Regexp::OPENIDSREGATTR() )
!~ Lemonldap::NG::Common::Regexp::OPENIDSREGATTR() )
{ {
push @tmp, $v; push @tmp, $v;
} }
@ -183,7 +185,8 @@ sub tests {
} }
return ( return (
1, 1,
( @tmp (
@tmp
? 'Values of parameter(s) "' ? 'Values of parameter(s) "'
. join( ', ', @tmp ) . join( ', ', @tmp )
. '" are not exported by OpenID SREG' . '" are not exported by OpenID SREG'
@ -195,12 +198,11 @@ sub tests {
# Try to use Apache::Session module # Try to use Apache::Session module
testApacheSession => sub { testApacheSession => sub {
my ( $id, %h ); my ( $id, %h );
my $gc = Lemonldap::NG::Handler::Main->tsv my $gc = Lemonldap::NG::Handler::Main->tsv->{sessionStorageModule};
->{sessionStorageModule};
return 1 return 1
if ( ( $gc and $gc eq $conf->{globalStorage} ) if ( ( $gc and $gc eq $conf->{globalStorage} )
or $conf->{globalStorage} or $conf->{globalStorage} =~
=~ /^Lemonldap::NG::Common::Apache::Session::/ ); /^Lemonldap::NG::Common::Apache::Session::/ );
eval "use $conf->{globalStorage}"; eval "use $conf->{globalStorage}";
return ( -1, "Unknown package $conf->{globalStorage}" ) if ($@); return ( -1, "Unknown package $conf->{globalStorage}" ) if ($@);
eval { eval {
@ -235,10 +237,11 @@ sub tests {
# Warn if cookie name has changed # Warn if cookie name has changed
cookieNameChanged => sub { cookieNameChanged => sub {
my $cn = $Lemonldap::NG::Handler::PSGI::API::tsv->{cookieName}; my $cn = Lemonldap::NG::Handler::Main->tsv->{cookieName};
return ( return (
1, 1,
( $cn (
$cn
and $cn ne $conf->{cookieName} and $cn ne $conf->{cookieName}
? 'Cookie name has changed, you must restart all your web servers' ? 'Cookie name has changed, you must restart all your web servers'
: () : ()
@ -250,7 +253,8 @@ sub tests {
cookieTTL => sub { cookieTTL => sub {
return 1 unless ( defined $conf->{cookieExpiration} ); return 1 unless ( defined $conf->{cookieExpiration} );
return ( 0, "Cookie TTL must be higher than one minute" ) return ( 0, "Cookie TTL must be higher than one minute" )
unless ( $conf->{cookieExpiration} == 0 || $conf->{cookieExpiration} > 60 ); unless ( $conf->{cookieExpiration} == 0
|| $conf->{cookieExpiration} > 60 );
return ( 1, "Cookie TTL should be higher or equal than one hour" ) return ( 1, "Cookie TTL should be higher or equal than one hour" )
unless ( $conf->{cookieExpiration} >= 3600 unless ( $conf->{cookieExpiration} >= 3600
|| $conf->{cookieExpiration} == 0 ); || $conf->{cookieExpiration} == 0 );
@ -290,8 +294,8 @@ sub tests {
"Activity timeout interval must be lower than session activity timeout" "Activity timeout interval must be lower than session activity timeout"
) )
if ( $conf->{timeoutActivity} if ( $conf->{timeoutActivity}
and $conf->{timeoutActivity} and $conf->{timeoutActivity} <=
<= $conf->{timeoutActivityInterval} ); $conf->{timeoutActivityInterval} );
# Return # Return
return 1; return 1;
@ -301,7 +305,8 @@ sub tests {
managerProtection => sub { managerProtection => sub {
return ( return (
1, 1,
( $conf->{cfgAuthor} eq 'anonymous' (
$conf->{cfgAuthor} eq 'anonymous'
? 'Your manager seems to be unprotected' ? 'Your manager seems to be unprotected'
: '' : ''
) )
@ -347,8 +352,9 @@ sub tests {
my $res = 1; my $res = 1;
my %entityIds; my %entityIds;
foreach my $idpId ( keys %{ $conf->{samlIDPMetaDataXML} } ) { foreach my $idpId ( keys %{ $conf->{samlIDPMetaDataXML} } ) {
unless ( $conf->{samlIDPMetaDataXML}->{$idpId} unless (
->{samlIDPMetaDataXML} =~ /entityID=(['"])(.+?)\1/si ) $conf->{samlIDPMetaDataXML}->{$idpId}->{samlIDPMetaDataXML}
=~ /entityID=(['"])(.+?)\1/si )
{ {
push @msg, "$idpId SAML metadata has no EntityID"; push @msg, "$idpId SAML metadata has no EntityID";
$res = 0; $res = 0;
@ -374,8 +380,8 @@ sub tests {
my %entityIds; my %entityIds;
foreach my $spId ( keys %{ $conf->{samlSPMetaDataXML} } ) { foreach my $spId ( keys %{ $conf->{samlSPMetaDataXML} } ) {
unless ( unless (
$conf->{samlSPMetaDataXML}->{$spId}->{samlSPMetaDataXML} $conf->{samlSPMetaDataXML}->{$spId}->{samlSPMetaDataXML} =~
=~ /entityID=(['"])(.+?)\1/si ) /entityID=(['"])(.+?)\1/si )
{ {
push @msg, "$spId SAML metadata has no EntityID"; push @msg, "$spId SAML metadata has no EntityID";
$res = 0; $res = 0;
@ -409,8 +415,8 @@ sub tests {
); );
} }
eval { eval {
Lemonldap::NG::Common::Combination::Parser->parse( Lemonldap::NG::Common::Combination::Parser->parse( $moduleList,
$moduleList, $conf->{combination} ); $conf->{combination} );
}; };
return ( 0, $@ ) if ($@); return ( 0, $@ ) if ($@);
@ -489,7 +495,9 @@ sub tests {
return 1 unless ( defined $conf->{totp2fDigits} ); return 1 unless ( defined $conf->{totp2fDigits} );
return ( return (
1, 1,
( ( $conf->{totp2fDigits} == 6 (
(
$conf->{totp2fDigits} == 6
or $conf->{totp2fDigits} == 8 or $conf->{totp2fDigits} == 8
) )
? '' ? ''
@ -519,7 +527,8 @@ sub tests {
&& defined $conf->{yubikey2fClientID} ); && defined $conf->{yubikey2fClientID} );
return ( return (
1, 1,
( ( $conf->{yubikey2fPublicIDSize} == 12 ) (
( $conf->{yubikey2fPublicIDSize} == 12 )
? '' ? ''
: 'Yubikey public ID size should be 12 digits long' : 'Yubikey public ID size should be 12 digits long'
) )
@ -551,8 +560,7 @@ sub tests {
$ok ||= $conf->{'utotp2fActivation'} $ok ||= $conf->{'utotp2fActivation'}
&& ( $conf->{'u2fSelfRegistration'} && ( $conf->{'u2fSelfRegistration'}
|| $conf->{'totp2fSelfRegistration'} ); || $conf->{'totp2fSelfRegistration'} );
$msg $msg = "A self registrable module should be enabled to require 2FA"
= "A self registrable module should be enabled to require 2FA"
unless ($ok); unless ($ok);
return ( 1, $msg ); return ( 1, $msg );
@ -584,8 +592,7 @@ sub tests {
# Warn if number of password reset retries is null # Warn if number of password reset retries is null
passwordResetRetries => sub { passwordResetRetries => sub {
return 1 unless ( $conf->{portalDisplayResetPassword} ); return 1 unless ( $conf->{portalDisplayResetPassword} );
return ( 1, return ( 1, "Number of reset password retries should not be null" )
"Number of reset password retries should not be null" )
unless ( $conf->{passwordResetAllowedRetries} ); unless ( $conf->{passwordResetAllowedRetries} );
# Return # Return

View File

@ -3,11 +3,10 @@
package Lemonldap::NG::Portal::Main::Menu; package Lemonldap::NG::Portal::Main::Menu;
use strict; use strict;
use utf8;
use Mouse; use Mouse;
use Clone 'clone'; use Clone 'clone';
our $VERSION = '2.0.1'; our $VERSION = '2.0.2';
extends 'Lemonldap::NG::Common::Module'; extends 'Lemonldap::NG::Common::Module';
@ -188,7 +187,6 @@ sub appslist {
sub _buildCategoryHash { sub _buildCategoryHash {
my ( $self, $req, $catid, $cathash, $catlevel ) = @_; my ( $self, $req, $catid, $cathash, $catlevel ) = @_;
my $catname = $cathash->{catname} || $catid; my $catname = $cathash->{catname} || $catid;
utf8::decode($catname);
my $applications; my $applications;
my $categories; my $categories;
@ -244,8 +242,6 @@ sub _buildApplicationHash {
my $appuri = $apphash->{options}->{uri} || ""; my $appuri = $apphash->{options}->{uri} || "";
my $appdesc = $apphash->{options}->{description}; my $appdesc = $apphash->{options}->{description};
my $applogo = $apphash->{options}->{logo}; my $applogo = $apphash->{options}->{logo};
utf8::decode($appname);
utf8::decode($appdesc) if $appdesc;
# Detect sub applications # Detect sub applications
my $subapphash; my $subapphash;