Search in sources :

Example 21 with PrincipalIterator

use of org.apache.jackrabbit.api.security.principal.PrincipalIterator in project jackrabbit-oak by apache.

the class PrincipalManagerImplTest method testGetPrincipalsNonGroup.

@Test
public void testGetPrincipalsNonGroup() {
    Iterator<? extends Principal> expected = provider.findPrincipals(PrincipalManager.SEARCH_TYPE_NOT_GROUP);
    PrincipalIterator it = principalMgr.getPrincipals(PrincipalManager.SEARCH_TYPE_NOT_GROUP);
    assertIterator(expected, it);
}
Also used : PrincipalIterator(org.apache.jackrabbit.api.security.principal.PrincipalIterator) Test(org.junit.Test)

Example 22 with PrincipalIterator

use of org.apache.jackrabbit.api.security.principal.PrincipalIterator in project jackrabbit-oak by apache.

the class PrincipalManagerImplTest method testFindPrincipal.

@Test
public void testFindPrincipal() {
    for (Principal pcpl : testPrincipals) {
        PrincipalIterator it = principalMgr.findPrincipals(pcpl.getName());
        assertTrue("findPrincipals does not find principal with filter '" + pcpl.getName() + '\'', Iterators.contains(it, pcpl));
    }
}
Also used : PrincipalIterator(org.apache.jackrabbit.api.security.principal.PrincipalIterator) Principal(java.security.Principal) Test(org.junit.Test)

Example 23 with PrincipalIterator

use of org.apache.jackrabbit.api.security.principal.PrincipalIterator in project jackrabbit-oak by apache.

the class PrincipalManagerImplTest method testFindPrincipalByTypeGroup.

@Test
public void testFindPrincipalByTypeGroup() {
    for (Principal pcpl : testPrincipals) {
        if (isGroup(pcpl)) {
            PrincipalIterator it = principalMgr.findPrincipals(pcpl.getName(), PrincipalManager.SEARCH_TYPE_GROUP);
            assertTrue("findPrincipals does not find principal with filter '" + pcpl.getName() + '\'', Iterators.contains(it, pcpl));
        } else {
            PrincipalIterator it = principalMgr.findPrincipals(pcpl.getName(), PrincipalManager.SEARCH_TYPE_NOT_GROUP);
            assertTrue("findPrincipals does not find principal with filter '" + pcpl.getName() + '\'', Iterators.contains(it, pcpl));
        }
    }
}
Also used : PrincipalIterator(org.apache.jackrabbit.api.security.principal.PrincipalIterator) Principal(java.security.Principal) Test(org.junit.Test)

Example 24 with PrincipalIterator

use of org.apache.jackrabbit.api.security.principal.PrincipalIterator in project jackrabbit-oak by apache.

the class PrincipalManagerImplTest method testFindEveryone.

@Test
public void testFindEveryone() {
    // untyped search -> everyone must be part of the result set
    PrincipalIterator it = principalMgr.findPrincipals(EveryonePrincipal.NAME);
    assertTrue("findPrincipals does not find principal with filter '" + EveryonePrincipal.NAME + '\'', Iterators.contains(it, EveryonePrincipal.getInstance()));
}
Also used : PrincipalIterator(org.apache.jackrabbit.api.security.principal.PrincipalIterator) Test(org.junit.Test)

Example 25 with PrincipalIterator

use of org.apache.jackrabbit.api.security.principal.PrincipalIterator in project jackrabbit-oak by apache.

the class FindAuthorizablesTest method testFindAuthorizable.

@Test
public void testFindAuthorizable() throws RepositoryException, NotExecutableException {
    Set<Principal> principals = new HashSet<Principal>();
    PrincipalManager pMgr = ((JackrabbitSession) superuser).getPrincipalManager();
    Principal p = pMgr.getPrincipal(superuser.getUserID());
    if (p != null) {
        principals.add(p);
        PrincipalIterator principalIterator = pMgr.getGroupMembership(p);
        while (principalIterator.hasNext()) {
            principals.add(principalIterator.nextPrincipal());
        }
    }
    Authorizable auth;
    for (Principal principal : principals) {
        auth = userMgr.getAuthorizable(principal);
        if (auth != null) {
            if (!auth.isGroup() && auth.hasProperty(UserConstants.REP_PRINCIPAL_NAME)) {
                String val = auth.getProperty(UserConstants.REP_PRINCIPAL_NAME)[0].getString();
                Iterator<Authorizable> users = userMgr.findAuthorizables(UserConstants.REP_PRINCIPAL_NAME, val);
                // the result must contain 1 authorizable
                assertTrue(users.hasNext());
                Authorizable first = users.next();
                assertEquals(first.getID(), val);
                // since id is unique -> there should be no more users in
                // the iterator left
                assertFalse(users.hasNext());
            }
        }
    }
}
Also used : PrincipalManager(org.apache.jackrabbit.api.security.principal.PrincipalManager) PrincipalIterator(org.apache.jackrabbit.api.security.principal.PrincipalIterator) Authorizable(org.apache.jackrabbit.api.security.user.Authorizable) JackrabbitSession(org.apache.jackrabbit.api.JackrabbitSession) Principal(java.security.Principal) HashSet(java.util.HashSet) Test(org.junit.Test)

Aggregations

PrincipalIterator (org.apache.jackrabbit.api.security.principal.PrincipalIterator)61 Principal (java.security.Principal)40 Test (org.junit.Test)35 EveryonePrincipal (org.apache.jackrabbit.oak.spi.security.principal.EveryonePrincipal)15 AbstractJCRTest (org.apache.jackrabbit.test.AbstractJCRTest)11 JackrabbitSession (org.apache.jackrabbit.api.JackrabbitSession)9 PrincipalManager (org.apache.jackrabbit.api.security.principal.PrincipalManager)9 NotExecutableException (org.apache.jackrabbit.test.NotExecutableException)9 ArrayList (java.util.ArrayList)8 Authorizable (org.apache.jackrabbit.api.security.user.Authorizable)7 Group (java.security.acl.Group)5 RepositoryException (javax.jcr.RepositoryException)4 Group (org.apache.jackrabbit.api.security.user.Group)4 TestPrincipal (org.apache.jackrabbit.core.security.TestPrincipal)4 EveryonePrincipal (org.apache.jackrabbit.core.security.principal.EveryonePrincipal)4 HashSet (java.util.HashSet)3 Impersonation (org.apache.jackrabbit.api.security.user.Impersonation)3 User (org.apache.jackrabbit.api.security.user.User)3 Session (javax.jcr.Session)2 Subject (javax.security.auth.Subject)2