Fix Bug #19415, Enhance Join VRE portlet performance
This commit is contained in:
parent
3c29afc3dc
commit
45cbc0ca5c
|
@ -4,6 +4,9 @@
|
||||||
<wb-resource deploy-path="/" source-path="/src/main/webapp" tag="defaultRootSource"/>
|
<wb-resource deploy-path="/" source-path="/src/main/webapp" tag="defaultRootSource"/>
|
||||||
<wb-resource deploy-path="/WEB-INF/classes" source-path="/src/main/java"/>
|
<wb-resource deploy-path="/WEB-INF/classes" source-path="/src/main/java"/>
|
||||||
<wb-resource deploy-path="/WEB-INF/classes" source-path="/src/main/resources"/>
|
<wb-resource deploy-path="/WEB-INF/classes" source-path="/src/main/resources"/>
|
||||||
|
<dependent-module archiveName="invites-common-library-1.5.1-SNAPSHOT.jar" deploy-path="/WEB-INF/lib" handle="module:/resource/invites-common-library/invites-common-library">
|
||||||
|
<dependency-type>uses</dependency-type>
|
||||||
|
</dependent-module>
|
||||||
<property name="java-output-path" value="/${module}/target/www/WEB-INF/classes"/>
|
<property name="java-output-path" value="/${module}/target/www/WEB-INF/classes"/>
|
||||||
<property name="context-root" value="join-vre"/>
|
<property name="context-root" value="join-vre"/>
|
||||||
</wb-module>
|
</wb-module>
|
||||||
|
|
|
@ -0,0 +1,94 @@
|
||||||
|
|
||||||
|
# Changelog
|
||||||
|
|
||||||
|
All notable changes to this project will be documented in this file.
|
||||||
|
This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||||
|
|
||||||
|
[v3.7.0] [r4.23.0] - 2020-06-03
|
||||||
|
|
||||||
|
Fixes
|
||||||
|
|
||||||
|
Bug #19415, Enhance Join VRE portlet performance when many VREs are present on a gateway and the user is logged in.
|
||||||
|
|
||||||
|
|
||||||
|
## [361] - [2018-11-09]
|
||||||
|
|
||||||
|
Fixed minor glitch border 5px on the body
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## [350] - [2018-03-13]
|
||||||
|
|
||||||
|
Feature #11434, Explore VREs use preloaders while loading VREs list
|
||||||
|
|
||||||
|
Ported to GWT 2.8.2
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## [350] - [2017-11-08]
|
||||||
|
|
||||||
|
Added support for optional layout via TabPages and browsing VREs by Organisations and Category
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## [340] - [2017-07-05]
|
||||||
|
|
||||||
|
Ported to GWT 2.8.1
|
||||||
|
|
||||||
|
Added support for Terms of Use Display
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## [330] - [2017-05-15]
|
||||||
|
|
||||||
|
Ported to Java8
|
||||||
|
|
||||||
|
Added support for template emails
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## [320] - [2016-11-17]
|
||||||
|
|
||||||
|
Removed ASL Session
|
||||||
|
|
||||||
|
Implemented Feature #4877 remove VRE association to single Category constraint
|
||||||
|
|
||||||
|
Info Button redircets to VRE Public page (if a public page exists for the VRE)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## [310] - [2016-10-03]
|
||||||
|
|
||||||
|
Added support for invite-only closed groups
|
||||||
|
|
||||||
|
Fix for Bug #4877 Email Notification sent multiple times sometimes
|
||||||
|
|
||||||
|
Logo VRE was not updated in the portlet due to liferay versioning of Document Library
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## [300] - [2016-03-28]
|
||||||
|
|
||||||
|
Ported to Liferay 6.2
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## [200] - [2015-10-22]
|
||||||
|
|
||||||
|
Refactored to support virtual groups and related descriptions through LR Custom Field
|
||||||
|
|
||||||
|
Refactored with GWT Bootstrap, new look and feel
|
||||||
|
|
||||||
|
Added support for showing external hosted VREso, see Feature #755
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## [110] - [2015-04-28]
|
||||||
|
|
||||||
|
Redesigned and restyles the way vre description is shown to end users
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## [100] - [2015-03-02]
|
||||||
|
|
||||||
|
First Release
|
4
pom.xml
4
pom.xml
|
@ -14,7 +14,7 @@
|
||||||
<groupId>org.gcube.portlets.user</groupId>
|
<groupId>org.gcube.portlets.user</groupId>
|
||||||
<artifactId>join-vre</artifactId>
|
<artifactId>join-vre</artifactId>
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
<version>3.7.0-SNAPSHOT</version>
|
<version>3.7.0</version>
|
||||||
<name>gCube Join VRE Portlet</name>
|
<name>gCube Join VRE Portlet</name>
|
||||||
<description>Display the available VRE to Join</description>
|
<description>Display the available VRE to Join</description>
|
||||||
<scm>
|
<scm>
|
||||||
|
@ -93,7 +93,7 @@
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.gcube.core</groupId>
|
<groupId>org.gcube.core</groupId>
|
||||||
<artifactId>common-scope-maps</artifactId>
|
<artifactId>common-scope-maps</artifactId>
|
||||||
<scope>runtime</scope>
|
<scope>provided</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.gcube.dvos</groupId>
|
<groupId>org.gcube.dvos</groupId>
|
||||||
|
|
|
@ -47,9 +47,11 @@ import com.liferay.portal.kernel.exception.SystemException;
|
||||||
import com.liferay.portal.kernel.log.Log;
|
import com.liferay.portal.kernel.log.Log;
|
||||||
import com.liferay.portal.kernel.log.LogFactoryUtil;
|
import com.liferay.portal.kernel.log.LogFactoryUtil;
|
||||||
import com.liferay.portal.model.Group;
|
import com.liferay.portal.model.Group;
|
||||||
|
import com.liferay.portal.model.MembershipRequest;
|
||||||
import com.liferay.portal.model.VirtualHost;
|
import com.liferay.portal.model.VirtualHost;
|
||||||
import com.liferay.portal.service.GroupLocalServiceUtil;
|
import com.liferay.portal.service.GroupLocalServiceUtil;
|
||||||
import com.liferay.portal.service.LayoutSetLocalServiceUtil;
|
import com.liferay.portal.service.LayoutSetLocalServiceUtil;
|
||||||
|
import com.liferay.portal.service.MembershipRequestLocalServiceUtil;
|
||||||
import com.liferay.portal.service.UserLocalServiceUtil;
|
import com.liferay.portal.service.UserLocalServiceUtil;
|
||||||
import com.liferay.portal.service.VirtualHostLocalServiceUtil;
|
import com.liferay.portal.service.VirtualHostLocalServiceUtil;
|
||||||
import com.liferay.portal.util.PortalUtil;
|
import com.liferay.portal.util.PortalUtil;
|
||||||
|
@ -393,12 +395,15 @@ public class JoinServiceImpl extends RemoteServiceServlet implements JoinService
|
||||||
|
|
||||||
List<GCubeGroup> currUserGroups = new ArrayList<GCubeGroup>();
|
List<GCubeGroup> currUserGroups = new ArrayList<GCubeGroup>();
|
||||||
GCubeUser currUser = pContext.getCurrentUser(getThreadLocalRequest());
|
GCubeUser currUser = pContext.getCurrentUser(getThreadLocalRequest());
|
||||||
|
_log.debug("before currUserGroups");
|
||||||
if (currUser != null) {
|
if (currUser != null) {
|
||||||
currUserGroups = groupsManager.listGroupsByUser(currUser.getUserId());
|
currUserGroups = groupsManager.listGroupsByUser(currUser.getUserId());
|
||||||
|
_log.debug("currUserGroups size= "+currUserGroups.size());
|
||||||
}
|
}
|
||||||
|
_log.debug("for each root sub organizations (VO): ");
|
||||||
//for each root sub organizations (VO)
|
//for each root sub organizations (VO)
|
||||||
for (GCubeGroup vOrg : rootGroupVO.getChildren()) {
|
for (GCubeGroup vOrg : rootGroupVO.getChildren()) {
|
||||||
|
_log.debug("vOrg: "+vOrg.getGroupName());
|
||||||
for (GCubeGroup vreSite : vOrg.getChildren()) {
|
for (GCubeGroup vreSite : vOrg.getChildren()) {
|
||||||
long vreID = vreSite.getGroupId();
|
long vreID = vreSite.getGroupId();
|
||||||
String vreName = vreSite.getGroupName();
|
String vreName = vreSite.getGroupName();
|
||||||
|
@ -408,6 +413,7 @@ public class JoinServiceImpl extends RemoteServiceServlet implements JoinService
|
||||||
String vreLogoURL = groupsManager.getGroupLogoURL(logoId);
|
String vreLogoURL = groupsManager.getGroupLogoURL(logoId);
|
||||||
String groupName = groupsManager.getInfrastructureScope(vreSite.getGroupId());
|
String groupName = groupsManager.getInfrastructureScope(vreSite.getGroupId());
|
||||||
String friendlyURL = GCubePortalConstants.PREFIX_GROUP_URL+vreSite.getFriendlyURL();
|
String friendlyURL = GCubePortalConstants.PREFIX_GROUP_URL+vreSite.getFriendlyURL();
|
||||||
|
_log.debug("vreName: "+vreName);
|
||||||
|
|
||||||
List<VirtualGroup> vreGroups = groupsManager.getVirtualGroups(vreID);
|
List<VirtualGroup> vreGroups = groupsManager.getVirtualGroups(vreID);
|
||||||
for (VirtualGroup vreGroup : vreGroups) {
|
for (VirtualGroup vreGroup : vreGroups) {
|
||||||
|
@ -422,10 +428,11 @@ public class JoinServiceImpl extends RemoteServiceServlet implements JoinService
|
||||||
}
|
}
|
||||||
if (currUser != null) {
|
if (currUser != null) {
|
||||||
//check if the user belongs to it
|
//check if the user belongs to it
|
||||||
|
_log.debug("//check if the user belongs to = "+vreSite.getGroupName());
|
||||||
if (currUserGroups.contains(vreSite)) {
|
if (currUserGroups.contains(vreSite)) {
|
||||||
toAdd.setUserBelonging(UserBelonging.BELONGING);
|
toAdd.setUserBelonging(UserBelonging.BELONGING);
|
||||||
}
|
}
|
||||||
else if (checkPending(currUser.getUsername(), vreSite.getGroupId()))
|
else if (checkPending(currUser.getUserId(), vreSite.getGroupId()))
|
||||||
toAdd.setUserBelonging(UserBelonging.PENDING);
|
toAdd.setUserBelonging(UserBelonging.PENDING);
|
||||||
}
|
}
|
||||||
toUpdate.add(toAdd);
|
toUpdate.add(toAdd);
|
||||||
|
@ -529,7 +536,7 @@ public class JoinServiceImpl extends RemoteServiceServlet implements JoinService
|
||||||
UserBelonging belongEnum = UserBelonging.NOT_BELONGING;
|
UserBelonging belongEnum = UserBelonging.NOT_BELONGING;
|
||||||
if (gm.listGroupsByUser(currUser.getUserId()).contains(selectedVRE))
|
if (gm.listGroupsByUser(currUser.getUserId()).contains(selectedVRE))
|
||||||
belongEnum = UserBelonging.BELONGING;
|
belongEnum = UserBelonging.BELONGING;
|
||||||
else if (checkPending(currUser.getUsername(), selectedVRE.getGroupId()))
|
else if (checkPending(currUser.getUserId(), selectedVRE.getGroupId()))
|
||||||
belongEnum = UserBelonging.PENDING;
|
belongEnum = UserBelonging.PENDING;
|
||||||
//return the selected VRE for this user
|
//return the selected VRE for this user
|
||||||
toReturn = new VRE(groupId, vreName, vreDescription, vreLogoURL, infraScope, friendlyURL, belongEnum, getVREMembershipType(selectedVRE.getMembershipType()));
|
toReturn = new VRE(groupId, vreName, vreDescription, vreLogoURL, infraScope, friendlyURL, belongEnum, getVREMembershipType(selectedVRE.getMembershipType()));
|
||||||
|
@ -554,22 +561,13 @@ public class JoinServiceImpl extends RemoteServiceServlet implements JoinService
|
||||||
return VreMembershipType.PRIVATE;
|
return VreMembershipType.PRIVATE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
*
|
private static boolean checkPending(long userId, long groupId) throws SystemException {
|
||||||
* @param screenName
|
_log.debug("checkPending of userId "+userId + " to groupId="+groupId);
|
||||||
* @param groupId
|
List<MembershipRequest> lRequests = MembershipRequestLocalServiceUtil.getMembershipRequests(userId, groupId, 0);
|
||||||
* @return
|
if (lRequests != null && lRequests.size() > 0)
|
||||||
* @throws UserRetrievalFault
|
|
||||||
* @throws GroupRetrievalFault
|
|
||||||
* @throws UserManagementSystemException
|
|
||||||
*/
|
|
||||||
private static boolean checkPending(String screenName, long groupId) throws UserManagementSystemException, GroupRetrievalFault, UserRetrievalFault {
|
|
||||||
UserManager um = new LiferayUserManager();
|
|
||||||
List<GCubeMembershipRequest> requests = um.listMembershipRequestsByGroup(groupId);
|
|
||||||
for (GCubeMembershipRequest r : requests) {
|
|
||||||
if ( r.getStatus() == MembershipRequestStatus.REQUEST && (r.getRequestingUser().getUsername().compareTo(screenName)==0))
|
|
||||||
return true;
|
return true;
|
||||||
}
|
_log.debug("checkPending did not find request" + userId);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -583,7 +581,8 @@ public class JoinServiceImpl extends RemoteServiceServlet implements JoinService
|
||||||
CacheRegistryUtil.clear();
|
CacheRegistryUtil.clear();
|
||||||
long groupId = theVRE.getId();
|
long groupId = theVRE.getId();
|
||||||
_log.debug("Look if a request exists already");
|
_log.debug("Look if a request exists already");
|
||||||
List<GCubeGroup> userGroups = new LiferayGroupManager().listGroupsByUser(new LiferayUserManager().getUserId(username));
|
long userId = new LiferayUserManager().getUserId(username);
|
||||||
|
List<GCubeGroup> userGroups = new LiferayGroupManager().listGroupsByUser(userId);
|
||||||
for (GCubeGroup g : userGroups) {
|
for (GCubeGroup g : userGroups) {
|
||||||
if (g.getGroupId() == groupId) {
|
if (g.getGroupId() == groupId) {
|
||||||
_log.warn("User already belongs to " + scope + " SKIP addMembershipRequest");
|
_log.warn("User already belongs to " + scope + " SKIP addMembershipRequest");
|
||||||
|
@ -591,7 +590,7 @@ public class JoinServiceImpl extends RemoteServiceServlet implements JoinService
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
CacheRegistryUtil.clear();
|
CacheRegistryUtil.clear();
|
||||||
if (checkPending(username, groupId)) {
|
if (checkPending(userId, groupId)) {
|
||||||
_log.warn("User already asked for " + scope + " REQUEST IS IN PENDING - SKIP addMembershipRequest");
|
_log.warn("User already asked for " + scope + " REQUEST IS IN PENDING - SKIP addMembershipRequest");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue