Search in sources :

Example 66 with TreePermission

use of org.apache.jackrabbit.oak.spi.security.authorization.permission.TreePermission in project jackrabbit-oak by apache.

the class CompositeProviderEmptyTest method testTreePermissionCanRead.

@Test
public void testTreePermissionCanRead() throws Exception {
    TreePermission parentPermission = TreePermission.EMPTY;
    for (String path : TP_PATHS) {
        Tree t = readOnlyRoot.getTree(path);
        TreePermission tp = cpp.getTreePermission(t, parentPermission);
        assertFalse(tp.canRead());
        parentPermission = tp;
    }
}
Also used : Tree(org.apache.jackrabbit.oak.api.Tree) TreePermission(org.apache.jackrabbit.oak.spi.security.authorization.permission.TreePermission) Test(org.junit.Test)

Example 67 with TreePermission

use of org.apache.jackrabbit.oak.spi.security.authorization.permission.TreePermission in project jackrabbit-oak by apache.

the class CompositeProviderFullScopeTest method testTreePermissionIsGranted.

@Test
public void testTreePermissionIsGranted() throws Exception {
    TreePermission parentPermission = TreePermission.EMPTY;
    for (String path : TP_PATHS) {
        TreePermission tp = cppTestUser.getTreePermission(readOnlyRoot.getTree(path), parentPermission);
        Long toTest = (defPermissions.containsKey(path)) ? defPermissions.get(path) : defPermissions.get(PathUtils.getAncestorPath(path, 1));
        if (toTest != null) {
            if (Permissions.READ_NODE == toTest) {
                assertTrue(path, tp.isGranted(toTest));
            } else {
                boolean canRead = Permissions.includes(toTest, Permissions.READ_NODE);
                assertEquals(path, canRead, tp.isGranted(Permissions.READ_NODE));
                assertFalse(path, tp.isGranted(toTest));
            }
        }
        parentPermission = tp;
    }
}
Also used : TreePermission(org.apache.jackrabbit.oak.spi.security.authorization.permission.TreePermission) Test(org.junit.Test)

Example 68 with TreePermission

use of org.apache.jackrabbit.oak.spi.security.authorization.permission.TreePermission in project jackrabbit-oak by apache.

the class CompositeProviderFullScopeTest method testTreePermissionCanReadProperty.

@Test
public void testTreePermissionCanReadProperty() throws Exception {
    TreePermission parentPermission = TreePermission.EMPTY;
    for (String nodePath : TP_PATHS) {
        Tree tree = readOnlyRoot.getTree(nodePath);
        TreePermission tp = cppTestUser.getTreePermission(tree, parentPermission);
        assertFalse(nodePath, tp.canRead(PROPERTY_STATE));
        parentPermission = tp;
    }
}
Also used : Tree(org.apache.jackrabbit.oak.api.Tree) TreePermission(org.apache.jackrabbit.oak.spi.security.authorization.permission.TreePermission) Test(org.junit.Test)

Example 69 with TreePermission

use of org.apache.jackrabbit.oak.spi.security.authorization.permission.TreePermission in project jackrabbit-oak by apache.

the class CompositeProviderNoScopeTest method testTreePermissionCanRead.

@Test
public void testTreePermissionCanRead() throws Exception {
    Map<String, Boolean> readMap = ImmutableMap.<String, Boolean>builder().put(ROOT_PATH, false).put(TEST_PATH, true).put(TEST_A_PATH, true).put(TEST_A_B_PATH, true).put(TEST_A_B_C_PATH, false).put(TEST_A_B_C_PATH + "/nonexisting", false).build();
    TreePermission parentPermission = TreePermission.EMPTY;
    TreePermission parentPermission2 = TreePermission.EMPTY;
    for (String nodePath : readMap.keySet()) {
        Tree tree = readOnlyRoot.getTree(nodePath);
        TreePermission tp = cppTestUser.getTreePermission(tree, parentPermission);
        TreePermission tp2 = defTestUser.getTreePermission(tree, parentPermission2);
        boolean expectedResult = readMap.get(nodePath);
        assertEquals(nodePath, expectedResult, tp.canRead());
        assertEquals(nodePath + "(default)", expectedResult, tp2.canRead());
        parentPermission = tp;
        parentPermission2 = tp2;
    }
}
Also used : Tree(org.apache.jackrabbit.oak.api.Tree) ImmutableTree(org.apache.jackrabbit.oak.plugins.tree.impl.ImmutableTree) TreePermission(org.apache.jackrabbit.oak.spi.security.authorization.permission.TreePermission) Test(org.junit.Test)

