mirror of https://github.com/apache/archiva.git
move a couple of pages around and improve an action
git-svn-id: https://svn.apache.org/repos/asf/maven/archiva/trunk@443124 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
e0e1b86df1
commit
ca5303139b
|
@ -17,11 +17,12 @@ package org.apache.maven.archiva.web.action.admin;
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import com.opensymphony.xwork.Preparable;
|
||||||
import org.codehaus.plexus.security.rbac.RBACManager;
|
import org.codehaus.plexus.security.rbac.RBACManager;
|
||||||
|
import org.codehaus.plexus.security.system.SecuritySession;
|
||||||
import org.codehaus.plexus.security.user.User;
|
import org.codehaus.plexus.security.user.User;
|
||||||
import org.codehaus.plexus.security.user.UserManager;
|
import org.codehaus.plexus.security.user.UserManager;
|
||||||
import org.codehaus.plexus.security.user.UserNotFoundException;
|
import org.codehaus.plexus.security.user.UserNotFoundException;
|
||||||
import org.codehaus.plexus.security.system.SecuritySession;
|
|
||||||
import org.codehaus.plexus.xwork.action.PlexusActionSupport;
|
import org.codehaus.plexus.xwork.action.PlexusActionSupport;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -37,9 +38,8 @@ import java.util.List;
|
||||||
* role-hint="userManagement"
|
* role-hint="userManagement"
|
||||||
*/
|
*/
|
||||||
public class UserManagementAction
|
public class UserManagementAction
|
||||||
extends PlexusActionSupport
|
extends PlexusActionSupport implements Preparable
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @plexus.requirement
|
* @plexus.requirement
|
||||||
*/
|
*/
|
||||||
|
@ -52,12 +52,12 @@ public class UserManagementAction
|
||||||
|
|
||||||
private User user;
|
private User user;
|
||||||
|
|
||||||
|
private boolean save = false;
|
||||||
|
|
||||||
private String email;
|
private String email;
|
||||||
|
|
||||||
private String fullName;
|
private String fullName;
|
||||||
|
|
||||||
private boolean locked;
|
|
||||||
|
|
||||||
private String username;
|
private String username;
|
||||||
|
|
||||||
private String principal;
|
private String principal;
|
||||||
|
@ -70,24 +70,49 @@ public class UserManagementAction
|
||||||
|
|
||||||
private String resourceName;
|
private String resourceName;
|
||||||
|
|
||||||
|
public void prepare()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
|
||||||
|
if ( username != null )
|
||||||
|
{
|
||||||
|
user = userManager.findUser( username );
|
||||||
|
|
||||||
|
principal = user.getPrincipal().toString();
|
||||||
|
fullName = user.getFullName();
|
||||||
|
email = user.getEmail();
|
||||||
|
|
||||||
|
if ( principal != null && rbacManager.userAssignmentExists( principal ) )
|
||||||
|
{
|
||||||
|
assignedRoles = new ArrayList( rbacManager.getAssignedRoles( principal ) );
|
||||||
|
availableRoles = new ArrayList( rbacManager.getUnassignedRoles( principal ) );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
assignedRoles = new ArrayList();
|
||||||
|
availableRoles = rbacManager.getAllAssignableRoles();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* for this method username should be populated
|
* for this method username should be populated
|
||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public String findUser()
|
public String input()
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if ( username == null )
|
if ( username != null )
|
||||||
{
|
|
||||||
return INPUT;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
user = userManager.findUser( username );
|
user = userManager.findUser( username );
|
||||||
return SUCCESS;
|
return SUCCESS;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return INPUT;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch ( UserNotFoundException ne )
|
catch ( UserNotFoundException ne )
|
||||||
{
|
{
|
||||||
|
@ -96,51 +121,25 @@ public class UserManagementAction
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* For this method, principal should be populated
|
|
||||||
*
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
public String display()
|
|
||||||
throws Exception
|
|
||||||
{
|
|
||||||
|
|
||||||
user = userManager.findUser( username );
|
|
||||||
|
|
||||||
principal = user.getPrincipal().toString();
|
|
||||||
fullName = user.getFullName();
|
|
||||||
email = user.getEmail();
|
|
||||||
locked = user.isLocked();
|
|
||||||
|
|
||||||
// for displaying the potential repositories to be displayed, remove the global resource
|
|
||||||
// from the list
|
|
||||||
resources = rbacManager.getAllResources();
|
|
||||||
//resources.remove( rbacManager.getGlobalResource() );
|
|
||||||
|
|
||||||
// check if the user has any roles assigned to them, and populate the lists for
|
|
||||||
// rendering assign and remove roles links
|
|
||||||
if ( principal != null && rbacManager.userAssignmentExists( principal ) )
|
|
||||||
{
|
|
||||||
assignedRoles = new ArrayList( rbacManager.getAssignedRoles( principal ) );
|
|
||||||
availableRoles = new ArrayList( rbacManager.getUnassignedRoles( principal ) );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
assignedRoles = new ArrayList();
|
|
||||||
availableRoles = rbacManager.getAllAssignableRoles();
|
|
||||||
}
|
|
||||||
|
|
||||||
return SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String save()
|
public String save()
|
||||||
throws Exception
|
throws Exception
|
||||||
{
|
{
|
||||||
|
if ( !save )
|
||||||
|
{
|
||||||
|
return INPUT;
|
||||||
|
}
|
||||||
|
|
||||||
User temp = userManager.findUser( username );
|
User temp = userManager.findUser( username );
|
||||||
|
|
||||||
temp.setEmail( email );
|
if ( email != null )
|
||||||
temp.setFullName( fullName );
|
{
|
||||||
temp.setLocked( locked );
|
temp.setEmail( email );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( fullName != null )
|
||||||
|
{
|
||||||
|
temp.setFullName( fullName );
|
||||||
|
}
|
||||||
|
|
||||||
temp = userManager.updateUser( temp );
|
temp = userManager.updateUser( temp );
|
||||||
|
|
||||||
|
@ -195,16 +194,6 @@ public class UserManagementAction
|
||||||
this.fullName = fullName;
|
this.fullName = fullName;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isLocked()
|
|
||||||
{
|
|
||||||
return locked;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setLocked( boolean locked )
|
|
||||||
{
|
|
||||||
this.locked = locked;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getPrincipal()
|
public String getPrincipal()
|
||||||
{
|
{
|
||||||
return principal;
|
return principal;
|
||||||
|
@ -254,4 +243,14 @@ public class UserManagementAction
|
||||||
{
|
{
|
||||||
this.resourceName = resourceName;
|
this.resourceName = resourceName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isSave()
|
||||||
|
{
|
||||||
|
return save;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setSave( boolean save )
|
||||||
|
{
|
||||||
|
this.save = save;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -253,18 +253,22 @@
|
||||||
</action>
|
</action>
|
||||||
|
|
||||||
|
|
||||||
<action name="user" class="userManagement" method="display">
|
<action name="user" class="userManagement">
|
||||||
<result name="success">/WEB-INF/jsp/user.jsp</result>
|
<result name="success">/WEB-INF/jsp/admin/user.jsp</result>
|
||||||
|
<result name="input" type="chain">userManagement</result>
|
||||||
|
<interceptor-ref name="configuredPrepareParamsStack"/>
|
||||||
</action>
|
</action>
|
||||||
|
|
||||||
<!-- plexus security actions -->
|
<!-- plexus security actions -->
|
||||||
|
|
||||||
<action name="userDetails" class="userManagement" method="display">
|
<action name="userDetails" class="userManagement" method="save">
|
||||||
<result name="success">/WEB-INF/jsp/userDetails.jsp</result>
|
<result name="input">/WEB-INF/jsp/admin/userDetails.jsp</result>
|
||||||
|
<result name="success" type="chain">user</result>
|
||||||
|
<interceptor-ref name="configuredPrepareParamsStack"/>
|
||||||
</action>
|
</action>
|
||||||
|
|
||||||
<action name="userManagement" class="userManagement" method="findUser">
|
<action name="userManagement" class="userManagement" method="input">
|
||||||
<result name="input">/WEB-INF/jsp/findUser.jsp</result>
|
<result name="input">/WEB-INF/jsp/admin/findUser.jsp</result>
|
||||||
<result name="success" type="chain">user</result>
|
<result name="success" type="chain">user</result>
|
||||||
</action>
|
</action>
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,99 @@
|
||||||
|
<%--
|
||||||
|
~ Copyright 2005-2006 The 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.
|
||||||
|
--%>
|
||||||
|
|
||||||
|
<%@ taglib prefix="ww" uri="/webwork" %>
|
||||||
|
<%@ taglib prefix="pss" uri="plexusSecuritySystem" %>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>User Management</title>
|
||||||
|
<ww:head />
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
|
||||||
|
<div id="contentArea">
|
||||||
|
<div id="searchBox">
|
||||||
|
<div style="float: right">
|
||||||
|
<%-- add this back in when the functionality works, or when we move to the plexus-user-management pages
|
||||||
|
<pss:ifAnyAuthorized permissions="edit-all-users,edit-user" resource="${username}">
|
||||||
|
<ww:url id="userDetailsUrl" action="userDetails" method="input">
|
||||||
|
<ww:param name="username">${sessionScope.SecuritySessionUser.username}</ww:param>
|
||||||
|
</ww:url>
|
||||||
|
<ww:a href="%{userDetailsUrl}">Edit details</ww:a>
|
||||||
|
</pss:ifAnyAuthorized>
|
||||||
|
--%>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<h2>${fullName}</h2>
|
||||||
|
|
||||||
|
<table class="bodyTable">
|
||||||
|
<tr class="a">
|
||||||
|
<th>Username</th>
|
||||||
|
|
||||||
|
<td>${username}</td>
|
||||||
|
</tr>
|
||||||
|
<tr class="b">
|
||||||
|
<th>Email</th>
|
||||||
|
<td>${email}</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<h2>Currently Assigned Roles</h2>
|
||||||
|
|
||||||
|
<table class="bodyTable">
|
||||||
|
<ww:iterator id="role" value="assignedRoles">
|
||||||
|
<tr class="a">
|
||||||
|
<td>
|
||||||
|
<em>${role.name}</em><br/>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</ww:iterator>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
|
||||||
|
<pss:ifAnyAuthorized permissions="grant-roles,remove-roles">
|
||||||
|
<h2>Role Management</h2>
|
||||||
|
|
||||||
|
<pss:ifAuthorized permission="grant-roles">
|
||||||
|
<h3>Grant</h3>
|
||||||
|
<ww:form action="assignRoleToUser" method="post">
|
||||||
|
<ww:hidden name="principal" value="${username}"/>
|
||||||
|
<ww:hidden name="username" value="${username}"/>
|
||||||
|
<ww:radio name="roleName" list="availableRoles" listKey="name" listValue="name" labelposition="left"/>
|
||||||
|
<ww:submit value="Grant"/>
|
||||||
|
</ww:form>
|
||||||
|
</pss:ifAuthorized>
|
||||||
|
|
||||||
|
<pss:ifAuthorized permission="remove-roles">
|
||||||
|
<h3>Remove</h3>
|
||||||
|
<ww:form action="removeRoleFromUser" method="post">
|
||||||
|
<ww:hidden name="principal" value="${username}"/>
|
||||||
|
<ww:hidden name="username" value="${username}"/>
|
||||||
|
<ww:radio name="roleName" list="assignedRoles" listKey="name" listValue="name" labelposition="left"/>
|
||||||
|
<ww:submit value="Remove"/>
|
||||||
|
</ww:form>
|
||||||
|
</pss:ifAuthorized>
|
||||||
|
</pss:ifAnyAuthorized>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="clear">
|
||||||
|
<hr/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -1,182 +0,0 @@
|
||||||
<%--
|
|
||||||
~ Copyright 2005-2006 The 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.
|
|
||||||
--%>
|
|
||||||
|
|
||||||
<%@ taglib prefix="ww" uri="/webwork" %>
|
|
||||||
<%@ taglib prefix="pss" uri="plexusSecuritySystem" %>
|
|
||||||
<html>
|
|
||||||
<head>
|
|
||||||
<title>User Management</title>
|
|
||||||
<ww:head />
|
|
||||||
</head>
|
|
||||||
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<div id="contentArea">
|
|
||||||
<div id="searchBox">
|
|
||||||
<div style="float: right">
|
|
||||||
<pss:ifAnyAuthorized permissions="edit-all-users,edit-user" resource="${username}">
|
|
||||||
<ww:url id="userDetailsUrl" action="userDetails">
|
|
||||||
<ww:param name="username">${sessionScope.SecuritySessionUser.username}</ww:param>
|
|
||||||
</ww:url>
|
|
||||||
<ww:a href="%{userDetailsUrl}">Edit details</ww:a>
|
|
||||||
</pss:ifAnyAuthorized>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<h2>${sessionScope.SecuritySessionUser.fullName}</h2>
|
|
||||||
|
|
||||||
<table class="bodyTable">
|
|
||||||
<tr class="a">
|
|
||||||
<th>Username</th>
|
|
||||||
|
|
||||||
<td>${username}</td>
|
|
||||||
</tr>
|
|
||||||
<tr class="b">
|
|
||||||
<th>Email</th>
|
|
||||||
<td>${email}</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
<h2>Assigned Roles</h2>
|
|
||||||
|
|
||||||
<table class="bodyTable">
|
|
||||||
<ww:iterator id="role" value="assignedRoles">
|
|
||||||
|
|
||||||
<tr class="a">
|
|
||||||
<td>
|
|
||||||
<em>${role.name}</em><br/>
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
<pss:ifAuthorized permission="remove-roles">
|
|
||||||
<ww:url id="removeAssignedRoleUrl" action="removeRoleFromUser">
|
|
||||||
<ww:param name="principal">${username}</ww:param>
|
|
||||||
<ww:param name="roleName">${role.name}</ww:param>
|
|
||||||
</ww:url>
|
|
||||||
<ww:a href="%{removeAssignedRoleUrl}">Delete</ww:a>
|
|
||||||
</pss:ifAuthorized>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</ww:iterator>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
<h2>Grant Roles</h2>
|
|
||||||
|
|
||||||
<pss:ifAuthorized permission="grant-roles">
|
|
||||||
<table class="bodyTable">
|
|
||||||
<ww:iterator id="role" value="availableRoles">
|
|
||||||
<tr class="a">
|
|
||||||
<td>
|
|
||||||
<em>${role.name}</em><br/>
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
<ww:url id="addRoleUrl" action="assignRoleToUser">
|
|
||||||
<ww:param name="principal">${username}</ww:param>
|
|
||||||
<ww:param name="roleName">${role.name}</ww:param>
|
|
||||||
</ww:url>
|
|
||||||
<ww:a href="%{addRoleUrl}">Add</ww:a>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</ww:iterator>
|
|
||||||
</table>
|
|
||||||
</pss:ifAuthorized>
|
|
||||||
|
|
||||||
|
|
||||||
<%--
|
|
||||||
<p>
|
|
||||||
This following screen needs have the various roles worked into it.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<table class="bodyTable">
|
|
||||||
<tr class="b">
|
|
||||||
<td>
|
|
||||||
<input type="radio" checked="checked"></input>
|
|
||||||
|
|
||||||
</td>
|
|
||||||
<td>Administrator</td>
|
|
||||||
<td>
|
|
||||||
<select>
|
|
||||||
<option>(Please Select)</option>
|
|
||||||
<option>System Administrator</option>
|
|
||||||
<option>User Administrator</option>
|
|
||||||
</select>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr class="a">
|
|
||||||
<td>
|
|
||||||
<input type="radio"></input>
|
|
||||||
</td>
|
|
||||||
<td>Repository</td>
|
|
||||||
|
|
||||||
<td>
|
|
||||||
<select>
|
|
||||||
<option>(Please Select)</option>
|
|
||||||
<option>manager</option>
|
|
||||||
<option>obverser</option>
|
|
||||||
</select>
|
|
||||||
of
|
|
||||||
<ww:select name="resourceName" list="resources" listKey="identifier" listValue="identifier" headerKey="" headerValue="(Please Select)"/>
|
|
||||||
</td>
|
|
||||||
</tr> --%>
|
|
||||||
<%-- add in for project level security
|
|
||||||
<tr class="b">
|
|
||||||
<td>
|
|
||||||
<input type="radio"></input>
|
|
||||||
</td>
|
|
||||||
<td>Project</td>
|
|
||||||
<td>
|
|
||||||
<select>
|
|
||||||
<option>(Please Select)</option>
|
|
||||||
|
|
||||||
<option>manager</option>
|
|
||||||
<option>obverser</option>
|
|
||||||
</select>
|
|
||||||
of
|
|
||||||
<select>
|
|
||||||
<option>(Please Select)</option>
|
|
||||||
<option>central</option>
|
|
||||||
|
|
||||||
<option>central-plugins</option>
|
|
||||||
<option>All repositories</option>
|
|
||||||
</select>
|
|
||||||
for project group
|
|
||||||
<input type="text" name="projectExpression"></input>
|
|
||||||
<br></br>
|
|
||||||
<span style="font-size: x-small">
|
|
||||||
(eg org.apache.maven gives permissions on that group, and any sugroups)
|
|
||||||
</span>
|
|
||||||
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
|
|
||||||
<tr class="a">
|
|
||||||
<td></td>
|
|
||||||
<td>
|
|
||||||
<input type="submit" value="Add Role"></input>
|
|
||||||
</td>
|
|
||||||
<td></td>
|
|
||||||
</tr>
|
|
||||||
|
|
||||||
</table>
|
|
||||||
--%>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="clear">
|
|
||||||
<hr/>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
Loading…
Reference in New Issue