Catalogue at root VO or VO level works in read only mode [#26854]
This commit is contained in:
parent
36f32bf438
commit
c9811d3fb0
|
@ -30,5 +30,10 @@
|
||||||
<attribute name="maven.pomderived" value="true"/>
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
</attributes>
|
</attributes>
|
||||||
</classpathentry>
|
</classpathentry>
|
||||||
|
<classpathentry excluding="**" kind="src" output="target/gcube-ckan-datacatalog-2.3.0-SNAPSHOT/WEB-INF/classes" path="src/main/resources">
|
||||||
|
<attributes>
|
||||||
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
|
</attributes>
|
||||||
|
</classpathentry>
|
||||||
<classpathentry kind="output" path="target/gcube-ckan-datacatalog-2.3.0-SNAPSHOT/WEB-INF/classes"/>
|
<classpathentry kind="output" path="target/gcube-ckan-datacatalog-2.3.0-SNAPSHOT/WEB-INF/classes"/>
|
||||||
</classpath>
|
</classpath>
|
||||||
|
|
|
@ -46,6 +46,10 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -115,6 +119,10 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -184,6 +192,10 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -253,6 +265,10 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -275,7 +291,8 @@
|
||||||
|
|
||||||
|
|
||||||
<wb-resource deploy-path="/WEB-INF/classes" source-path="/src/main/java"/>
|
<wb-resource deploy-path="/WEB-INF/classes" source-path="/src/main/java"/>
|
||||||
<dependent-module archiveName="metadata-profile-form-builder-widget-2.1.1-SNAPSHOT.jar" deploy-path="/WEB-INF/lib" handle="module:/resource/metadata-profile-form-builder-widget/metadata-profile-form-builder-widget">
|
<wb-resource deploy-path="/WEB-INF/classes" source-path="/src/main/resources"/>
|
||||||
|
<dependent-module archiveName="catalogue-util-library-1.4.0-SNAPSHOT.jar" deploy-path="/WEB-INF/lib" handle="module:/resource/catalogue-util-library/catalogue-util-library">
|
||||||
<dependency-type>uses</dependency-type>
|
<dependency-type>uses</dependency-type>
|
||||||
</dependent-module>
|
</dependent-module>
|
||||||
<dependent-module archiveName="ckan-metadata-publisher-widget-2.2.0-SNAPSHOT.jar" deploy-path="/WEB-INF/lib" handle="module:/resource/ckan-metadata-publisher-widget/ckan-metadata-publisher-widget">
|
<dependent-module archiveName="ckan-metadata-publisher-widget-2.2.0-SNAPSHOT.jar" deploy-path="/WEB-INF/lib" handle="module:/resource/ckan-metadata-publisher-widget/ckan-metadata-publisher-widget">
|
||||||
|
@ -328,6 +345,10 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -397,6 +418,10 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -466,6 +491,10 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -535,6 +564,10 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -9,6 +9,8 @@ This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.htm
|
||||||
- Supported the Edit facility [#26639]
|
- Supported the Edit facility [#26639]
|
||||||
- Support the Delete facility [#26793]
|
- Support the Delete facility [#26793]
|
||||||
- Revisited the Navigation Bar
|
- Revisited the Navigation Bar
|
||||||
|
- Revisited the "Select Item Resources" step when publishing from Workspace [#26874]
|
||||||
|
- Catalogue at root VO or VO level works in read only mode [#26854]
|
||||||
|
|
||||||
## [v2.2.7] - 2023-12-21
|
## [v2.2.7] - 2023-12-21
|
||||||
|
|
||||||
|
|
|
@ -65,8 +65,9 @@ public class CkanMetadataManagementPanel extends FlowPanel {
|
||||||
private Button types = new Button("Types");
|
private Button types = new Button("Types");
|
||||||
|
|
||||||
// user's own
|
// user's own
|
||||||
private InlineHTML separatorMyInfo = null;
|
private InlineHTML pipe_MyInfo_start = null;
|
||||||
private InlineHTML separatorAdminButtons = null;
|
private InlineHTML pipe_PublishItem_start = null;
|
||||||
|
private InlineHTML pipe_SelectedItemOptions_start = null;
|
||||||
|
|
||||||
private DropdownButton dropMyOptionButtons = new DropdownButton("My...");
|
private DropdownButton dropMyOptionButtons = new DropdownButton("My...");
|
||||||
private NavLink myDatasets = new NavLink("My Items");
|
private NavLink myDatasets = new NavLink("My Items");
|
||||||
|
@ -146,12 +147,15 @@ public class CkanMetadataManagementPanel extends FlowPanel {
|
||||||
shareLink.setEnabled(false);
|
shareLink.setEnabled(false);
|
||||||
uploadToZenodo.setEnabled(false);
|
uploadToZenodo.setEnabled(false);
|
||||||
|
|
||||||
|
// hide upload to zenodo
|
||||||
|
uploadToZenodo.setVisible(false);
|
||||||
|
|
||||||
// hide publish/update/delete
|
// hide publish/update/delete
|
||||||
editMeta.setVisible(false);
|
editMeta.setVisible(false);
|
||||||
deleteItem.setVisible(false);
|
deleteItem.setVisible(false);
|
||||||
insertMeta.setVisible(false);
|
insertMeta.setVisible(false);
|
||||||
|
|
||||||
//hide manage GRSF product and Moderation
|
// hide manage GRSF product and Moderation
|
||||||
manageGRSFProduct.setVisible(false);
|
manageGRSFProduct.setVisible(false);
|
||||||
manageGRSFProduct.setEnabled(false);
|
manageGRSFProduct.setEnabled(false);
|
||||||
manageCModS.setVisible(false);
|
manageCModS.setVisible(false);
|
||||||
|
@ -168,6 +172,7 @@ public class CkanMetadataManagementPanel extends FlowPanel {
|
||||||
|
|
||||||
nav.add(messageModerationEnanbled);
|
nav.add(messageModerationEnanbled);
|
||||||
|
|
||||||
|
nav.setId("the_catalogue_nav_bar");
|
||||||
nav.addStyleName("nav_bar_catalogue");
|
nav.addStyleName("nav_bar_catalogue");
|
||||||
// add to navigation bar
|
// add to navigation bar
|
||||||
nav.add(home);
|
nav.add(home);
|
||||||
|
@ -176,10 +181,10 @@ public class CkanMetadataManagementPanel extends FlowPanel {
|
||||||
nav.add(items);
|
nav.add(items);
|
||||||
nav.add(types);
|
nav.add(types);
|
||||||
nav.add(statistics);
|
nav.add(statistics);
|
||||||
separatorMyInfo = new InlineHTML(
|
pipe_MyInfo_start = new InlineHTML(
|
||||||
"<span style=\"font-weight:bold;vertical-alignment:middle;margin:0 5px;\">|</span>");
|
"<span style=\"font-weight:bold;vertical-alignment:middle;margin:0 5px;\">|</span>");
|
||||||
separatorMyInfo.setVisible(true);
|
pipe_MyInfo_start.setVisible(true);
|
||||||
nav.add(separatorMyInfo);
|
nav.add(pipe_MyInfo_start);
|
||||||
|
|
||||||
dropMyOptionButtons.setBaseIcon(IconType.USER);
|
dropMyOptionButtons.setBaseIcon(IconType.USER);
|
||||||
dropMyOptionButtons.add(myOrganizations);
|
dropMyOptionButtons.add(myOrganizations);
|
||||||
|
@ -188,14 +193,16 @@ public class CkanMetadataManagementPanel extends FlowPanel {
|
||||||
dropMyOptionButtons.setType(ButtonType.LINK);
|
dropMyOptionButtons.setType(ButtonType.LINK);
|
||||||
nav.add(dropMyOptionButtons);
|
nav.add(dropMyOptionButtons);
|
||||||
|
|
||||||
separatorAdminButtons = new InlineHTML(
|
pipe_PublishItem_start = new InlineHTML(
|
||||||
"<span style=\"font-weight:bold;vertical-alignment:middle;margin:0 5px;\">|</span>");
|
"<span style=\"font-weight:bold;vertical-alignment:middle;margin:0 5px;\">|</span>");
|
||||||
separatorAdminButtons.setVisible(true);
|
pipe_PublishItem_start.setVisible(false);
|
||||||
nav.add(separatorAdminButtons);
|
nav.add(pipe_PublishItem_start);
|
||||||
|
|
||||||
nav.add(insertMeta);
|
nav.add(insertMeta);
|
||||||
|
|
||||||
nav.add(new InlineHTML("<span style=\"font-weight:bold;vertical-alignment:middle;margin:0 5px;\">|</span>"));
|
pipe_SelectedItemOptions_start = new InlineHTML(
|
||||||
|
"<span style=\"font-weight:bold;vertical-alignment:middle;margin:0 5px;\">|</span>");
|
||||||
|
pipe_SelectedItemOptions_start.setVisible(true);
|
||||||
|
nav.add(pipe_SelectedItemOptions_start);
|
||||||
|
|
||||||
nav.add(editMeta);
|
nav.add(editMeta);
|
||||||
nav.add(deleteItem);
|
nav.add(deleteItem);
|
||||||
|
@ -384,19 +391,12 @@ public class CkanMetadataManagementPanel extends FlowPanel {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Those buttons can be only visible when the logged user has role
|
* Enable publish button.
|
||||||
* EDITOR/ADMIN/SYSADMIN
|
|
||||||
*
|
*
|
||||||
* @param show the show
|
* @param enable the enable
|
||||||
*/
|
*/
|
||||||
public void visibilityPublishUpdateDeleteButtons(boolean show) {
|
public void enablePublishItemButton(boolean enable) {
|
||||||
|
insertMeta.setEnabled(enable);
|
||||||
// editMeta.setVisible(show); TODO
|
|
||||||
// separatorAdminButtons.setVisible(show);
|
|
||||||
insertMeta.setVisible(show);
|
|
||||||
editMeta.setVisible(show);
|
|
||||||
deleteItem.setVisible(show);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -491,6 +491,20 @@ public class CkanMetadataManagementPanel extends FlowPanel {
|
||||||
uploadToZenodo.setVisible(value);
|
uploadToZenodo.setVisible(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Visibility publish item button.
|
||||||
|
*
|
||||||
|
* @param value the value
|
||||||
|
* @param alsoThePipe the also the pipe. If true set bool value also the related
|
||||||
|
* pipe 'pipe_PublishItem_start'
|
||||||
|
*/
|
||||||
|
public void visibilityPublishItemButton(boolean bool, boolean alsoThePipe) {
|
||||||
|
insertMeta.setVisible(bool);
|
||||||
|
if (alsoThePipe) {
|
||||||
|
pipe_PublishItem_start.setVisible(bool);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Visibility edit item button.
|
* Visibility edit item button.
|
||||||
*
|
*
|
||||||
|
@ -514,8 +528,9 @@ public class CkanMetadataManagementPanel extends FlowPanel {
|
||||||
*/
|
*/
|
||||||
public void doNotShowUserRelatedInfo() {
|
public void doNotShowUserRelatedInfo() {
|
||||||
|
|
||||||
separatorMyInfo.setVisible(false);
|
pipe_MyInfo_start.setVisible(false);
|
||||||
separatorAdminButtons.setVisible(false);
|
pipe_PublishItem_start.setVisible(false);
|
||||||
|
pipe_SelectedItemOptions_start.setVisible(false);
|
||||||
shareLink.setVisible(false);
|
shareLink.setVisible(false);
|
||||||
uploadToZenodo.setVisible(false);
|
uploadToZenodo.setVisible(false);
|
||||||
insertMeta.setVisible(false);
|
insertMeta.setVisible(false);
|
||||||
|
@ -540,8 +555,8 @@ public class CkanMetadataManagementPanel extends FlowPanel {
|
||||||
groups.setVisible(false);
|
groups.setVisible(false);
|
||||||
items.setVisible(false);
|
items.setVisible(false);
|
||||||
types.setVisible(false);
|
types.setVisible(false);
|
||||||
separatorMyInfo.setVisible(false);
|
pipe_MyInfo_start.setVisible(false);
|
||||||
separatorAdminButtons.setVisible(false);
|
pipe_PublishItem_start.setVisible(false);
|
||||||
dropMyOptionButtons.setVisible(false);
|
dropMyOptionButtons.setVisible(false);
|
||||||
// myDatasets.setVisible(false);
|
// myDatasets.setVisible(false);
|
||||||
// myOrganizations.setVisible(false);
|
// myOrganizations.setVisible(false);
|
||||||
|
|
|
@ -181,25 +181,57 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onFailure(Throwable caught) {
|
public void onFailure(Throwable caught) {
|
||||||
showPublishUpdateDeleteButtons(false);
|
managementPanel.visibilityEditItemButton(false);
|
||||||
|
managementPanel.visibilityDeleteItemButton(false);
|
||||||
|
managementPanel.visibilityPublishItemButton(false, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onSuccess(RolesCkanGroupOrOrg result) {
|
public void onSuccess(RolesCkanGroupOrOrg result) {
|
||||||
|
GWT.log("isUserLoggedInVRE: "+ckanAccessPoint.isUserLoggedInVRE());
|
||||||
|
GWT.log("getLoggedInScope: "+ckanAccessPoint.getLoggedInScope());
|
||||||
|
|
||||||
|
if (ckanAccessPoint.isUserLoggedInVRE()) {
|
||||||
|
|
||||||
switch (result) {
|
switch (result) {
|
||||||
case ADMIN:
|
case ADMIN: {
|
||||||
showPublishUpdateDeleteButtons(true);
|
managementPanel.visibilityPublishItemButton(true, true);
|
||||||
|
managementPanel.visibilityEditItemButton(true);
|
||||||
|
managementPanel.visibilityDeleteItemButton(true);
|
||||||
|
managementPanel.enablePublishItemButton(true);
|
||||||
break;
|
break;
|
||||||
case EDITOR:
|
}
|
||||||
showPublishUpdateDeleteButtons(true);
|
case EDITOR: {
|
||||||
|
managementPanel.visibilityPublishItemButton(true, true);
|
||||||
|
managementPanel.visibilityEditItemButton(true);
|
||||||
|
managementPanel.visibilityDeleteItemButton(true);
|
||||||
|
managementPanel.enablePublishItemButton(true);
|
||||||
break;
|
break;
|
||||||
case MEMBER:
|
}
|
||||||
showPublishUpdateDeleteButtons(false);
|
case MEMBER: {
|
||||||
|
managementPanel.visibilityEditItemButton(false);
|
||||||
|
managementPanel.visibilityDeleteItemButton(false);
|
||||||
|
// Disable the button "Publish Item" is to inform the user that he/she has
|
||||||
|
// not the rights to publish
|
||||||
|
managementPanel.visibilityPublishItemButton(true, true);
|
||||||
|
managementPanel.enablePublishItemButton(false);
|
||||||
break;
|
break;
|
||||||
default:
|
}
|
||||||
showPublishUpdateDeleteButtons(false);
|
default: {
|
||||||
|
managementPanel.visibilityEditItemButton(false);
|
||||||
|
managementPanel.visibilityDeleteItemButton(false);
|
||||||
|
// Disable the button "Publish Item" is to inform the user that he/she has
|
||||||
|
// not the rights to publish
|
||||||
|
managementPanel.visibilityPublishItemButton(true, true);
|
||||||
|
managementPanel.enablePublishItemButton(false);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
managementPanel.visibilityPublishItemButton(false, true);
|
||||||
|
managementPanel.visibilityEditItemButton(false);
|
||||||
|
managementPanel.visibilityDeleteItemButton(false);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -414,15 +446,15 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate {
|
||||||
updateSize();
|
updateSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
// /**
|
||||||
* show or hide the Publish/Update/Delete buttons according to the role.
|
// * show or hide the Publish/Update/Delete buttons according to the role.
|
||||||
*
|
// *
|
||||||
* @param show the show
|
// * @param show the show
|
||||||
*/
|
// */
|
||||||
public void showPublishUpdateDeleteButtons(boolean show) {
|
// public void showPublishUpdateDeleteButtons(boolean show) {
|
||||||
|
//
|
||||||
managementPanel.visibilityPublishUpdateDeleteButtons(show);
|
// managementPanel.visibilityUpdateDeleteButtons(show);
|
||||||
}
|
// }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Instance ckan frame.
|
* Instance ckan frame.
|
||||||
|
|
|
@ -88,7 +88,7 @@ public class GcubeCkanDataCatalogServiceImpl extends RemoteServiceServlet implem
|
||||||
try{
|
try{
|
||||||
|
|
||||||
// just get the current scope and set it into ScopeProvider...
|
// just get the current scope and set it into ScopeProvider...
|
||||||
SessionUtil.getCurrentContext(getThreadLocalRequest(), true);
|
String loggedInScope = SessionUtil.getCurrentContext(getThreadLocalRequest(), true);
|
||||||
|
|
||||||
// retrieve scope per current portlet url
|
// retrieve scope per current portlet url
|
||||||
String scopePerCurrentUrl = SessionUtil.getScopeFromClientUrl(getThreadLocalRequest());
|
String scopePerCurrentUrl = SessionUtil.getScopeFromClientUrl(getThreadLocalRequest());
|
||||||
|
@ -112,7 +112,15 @@ public class GcubeCkanDataCatalogServiceImpl extends RemoteServiceServlet implem
|
||||||
pathInfoParameter = isViewPerVREEnabled(browserLocationURL);
|
pathInfoParameter = isViewPerVREEnabled(browserLocationURL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//#26854
|
||||||
CkanConnectorAccessPoint ckAP = getCkanConnectorAccessPoint(browserLocationURL, pathInfoParameter, queryStringParameters, scopePerCurrentUrl);
|
CkanConnectorAccessPoint ckAP = getCkanConnectorAccessPoint(browserLocationURL, pathInfoParameter, queryStringParameters, scopePerCurrentUrl);
|
||||||
|
ckAP.setLoggedInScope(loggedInScope);
|
||||||
|
ckAP.setOperativeScope(scopePerCurrentUrl);
|
||||||
|
if(loggedInScope!=null) {
|
||||||
|
ScopeBean scopeBeanLS = new ScopeBean(loggedInScope);
|
||||||
|
boolean loggedInVRE = scopeBeanLS.is(Type.VRE);
|
||||||
|
ckAP.setUserLoggedInVRE(loggedInVRE);
|
||||||
|
}
|
||||||
SessionUtil.saveCkanAccessPoint(this.getThreadLocalRequest().getSession(), scopePerCurrentUrl, ckAP);
|
SessionUtil.saveCkanAccessPoint(this.getThreadLocalRequest().getSession(), scopePerCurrentUrl, ckAP);
|
||||||
logger.info("Built the URI to CKAN (connector in case of user logged): "+ckAP.buildURI());
|
logger.info("Built the URI to CKAN (connector in case of user logged): "+ckAP.buildURI());
|
||||||
logger.debug("returning ckanConnectorUri: "+ckAP);
|
logger.debug("returning ckanConnectorUri: "+ckAP);
|
||||||
|
@ -238,8 +246,8 @@ public class GcubeCkanDataCatalogServiceImpl extends RemoteServiceServlet implem
|
||||||
RolesCkanGroupOrOrg toReturn = RolesCkanGroupOrOrg.MEMBER;
|
RolesCkanGroupOrOrg toReturn = RolesCkanGroupOrOrg.MEMBER;
|
||||||
|
|
||||||
if(!SessionUtil.isIntoPortal()){
|
if(!SessionUtil.isIntoPortal()){
|
||||||
logger.warn("OUT FROM PORTAL DETECTED RETURNING ROLE: "+RolesCkanGroupOrOrg.ADMIN);
|
|
||||||
toReturn = RolesCkanGroupOrOrg.ADMIN;
|
toReturn = RolesCkanGroupOrOrg.ADMIN;
|
||||||
|
logger.warn("OUT FROM PORTAL DETECTED RETURNING ROLE: "+toReturn);
|
||||||
}else{
|
}else{
|
||||||
|
|
||||||
HttpSession httpSession = this.getThreadLocalRequest().getSession();
|
HttpSession httpSession = this.getThreadLocalRequest().getSession();
|
||||||
|
|
|
@ -10,14 +10,12 @@ import java.util.Set;
|
||||||
|
|
||||||
import org.gcube.portlets.gcubeckan.gcubeckandatacatalog.server.GcubeCkanDataCatalogServiceImpl;
|
import org.gcube.portlets.gcubeckan.gcubeckandatacatalog.server.GcubeCkanDataCatalogServiceImpl;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The Class CkanConnectorAccessPoint.
|
* The Class CkanConnectorAccessPoint.
|
||||||
*
|
*
|
||||||
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
|
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it Jun 23, 2016
|
||||||
* Jun 23, 2016
|
|
||||||
*/
|
*/
|
||||||
public class CkanConnectorAccessPoint implements Serializable{
|
public class CkanConnectorAccessPoint implements Serializable {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -37,6 +35,10 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
private boolean outsideLoginOnPortal = false;
|
private boolean outsideLoginOnPortal = false;
|
||||||
private String catalogueBaseUrl = null;
|
private String catalogueBaseUrl = null;
|
||||||
|
|
||||||
|
private String operativeScope = null;
|
||||||
|
private String loggedInScope = null;
|
||||||
|
private boolean isUserLoggedInVRE = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Instantiates a new ckan connector access point.
|
* Instantiates a new ckan connector access point.
|
||||||
*/
|
*/
|
||||||
|
@ -49,7 +51,7 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
* @param baseUrl the base url
|
* @param baseUrl the base url
|
||||||
* @param serviceContext the service context
|
* @param serviceContext the service context
|
||||||
*/
|
*/
|
||||||
public CkanConnectorAccessPoint(String baseUrl, String serviceContext){
|
public CkanConnectorAccessPoint(String baseUrl, String serviceContext) {
|
||||||
this.baseUrl = baseUrl;
|
this.baseUrl = baseUrl;
|
||||||
this.catalogueBaseUrl = baseUrl.split("ckan-connector")[0];
|
this.catalogueBaseUrl = baseUrl.split("ckan-connector")[0];
|
||||||
this.serviceContext = serviceContext;
|
this.serviceContext = serviceContext;
|
||||||
|
@ -61,26 +63,26 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
* @param key the key
|
* @param key the key
|
||||||
* @param value the value
|
* @param value the value
|
||||||
*/
|
*/
|
||||||
public void addGenericParameter(String key, String value){
|
public void addGenericParameter(String key, String value) {
|
||||||
queryStringParameters=queryStringParameters==null?key+"="+value:queryStringParameters+"&"+key+"="+value;
|
queryStringParameters = queryStringParameters == null ? key + "=" + value
|
||||||
|
: queryStringParameters + "&" + key + "=" + value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds the query string.
|
* Adds the query string.
|
||||||
*
|
*
|
||||||
* @param queryString the query string
|
* @param queryString the query string
|
||||||
*/
|
*/
|
||||||
public void addQueryString(String queryString){
|
public void addQueryString(String queryString) {
|
||||||
|
|
||||||
if(queryString==null || queryString.isEmpty())
|
if (queryString == null || queryString.isEmpty())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if(queryString.startsWith("&") || queryString.startsWith("?")){
|
if (queryString.startsWith("&") || queryString.startsWith("?")) {
|
||||||
queryString = queryString.substring(1, queryString.length()); //removes '&' or '?'
|
queryString = queryString.substring(1, queryString.length()); // removes '&' or '?'
|
||||||
}
|
}
|
||||||
|
|
||||||
queryStringParameters=queryStringParameters==null?queryString:queryStringParameters+"&"+queryString;
|
queryStringParameters = queryStringParameters == null ? queryString : queryStringParameters + "&" + queryString;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -88,8 +90,8 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
*
|
*
|
||||||
* @param value the value
|
* @param value the value
|
||||||
*/
|
*/
|
||||||
public void addGubeToken(String value){
|
public void addGubeToken(String value) {
|
||||||
if(!outsideLoginOnPortal){
|
if (!outsideLoginOnPortal) {
|
||||||
this.gcubeTokenValue = value;
|
this.gcubeTokenValue = value;
|
||||||
addGenericParameter(GCUBE_TOKEN_PARAMETER, value);
|
addGenericParameter(GCUBE_TOKEN_PARAMETER, value);
|
||||||
}
|
}
|
||||||
|
@ -100,18 +102,19 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
*
|
*
|
||||||
* @param listVREs the list vr es
|
* @param listVREs the list vr es
|
||||||
*/
|
*/
|
||||||
public void addListOfVREs(Map<String, String> listVREs){
|
public void addListOfVREs(Map<String, String> listVREs) {
|
||||||
this.mapVresRoles = listVREs;
|
this.mapVresRoles = listVREs;
|
||||||
String vres = "";
|
String vres = "";
|
||||||
if(listVREs!=null && listVREs.size()>0){
|
if (listVREs != null && listVREs.size() > 0) {
|
||||||
Set<Entry<String, String>> set = listVREs.entrySet();
|
Set<Entry<String, String>> set = listVREs.entrySet();
|
||||||
for (Entry<String, String> entry : set) {
|
for (Entry<String, String> entry : set) {
|
||||||
vres += entry.getKey().toLowerCase() + "|" + entry.getValue() + ",";
|
vres += entry.getKey().toLowerCase() + "|" + entry.getValue() + ",";
|
||||||
}
|
}
|
||||||
vres = vres.substring(0, vres.length()-1); //remove last "," and to lower case. A CKAN Organization ID must be lower case
|
vres = vres.substring(0, vres.length() - 1); // remove last "," and to lower case. A CKAN Organization ID
|
||||||
|
// must be lower case
|
||||||
}
|
}
|
||||||
|
|
||||||
if(vres.length()>0){
|
if (vres.length() > 0) {
|
||||||
addGenericParameter(LIST_OF_VRES_PARAMETER, vres);
|
addGenericParameter(LIST_OF_VRES_PARAMETER, vres);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -121,27 +124,75 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
*
|
*
|
||||||
* @param pathInfo the path info
|
* @param pathInfo the path info
|
||||||
*/
|
*/
|
||||||
public void addPathInfo(String pathInfo){
|
public void addPathInfo(String pathInfo) {
|
||||||
pathInfoParameter = pathInfo;
|
pathInfoParameter = pathInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Builds the URI to contact the CKAN (connector in case of user logged)
|
* Builds the URI to contact the CKAN (connector in case of user logged).
|
||||||
*
|
*
|
||||||
* @return the string
|
* @return the string
|
||||||
*/
|
*/
|
||||||
public String buildURI(){
|
public String buildURI() {
|
||||||
|
|
||||||
String path = "";
|
String path = "";
|
||||||
String query = "";
|
String query = "";
|
||||||
path = checkURLPathSeparator(pathInfoParameter, true, false);
|
path = checkURLPathSeparator(pathInfoParameter, true, false);
|
||||||
query = checkNullString(queryStringParameters);
|
query = checkNullString(queryStringParameters);
|
||||||
String url = getBaseUrlWithContext()+path;
|
String url = getBaseUrlWithContext() + path;
|
||||||
url+= !query.isEmpty()?"?"+query:"";
|
url += !query.isEmpty() ? "?" + query : "";
|
||||||
return url;
|
return url;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the operative scope.
|
||||||
|
*
|
||||||
|
* @return the operative scope
|
||||||
|
*/
|
||||||
|
public String getOperativeScope() {
|
||||||
|
return operativeScope;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the logged in scope.
|
||||||
|
*
|
||||||
|
* @return the logged in scope
|
||||||
|
*/
|
||||||
|
public String getLoggedInScope() {
|
||||||
|
return loggedInScope;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isUserLoggedInVRE() {
|
||||||
|
return isUserLoggedInVRE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the user logged in VRE.
|
||||||
|
*
|
||||||
|
* @param isUserLoggedInVRE the new user logged in VRE
|
||||||
|
*/
|
||||||
|
public void setUserLoggedInVRE(boolean isUserLoggedInVRE) {
|
||||||
|
this.isUserLoggedInVRE = isUserLoggedInVRE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the operative scope.
|
||||||
|
*
|
||||||
|
* @param operativeScope the new operative scope
|
||||||
|
*/
|
||||||
|
public void setOperativeScope(String operativeScope) {
|
||||||
|
this.operativeScope = operativeScope;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the logged in scope.
|
||||||
|
*
|
||||||
|
* @param loggedInScope the new logged in scope
|
||||||
|
*/
|
||||||
|
public void setLoggedInScope(String loggedInScope) {
|
||||||
|
this.loggedInScope = loggedInScope;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the base url with context.
|
* Gets the base url with context.
|
||||||
*
|
*
|
||||||
|
@ -149,10 +200,9 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
*/
|
*/
|
||||||
public String getBaseUrlWithContext() {
|
public String getBaseUrlWithContext() {
|
||||||
|
|
||||||
return baseUrl+serviceContext;
|
return baseUrl + serviceContext;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the path info parameter.
|
* Gets the path info parameter.
|
||||||
*
|
*
|
||||||
|
@ -163,7 +213,6 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
return pathInfoParameter;
|
return pathInfoParameter;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the query string parameters.
|
* Gets the query string parameters.
|
||||||
*
|
*
|
||||||
|
@ -174,7 +223,6 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
return queryStringParameters;
|
return queryStringParameters;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the gcube token value.
|
* Gets the gcube token value.
|
||||||
*
|
*
|
||||||
|
@ -185,7 +233,6 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
return gcubeTokenValue;
|
return gcubeTokenValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the list of v res.
|
* Gets the list of v res.
|
||||||
*
|
*
|
||||||
|
@ -200,24 +247,28 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
* Check url path separator.
|
* Check url path separator.
|
||||||
*
|
*
|
||||||
* @param url the url
|
* @param url the url
|
||||||
* @param head - checks the {@link GcubeCkanDataCatalogServiceImpl.URL_PATH_SEPARATOR} in head adding if do not exist
|
* @param head - checks the
|
||||||
* @param tail - checks the {@link GcubeCkanDataCatalogServiceImpl.URL_PATH_SEPARATOR} in tail adding if do not exist
|
* {@link GcubeCkanDataCatalogServiceImpl.URL_PATH_SEPARATOR} in
|
||||||
* @return the string - if null return an empty string otherwise a string with {@link GcubeCkanDataCatalogServiceImpl.URL_PATH_SEPARATOR}
|
* head adding if do not exist
|
||||||
|
* @param tail - checks the
|
||||||
|
* {@link GcubeCkanDataCatalogServiceImpl.URL_PATH_SEPARATOR} in
|
||||||
|
* tail adding if do not exist
|
||||||
|
* @return the string - if null return an empty string otherwise a string with
|
||||||
|
* {@link GcubeCkanDataCatalogServiceImpl.URL_PATH_SEPARATOR}
|
||||||
*/
|
*/
|
||||||
public static String checkURLPathSeparator(String url, boolean head, boolean tail){
|
public static String checkURLPathSeparator(String url, boolean head, boolean tail) {
|
||||||
|
|
||||||
if(url!=null && url.length()>0){
|
if (url != null && url.length() > 0) {
|
||||||
if(head)
|
if (head)
|
||||||
url=url.startsWith(URL_PATH_SEPARATOR)?url:URL_PATH_SEPARATOR+url;
|
url = url.startsWith(URL_PATH_SEPARATOR) ? url : URL_PATH_SEPARATOR + url;
|
||||||
if(tail)
|
if (tail)
|
||||||
url=url.endsWith(URL_PATH_SEPARATOR)?url:url+URL_PATH_SEPARATOR;
|
url = url.endsWith(URL_PATH_SEPARATOR) ? url : url + URL_PATH_SEPARATOR;
|
||||||
}else
|
} else
|
||||||
url = "";
|
url = "";
|
||||||
|
|
||||||
return url;
|
return url;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the base url.
|
* Gets the base url.
|
||||||
*
|
*
|
||||||
|
@ -228,23 +279,20 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
return baseUrl;
|
return baseUrl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check null string.
|
* Check null string.
|
||||||
*
|
*
|
||||||
* @param value the value
|
* @param value the value
|
||||||
* @return the string if is not null otherwise an empty string
|
* @return the string if is not null otherwise an empty string
|
||||||
*/
|
*/
|
||||||
public static String checkNullString(String value){
|
public static String checkNullString(String value) {
|
||||||
|
|
||||||
if(value==null)
|
if (value == null)
|
||||||
return "";
|
return "";
|
||||||
else
|
else
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks if is outside login on portal.
|
* Checks if is outside login on portal.
|
||||||
*
|
*
|
||||||
|
@ -255,7 +303,6 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
return outsideLoginOnPortal;
|
return outsideLoginOnPortal;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the outside login on portal.
|
* Sets the outside login on portal.
|
||||||
*
|
*
|
||||||
|
@ -275,8 +322,14 @@ public class CkanConnectorAccessPoint implements Serializable{
|
||||||
return catalogueBaseUrl;
|
return catalogueBaseUrl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
/* (non-Javadoc)
|
* To string.
|
||||||
|
*
|
||||||
|
* @return the string
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* (non-Javadoc)
|
||||||
|
*
|
||||||
* @see java.lang.Object#toString()
|
* @see java.lang.Object#toString()
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in New Issue