summaryrefslogtreecommitdiffstats
path: root/base/server/cms/src/org
diff options
context:
space:
mode:
authorEndi S. Dewata <edewata@redhat.com>2016-10-20 00:54:47 +0200
committerEndi S. Dewata <edewata@redhat.com>2016-10-21 17:17:57 +0200
commitf979c3b436e9a12e8c71ba0abab5c892d375f945 (patch)
tree4b2698b5eae632e6469611033e12971de6bf5edf /base/server/cms/src/org
parent3e05e67da87c5ce4742c77b43f2a122a968e4cc9 (diff)
downloadpki-f979c3b436e9a12e8c71ba0abab5c892d375f945.tar.gz
pki-f979c3b436e9a12e8c71ba0abab5c892d375f945.tar.xz
pki-f979c3b436e9a12e8c71ba0abab5c892d375f945.zip
Fixed TPS UI system menu.
The TPS UI has been modified to adjust the system menu based on the list of accessible components obtained during login. The TPSApplication has been modified to use TPSAccountService which returns the list of accessible components based on the following properties in the CS.cfg: * admin: target.configure.list * agent: target.agent_approve.list The AccountInfo has been changed to extend the ResourceMessage such that it can be used to pass the list of accessible components as an attribute. https://fedorahosted.org/pki/ticket/2523
Diffstat (limited to 'base/server/cms/src/org')
-rw-r--r--base/server/cms/src/org/dogtagpki/server/rest/AccountService.java46
1 files changed, 17 insertions, 29 deletions
diff --git a/base/server/cms/src/org/dogtagpki/server/rest/AccountService.java b/base/server/cms/src/org/dogtagpki/server/rest/AccountService.java
index 827e99e07..673db45b6 100644
--- a/base/server/cms/src/org/dogtagpki/server/rest/AccountService.java
+++ b/base/server/cms/src/org/dogtagpki/server/rest/AccountService.java
@@ -21,13 +21,8 @@ package org.dogtagpki.server.rest;
import java.security.Principal;
import java.util.Arrays;
-import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.HttpHeaders;
-import javax.ws.rs.core.Request;
import javax.ws.rs.core.Response;
-import javax.ws.rs.core.UriInfo;
import org.apache.catalina.realm.GenericPrincipal;
import org.apache.commons.lang.StringUtils;
@@ -43,47 +38,40 @@ import com.netscape.cms.servlet.base.PKIService;
*/
public class AccountService extends PKIService implements AccountResource {
- @Context
- private UriInfo uriInfo;
-
- @Context
- private HttpHeaders headers;
-
- @Context
- private Request request;
-
- @Context
- private HttpServletRequest servletRequest;
-
- @Override
- public Response login() {
- HttpSession session = servletRequest.getSession();
- System.out.println("Creating session "+session.getId());
-
+ protected AccountInfo createAccountInfo() {
Principal principal = servletRequest.getUserPrincipal();
- System.out.println("Principal: "+principal);
+ System.out.println("Principal: " + principal);
- AccountInfo response = new AccountInfo();
+ AccountInfo accountInfo = new AccountInfo();
String name = principal.getName();
- response.setID(name);
+ accountInfo.setID(name);
if (principal instanceof PKIPrincipal) {
PKIPrincipal pkiPrincipal = (PKIPrincipal)principal;
IUser user = pkiPrincipal.getUser();
String fullName = user.getFullName();
- if (!StringUtils.isEmpty(fullName)) response.setFullName(fullName);
+ if (!StringUtils.isEmpty(fullName)) accountInfo.setFullName(fullName);
String email = user.getEmail();
- if (!StringUtils.isEmpty(email)) response.setEmail(email);
+ if (!StringUtils.isEmpty(email)) accountInfo.setEmail(email);
}
if (principal instanceof GenericPrincipal) {
String[] roles = ((GenericPrincipal) principal).getRoles();
- response.setRoles(Arrays.asList(roles));
+ accountInfo.setRoles(Arrays.asList(roles));
}
- return createOKResponse(response);
+ return accountInfo;
+ }
+
+ @Override
+ public Response login() {
+ HttpSession session = servletRequest.getSession();
+ System.out.println("Creating session " + session.getId());
+
+ AccountInfo accountInfo = createAccountInfo();
+ return createOKResponse(accountInfo);
}
@Override