3 changed files with 159 additions and 2 deletions
@ -0,0 +1,105 @@
@@ -0,0 +1,105 @@
|
||||
/* |
||||
* Copyright 2002-2022 the original author or authors. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* https://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.springframework.security.ldap.userdetails; |
||||
|
||||
import java.util.Set; |
||||
|
||||
import org.junit.jupiter.api.BeforeEach; |
||||
import org.junit.jupiter.api.Test; |
||||
import org.junit.jupiter.api.extension.ExtendWith; |
||||
|
||||
import org.springframework.beans.factory.DisposableBean; |
||||
import org.springframework.beans.factory.annotation.Autowired; |
||||
import org.springframework.context.annotation.Bean; |
||||
import org.springframework.context.annotation.Configuration; |
||||
import org.springframework.ldap.core.ContextSource; |
||||
import org.springframework.ldap.core.DirContextAdapter; |
||||
import org.springframework.ldap.core.DistinguishedName; |
||||
import org.springframework.security.core.authority.AuthorityUtils; |
||||
import org.springframework.security.ldap.DefaultSpringSecurityContextSource; |
||||
import org.springframework.security.ldap.server.ApacheDSContainer; |
||||
import org.springframework.test.context.ContextConfiguration; |
||||
import org.springframework.test.context.junit.jupiter.SpringExtension; |
||||
|
||||
import static org.assertj.core.api.Assertions.assertThat; |
||||
|
||||
/** |
||||
* @author Dayan Kodippily |
||||
*/ |
||||
@ExtendWith(SpringExtension.class) |
||||
@ContextConfiguration( |
||||
classes = DefaultLdapAuthoritiesPopulatorGetGrantedAuthoritiesTests.ApacheDsContainerWithUndefinedGroupRoleAttributeConfig.class) |
||||
public class DefaultLdapAuthoritiesPopulatorGetGrantedAuthoritiesTests { |
||||
|
||||
@Autowired |
||||
private DefaultSpringSecurityContextSource contextSource; |
||||
|
||||
private DefaultLdapAuthoritiesPopulator populator; |
||||
|
||||
@BeforeEach |
||||
public void setUp() { |
||||
this.populator = new DefaultLdapAuthoritiesPopulator(this.contextSource, "ou=groups"); |
||||
this.populator.setIgnorePartialResultException(false); |
||||
} |
||||
|
||||
@Test |
||||
public void groupSearchDoesNotAllowNullRoles() { |
||||
this.populator.setRolePrefix("ROLE_"); |
||||
this.populator.setGroupRoleAttribute("ou"); |
||||
this.populator.setSearchSubtree(true); |
||||
this.populator.setSearchSubtree(false); |
||||
this.populator.setConvertToUpperCase(true); |
||||
this.populator.setGroupSearchFilter("(member={0})"); |
||||
|
||||
DirContextAdapter ctx = new DirContextAdapter( |
||||
new DistinguishedName("uid=dayan,ou=people,dc=springframework,dc=org")); |
||||
|
||||
Set<String> authorities = AuthorityUtils.authorityListToSet(this.populator.getGrantedAuthorities(ctx, "dayan")); |
||||
|
||||
assertThat(authorities).as("Should have 1 role").hasSize(2); |
||||
|
||||
assertThat(authorities.contains("ROLE_DEVELOPER")).isTrue(); |
||||
assertThat(authorities.contains("ROLE_")).isTrue(); |
||||
} |
||||
|
||||
@Configuration |
||||
static class ApacheDsContainerWithUndefinedGroupRoleAttributeConfig implements DisposableBean { |
||||
|
||||
private ApacheDSContainer container; |
||||
|
||||
@Bean |
||||
ApacheDSContainer ldapContainer() throws Exception { |
||||
this.container = new ApacheDSContainer("dc=springframework,dc=org", |
||||
"classpath:test-server-with-undefined-group-role-attributes.ldif"); |
||||
this.container.setPort(0); |
||||
return this.container; |
||||
} |
||||
|
||||
@Bean |
||||
ContextSource contextSource(ApacheDSContainer ldapContainer) { |
||||
return new DefaultSpringSecurityContextSource( |
||||
"ldap://127.0.0.1:" + ldapContainer.getLocalPort() + "/dc=springframework,dc=org"); |
||||
} |
||||
|
||||
@Override |
||||
public void destroy() { |
||||
this.container.stop(); |
||||
} |
||||
|
||||
} |
||||
|
||||
} |
||||
@ -0,0 +1,41 @@
@@ -0,0 +1,41 @@
|
||||
dn: ou=groups,dc=springframework,dc=org |
||||
objectclass: top |
||||
objectclass: organizationalUnit |
||||
ou: groups |
||||
|
||||
dn: ou=people,dc=springframework,dc=org |
||||
objectclass: top |
||||
objectclass: organizationalUnit |
||||
ou: people |
||||
|
||||
dn: uid=dayan,ou=people,dc=springframework,dc=org |
||||
objectclass: top |
||||
objectclass: person |
||||
objectclass: organizationalPerson |
||||
objectclass: inetOrgPerson |
||||
cn: Dayan K |
||||
sn: Dayan |
||||
uid: dayan |
||||
userPassword: dayanspassword |
||||
|
||||
|
||||
|
||||
dn: cn=managers,ou=groups,dc=springframework,dc=org |
||||
objectclass: top |
||||
objectclass: groupOfNames |
||||
cn: managers |
||||
ou: |
||||
member: uid=dayan,ou=people,dc=springframework,dc=org |
||||
|
||||
dn: cn=researchers,ou=groups,dc=springframework,dc=org |
||||
objectclass: top |
||||
objectclass: groupOfNames |
||||
cn: researchers |
||||
member: uid=dayan,ou=people,dc=springframework,dc=org |
||||
|
||||
dn: cn=developers,ou=groups,dc=springframework,dc=org |
||||
objectclass: top |
||||
objectclass: groupOfNames |
||||
cn: developers |
||||
ou: developer |
||||
member: uid=dayan,ou=people,dc=springframework,dc=org |
||||
Loading…
Reference in new issue