Package org.apache.jetspeed.portlets.security.groups

Source Code of org.apache.jetspeed.portlets.security.groups.GroupDetails

/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements.  See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License.  You may obtain a copy of the License at
*
*     http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.jetspeed.portlets.security.groups;

import java.io.IOException;
import java.io.NotSerializableException;
import java.security.Principal;
import java.sql.Types;
import java.util.ArrayList;
import java.util.Enumeration;
import java.util.Iterator;
import java.util.List;
import java.util.StringTokenizer;

import javax.portlet.ActionRequest;
import javax.portlet.ActionResponse;
import javax.portlet.PortletConfig;
import javax.portlet.PortletException;
import javax.portlet.PortletMode;
import javax.portlet.RenderRequest;
import javax.portlet.RenderResponse;

import org.apache.jetspeed.CommonPortletServices;
import org.apache.jetspeed.portlets.security.SecurityResources;
import org.apache.jetspeed.portlets.security.SecurityUtil;
import org.apache.jetspeed.security.GroupManager;
import org.apache.jetspeed.security.Role;
import org.apache.jetspeed.security.RoleManager;
import org.apache.jetspeed.security.SecurityException;
import org.apache.jetspeed.security.User;
import org.apache.jetspeed.security.UserManager;
import org.apache.jetspeed.security.UserPrincipal;
import org.apache.portals.gems.browser.BrowserIterator;
import org.apache.portals.gems.browser.DatabaseBrowserIterator;
import org.apache.portals.gems.browser.BrowserPortlet;
import org.apache.portals.gems.util.StatusMessage;
import org.apache.portals.messaging.PortletMessaging;
import org.apache.velocity.context.Context;

/**
* Group Details
*
* @author <a href="mailto:taylor@apache.org">David Sean Taylor</a>
* @version $Id: GroupDetails.java 348264 2005-11-22 22:06:45Z taylor $
*/
public class GroupDetails extends BrowserPortlet
{
    private UserManager userManager;
    private RoleManager roleManager;
    private GroupManager groupManager;
       
    public void init(PortletConfig config)
    throws PortletException
    {
        super.init(config);
        userManager = (UserManager) getPortletContext().getAttribute(CommonPortletServices.CPS_USER_MANAGER_COMPONENT);
        if (null == userManager)
        {
            throw new PortletException("Failed to find the User Manager on portlet initialization");
        }
        roleManager = (RoleManager) getPortletContext().getAttribute(CommonPortletServices.CPS_ROLE_MANAGER_COMPONENT);
        if (null == roleManager)
        {
            throw new PortletException("Failed to find the Role Manager on portlet initialization");
        }
        groupManager = (GroupManager) getPortletContext().getAttribute(CommonPortletServices.CPS_GROUP_MANAGER_COMPONENT);
        if (null == groupManager)
        {
            throw new PortletException("Failed to find the Group Manager on portlet initialization");
        }       
    }
   
    public void getRows(RenderRequest request, String sql, int windowSize)
    {
        getRows(request, sql, windowSize, null);       
    }

    public void getRows(RenderRequest request, String sql, int windowSize, String filter)
    {
        List resultSetTitleList = new ArrayList();
        List resultSetTypeList = new ArrayList();
        if ( filter != null )
        {
            if ( filter.length() == 0 )
            {
                filter = null;
            }
            else
            {
                filter = filter.toLowerCase();
            }
        }
       
        List list = new ArrayList();
        resultSetTypeList.add(String.valueOf(Types.VARCHAR));
       
        String groupTab = request.getParameter("groupTab");
        if ( groupTab == null )
        {
            groupTab = "users";
        }           
        if ("users".equals(groupTab))
        {
            resultSetTitleList.add("usersingroup"); // resource bundle key
           
            String selectedGroup = (String)PortletMessaging.receive(request, SecurityResources.TOPIC_GROUPS, SecurityResources.MESSAGE_SELECTED);
            if (selectedGroup != null)
            {
                try
                {
                    Iterator users = userManager.getUsersInGroup(selectedGroup).iterator();
                    while (users.hasNext())
                    {
                        User user = (User)users.next();
                        Principal principal = SecurityUtil.getPrincipal(user.getSubject(),
                                UserPrincipal.class);
                        if ( filter == null || principal.getName().toLowerCase().startsWith(filter))
                        {
                            list.add(principal.getName());
                        }
                    }
                }
                catch (SecurityException sex)
                {
                    SecurityUtil.publishErrorMessage(request, SecurityResources.TOPIC_GROUP, sex.getMessage());
                }                                   
               
            }
            BrowserIterator iterator = new DatabaseBrowserIterator(list, resultSetTitleList, resultSetTypeList, windowSize);
            setBrowserIterator(request, iterator);
            iterator.sort("usersingroup"); // resource bundle key
        }
        else
        {
            resultSetTitleList.add("rolesingroup"); // resource bundle key
           
            String selectedGroup = (String)PortletMessaging.receive(request, SecurityResources.TOPIC_GROUPS, SecurityResources.MESSAGE_SELECTED);
            if (selectedGroup != null)
            {
                try
                {
                    Iterator roles = roleManager.getRolesInGroup(selectedGroup).iterator();                                   
                    while (roles.hasNext())
                    {
                        String roleName = ((Role)roles.next()).getPrincipal().getName();
                        if ( filter == null || roleName.toLowerCase().startsWith(filter))
                        {
                            list.add(roleName);
                        }
                    }
                }
                catch (SecurityException sex)
                {
                    SecurityUtil.publishErrorMessage(request, SecurityResources.TOPIC_GROUP, sex.getMessage());
                }                                   
            }
            BrowserIterator iterator = new DatabaseBrowserIterator(list, resultSetTitleList, resultSetTypeList, windowSize);
            setBrowserIterator(request, iterator);
            iterator.sort("usersingroup"); // resource bundle key
        }
    }
          
    public void doView(RenderRequest request, RenderResponse response)
    throws PortletException, IOException
    {
        String change = (String)PortletMessaging.consume(request, SecurityResources.TOPIC_GROUPS, SecurityResources.MESSAGE_CHANGED);
        if (change != null)
        {
            this.clearBrowserIterator(request);
            PortletMessaging.cancel(request, SecurityResources.TOPIC_GROUP, SecurityResources.MESSAGE_FILTERED);
        }

        Context context = this.getContext(request);
               
        String selectedGroup = (String)PortletMessaging.receive(request, SecurityResources.TOPIC_GROUPS, SecurityResources.MESSAGE_SELECTED);
        if (selectedGroup != null)
        {       
            context.put("group", selectedGroup);
        }       
        String groupTab = request.getParameter("groupTab");
        if ( groupTab == null )
        {
            groupTab = "users";
        }
        context.put("groupTab",groupTab);
       
        if ("users".equals(groupTab))
        {
            String popupChooser = SecurityUtil.getAbsoluteUrl(request, "/Administrative/choosers/multiusers.psml");       
            context.put("popupChooser", popupChooser);           
        }
        else
        {
            String popupChooser = SecurityUtil.getAbsoluteUrl(request, "/Administrative/choosers/multiroles.psml");       
            context.put("popupChooser", popupChooser);
        }
       
        StatusMessage msg = (StatusMessage)PortletMessaging.consume(request, SecurityResources.TOPIC_GROUP, SecurityResources.MESSAGE_STATUS);
        if (msg != null)
        {
            this.getContext(request).put("statusMsg", msg);           
        }
         
        String filtered = (String)PortletMessaging.receive(request, SecurityResources.TOPIC_GROUP, SecurityResources.MESSAGE_FILTERED);
        if (filtered != null)
        {
            this.getContext(request).put(FILTERED, "on");           
        }       
       
        String refresh = (String)PortletMessaging.consume(request, SecurityResources.TOPIC_GROUP, SecurityResources.MESSAGE_REFRESH);
        if (refresh != null)
        {       
            this.clearBrowserIterator(request);
        }               

        ArrayList errorMessages = (ArrayList)PortletMessaging.consume(request, SecurityResources.TOPIC_GROUP, SecurityResources.ERROR_MESSAGES);
        if (errorMessages != null )
        {
            this.getContext(request).put(SecurityResources.ERROR_MESSAGES, errorMessages);
        }

        super.doView(request, response);
    }
       
   
    public void processAction(ActionRequest request, ActionResponse response)
    throws PortletException, IOException
    {
        if (request.getPortletMode() == PortletMode.VIEW)
        {
            String groupTab = request.getParameter("groupTab");
            if ( groupTab == null )
            {
                PortletMessaging.publish(request, SecurityResources.TOPIC_GROUP, SecurityResources.MESSAGE_REFRESH, "true");                       
                PortletMessaging.cancel(request, SecurityResources.TOPIC_GROUP, SecurityResources.MESSAGE_FILTERED);
                groupTab = request.getParameter("switchTab");
                if ( groupTab == null )
                {
                    // should never happen
                    groupTab = "users";
                }
            }
            response.setRenderParameter("groupTab",groupTab);

           
            if (request.getParameter("group.action.Save") != null)
            {
                addGroup(request);
            }
            else if (request.getParameter("group.action.Add_New_Group") != null)
            {
                PortletMessaging.cancel(request, SecurityResources.TOPIC_GROUPS, SecurityResources.MESSAGE_SELECTED);               
            }
            else if (request.getParameter("group.action.Remove_Group") != null)
            {
                removeGroup(request);
            }
            else if ("users".equals(groupTab))
            {
                String users = request.getParameter("users");
               
                if (users != null && users.length() > 0)
                {
                    addUsersToGroup(request, users);
                }
                else if (request.getParameter("group.action.Remove_Checked_Users") != null)
                {
                    removeUsersFromGroup(request);
                }
            }
            else
            {
                String roles = request.getParameter("roles");
               
                if (roles != null && roles.length() > 0)
                {
                    addRolesToGroup(request, roles);
                }
                else if (request.getParameter("group.action.Remove_Checked_Roles") != null)
                {
                    removeRolesFromGroup(request);
                }
            }
           
            if (request.getParameter(FILTERED) != null )
            {
                PortletMessaging.publish(request, SecurityResources.TOPIC_GROUP, SecurityResources.MESSAGE_FILTERED, "on");           
            }
            else
            {
                PortletMessaging.cancel(request, SecurityResources.TOPIC_GROUP, SecurityResources.MESSAGE_FILTERED);                   
            }
        }
       
       
        super.processAction(request, response);           
    }

    protected void addGroup(ActionRequest actionRequest)
    {
        String group = actionRequest.getParameter("group");
        if (!SecurityUtil.isEmpty(group))
        {
            try
            {
                groupManager.addGroup(group);
                PortletMessaging.publish(actionRequest, SecurityResources.TOPIC_GROUPS, SecurityResources.MESSAGE_REFRESH, "true");
                PortletMessaging.publish(actionRequest, SecurityResources.TOPIC_GROUPS, SecurityResources.MESSAGE_SELECTED, group);
                PortletMessaging.publish(actionRequest, SecurityResources.TOPIC_GROUPS, SecurityResources.MESSAGE_CHANGED, group);
                PortletMessaging.publish(actionRequest, SecurityResources.TOPIC_USERS, SecurityResources.MESSAGE_REFRESH_GROUPS, "true");                       
            }
            catch (NotSerializableException e)
            {
                e.printStackTrace();
            }
            catch (SecurityException sex)
            {
                SecurityUtil.publishErrorMessage(actionRequest, SecurityResources.TOPIC_GROUP, sex.getMessage());
            }
        }
    }

    protected void removeGroup(ActionRequest actionRequest)
    {
        String group = actionRequest.getParameter("group");
        if (!SecurityUtil.isEmpty(group))
        {
            try
            {           
                groupManager.removeGroup(group);
                try
                {
                    PortletMessaging.publish(actionRequest, SecurityResources.TOPIC_GROUPS, SecurityResources.MESSAGE_REFRESH, "true");
                    PortletMessaging.publish(actionRequest, SecurityResources.TOPIC_USERS, SecurityResources.MESSAGE_REFRESH_GROUPS, "true");                       
                }
                catch (NotSerializableException e)
                {
                    e.printStackTrace();
                }
                PortletMessaging.cancel(actionRequest, SecurityResources.TOPIC_GROUPS, SecurityResources.MESSAGE_SELECTED);                                               
            }
            catch (SecurityException sex)
            {
                SecurityUtil.publishErrorMessage(actionRequest, SecurityResources.TOPIC_GROUP, sex.getMessage());
            }
        }
    }
   
    protected void addUsersToGroup(ActionRequest request, String users)
    {
        String group = request.getParameter("group");
        if (group != null)
        {
            int count = 0;
            StringTokenizer tokenizer = new StringTokenizer(users, ",");
            while (tokenizer.hasMoreTokens())
            {
                String user = tokenizer.nextToken();
                try
                {
                    if (user.startsWith("box_"))
                    {
                        user = user.substring("box_".length());
                        groupManager.addUserToGroup(user, group);
                        count++;
                    }
                }
                catch (SecurityException sex)
                {
                    SecurityUtil.publishErrorMessage(request, SecurityResources.TOPIC_GROUP, sex.getMessage());
                }
            }
            if (count > 0)
            {
                try
                {
                    PortletMessaging.publish(request, SecurityResources.TOPIC_GROUP, SecurityResources.MESSAGE_REFRESH, "true");
                }
                catch (Exception e)
                {
                    e.printStackTrace();
                }
            }
        }
    }

    protected void removeUsersFromGroup(ActionRequest request)
    {
        String group = request.getParameter("group");
        if (group != null)
        {
            int count = 0;
            Enumeration e = request.getParameterNames();
            while (e.hasMoreElements())
            {
                String name = (String)e.nextElement();
                if (name.startsWith("box_"))
                {
                    String user = name.substring("box_".length());
                    try
                    {
                        groupManager.removeUserFromGroup(user, group);                       
                        count++;
                    }
                    catch (SecurityException sex)
                    {
                        SecurityUtil.publishErrorMessage(request, SecurityResources.TOPIC_GROUP, sex.getMessage());
                    }
                   
                }
            }
            if (count > 0)
            {
                try
                {
                    PortletMessaging.publish(request, SecurityResources.TOPIC_GROUP, SecurityResources.MESSAGE_REFRESH, "true");
                }
                catch (Exception ex)
                {
                    ex.printStackTrace();
                }
            }
        }
    }
   
    protected void addRolesToGroup(ActionRequest request, String roles)
    {
        String group = request.getParameter("group");
        if (group != null)
        {
            int count = 0;
            StringTokenizer tokenizer = new StringTokenizer(roles, ",");
            while (tokenizer.hasMoreTokens())
            {
                String role = tokenizer.nextToken();
                try
                {
                    if (role.startsWith("box_"))
                    {
                        role = role.substring("box_".length());
                        roleManager.addRoleToGroup(role, group);
                        count++;
                    }
                }
                catch (SecurityException sex)
                {
                    SecurityUtil.publishErrorMessage(request, SecurityResources.TOPIC_GROUP, sex.getMessage());
                }
            }
            if (count > 0)
            {
                try
                {
                    PortletMessaging.publish(request, SecurityResources.TOPIC_GROUP, SecurityResources.MESSAGE_REFRESH, "true");
                }
                catch (Exception e)
                {
                    e.printStackTrace();
                }
            }
        }
    }

    protected void removeRolesFromGroup(ActionRequest request)
    {
        String group = request.getParameter("group");
        if (group != null)
        {
            int count = 0;
            Enumeration e = request.getParameterNames();
            while (e.hasMoreElements())
            {
                String name = (String)e.nextElement();
                if (name.startsWith("box_"))
                {
                    String role = name.substring("box_".length());
                    try
                    {
                        roleManager.removeRoleFromGroup(role, group);                       
                        count++;
                    }
                    catch (SecurityException sex)
                    {
                        SecurityUtil.publishErrorMessage(request, SecurityResources.TOPIC_GROUP, sex.getMessage());
                    }
                   
                }
            }
            if (count > 0)
            {
                try
                {
                    PortletMessaging.publish(request, SecurityResources.TOPIC_GROUP, SecurityResources.MESSAGE_REFRESH, "true");
                }
                catch (Exception ex)
                {
                    ex.printStackTrace();
                }
            }
        }
    }
}
TOP

Related Classes of org.apache.jetspeed.portlets.security.groups.GroupDetails

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.