org.rhq.enterprise.gui.admin.role.ViewAction.java Source code

Java tutorial

Introduction

Here is the source code for org.rhq.enterprise.gui.admin.role.ViewAction.java

Source

/*
 * RHQ Management Platform
 * Copyright (C) 2005-2008 Red Hat, Inc.
 * All rights reserved.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation version 2 of the License.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */
package org.rhq.enterprise.gui.admin.role;

import java.util.HashMap;
import java.util.Map;
import java.util.Set;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.apache.struts.tiles.ComponentContext;

import org.rhq.core.domain.auth.Subject;
import org.rhq.core.domain.authz.Permission;
import org.rhq.core.domain.authz.Role;
import org.rhq.core.domain.resource.group.LdapGroup;
import org.rhq.core.domain.resource.group.ResourceGroup;
import org.rhq.core.domain.util.AuthzConstants;
import org.rhq.core.domain.util.PageControl;
import org.rhq.core.domain.util.PageList;
import org.rhq.enterprise.gui.legacy.Constants;
import org.rhq.enterprise.gui.legacy.action.WorkflowPrepareAction;
import org.rhq.enterprise.gui.legacy.util.RequestUtils;
import org.rhq.enterprise.gui.util.WebUtility;
import org.rhq.enterprise.server.authz.RoleManagerLocal;
import org.rhq.enterprise.server.resource.group.LdapGroupManagerLocal;
import org.rhq.enterprise.server.resource.group.ResourceGroupManagerLocal;
import org.rhq.enterprise.server.util.LookupUtil;

/**
 * An Action that retrieves a specific role. This is executed when you view a specific role.
 */
public class ViewAction extends WorkflowPrepareAction {

    LdapGroupManagerLocal ldapManager = LookupUtil.getLdapGroupManager();
    RoleManagerLocal roleManager = LookupUtil.getRoleManager();
    ResourceGroupManagerLocal groupManager = LookupUtil.getResourceGroupManager();

    /**
     */
    public ActionForward workflow(ComponentContext context, ActionMapping mapping, ActionForm form,
            HttpServletRequest request, HttpServletResponse response) throws Exception {
        Log log = LogFactory.getLog(ViewAction.class.getName());

        // make sure the request has selected a role
        Integer roleId = RequestUtils.getRoleId(request);
        Role role = (Role) request.getAttribute(Constants.ROLE_ATTR);
        if (role == null) {
            RequestUtils.setError(request, Constants.ERR_ROLE_NOT_FOUND);
            return null;
        }

        // get the current user and its current page controls
        Subject whoami = RequestUtils.getSubject(request);
        PageControl pcu = WebUtility.getPageControl(request, "u");
        PageControl pcg = WebUtility.getPageControl(request, "g");
        PageControl pcldap = WebUtility.getPageControl(request, "l");
        log.trace("user page control: " + pcu);
        log.trace("group page control: " + pcg);
        log.trace("ldap group page control: " + pcldap);

        //        RoleManagerLocal roleManager = LookupUtil.getRoleManager();
        //        ResourceGroupManagerLocal groupManager = LookupUtil.getResourceGroupManager();

        // get all the role permissions
        Set<Permission> permissions = roleManager.getPermissions(roleId);
        Map<String, Boolean> permission_map = new HashMap<String, Boolean>();

        // global permissions - put in a map to make jsp writing easier
        for (Permission p : permissions) {
            permission_map.put(p.name(), Boolean.TRUE);
        }

        request.setAttribute(Constants.ROLE_PERMISSIONS_PARAM, permission_map);

        // get the subjects attached to the role
        log.trace("getting users for role [" + roleId + "]");
        //        PageList<Subject> users = roleManager.findSubjectsByRole(roleId, pcu);
        PageList<Subject> users = roleManager.findSubjectsByRole(roleId, pcu);
        request.setAttribute(Constants.ROLE_USERS_ATTR, users);

        // get the groups attached to the role
        log.trace("getting resource groups for role [" + roleId + "]");
        PageList<ResourceGroup> groups = groupManager.findResourceGroupsForRole(whoami, roleId, pcg);
        request.setAttribute(Constants.ROLE_RESGRPS_ATTR, groups);
        if (groups == null) {
            request.setAttribute(Constants.NUM_RESGRPS_ATTR, new Integer(0));
        } else {
            request.setAttribute(Constants.NUM_RESGRPS_ATTR, new Integer(groups.getTotalSize()));
        }

        PageList<LdapGroup> ldapGroups = ldapManager.findLdapGroupsByRole(roleId, pcldap);
        request.setAttribute(Constants.ROLE_LDAPGRPS_ATTR, ldapGroups);
        if (ldapGroups == null) {
            request.setAttribute(Constants.NUM_LDAPGRPS_ATTR, new Integer(0));
        } else {
            request.setAttribute(Constants.NUM_LDAPGRPS_ATTR, new Integer(ldapGroups.getTotalSize()));
        }

        // create and initialize the remove users form
        RemoveUsersForm rmUsersForm = new RemoveUsersForm();
        rmUsersForm.setR(roleId);
        int psu = RequestUtils.getPageSize(request, "psu");
        rmUsersForm.setPs(new Integer(psu));
        request.setAttribute(Constants.ROLE_REMOVE_USERS_FORM_ATTR, rmUsersForm);

        // create and initialize the remove resource groups form
        RemoveResourceGroupsForm rmGroupsForm = new RemoveResourceGroupsForm();
        rmGroupsForm.setR(roleId);
        int psg = RequestUtils.getPageSize(request, "psg");
        rmGroupsForm.setPs(new Integer(psg));
        request.setAttribute(Constants.ROLE_REMOVE_RESOURCE_GROUPS_FORM_ATTR, rmGroupsForm);

        // TODO : do I need this?
        if (AuthzConstants.authzResourceGroupId.intValue() == roleId.intValue()) {
            context.putAttribute("superUser", "true");
        }

        return null;
    }
}