Implemented Feature #4877 remove VRE association to single Category constraint

git-svn-id: https://svn.research-infrastructures.eu/d4science/gcube/trunk/portlets/user/join-vre@134338 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
Massimiliano Assante 2016-11-17 16:59:46 +00:00
parent 2dcf8b5e4c
commit 1be03d5f66
2 changed files with 34 additions and 73 deletions

View File

@ -1,4 +1,8 @@
<ReleaseNotes> <ReleaseNotes>
<Changeset component="org.gcube.portlets-user.join-vre.3.2.0" date="2016-11-17">
<Change>Removed ASL Session</Change>
<Change>Implemented Feature #4877 remove VRE association to single Category constraint</Change>
</Changeset>
<Changeset component="org.gcube.portlets-user.join-vre.3.1.0" <Changeset component="org.gcube.portlets-user.join-vre.3.1.0"
date="2016-10-03"> date="2016-10-03">
<Change>Added support for invite-only closed groups</Change> <Change>Added support for invite-only closed groups</Change>

View File

@ -35,6 +35,7 @@ import org.gcube.vomanagement.usermanagement.model.GCubeUser;
import org.gcube.vomanagement.usermanagement.model.GroupMembershipType; import org.gcube.vomanagement.usermanagement.model.GroupMembershipType;
import org.gcube.vomanagement.usermanagement.model.MembershipRequestStatus; import org.gcube.vomanagement.usermanagement.model.MembershipRequestStatus;
import org.gcube.vomanagement.usermanagement.model.VirtualGroup; import org.gcube.vomanagement.usermanagement.model.VirtualGroup;
import org.gcube.vomanagement.usermanagement.util.ManagementUtils;
import com.google.gwt.user.server.rpc.RemoteServiceServlet; import com.google.gwt.user.server.rpc.RemoteServiceServlet;
import com.liferay.portal.kernel.cache.CacheRegistryUtil; import com.liferay.portal.kernel.cache.CacheRegistryUtil;
@ -113,13 +114,12 @@ public class JoinServiceImpl extends RemoteServiceServlet implements JoinService
* @throws PortalException * @throws PortalException
*/ */
public LinkedHashMap<VRECategory, ArrayList<VRE>> getPortalSitesMappedToVRE() throws Exception { public LinkedHashMap<VRECategory, ArrayList<VRE>> getPortalSitesMappedToVRE() throws Exception {
GroupManager gm = new LiferayGroupManager(); GroupManager gm = new LiferayGroupManager();
LinkedHashMap<VRECategory, ArrayList<VRE>> toReturn = new LinkedHashMap<VRECategory, ArrayList<VRE>>(); LinkedHashMap<VRECategory, ArrayList<VRE>> toReturn = new LinkedHashMap<VRECategory, ArrayList<VRE>>();
long currentSiteGroupId = getSiteFromServletRequest(getThreadLocalRequest()).getGroupId(); long currentSiteGroupId = getSiteFromServletRequest(getThreadLocalRequest()).getGroupId();
List<VirtualGroup> currentSiteVGroups = getVirtualGroups(currentSiteGroupId); List<VirtualGroup> currentSiteVGroups = gm.getVirtualGroups(currentSiteGroupId);
for (VirtualGroup vg : currentSiteVGroups) { for (VirtualGroup vg : currentSiteVGroups) {
ArrayList<VRE> toCreate = new ArrayList<VRE>(); ArrayList<VRE> toCreate = new ArrayList<VRE>();
VRECategory cat = new VRECategory(1L, vg.getName(), vg.getDescription()); VRECategory cat = new VRECategory(1L, vg.getName(), vg.getDescription());
@ -144,36 +144,34 @@ public class JoinServiceImpl extends RemoteServiceServlet implements JoinService
//for each root sub organizations (VO) //for each root sub organizations (VO)
for (GCubeGroup vOrg : rootGroupVO.getChildren()) { for (GCubeGroup vOrg : rootGroupVO.getChildren()) {
for (GCubeGroup vreOrganization : vOrg.getChildren()) { for (GCubeGroup vreSite : vOrg.getChildren()) {
long vreID = vreOrganization.getGroupId(); long vreID = vreSite.getGroupId();
String vreName = vreOrganization.getGroupName(); String vreName = vreSite.getGroupName();
String vreDescription = vreOrganization.getDescription(); String vreDescription = vreSite.getDescription();
long logoId = vreOrganization.getLogoId(); long logoId = vreSite.getLogoId();
String vreLogoURL = gm.getGroupLogoURL(logoId); String vreLogoURL = gm.getGroupLogoURL(logoId);
String groupName = gm.getInfrastructureScope(vreOrganization.getGroupId()); String groupName = gm.getInfrastructureScope(vreSite.getGroupId());
String friendlyURL = GCubePortalConstants.PREFIX_GROUP_URL+vreOrganization.getFriendlyURL(); String friendlyURL = GCubePortalConstants.PREFIX_GROUP_URL+vreSite.getFriendlyURL();
String catName = gm.getVirtualGroup(vreID).getName(); List<VirtualGroup> vreGroups = gm.getVirtualGroups(vreID);
for (VirtualGroup vreGroup : vreGroups) {
VRECategory toLookFor = null; for (VRECategory vre : toReturn.keySet()) {
for (VRECategory vre : toReturn.keySet()) { if (vre.getName().compareTo(vreGroup.getName())==0) {
if (vre.getName().compareTo(catName)==0) ArrayList<VRE> toUpdate = toReturn.get(vre);
toLookFor = vre; UserBelonging belongs = UserBelonging.NOT_BELONGING;
} VRE toAdd = new VRE(vreID,vreName, vreDescription, vreLogoURL, groupName, friendlyURL, belongs, getVREMembershipType(vreSite.getMembershipType()));
if (toLookFor != null) { if (currUser != null) {
ArrayList<VRE> toUpdate = toReturn.get(toLookFor); //check if the user belongs to it
UserBelonging belongs = UserBelonging.NOT_BELONGING; if (currUserGroups.contains(vreSite)) {
VRE toAdd = new VRE(vreID,vreName, vreDescription, vreLogoURL, groupName, friendlyURL, belongs, getVREMembershipType(vreOrganization.getMembershipType())); toAdd.setUserBelonging(UserBelonging.BELONGING);
if (currUser != null) { }
//check if the user belongs to it else if (checkPending(currUser.getUsername(), vreSite.getGroupId()))
if (currUserGroups.contains(vreOrganization)) { toAdd.setUserBelonging(UserBelonging.PENDING);
toAdd.setUserBelonging(UserBelonging.BELONGING); }
toUpdate.add(toAdd);
} }
else if (checkPending(currUser.getUsername(), vreOrganization.getGroupId())) }
toAdd.setUserBelonging(UserBelonging.PENDING);
}
toUpdate.add(toAdd);
} }
} }
} }
@ -400,11 +398,11 @@ public class JoinServiceImpl extends RemoteServiceServlet implements JoinService
@Override @Override
public String isExistingInvite(long groupId) { public String isExistingInvite(long groupId) {
_log.debug("initiating Store"); _log.debug("initiating Store");
initStore(); initStore();
_log.debug("initStore OK"); _log.debug("initStore OK");
String email = PortalContext.getConfiguration().getCurrentUser(getThreadLocalRequest()).getEmail(); String email = PortalContext.getConfiguration().getCurrentUser(getThreadLocalRequest()).getEmail();
String infraScope = null; String infraScope = null;
try { try {
@ -433,48 +431,7 @@ public class JoinServiceImpl extends RemoteServiceServlet implements JoinService
return null; return null;
} }
/**
* read the list of virtual groups the current site (i-marine, services etc. ) should show up
* @param actualGroupId
* @return he list of virtual groups the current site (i-marine, services etc. ) should show up
* @throws GroupRetrievalFault
* @throws VirtualGroupNotExistingException
*/
private List<VirtualGroup> getVirtualGroups(long actualGroupId) throws GroupRetrievalFault, VirtualGroupNotExistingException {
List<VirtualGroup> toReturn = new ArrayList<VirtualGroup>();
try {
long userId = LiferayUserManager.getAdmin().getUserId();
PrincipalThreadLocal.setName(userId);
PermissionChecker permissionChecker = PermissionCheckerFactoryUtil.create(UserLocalServiceUtil.getUser(userId));
PermissionThreadLocal.setPermissionChecker(permissionChecker);
Group site = GroupLocalServiceUtil.getGroup(actualGroupId);
_log.debug("Set Thread Permission done, getVirtual Group of " + site.getName());
if (site.getExpandoBridge().getAttribute(CustomAttributeKeys.VIRTUAL_GROUP.getKeyName()) == null || site.getExpandoBridge().getAttribute(CustomAttributeKeys.VIRTUAL_GROUP.getKeyName()).equals("")) {
String warningMessage = String.format("Attribute %s not initialized.", CustomAttributeKeys.VIRTUAL_GROUP.getKeyName());
_log.warn(warningMessage);
throw new VirtualGroupNotExistingException(warningMessage);
} else {
String[] values = (String[]) site.getExpandoBridge().getAttribute(CustomAttributeKeys.VIRTUAL_GROUP.getKeyName());
VirtualGroup toAdd = new VirtualGroup();
if (values != null && values.length > 0) {
for (int i = 0; i < values.length; i++) {
toAdd = new VirtualGroup();
String[] splits = values[i].split("\\|");
toAdd.setName(splits[0]);
toAdd.setDescription(splits[1]);
toReturn.add(toAdd);
_log.debug("VirtualGroup selected found for " + site.getName() + " -> " + toAdd.getName());
}
} else {
toAdd.setName("NoVirtualGroupAssigned");
toAdd.setDescription("NoVirtualGroupDescription");
}
}
} catch (Exception e) {
e.printStackTrace();
}
return toReturn;
}
/** /**
* *
* @param request * @param request