diff options
author | Endi S. Dewata <edewata@redhat.com> | 2016-10-20 00:54:47 +0200 |
---|---|---|
committer | Endi S. Dewata <edewata@redhat.com> | 2016-10-21 17:17:57 +0200 |
commit | f979c3b436e9a12e8c71ba0abab5c892d375f945 (patch) | |
tree | 4b2698b5eae632e6469611033e12971de6bf5edf /base/server/cms | |
parent | 3e05e67da87c5ce4742c77b43f2a122a968e4cc9 (diff) | |
download | pki-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')
-rw-r--r-- | base/server/cms/src/org/dogtagpki/server/rest/AccountService.java | 46 |
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 |