Completed Task #6492
git-svn-id: http://svn.research-infrastructures.eu/public/d4science/gcube/trunk/data-transfer/uri-resolver@141977 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
parent
b99016706a
commit
406886b6b6
2
pom.xml
2
pom.xml
|
@ -8,7 +8,7 @@
|
||||||
</parent>
|
</parent>
|
||||||
<groupId>org.gcube.data.transfer</groupId>
|
<groupId>org.gcube.data.transfer</groupId>
|
||||||
<artifactId>uri-resolver</artifactId>
|
<artifactId>uri-resolver</artifactId>
|
||||||
<version>1.9.0-SNAPSHOT</version>
|
<version>1.10.0-SNAPSHOT</version>
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
<description>The URI Resolver is an HTTP URI resolver implemented as an HTTP servlet which gives access trough HTTP to different protocols URIs. </description>
|
<description>The URI Resolver is an HTTP URI resolver implemented as an HTTP servlet which gives access trough HTTP to different protocols URIs. </description>
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,126 @@
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
package org.gcube.datatransfer.resolver;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Enum ResourceCatalogueCodes.
|
||||||
|
*
|
||||||
|
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
|
||||||
|
* Jan 31, 2017
|
||||||
|
*
|
||||||
|
* see wiki page: https://wiki.gcube-system.org/gcube/URI_Resolver#CATALOGUE_Resolver
|
||||||
|
*/
|
||||||
|
public enum ResourceCatalogueCodes {
|
||||||
|
|
||||||
|
CTLG("ctlg","product", "Catalogue Product/Dataset"),
|
||||||
|
CTLGP("ctlg-p","product", "Catalogue Product"),
|
||||||
|
CTLGD("ctlg-d","dataset", "Catalogue Dataset"),
|
||||||
|
CTLGO("ctlg-o","organization", "Catalogue Organization"),
|
||||||
|
CTLGG("ctlg-g","group", "Catalogue Group");
|
||||||
|
|
||||||
|
private String id; //the code id
|
||||||
|
private String value; //the code value
|
||||||
|
private String description;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Instantiates a new resource catalogue codes.
|
||||||
|
*
|
||||||
|
* @param id the id
|
||||||
|
* @param value the value
|
||||||
|
* @param description the description
|
||||||
|
*/
|
||||||
|
private ResourceCatalogueCodes(String id, String value, String description) {
|
||||||
|
this.id = id;
|
||||||
|
this.value = value;
|
||||||
|
this.description = description;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the id.
|
||||||
|
*
|
||||||
|
* @return the id
|
||||||
|
*/
|
||||||
|
public String getId() {
|
||||||
|
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the value.
|
||||||
|
*
|
||||||
|
* @return the value
|
||||||
|
*/
|
||||||
|
public String getValue() {
|
||||||
|
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the description.
|
||||||
|
*
|
||||||
|
* @return the description
|
||||||
|
*/
|
||||||
|
public String getDescription() {
|
||||||
|
|
||||||
|
return description;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Codes.
|
||||||
|
*
|
||||||
|
* @return the list
|
||||||
|
*/
|
||||||
|
public static List<String> codes(){
|
||||||
|
|
||||||
|
List<String> codes = new ArrayList<String>(ResourceCatalogueCodes.values().length);
|
||||||
|
for (ResourceCatalogueCodes value : ResourceCatalogueCodes.values()) {
|
||||||
|
codes.add(value.getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
return codes;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Value of code id.
|
||||||
|
*
|
||||||
|
* @param id the id
|
||||||
|
* @return the resource catalogue codes
|
||||||
|
*/
|
||||||
|
public static ResourceCatalogueCodes valueOfCodeId(String id){
|
||||||
|
if(id==null || id.isEmpty())
|
||||||
|
return null;
|
||||||
|
|
||||||
|
for (ResourceCatalogueCodes value : ResourceCatalogueCodes.values()) {
|
||||||
|
if(value.id.compareTo(id)==0)
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Value of code value.
|
||||||
|
*
|
||||||
|
* @param codeValue the code value
|
||||||
|
* @return the resource catalogue codes
|
||||||
|
*/
|
||||||
|
public static ResourceCatalogueCodes valueOfCodeValue(String codeValue){
|
||||||
|
if(codeValue==null || codeValue.isEmpty())
|
||||||
|
return null;
|
||||||
|
|
||||||
|
for (ResourceCatalogueCodes rcc : ResourceCatalogueCodes.values()) {
|
||||||
|
if(rcc.value.compareTo(codeValue)==0)
|
||||||
|
return rcc;
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
|
@ -4,6 +4,8 @@
|
||||||
package org.gcube.datatransfer.resolver;
|
package org.gcube.datatransfer.resolver;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
import javax.servlet.Filter;
|
import javax.servlet.Filter;
|
||||||
import javax.servlet.FilterChain;
|
import javax.servlet.FilterChain;
|
||||||
|
@ -49,6 +51,8 @@ public class UriResolverRewriteFilter implements Filter{
|
||||||
protected static final Logger logger = LoggerFactory.getLogger(UriResolverRewriteFilter.class);
|
protected static final Logger logger = LoggerFactory.getLogger(UriResolverRewriteFilter.class);
|
||||||
private FilterConfig config;
|
private FilterConfig config;
|
||||||
|
|
||||||
|
private static final Set<String> resourceCataloguesCodes = new HashSet<String>(ResourceCatalogueCodes.codes());
|
||||||
|
|
||||||
//private ApplicationProfileReaderForCatalogueResolver appPrfCatResolver = new ApplicationProfileReaderForCatalogueResolver(scope, useRootScope)
|
//private ApplicationProfileReaderForCatalogueResolver appPrfCatResolver = new ApplicationProfileReaderForCatalogueResolver(scope, useRootScope)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -79,43 +83,74 @@ public class UriResolverRewriteFilter implements Filter{
|
||||||
MultiReadHttpServletRequest multiReadRequest = new MultiReadHttpServletRequest((HttpServletRequest) req);
|
MultiReadHttpServletRequest multiReadRequest = new MultiReadHttpServletRequest((HttpServletRequest) req);
|
||||||
String requestURI = multiReadRequest.getRequestURI();
|
String requestURI = multiReadRequest.getRequestURI();
|
||||||
String queryString = multiReadRequest.getQueryString();
|
String queryString = multiReadRequest.getQueryString();
|
||||||
logger.debug("Request URI: " + requestURI + ", QueryString: " +queryString+ ", Servlet path: "+multiReadRequest.getServletPath());
|
String servletPath = multiReadRequest.getServletPath();
|
||||||
|
logger.debug("Request URI: " + requestURI + ", QueryString: " +queryString+ ", Servlet path: "+servletPath);
|
||||||
|
|
||||||
//IS A REQUEST FOR GEONETWORK AUTHENTICATION? (CKAN HARVESTING?)
|
//IS A REQUEST FOR GEONETWORK AUTHENTICATION? (CKAN HARVESTING?)
|
||||||
if(multiReadRequest.getServletPath().startsWith(SERVLET_GEONETWORK) || multiReadRequest.getServletPath().startsWith(SERVLET_URI_RESOLVER+SERVLET_GEONETWORK)){
|
if(servletPath.startsWith(SERVLET_GEONETWORK) || servletPath.startsWith(SERVLET_URI_RESOLVER+SERVLET_GEONETWORK)){
|
||||||
logger.debug("is geonetwork request");
|
logger.debug("It is a request to geonetwork");
|
||||||
GeonetworkRequestDecoder grd = new GeonetworkRequestDecoder(multiReadRequest.getServletPath(), queryString);
|
GeonetworkRequestDecoder grd = new GeonetworkRequestDecoder(servletPath, queryString);
|
||||||
logger.debug("forward to: "+grd.getNewURI());
|
logger.debug("forward to: "+grd.getNewURI());
|
||||||
multiReadRequest.getRequestDispatcher(grd.getNewURI()).forward(multiReadRequest, response);
|
multiReadRequest.getRequestDispatcher(grd.getNewURI()).forward(multiReadRequest, response);
|
||||||
|
|
||||||
}else if(multiReadRequest.getServletPath().startsWith(SERVLET_CATALOGUE) || multiReadRequest.getServletPath().startsWith(SERVLET_URI_RESOLVER+SERVLET_CATALOGUE)){
|
}else{
|
||||||
logger.debug("is a catalogue request");
|
logger.debug("checking if it is a request to catologue...");
|
||||||
|
boolean isCatalogueServletReference = servletPath.startsWith(SERVLET_CATALOGUE);
|
||||||
|
|
||||||
|
String idCodeCatalogue = null;
|
||||||
|
boolean isIdCodeCatalogue = false;
|
||||||
|
String splittedServletPath[] = servletPath.split(PATH_SEPARATOR);
|
||||||
|
if(!isCatalogueServletReference){
|
||||||
|
idCodeCatalogue = splittedServletPath[1];
|
||||||
|
logger.trace("checking if the code: "+idCodeCatalogue+" belongs to a catalogue code");
|
||||||
|
isIdCodeCatalogue = resourceCataloguesCodes.contains(idCodeCatalogue);
|
||||||
|
logger.debug("\tIs it a catalogue code? "+isIdCodeCatalogue);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(isCatalogueServletReference || isIdCodeCatalogue){
|
||||||
|
|
||||||
//int startIndex = requestURI.indexOf(SERVLET_CATALOGUE))+SERVLET_CATALOGUE.length();
|
//int startIndex = requestURI.indexOf(SERVLET_CATALOGUE))+SERVLET_CATALOGUE.length();
|
||||||
//String vreName = requestURI.substring(beginIndex)
|
//String vreName = requestURI.substring(beginIndex)
|
||||||
HttpServletRequest request = (HttpServletRequest) req;
|
HttpServletRequest request = (HttpServletRequest) req;
|
||||||
logger.debug("method is: "+request.getMethod());
|
logger.trace("method is: "+request.getMethod());
|
||||||
|
|
||||||
if(request.getMethod().compareTo("POST")==0){
|
if(request.getMethod().compareToIgnoreCase("POST")==0){
|
||||||
logger.debug("is POST request...");
|
logger.debug("Managing as Catalogue POST request..");
|
||||||
logger.debug("forward to: " + SERVLET_CATALOGUE);
|
logger.debug("forward to: " + SERVLET_CATALOGUE);
|
||||||
multiReadRequest.getRequestDispatcher(SERVLET_CATALOGUE).forward(multiReadRequest, response);
|
multiReadRequest.getRequestDispatcher(SERVLET_CATALOGUE).forward(multiReadRequest, response);
|
||||||
}
|
}else{
|
||||||
else{
|
logger.debug("Managing as Catalogue GET request..");
|
||||||
logger.debug("is GET request...");
|
|
||||||
String[] pathSplit = multiReadRequest.getServletPath().split(PATH_SEPARATOR);
|
|
||||||
String newURI = SERVLET_CATALOGUE;
|
String newURI = SERVLET_CATALOGUE;
|
||||||
if(pathSplit.length==5){
|
//String[] pathSplit = newServletPath.split(PATH_SEPARATOR);
|
||||||
logger.info("Resolving a clear URL to catalogue...");
|
if(isIdCodeCatalogue){
|
||||||
logger.debug("found VRE name: "+pathSplit[2]);
|
//TO BUILD A COMPLETE URL
|
||||||
String gcubeScope = CatalogueRequestParameter.GCUBE_SCOPE.getKey() +"="+pathSplit[2];
|
// logger.debug("is a catalogue code, rebuilding complete url...");
|
||||||
String eC = CatalogueRequestParameter.ENTITY_CONTEXT.getKey() +"="+pathSplit[3];
|
// ResourceCatalogueCodes rcc = ResourceCatalogueCodes.valueOfId(idCodeCatalogue);
|
||||||
|
// newServletPath = SERVLET_CATALOGUE+splittedServletPath[2]+PATH_SEPARATOR+rcc.getValue()+PATH_SEPARATOR+splittedServletPath[3];
|
||||||
|
// logger.debug("rebuilded complete url: "+newServletPath);
|
||||||
|
logger.debug("is a catalogue code, resolving a short url in clear ...");
|
||||||
|
ResourceCatalogueCodes rcc = ResourceCatalogueCodes.valueOfCodeId(idCodeCatalogue);
|
||||||
|
logger.debug("found VRE name: "+splittedServletPath[2]);
|
||||||
|
String gcubeScope = CatalogueRequestParameter.GCUBE_SCOPE.getKey() +"="+splittedServletPath[2];
|
||||||
|
String eC = CatalogueRequestParameter.ENTITY_CONTEXT.getKey() +"="+rcc.getValue();
|
||||||
|
logger.debug("found id code: "+idCodeCatalogue+", resolving it with context name: "+eC);
|
||||||
|
String eN = CatalogueRequestParameter.ENTITY_NAME.getKey() +"="+splittedServletPath[3];
|
||||||
|
logger.debug("found entity name: "+eN);
|
||||||
|
String encodedQuery = UrlEncoderUtil.encodeQuery(gcubeScope,eC,eN);
|
||||||
|
newURI+= "?" + PARAMETER_DIRECT_CATALOGUE_LINK + "=" + encodedQuery;
|
||||||
|
}else
|
||||||
|
if(splittedServletPath.length==5){
|
||||||
|
logger.info("resolving a complete URL in clear...");
|
||||||
|
logger.debug("found VRE name: "+splittedServletPath[2]);
|
||||||
|
String gcubeScope = CatalogueRequestParameter.GCUBE_SCOPE.getKey() +"="+splittedServletPath[2];
|
||||||
|
String eC = CatalogueRequestParameter.ENTITY_CONTEXT.getKey() +"="+splittedServletPath[3];
|
||||||
logger.debug("found context name: "+eC);
|
logger.debug("found context name: "+eC);
|
||||||
String eN = CatalogueRequestParameter.ENTITY_NAME.getKey() +"="+pathSplit[4];
|
String eN = CatalogueRequestParameter.ENTITY_NAME.getKey() +"="+splittedServletPath[4];
|
||||||
logger.debug("found entity name: "+eN);
|
logger.debug("found entity name: "+eN);
|
||||||
String encodedQuery = UrlEncoderUtil.encodeQuery(gcubeScope,eC,eN);
|
String encodedQuery = UrlEncoderUtil.encodeQuery(gcubeScope,eC,eN);
|
||||||
newURI+= "?" + PARAMETER_DIRECT_CATALOGUE_LINK + "=" + encodedQuery;
|
newURI+= "?" + PARAMETER_DIRECT_CATALOGUE_LINK + "=" + encodedQuery;
|
||||||
}else{
|
}else{
|
||||||
|
|
||||||
logger.info("Resolving an encrypted URL to catalogue...");
|
logger.info("Resolving an encrypted URL to catalogue...");
|
||||||
int lastSlash = requestURI.lastIndexOf(PATH_SEPARATOR);
|
int lastSlash = requestURI.lastIndexOf(PATH_SEPARATOR);
|
||||||
String toCatalogueLink = requestURI.substring(lastSlash + 1, requestURI.length());
|
String toCatalogueLink = requestURI.substring(lastSlash + 1, requestURI.length());
|
||||||
|
@ -128,7 +163,8 @@ public class UriResolverRewriteFilter implements Filter{
|
||||||
|
|
||||||
//chain.doFilter(multiReadRequest, response);
|
//chain.doFilter(multiReadRequest, response);
|
||||||
}else{
|
}else{
|
||||||
//IS WORKSPACE REQUEST?
|
logger.debug("It is a request to workspace/storage");
|
||||||
|
//LAST CASE, IS WORKSPACE REQUEST?
|
||||||
if (queryString == null) { // IS A /XXXXX
|
if (queryString == null) { // IS A /XXXXX
|
||||||
logger.debug("QueryString is null, is It a new SMP public uri by ID?");
|
logger.debug("QueryString is null, is It a new SMP public uri by ID?");
|
||||||
int lastSlash = requestURI.lastIndexOf(PATH_SEPARATOR);
|
int lastSlash = requestURI.lastIndexOf(PATH_SEPARATOR);
|
||||||
|
@ -151,7 +187,10 @@ public class UriResolverRewriteFilter implements Filter{
|
||||||
chain.doFilter(multiReadRequest, response);
|
chain.doFilter(multiReadRequest, response);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the scope.
|
* Gets the scope.
|
||||||
|
|
|
@ -17,6 +17,7 @@ import org.apache.commons.httpclient.HttpStatus;
|
||||||
import org.apache.commons.io.IOUtils;
|
import org.apache.commons.io.IOUtils;
|
||||||
import org.gcube.common.encryption.StringEncrypter;
|
import org.gcube.common.encryption.StringEncrypter;
|
||||||
import org.gcube.common.scope.api.ScopeProvider;
|
import org.gcube.common.scope.api.ScopeProvider;
|
||||||
|
import org.gcube.datatransfer.resolver.ResourceCatalogueCodes;
|
||||||
import org.gcube.datatransfer.resolver.UriResolverRewriteFilter;
|
import org.gcube.datatransfer.resolver.UriResolverRewriteFilter;
|
||||||
import org.json.JSONArray;
|
import org.json.JSONArray;
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
|
@ -264,7 +265,7 @@ public class CatalogueResolver extends HttpServlet{
|
||||||
}
|
}
|
||||||
|
|
||||||
String buildLink = getServerURL(req);
|
String buildLink = getServerURL(req);
|
||||||
buildLink += req.getRequestURI();
|
//buildLink += req.getRequestURI(); //AVOIDNG TO ADD THE SERVLET NAME: 'catalogue', THERE IS THE URL REWRITE USED FOR 'uri-resolver'
|
||||||
|
|
||||||
String clearURL = cer.getValueOfParameter(CatalogueRequestParameter.CLEAR_URL.getKey());
|
String clearURL = cer.getValueOfParameter(CatalogueRequestParameter.CLEAR_URL.getKey());
|
||||||
|
|
||||||
|
@ -281,8 +282,16 @@ public class CatalogueResolver extends HttpServlet{
|
||||||
logger.info("Clear URL is: "+bClearURL);
|
logger.info("Clear URL is: "+bClearURL);
|
||||||
if(bClearURL){
|
if(bClearURL){
|
||||||
|
|
||||||
String lastContext = scope.substring(scope.lastIndexOf("/")+1, scope.length());
|
String vreName = scope.substring(scope.lastIndexOf("/")+1, scope.length());
|
||||||
buildLink+=PATH_SEPARATOR+lastContext+PATH_SEPARATOR+cer.getValueOfParameter(CatalogueRequestParameter.ENTITY_CONTEXT.getKey())+PATH_SEPARATOR+cer.getValueOfParameter(CatalogueRequestParameter.ENTITY_NAME.getKey());
|
//buildLink+=PATH_SEPARATOR+vreName+PATH_SEPARATOR+cer.getValueOfParameter(CatalogueRequestParameter.ENTITY_CONTEXT.getKey())+PATH_SEPARATOR+cer.getValueOfParameter(CatalogueRequestParameter.ENTITY_NAME.getKey());
|
||||||
|
String econtext = cer.getValueOfParameter(CatalogueRequestParameter.ENTITY_CONTEXT.getKey());
|
||||||
|
ResourceCatalogueCodes rc = ResourceCatalogueCodes.valueOfCodeValue(econtext);
|
||||||
|
if(rc==null){
|
||||||
|
logger.error("Entity context is null/malformed");
|
||||||
|
sendError(resp, HttpStatus.SC_INTERNAL_SERVER_ERROR, "Error during generating Data Catalogue Link, the entity context passed is not recognized. Is it malformed?");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
buildLink += PATH_SEPARATOR+rc.getId()+PATH_SEPARATOR+vreName+PATH_SEPARATOR+cer.getValueOfParameter(CatalogueRequestParameter.ENTITY_NAME.getKey());
|
||||||
logger.info("Writing Decoded Catalogue Link: "+buildLink);
|
logger.info("Writing Decoded Catalogue Link: "+buildLink);
|
||||||
}else{
|
}else{
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,7 @@ import org.gcube.spatial.data.geonetwork.LoginLevel;
|
||||||
import org.gcube.spatial.data.geonetwork.configuration.Configuration;
|
import org.gcube.spatial.data.geonetwork.configuration.Configuration;
|
||||||
import org.gcube.spatial.data.geonetwork.model.Account;
|
import org.gcube.spatial.data.geonetwork.model.Account;
|
||||||
import org.gcube.spatial.data.geonetwork.model.Account.Type;
|
import org.gcube.spatial.data.geonetwork.model.Account.Type;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -22,20 +23,21 @@ public class GeonetworkQueryTest {
|
||||||
|
|
||||||
//private String[] scopes = {"/gcube/devNext/NextNext"};
|
//private String[] scopes = {"/gcube/devNext/NextNext"};
|
||||||
|
|
||||||
private String[] scopesProd = {"/d4science.research-infrastructures.eu/gCubeApps/BiodiversityLab"};
|
//private String[] scopesProd = {"/d4science.research-infrastructures.eu/gCubeApps/BiodiversityLab"};
|
||||||
|
|
||||||
private LoginLevel loginLevel = LoginLevel.ADMIN;
|
private String[] scopesProd = {"/d4science.research-infrastructures.eu/gCubeApps/SIASPA"};
|
||||||
|
|
||||||
|
private LoginLevel loginLevel = LoginLevel.CKAN;
|
||||||
|
|
||||||
private Type accountType = Type.SCOPE;
|
private Type accountType = Type.SCOPE;
|
||||||
|
|
||||||
//@Test
|
@Test
|
||||||
public void getCount() throws Exception{
|
public void getCount() throws Exception{
|
||||||
try{
|
try{
|
||||||
for(String scope:scopesProd){
|
for(String scope:scopesProd){
|
||||||
ScopeProvider.instance.set(scope);
|
ScopeProvider.instance.set(scope);
|
||||||
GeoNetworkPublisher reader=GeoNetwork.get();
|
GeoNetworkPublisher reader=GeoNetwork.get();
|
||||||
|
|
||||||
|
|
||||||
Configuration config = reader.getConfiguration();
|
Configuration config = reader.getConfiguration();
|
||||||
Account account=config.getScopeConfiguration().getAccounts().get(accountType);
|
Account account=config.getScopeConfiguration().getAccounts().get(accountType);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue