/* Copyright 2004 Apache Software Foundation
*
* Licensed 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.roles;
import java.io.IOException;
import java.security.Principal;
import java.sql.Types;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
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.portlets.security.SecurityResources;
import org.apache.jetspeed.security.Role;
import org.apache.jetspeed.security.RoleManager;
import org.apache.jetspeed.security.SecurityException;
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;
/**
* Role Browser - flat non-hierarchical view
*
* @author <a href="mailto:taylor@apache.org">David Sean Taylor</a>
* @version $Id: RoleBrowser.java,v 1.2 2005/03/27 23:33:17 ate Exp $
*/
public class RoleBrowser extends BrowserPortlet
{
private RoleManager roleManager;
public void init(PortletConfig config)
throws PortletException
{
super.init(config);
roleManager = (RoleManager)
getPortletContext().getAttribute(SecurityResources.CPS_ROLE_MANAGER_COMPONENT);
if (null == roleManager)
{
throw new PortletException("Failed to find the Role Manager on portlet initialization");
}
}
public void getRows(RenderRequest request, String sql, int windowSize)
throws Exception
{
List resultSetTitleList = new ArrayList();
List resultSetTypeList = new ArrayList();
try
{
Iterator roles = roleManager.getRoles("");
resultSetTypeList.add(String.valueOf(Types.VARCHAR));
resultSetTitleList.add("Role");
List list = new ArrayList();
while (roles.hasNext())
{
Role role = (Role)roles.next();
Principal principal = role.getPrincipal();
list.add(principal.getName());
}
BrowserIterator iterator = new DatabaseBrowserIterator(
list, resultSetTitleList, resultSetTypeList,
windowSize);
setBrowserIterator(request, iterator);
iterator.sort("Role");
}
catch (Exception e)
{
//log.error("Exception in CMSBrowserAction.getRows: ", e);
e.printStackTrace();
throw e;
}
}
public void doView(RenderRequest request, RenderResponse response)
throws PortletException, IOException
{
String selected = (String)PortletMessaging.receive(request, "role", "selected");
if (selected != null)
{
Context context = this.getContext(request);
context.put("selected", selected);
}
StatusMessage msg = (StatusMessage)PortletMessaging.consume(request, "RoleBrowser", "status");
if (msg != null)
{
this.getContext(request).put("statusMsg", msg);
}
super.doView(request, response);
}
public void processAction(ActionRequest request, ActionResponse response)
throws PortletException, IOException
{
if (request.getPortletMode() == PortletMode.VIEW)
{
String selected = request.getParameter("role");
if (selected != null)
{
Role role = lookupRole(selected);
if (role != null)
{
PortletMessaging.publish(request, "role", "selected", selected);
PortletMessaging.publish(request, "role", "change", selected);
}
}
String refresh = request.getParameter("role.refresh");
String save = request.getParameter("role.save");
String neue = request.getParameter("role.new");
String delete = request.getParameter("roleDelete");
if (refresh != null)
{
this.clearBrowserIterator(request);
}
else if (neue != null)
{
PortletMessaging.cancel(request, "role", "selected");
}
else if (delete != null && (!(isEmpty(delete))))
{
try
{
Role role = lookupRole(delete);
if (role != null)
{
roleManager.removeRole(delete);
this.clearBrowserIterator(request);
PortletMessaging.cancel(request, "role", "selected");
PortletMessaging.publish(request, SecurityResources.USER_BROWSER, "roles", "refresh");
}
}
catch (Exception e)
{
publishStatusMessage(request, "RoleBrowser", "status", e, "Could not remove role");
}
}
else if (save != null)
{
String roleName = request.getParameter("role.name");
if (!(isEmpty(roleName)))
{
try
{
Role role = null;
String old = (String)PortletMessaging.receive(request, "role", "selected");
if (old != null)
{
role = lookupRole(old);
}
else
{
role = lookupRole(roleName);
}
if (role != null)
{
if (old != null && !old.equals(roleName))
{
roleManager.removeRole(old);
roleManager.addRole(roleName);
this.clearBrowserIterator(request);
PortletMessaging.publish(request, "role", "selected", roleName);
}
}
else
{
roleManager.addRole(roleName);
this.clearBrowserIterator(request);
}
PortletMessaging.publish(request, SecurityResources.USER_BROWSER, "roles", "refresh");
}
catch (Exception e)
{
publishStatusMessage(request, "RoleBrowser", "status", e, "Could not store role");
}
}
}
}
super.processAction(request, response);
}
private Role lookupRole(String roleName)
{
try
{
return roleManager.getRole(roleName);
}
catch (SecurityException e)
{
return null;
}
}
private boolean isEmpty(String s)
{
if (s == null) return true;
if (s.trim().equals("")) return true;
return false;
}
}