Search in sources :

Example 1 with TestPlugin

use of org.opensolaris.opengrok.authorization.TestPlugin in project OpenGrok by OpenGrok.

the class ProjectHelperTestBase method setUp.

@Before
public void setUp() {
    Assert.assertEquals("Should contain 4 groups", 4, env.getGroups().size());
    Assert.assertEquals("Should contain 40 project", 40, env.getProjects().size());
    Assert.assertEquals("Should contain 20 repositories", 20, env.getRepositories().size());
    Assert.assertNotNull("Repository map should not be null", env.getProjectRepositoriesMap());
    Assert.assertEquals("Repository map should contain 20 project", 20, env.getProjectRepositoriesMap().size());
    env.setAuthorizationFramework(new AuthorizationFramework());
    env.getAuthorizationFramework().reload();
    IAuthorizationPlugin plugin = new TestPlugin() {

        @Override
        public boolean isAllowed(HttpServletRequest request, Project project) {
            return project.getName().startsWith("allowed");
        }

        @Override
        public boolean isAllowed(HttpServletRequest request, Group group) {
            return group.getName().startsWith("allowed");
        }
    };
    invokeAddPlugin(plugin);
    cfg = PageConfig.get(getRequest());
    helper = cfg.getProjectHelper();
}
Also used : HttpServletRequest(javax.servlet.http.HttpServletRequest) Project(org.opensolaris.opengrok.configuration.Project) Group(org.opensolaris.opengrok.configuration.Group) AuthorizationFramework(org.opensolaris.opengrok.authorization.AuthorizationFramework) IAuthorizationPlugin(org.opensolaris.opengrok.authorization.IAuthorizationPlugin) TestPlugin(org.opensolaris.opengrok.authorization.TestPlugin) Before(org.junit.Before)

Example 2 with TestPlugin

use of org.opensolaris.opengrok.authorization.TestPlugin in project OpenGrok by OpenGrok.

the class PageConfigTest method testGetResourceFileList.

/**
 * Testing the root of /xref for authorization filtering.
 */
@Test
public void testGetResourceFileList() {
    RuntimeEnvironment env = RuntimeEnvironment.getInstance();
    // backup original values
    String oldSourceRootPath = env.getSourceRootPath();
    AuthorizationFramework oldAuthorizationFramework = env.getAuthorizationFramework();
    Map<String, Project> oldProjects = env.getProjects();
    // Set up the source root directory containing some projects.
    env.setSourceRoot(repository.getSourceRoot());
    env.setProjectsEnabled(true);
    // Enable projects.
    for (String file : new File(repository.getSourceRoot()).list()) {
        Project proj = new Project(file);
        proj.setIndexed(true);
        env.getProjects().put(file, proj);
    }
    HttpServletRequest req = createRequest("/source", "/xref", "");
    PageConfig cfg = PageConfig.get(req);
    List<String> allFiles = new ArrayList<>(cfg.getResourceFileList());
    /**
     * Check if there are some files (the "5" here is just a sufficient
     * value for now which won't break any future repository tests) without
     * any authorization.
     */
    assertTrue(allFiles.size() > 5);
    assertTrue(allFiles.contains("git"));
    assertTrue(allFiles.contains("mercurial"));
    /**
     * Now set up the same projects with authorization plugin enabling only
     * some of them.
     * <pre>
     *  - disabling "git"
     *  - disabling "mercurial"
     * </pre>
     */
    env.setAuthorizationFramework(new AuthorizationFramework());
    env.getAuthorizationFramework().reload();
    env.getAuthorizationFramework().getStack().add(new AuthorizationPlugin(AuthControlFlag.REQUIRED, new TestPlugin() {

        @Override
        public boolean isAllowed(HttpServletRequest request, Project project) {
            return !project.getName().startsWith("git") && !project.getName().startsWith("mercurial");
        }
    }));
    req = createRequest("/source", "/xref", "");
    cfg = PageConfig.get(req);
    List<String> filteredFiles = new ArrayList<>(cfg.getResourceFileList());
    // list subtraction - retains only disabled files
    allFiles.removeAll(filteredFiles);
    assertEquals(2, allFiles.size());
    assertTrue(allFiles.contains("git"));
    assertTrue(allFiles.contains("mercurial"));
    // restore original values
    env.setAuthorizationFramework(oldAuthorizationFramework);
    env.setSourceRoot(oldSourceRootPath);
    env.setProjects(oldProjects);
}
Also used : HttpServletRequest(javax.servlet.http.HttpServletRequest) Project(org.opensolaris.opengrok.configuration.Project) RuntimeEnvironment(org.opensolaris.opengrok.configuration.RuntimeEnvironment) AuthorizationFramework(org.opensolaris.opengrok.authorization.AuthorizationFramework) ArrayList(java.util.ArrayList) AuthorizationPlugin(org.opensolaris.opengrok.authorization.AuthorizationPlugin) TestPlugin(org.opensolaris.opengrok.authorization.TestPlugin) File(java.io.File) Test(org.junit.Test)

Aggregations

HttpServletRequest (javax.servlet.http.HttpServletRequest)2 AuthorizationFramework (org.opensolaris.opengrok.authorization.AuthorizationFramework)2 TestPlugin (org.opensolaris.opengrok.authorization.TestPlugin)2 Project (org.opensolaris.opengrok.configuration.Project)2 File (java.io.File)1 ArrayList (java.util.ArrayList)1 Before (org.junit.Before)1 Test (org.junit.Test)1 AuthorizationPlugin (org.opensolaris.opengrok.authorization.AuthorizationPlugin)1 IAuthorizationPlugin (org.opensolaris.opengrok.authorization.IAuthorizationPlugin)1 Group (org.opensolaris.opengrok.configuration.Group)1 RuntimeEnvironment (org.opensolaris.opengrok.configuration.RuntimeEnvironment)1