org.icgc.dcc.submission.shiro.DccWrappingRealm.java Source code

Java tutorial

Introduction

Here is the source code for org.icgc.dcc.submission.shiro.DccWrappingRealm.java

Source

/*
 * Copyright (c) 2013 The Ontario Institute for Cancer Research. All rights reserved.                             
 *                                                                                                               
 * This program and the accompanying materials are made available under the terms of the GNU Public License v3.0.
 * You should have received a copy of the GNU General Public License along with                                  
 * this program. If not, see <http://www.gnu.org/licenses/>.                                                     
 *                                                                                                               
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY                           
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES                          
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT                           
 * SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,                                
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED                          
 * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;                               
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER                              
 * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN                         
 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */
package org.icgc.dcc.submission.shiro;

import java.util.Collection;
import java.util.Set;

import org.apache.commons.collections.CollectionUtils;
import org.apache.shiro.authc.SimpleAccount;
import org.apache.shiro.authz.AuthorizationInfo;
import org.apache.shiro.realm.text.IniRealm;
import org.apache.shiro.subject.PrincipalCollection;
import org.icgc.dcc.submission.core.model.Project;
import org.icgc.dcc.submission.service.ProjectService;
import org.icgc.dcc.submission.web.util.Authorizations;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.google.common.collect.Sets;

/**
 * Accesses user authentication and role authorizations from the realm.ini file.
 */
public class DccWrappingRealm extends IniRealm {

    private static final Logger log = LoggerFactory.getLogger(DccWrappingRealm.class);

    private final ProjectService projectService;

    public DccWrappingRealm(ProjectService projectService) {
        this.projectService = projectService;
    }

    /**
     * TODO: <code>{@link DccRealm#getPermissions(String)}</code>
     */
    @Override
    protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {
        log.debug("Putting together authorizations for user {}", principals.getPrimaryPrincipal());
        String username = super.getUsername(principals);
        SimpleAccount simpleAccount = super.getUser(username); // this gives access to implementation of
                                                               // AuthorizationInfo...

        Collection<String> iniRoles = simpleAccount.getRoles();
        Set<String> projectSpecificPermissions = buildProjectSpecificPermissions(username, iniRoles);
        log.debug(
                "Dynamically adding Project-specific permissions for user {}: {}, top of existing roles from INI: {} ({})",
                new Object[] { username, projectSpecificPermissions, iniRoles,
                        simpleAccount.getObjectPermissions() });
        simpleAccount.addStringPermissions(projectSpecificPermissions);

        return simpleAccount;
    }

    private Set<String> buildProjectSpecificPermissions(String username, Collection<String> roles) {
        Set<String> permissions = Sets.newLinkedHashSet();
        for (Project project : projectService.getProjects()) {
            if (Authorizations.hasAdminRole(roles) || project.hasUser(username)
                    || CollectionUtils.containsAny(project.getGroups(), roles)) {
                permissions.add(AuthorizationPrivileges.projectViewPrivilege(project.getKey()));
            }
        }
        return permissions;
    }

}