Java Code Examples for org.apache.jackrabbit.api.security.user.User#getPrincipal()
The following examples show how to use
org.apache.jackrabbit.api.security.user.User#getPrincipal() .
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: ImportTests.java From jackrabbit-filevault with Apache License 2.0 | 5 votes |
@Test public void testImportWithoutRootAccess() throws IOException, RepositoryException, ConfigurationException { Assume.assumeTrue(!isOak()); // Create test user UserManager userManager = ((JackrabbitSession)admin).getUserManager(); String userId = "user1"; String userPwd = "pwd1"; User user1 = userManager.createUser(userId, userPwd); Principal principal1 = user1.getPrincipal(); // Create /tmp folder admin.getRootNode().addNode("tmp"); admin.save(); // Setup test user ACLs such that the // root node is not accessible AccessControlUtils.addAccessControlEntry(admin, null, principal1, new String[]{"jcr:namespaceManagement","jcr:nodeTypeDefinitionManagement"}, true); AccessControlUtils.addAccessControlEntry(admin, "/", principal1, new String[]{"jcr:all"}, false); AccessControlUtils.addAccessControlEntry(admin, "/tmp", principal1, new String[]{"jcr:all"}, true); admin.save(); // Import with a session associated to the test user Session session = repository.login(new SimpleCredentials(userId, userPwd.toCharArray())); ZipArchive archive = new ZipArchive(getTempFile("/test-packages/tmp.zip")); archive.open(true); ImportOptions opts = getDefaultOptions(); Importer importer = new Importer(opts); importer.run(archive, session, "/"); session.logout(); assertNodeExists("/tmp/foo/bar/tobi"); }
Example 2
Source File: ImportTests.java From jackrabbit-filevault with Apache License 2.0 | 5 votes |
@Test public void testImportWithoutRootAndTmpAccess() throws IOException, RepositoryException, ConfigurationException { Assume.assumeTrue(!isOak()); // Create test user UserManager userManager = ((JackrabbitSession)admin).getUserManager(); String userId = "user1"; String userPwd = "pwd1"; User user1 = userManager.createUser(userId, userPwd); Principal principal1 = user1.getPrincipal(); // Create /tmp folder admin.getRootNode().addNode("tmp").addNode("foo"); admin.save(); // Setup test user ACLs such that the // root node is not accessible AccessControlUtils.addAccessControlEntry(admin, null, principal1, new String[]{"jcr:namespaceManagement","jcr:nodeTypeDefinitionManagement"}, true); AccessControlUtils.addAccessControlEntry(admin, "/", principal1, new String[]{"jcr:all"}, false); AccessControlUtils.addAccessControlEntry(admin, "/tmp/foo", principal1, new String[]{"jcr:all"}, true); admin.save(); // Import with a session associated to the test user Session session = repository.login(new SimpleCredentials(userId, userPwd.toCharArray())); ZipArchive archive = new ZipArchive(getTempFile("/test-packages/tmp_foo.zip")); archive.open(true); ImportOptions opts = getDefaultOptions(); Importer importer = new Importer(opts); importer.run(archive, session, "/"); session.logout(); assertNodeExists("/tmp/foo/bar/tobi"); }
Example 3
Source File: TestPackageInstall.java From jackrabbit-filevault with Apache License 2.0 | 5 votes |
/** * Installs a package with an install hook and a not allowed user */ @Test public void testHookWithNotAllowedNonAdminUser() throws RepositoryException, IOException, PackageException { if (admin.nodeExists("/testroot")) { admin.getNode("/testroot").remove(); } admin.getRootNode().addNode("testroot", "nt:unstructured").addNode("testnode", "nt:unstructured"); admin.save(); // Create test user UserManager userManager = ((JackrabbitSession)admin).getUserManager(); String userId = "user1"; String userPwd = "pwd1"; User user1 = userManager.createUser(userId, userPwd); Principal principal1 = user1.getPrincipal(); // Setup test user ACLs that there are no restrictions AccessControlUtils.addAccessControlEntry(admin, null, principal1, new String[]{"jcr:namespaceManagement","jcr:nodeTypeDefinitionManagement"}, true); AccessControlUtils.addAccessControlEntry(admin, "/", principal1, new String[]{"jcr:all"}, true); admin.save(); Session userSession = repository.login(new SimpleCredentials(userId, userPwd.toCharArray())); try { packMgr = new JcrPackageManagerImpl(userSession, new String[0], null, null); PackageEventDispatcherImpl dispatcher = new PackageEventDispatcherImpl(); dispatcher.bindPackageEventListener(new ActivityLog(), Collections.singletonMap("component.id", (Object) "1234")); packMgr.setDispatcher(dispatcher); JcrPackage pack = packMgr.upload(getStream("/test-packages/test_hook.zip"), false); assertNotNull(pack); thrown.expect(PackageException.class); thrown.expectMessage("Package extraction requires admin session as it has a hook"); packMgr.getInternalRegistry().installPackage(userSession, new JcrRegisteredPackage(pack), getDefaultOptions(), true); } finally { userSession.logout(); } }
Example 4
Source File: TestPackageInstall.java From jackrabbit-filevault with Apache License 2.0 | 5 votes |
/** * Installs a package with an install hook and an explicitly allowed user */ @Test public void testHookWithAllowedNonAdminUser() throws RepositoryException, IOException, PackageException { if (admin.nodeExists("/testroot")) { admin.getNode("/testroot").remove(); } admin.getRootNode().addNode("testroot", "nt:unstructured").addNode("testnode", "nt:unstructured"); admin.save(); // Create test user UserManager userManager = ((JackrabbitSession)admin).getUserManager(); String userId = "user1"; String userPwd = "pwd1"; User user1 = userManager.createUser(userId, userPwd); Principal principal1 = user1.getPrincipal(); // Setup test user ACLs that there are no restrictions AccessControlUtils.addAccessControlEntry(admin, null, principal1, new String[]{"jcr:namespaceManagement","jcr:nodeTypeDefinitionManagement"}, true); AccessControlUtils.addAccessControlEntry(admin, "/", principal1, new String[]{"jcr:all"}, true); admin.save(); Session userSession = repository.login(new SimpleCredentials(userId, userPwd.toCharArray())); try { packMgr = new JcrPackageManagerImpl(userSession, new String[0], new String[] {"user1"}, null); PackageEventDispatcherImpl dispatcher = new PackageEventDispatcherImpl(); dispatcher.bindPackageEventListener(new ActivityLog(), Collections.singletonMap("component.id", (Object) "1234")); packMgr.setDispatcher(dispatcher); JcrPackage pack = packMgr.upload(getStream("/test-packages/test_hook.zip"), false); assertNotNull(pack); packMgr.getInternalRegistry().installPackage(userSession, new JcrRegisteredPackage(pack), getDefaultOptions(), true); assertTrue(admin.propertyExists("/testroot/hook-example")); } finally { userSession.logout(); } }
Example 5
Source File: TestPackageInstall.java From jackrabbit-filevault with Apache License 2.0 | 5 votes |
/** * Tests if package installation works w/o RW access to / and /tmp. * this currently fails, due to the creation of the snapshot. * also see {@link TestNoRootAccessExport#exportNoRootAccess()} */ @Test @Ignore("JCRVLT-100") public void testInstallWithoutRootAndTmpAccess() throws IOException, RepositoryException, ConfigurationException, PackageException { JcrPackage pack = packMgr.upload(getStream("/test-packages/tmp_foo.zip"), true, true); assertNotNull(pack); assertTrue(pack.isValid()); PackageId id = pack.getPackage().getId(); pack.close(); // Create test user UserManager userManager = ((JackrabbitSession)admin).getUserManager(); String userId = "user1"; String userPwd = "pwd1"; User user1 = userManager.createUser(userId, userPwd); Principal principal1 = user1.getPrincipal(); // Create /tmp folder admin.getRootNode().addNode("tmp").addNode("foo"); admin.save(); // Setup test user ACLs such that the // root node is not accessible AccessControlUtils.addAccessControlEntry(admin, null, principal1, new String[]{"jcr:namespaceManagement","jcr:nodeTypeDefinitionManagement"}, true); AccessControlUtils.addAccessControlEntry(admin, "/", principal1, new String[]{"jcr:all"}, false); AccessControlUtils.addAccessControlEntry(admin, ((JcrPackageRegistry)packMgr.getRegistry()).getPackRootPaths()[0], principal1, new String[]{"jcr:all"}, true); AccessControlUtils.addAccessControlEntry(admin, "/tmp/foo", principal1, new String[]{"jcr:all"}, true); admin.save(); Session session = repository.login(new SimpleCredentials(userId, userPwd.toCharArray())); JcrPackageManagerImpl userPackMgr = new JcrPackageManagerImpl(session, new String[0], null, null); pack = userPackMgr.open(id); ImportOptions opts = getDefaultOptions(); pack.install(opts); pack.close(); session.logout(); assertNodeExists("/tmp/foo/bar/tobi"); }
Example 6
Source File: TestPackageInstall.java From jackrabbit-filevault with Apache License 2.0 | 5 votes |
/** * Test if package extraction works w/o RW access to / and /tmp. */ @Test public void testExtractWithoutRootAndTmpAccess() throws IOException, RepositoryException, ConfigurationException, PackageException { Assume.assumeTrue(!isOak()); JcrPackage pack = packMgr.upload(getStream("/test-packages/tmp_foo.zip"), true, true); assertNotNull(pack); assertTrue(pack.isValid()); PackageId id = pack.getPackage().getId(); pack.close(); // Create test user UserManager userManager = ((JackrabbitSession)admin).getUserManager(); String userId = "user1"; String userPwd = "pwd1"; User user1 = userManager.createUser(userId, userPwd); Principal principal1 = user1.getPrincipal(); // Create /tmp folder admin.getRootNode().addNode("tmp").addNode("foo"); admin.save(); // Setup test user ACLs such that the // root node is not accessible AccessControlUtils.addAccessControlEntry(admin, null, principal1, new String[]{"jcr:namespaceManagement","jcr:nodeTypeDefinitionManagement"}, true); AccessControlUtils.addAccessControlEntry(admin, "/", principal1, new String[]{"jcr:all"}, false); AccessControlUtils.addAccessControlEntry(admin, ((JcrPackageRegistry)packMgr.getRegistry()).getPackRootPaths()[0], principal1, new String[]{"jcr:all"}, true); AccessControlUtils.addAccessControlEntry(admin, "/tmp/foo", principal1, new String[]{"jcr:all"}, true); admin.save(); Session session = repository.login(new SimpleCredentials(userId, userPwd.toCharArray())); JcrPackageManagerImpl userPackMgr = new JcrPackageManagerImpl(session, new String[0], null, null); pack = userPackMgr.open(id); ImportOptions opts = getDefaultOptions(); pack.extract(opts); pack.close(); session.logout(); assertNodeExists("/tmp/foo/bar/tobi"); }