ClientContextLibrary
Contents
Client Context library for gCube Portlets
Starting from gCube 4.2, the current Context identifier resides client side. If your Portlet does use AJAX calls (i.e. XMLHttpRequest to exchange data with a server behind the scenes) you don't need this component. Everything is already set up for you by the gCube Portal/Gateway in which your application is running.
If you use standard http GET or POST to exchange data with the server instead, and you need to pass to the server the current Infrastructure scope identifier (the Liferay groupId).
Getting the Client Context in Javascript
<script> var groupId = Liferay.ThemeDisplay.getScopeGroupId(); </script>
Read more about Liferay Javascript Object: [1]
Getting the Client Context in GWT (Widget)
The Client Context has been wrapped as a GWT Widget. Its source code is available in the gCube SVN repository, at this url.
To use the widget, you need to declare the following maven dependency in your project's pom.xml
<dependency> <groupId>org.gcube.portal</groupId> <artifactId>client-context-library</artifactId> <version>[1.0.0-SNAPSHOT,)</version> <scope>compile</scope> </dependency>
as well as the following line in the gwt.xml file of your gwt-portlet:
<!--Inherit the GCubeClientContext widget code --> <inherits name='org.gcube.portal.clientcontext.GCubeClientContext' />
then you just use the GCubeClientContext.getCurrentContextId() method:
public static native String getCurrentContextId();
Either if you pass this identifier explicitly as parameter, or embed it in the header of your cal, in the server you can use the following snippet to get the infrastructure scope:
//groupIdNo is the String in the server passed from the client if (groupIdNo != null) { long groupId = -1; try { groupId = Long.parseLong(groupIdNo); LiferayGroupManager gm = new LiferayGroupManager(); if (gm.isRootVO(groupId)) { return SCOPE_SEPARATOR + getInfrastructureName(); } else return new LiferayGroupManager().getInfrastructureScope(groupId); } catch (NumberFormatException e) { _log.error("The groupId is not a number -> " + groupId); } catch (Exception e) { _log.error("This groupId does not belong to any group in this portal -> " + groupId); } }
References
[1] Liferay Javascript Object usage: https://web.liferay.com/web/pankaj.kathiriya/blog/-/blogs/usage-of-liferay-js-object