ported to Liferay 6.2
git-svn-id: http://svn.research-infrastructures.eu/public/d4science/gcube/trunk/portlets/user/gcube-loggedin@126093 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
parent
c1891d3590
commit
0c2ba66188
10
pom.xml
10
pom.xml
|
@ -104,16 +104,6 @@
|
||||||
<artifactId>aslcore</artifactId>
|
<artifactId>aslcore</artifactId>
|
||||||
<scope>provided</scope>
|
<scope>provided</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
|
||||||
<groupId>org.gcube.common</groupId>
|
|
||||||
<artifactId>home-library-jcr</artifactId>
|
|
||||||
<scope>provided</scope>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.gcube.common</groupId>
|
|
||||||
<artifactId>home-library</artifactId>
|
|
||||||
<scope>provided</scope>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.gcube.dvos</groupId>
|
<groupId>org.gcube.dvos</groupId>
|
||||||
<artifactId>usermanagement-core</artifactId>
|
<artifactId>usermanagement-core</artifactId>
|
||||||
|
|
|
@ -9,11 +9,8 @@ import javax.servlet.http.HttpServletRequest;
|
||||||
|
|
||||||
import org.gcube.application.framework.core.session.ASLSession;
|
import org.gcube.application.framework.core.session.ASLSession;
|
||||||
import org.gcube.application.framework.core.session.SessionManager;
|
import org.gcube.application.framework.core.session.SessionManager;
|
||||||
import org.gcube.common.homelibrary.home.HomeLibrary;
|
import org.gcube.common.portal.CustomAttributeKeys;
|
||||||
import org.gcube.common.homelibrary.home.exceptions.InternalErrorException;
|
|
||||||
import org.gcube.common.homelibrary.home.workspace.exceptions.ItemNotFoundException;
|
|
||||||
import org.gcube.common.portal.PortalContext;
|
import org.gcube.common.portal.PortalContext;
|
||||||
import org.gcube.portal.custom.communitymanager.SiteManagerUtil;
|
|
||||||
import org.gcube.portal.custom.scopemanager.scopehelper.ScopeHelper;
|
import org.gcube.portal.custom.scopemanager.scopehelper.ScopeHelper;
|
||||||
import org.gcube.portlets.user.gcubeloggedin.client.LoggedinService;
|
import org.gcube.portlets.user.gcubeloggedin.client.LoggedinService;
|
||||||
import org.gcube.portlets.user.gcubeloggedin.shared.VObject;
|
import org.gcube.portlets.user.gcubeloggedin.shared.VObject;
|
||||||
|
@ -32,15 +29,6 @@ import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import com.google.gwt.user.server.rpc.RemoteServiceServlet;
|
import com.google.gwt.user.server.rpc.RemoteServiceServlet;
|
||||||
import com.liferay.portal.kernel.bean.BeanLocatorException;
|
|
||||||
import com.liferay.portal.kernel.exception.PortalException;
|
|
||||||
import com.liferay.portal.kernel.exception.SystemException;
|
|
||||||
import com.liferay.portal.model.Group;
|
|
||||||
import com.liferay.portal.model.User;
|
|
||||||
import com.liferay.portal.security.permission.PermissionChecker;
|
|
||||||
import com.liferay.portal.security.permission.PermissionCheckerFactoryUtil;
|
|
||||||
import com.liferay.portal.security.permission.PermissionThreadLocal;
|
|
||||||
import com.liferay.portal.service.GroupLocalServiceUtil;
|
|
||||||
import com.liferay.portal.service.UserLocalServiceUtil;
|
import com.liferay.portal.service.UserLocalServiceUtil;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -50,8 +38,6 @@ import com.liferay.portal.service.UserLocalServiceUtil;
|
||||||
public class LoggedinServiceImpl extends RemoteServiceServlet implements LoggedinService {
|
public class LoggedinServiceImpl extends RemoteServiceServlet implements LoggedinService {
|
||||||
|
|
||||||
private static final Logger _log = LoggerFactory.getLogger(LoggedinServiceImpl.class);
|
private static final Logger _log = LoggerFactory.getLogger(LoggedinServiceImpl.class);
|
||||||
private static final String MANDATORY_GROUP = "Mandatory";
|
|
||||||
private static final String REQUEST_BASED_GROUP = "Requestbasedgroup";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the current ASLSession
|
* the current ASLSession
|
||||||
|
@ -90,7 +76,6 @@ public class LoggedinServiceImpl extends RemoteServiceServlet implements Loggedi
|
||||||
|
|
||||||
public VObject getSelectedRE(String portalURL) {
|
public VObject getSelectedRE(String portalURL) {
|
||||||
ASLSession aslSession = getASLSession();
|
ASLSession aslSession = getASLSession();
|
||||||
String username = aslSession.getUsername();
|
|
||||||
String friendlyURL = ScopeServiceImpl.extractOrgFriendlyURL(portalURL);
|
String friendlyURL = ScopeServiceImpl.extractOrgFriendlyURL(portalURL);
|
||||||
|
|
||||||
if (friendlyURL == null) {//the URL is not a portal URL, we are in devmode.
|
if (friendlyURL == null) {//the URL is not a portal URL, we are in devmode.
|
||||||
|
@ -132,102 +117,20 @@ public class LoggedinServiceImpl extends RemoteServiceServlet implements Loggedi
|
||||||
//set the description for the vre
|
//set the description for the vre
|
||||||
if (currSite.getDescription() != null)
|
if (currSite.getDescription() != null)
|
||||||
desc = currSite.getDescription();
|
desc = currSite.getDescription();
|
||||||
Group currGroup = null;
|
|
||||||
|
Boolean isMandatory = false;
|
||||||
try {
|
try {
|
||||||
currGroup = GroupLocalServiceUtil.getGroup(currSite.getGroupId());
|
isMandatory = (Boolean) gm.readCustomAttr(currSite.getGroupId(), CustomAttributeKeys.MANDATORY.getKeyName());
|
||||||
} catch (PortalException e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
|
||||||
} catch (SystemException e) {
|
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
VREClient vre = new VREClient(name, "", desc, logoURL, "", UserBelongingClient.BELONGING, isEnabled(username, currGroup, MANDATORY_GROUP), isEnabled(username, currGroup, REQUEST_BASED_GROUP));
|
|
||||||
|
VREClient vre = new VREClient(
|
||||||
|
name, "", desc, logoURL, "", UserBelongingClient.BELONGING,
|
||||||
|
isMandatory,
|
||||||
|
currSite.isRequestBasedGroup());
|
||||||
return vre;
|
return vre;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private Boolean isEnabled(String username, Group currOrg, String attrToCheck) {
|
|
||||||
Boolean isEnabled = false;
|
|
||||||
if (username.compareTo("test.user") == 0) {
|
|
||||||
_log.warn("Found test.user maybe you are in dev mode, returning ... ");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
|
|
||||||
long companyId = SiteManagerUtil.getCompany().getCompanyId();
|
|
||||||
_log.trace("Setting Thread Permission");
|
|
||||||
User user = UserLocalServiceUtil.getUserByScreenName(companyId, ScopeHelper.getAdministratorUsername());
|
|
||||||
PermissionChecker permissionChecker = PermissionCheckerFactoryUtil.create(user);
|
|
||||||
PermissionThreadLocal.setPermissionChecker(permissionChecker);
|
|
||||||
_log.trace("Setting Permission ok!");
|
|
||||||
|
|
||||||
User currentUser = SiteManagerUtil.validateUser(username);
|
|
||||||
if (currOrg.getExpandoBridge().getAttribute(attrToCheck) == null || currOrg.getExpandoBridge().getAttribute(attrToCheck).equals("")) {
|
|
||||||
_log.trace("Attribute " + attrToCheck + " must be initialized");
|
|
||||||
setOrgCustomAttribute(username, currOrg, attrToCheck);
|
|
||||||
isEnabled = true;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
String currVal = (String) currOrg.getExpandoBridge().getAttribute(attrToCheck);
|
|
||||||
isEnabled = (currVal.compareTo("true") == 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
_log.trace("Setting Thread Permission back to regular");
|
|
||||||
permissionChecker = PermissionCheckerFactoryUtil.create(currentUser);
|
|
||||||
PermissionThreadLocal.setPermissionChecker(permissionChecker);
|
|
||||||
_log.trace("Setting Permission ok! returning ...");
|
|
||||||
_log.debug(" returning *********** isEnabled=" + isEnabled);
|
|
||||||
return isEnabled;
|
|
||||||
} catch (BeanLocatorException ex) {
|
|
||||||
ex.printStackTrace();
|
|
||||||
_log.warn("Could not read the property " + attrToCheck + " from LR DB, maybe you are in dev mode, returning true");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
catch (Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param username
|
|
||||||
* @param attribute2Set
|
|
||||||
*/
|
|
||||||
private void setOrgCustomAttribute(String username, Group currGroup, String attribute2Set) {
|
|
||||||
User currUser = null;
|
|
||||||
if (username.compareTo("test.user") == 0) {
|
|
||||||
_log.warn("Found Test User, returning ... ");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
long companyId = SiteManagerUtil.getCompany().getCompanyId();
|
|
||||||
_log.trace("Setting Thread Permission");
|
|
||||||
User user = UserLocalServiceUtil.getUserByScreenName(companyId, ScopeHelper.getAdministratorUsername());
|
|
||||||
PermissionChecker permissionChecker = PermissionCheckerFactoryUtil.create(user);
|
|
||||||
PermissionThreadLocal.setPermissionChecker(permissionChecker);
|
|
||||||
_log.trace("Setting Permission ok!");
|
|
||||||
|
|
||||||
_log.debug("Creating and Setting custom attribute for colName " + attribute2Set + " to " +true);
|
|
||||||
//add the custom attrs
|
|
||||||
currUser = UserLocalServiceUtil.getUserByScreenName(companyId, username);
|
|
||||||
|
|
||||||
if (! currGroup.getExpandoBridge().hasAttribute(attribute2Set))
|
|
||||||
currGroup.getExpandoBridge().addAttribute(attribute2Set);
|
|
||||||
|
|
||||||
currGroup.getExpandoBridge().setAttribute(attribute2Set, "true");
|
|
||||||
_log.trace("setAttribute true");
|
|
||||||
|
|
||||||
|
|
||||||
_log.trace("Setting Thread Permission back to regular");
|
|
||||||
permissionChecker = PermissionCheckerFactoryUtil.create(currUser);
|
|
||||||
PermissionThreadLocal.setPermissionChecker(permissionChecker);
|
|
||||||
}
|
|
||||||
catch (Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @return the portal basic url, e.g. http://www.foo.com
|
* @return the portal basic url, e.g. http://www.foo.com
|
||||||
|
@ -261,7 +164,6 @@ public class LoggedinServiceImpl extends RemoteServiceServlet implements Loggedi
|
||||||
UserManager userM = new LiferayUserManager();
|
UserManager userM = new LiferayUserManager();
|
||||||
try {
|
try {
|
||||||
userM.dismissUserFromGroup(getCurrentGroupID(), userM.getUserId(username));
|
userM.dismissUserFromGroup(getCurrentGroupID(), userM.getUserId(username));
|
||||||
removeUserFromHLGroup(username, getASLSession().getScope());
|
|
||||||
sendUserUnregisteredNotification(username, getASLSession().getScope(), getPortalBasicUrl(), PortalContext.getConfiguration().getGatewayName());
|
sendUserUnregisteredNotification(username, getASLSession().getScope(), getPortalBasicUrl(), PortalContext.getConfiguration().getGatewayName());
|
||||||
return "/";
|
return "/";
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
@ -292,16 +194,7 @@ public class LoggedinServiceImpl extends RemoteServiceServlet implements Loggedi
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void removeUserFromHLGroup(String username, String group) {
|
|
||||||
try {
|
|
||||||
org.gcube.common.homelibrary.home.workspace.usermanager.UserManager um = HomeLibrary.getHomeManagerFactory().getUserManager();
|
|
||||||
um.removeUserFromGroup(group, username, getASLSession().getUsername());
|
|
||||||
} catch (InternalErrorException e) {
|
|
||||||
_log.error("Failed to get the usermanager from HL. Could not add remove user from the HL group");
|
|
||||||
} catch (ItemNotFoundException e1) {
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected static ArrayList<String> getAdministratorsEmails(String scope) {
|
protected static ArrayList<String> getAdministratorsEmails(String scope) {
|
||||||
LiferayUserManager userManager = new LiferayUserManager();
|
LiferayUserManager userManager = new LiferayUserManager();
|
||||||
|
|
Loading…
Reference in New Issue