Skip to content

Commit

Permalink
feat(jans-auth-server): added allowSpontaneousScopes AS json config #…
Browse files Browse the repository at this point in the history
…2074 (#2111)

* feat(jans-auth-server): added allowSpontaneousScopes AS JSON config  #2074

#2074
docs: swagger updated

* test(jans-auth-server): added SpontaneousScopeServiceTest #2074

docs: no docs
  • Loading branch information
yuriyz authored Aug 15, 2022
1 parent fceec83 commit 3083a3f
Show file tree
Hide file tree
Showing 7 changed files with 71 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,7 @@ public class AppConfiguration implements Configuration {
private int statTimerIntervalInSeconds;
private String statAuthorizationScope;

private Boolean allowSpontaneousScopes;
private int spontaneousScopeLifetime;
private String openidSubAttribute;
private Boolean publicSubjectIdentifierPerClientEnabled = false;
Expand Down Expand Up @@ -1489,6 +1490,15 @@ public void setUmaPctLifetime(int umaPctLifetime) {
this.umaPctLifetime = umaPctLifetime;
}

public Boolean getAllowSpontaneousScopes() {
if (allowSpontaneousScopes == null) allowSpontaneousScopes = false;
return allowSpontaneousScopes;
}

public void setAllowSpontaneousScopes(Boolean allowSpontaneousScopes) {
this.allowSpontaneousScopes = allowSpontaneousScopes;
}

public int getSpontaneousScopeLifetime() {
return spontaneousScopeLifetime;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,20 +14,17 @@
import io.jans.as.model.configuration.AppConfiguration;
import io.jans.as.model.util.Pair;
import io.jans.as.persistence.model.Scope;
import org.apache.commons.lang3.BooleanUtils;
import org.python.google.common.collect.Sets;
import org.slf4j.Logger;

import jakarta.ejb.Stateless;
import jakarta.inject.Inject;
import jakarta.inject.Named;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.Set;
import java.util.UUID;
import org.python.google.common.collect.Sets;
import org.slf4j.Logger;

import java.util.*;
import java.util.regex.Pattern;

import static org.apache.commons.lang3.BooleanUtils.isFalse;

@Stateless
@Named
public class SpontaneousScopeService {
Expand All @@ -49,7 +46,7 @@ public Scope createSpontaneousScopeIfNeeded(Set<String> regExps, String scopeId,
}

final Pair<Boolean, String> isAllowed = isAllowedBySpontaneousScopes(regExps, scopeId);
if (BooleanUtils.isFalse(isAllowed.getFirst())) {
if (isFalse(isAllowed.getFirst())) {
log.error("Forbidden by client. Check client configuration.");
return null;
}
Expand Down Expand Up @@ -87,7 +84,11 @@ public long getLifetime() {
}

public boolean isAllowedBySpontaneousScopes(Client client, String scopeRequested) {
if (BooleanUtils.isFalse(client.getAttributes().getAllowSpontaneousScopes())) {
if (isFalse(appConfiguration.getAllowSpontaneousScopes())) {
return false;
}

if (isFalse(client.getAttributes().getAllowSpontaneousScopes())) {
return false;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,10 @@ public Scope getOrCreate(Client client, String scopeId, Set<String> regExps) {
return fromLdap;
}

if (isFalse(appConfiguration.getAllowSpontaneousScopes())) {
return null;
}

if (isFalse(client.getAttributes().getAllowSpontaneousScopes())) {
return null;
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
package io.jans.as.server.service;

import io.jans.as.common.model.registration.Client;
import io.jans.as.model.config.StaticConfiguration;
import io.jans.as.model.configuration.AppConfiguration;
import org.mockito.InjectMocks;
import org.mockito.Mock;
import org.mockito.testng.MockitoTestNGListener;
import org.slf4j.Logger;
import org.testng.annotations.Listeners;
import org.testng.annotations.Test;

import static org.testng.Assert.assertFalse;

/**
* @author Yuriy Z
*/
@Listeners(MockitoTestNGListener.class)
public class SpontaneousScopeServiceTest {

@InjectMocks
private SpontaneousScopeService spontaneousScopeService;

@Mock
private Logger log;
@Mock
private StaticConfiguration staticConfiguration;
@Mock
private AppConfiguration appConfiguration;
@Mock
private ScopeService scopeService;

@Test
public void isAllowedBySpontaneousScopes_whenGlobalConfigReturnsFalse_shouldReturnFalse() {
Client client = new Client();
client.getAttributes().setAllowSpontaneousScopes(true);

assertFalse(spontaneousScopeService.isAllowedBySpontaneousScopes(client, "scope"));
}
}
1 change: 1 addition & 0 deletions jans-auth-server/server/src/test/resources/testng.xml
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
<class name="io.jans.as.server.service.MTLSServiceTest" />
<class name="io.jans.as.server.model.authorize.JwtAuthorizationRequestTest" />
<class name="io.jans.as.server.service.ScopeServiceTest" />
<class name="io.jans.as.server.service.SpontaneousScopeServiceTest" />
<class name="io.jans.as.server.model.CIBAGrantTest" />
<class name="io.jans.as.server.service.RedirectionUriServiceTest" />
<class name="io.jans.as.server.service.external.ExternalAuthenticationServiceTest" />
Expand Down
3 changes: 3 additions & 0 deletions jans-config-api/docs/jans-config-api-swagger.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4249,6 +4249,9 @@ components:
umaRestrictResourceToAssociatedClient:
type: boolean
description: Restrict access to resource by associated client.
allowSpontaneousScopes:
type: boolean
description: Specifies whether to allow spontaneous scopes
spontaneousScopeLifetime:
type: integer
description: The lifetime of spontaneous scope in seconds.
Expand Down
1 change: 1 addition & 0 deletions jans-linux-setup/jans_setup/setup_app/test_data_loader.py
Original file line number Diff line number Diff line change
Expand Up @@ -238,6 +238,7 @@ def load_test_data(self):
'fapiCompatibility': False,
'forceIdTokenHintPrecense': False,
'introspectionScriptBackwardCompatibility': False,
'allowSpontaneousScopes': True,
'spontaneousScopeLifetime': 0,
'tokenEndpointAuthMethodsSupported': [ 'client_secret_basic', 'client_secret_post', 'client_secret_jwt', 'private_key_jwt', 'tls_client_auth', 'self_signed_tls_client_auth', 'none' ],
'sessionIdRequestParameterEnabled': True,
Expand Down

0 comments on commit 3083a3f

Please sign in to comment.