Example 70 with TreePermission

use of org.apache.jackrabbit.oak.spi.security.authorization.permission.TreePermission in project jackrabbit-oak by apache.

the class CompositeProviderNoScopeTest method testTreePermissionCanReadProperty.

@Test
public void testTreePermissionCanReadProperty() throws Exception {
    Map<String, Boolean> readMap = ImmutableMap.<String, Boolean>builder().put(ROOT_PATH, false).put(TEST_PATH, true).put(TEST_A_PATH, true).put(TEST_A_B_PATH, true).put(TEST_A_B_C_PATH, true).put(TEST_A_B_C_PATH + "/nonexisting", true).build();
    TreePermission parentPermission = TreePermission.EMPTY;
    TreePermission parentPermission2 = TreePermission.EMPTY;
    for (String nodePath : readMap.keySet()) {
        Tree tree = readOnlyRoot.getTree(nodePath);
        TreePermission tp = cppTestUser.getTreePermission(tree, parentPermission);
        TreePermission tp2 = defTestUser.getTreePermission(tree, parentPermission2);
        boolean expectedResult = readMap.get(nodePath);
        assertEquals(nodePath, expectedResult, tp.canRead(PROPERTY_STATE));
        assertEquals(nodePath + "(default)", expectedResult, tp2.canRead(PROPERTY_STATE));
        parentPermission = tp;
        parentPermission2 = tp2;
    }
}
Also used : Tree(org.apache.jackrabbit.oak.api.Tree) ImmutableTree(org.apache.jackrabbit.oak.plugins.tree.impl.ImmutableTree) TreePermission(org.apache.jackrabbit.oak.spi.security.authorization.permission.TreePermission) Test(org.junit.Test)

Aggregations

TreePermission (org.apache.jackrabbit.oak.spi.security.authorization.permission.TreePermission)109 Test (org.junit.Test)94 Tree (org.apache.jackrabbit.oak.api.Tree)53 AbstractSecurityTest (org.apache.jackrabbit.oak.AbstractSecurityTest)41 ImmutableTree (org.apache.jackrabbit.oak.plugins.tree.impl.ImmutableTree)22 PermissionProvider (org.apache.jackrabbit.oak.spi.security.authorization.permission.PermissionProvider)11 NodeState (org.apache.jackrabbit.oak.spi.state.NodeState)10 AggregatedPermissionProvider (org.apache.jackrabbit.oak.spi.security.authorization.permission.AggregatedPermissionProvider)8 PropertyState (org.apache.jackrabbit.oak.api.PropertyState)6 Nonnull (javax.annotation.Nonnull)4 AccessControlManager (javax.jcr.security.AccessControlManager)4 Root (org.apache.jackrabbit.oak.api.Root)4 JackrabbitAccessControlList (org.apache.jackrabbit.api.security.JackrabbitAccessControlList)3 TreeType (org.apache.jackrabbit.oak.plugins.tree.TreeType)3 NodeUtil (org.apache.jackrabbit.oak.util.NodeUtil)3 Field (java.lang.reflect.Field)2 AuthorizationConfiguration (org.apache.jackrabbit.oak.spi.security.authorization.AuthorizationConfiguration)2 ArrayList (java.util.ArrayList)1 HashMap (java.util.HashMap)1 CheckForNull (javax.annotation.CheckForNull)1