export_to_pdf #8

Merged
francesco.mangiacrapa merged 84 commits from export_to_pdf into master 2024-06-28 15:17:39 +02:00
3 changed files with 302 additions and 160 deletions
Showing only changes of commit 99cfe3976a - Show all commits

View File

@ -7,7 +7,7 @@ This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.htm
## [v2.10.0-SNAPSHOT] ## [v2.10.0-SNAPSHOT]
- GeoPortal-Resolver enhancement: implemented share link towards Geoportal Data-Entry facility [#27135] - GeoPortal-Resolver enhancement: implemented share link towards Geoportal Data-Entry facility [#27135]
- Added Geoportal Exporter as PDF [#26026] - Added Geoportal Exporter as PDF [#27274]
## [v2.9.0] ## [v2.9.0]

View File

@ -19,14 +19,19 @@ import javax.ws.rs.core.MultivaluedMap;
import javax.ws.rs.core.UriBuilder; import javax.ws.rs.core.UriBuilder;
import javax.ws.rs.ext.Provider; import javax.ws.rs.ext.Provider;
import org.gcube.common.authorization.library.provider.AccessTokenProvider;
import org.gcube.common.authorization.library.provider.SecurityTokenProvider; import org.gcube.common.authorization.library.provider.SecurityTokenProvider;
import org.gcube.common.authorization.utils.manager.SecretManager;
import org.gcube.common.authorization.utils.manager.SecretManagerProvider;
import org.gcube.common.authorization.utils.secret.GCubeSecret;
import org.gcube.common.authorization.utils.secret.JWTSecret;
import org.gcube.common.authorization.utils.secret.Secret;
import org.gcube.common.scope.api.ScopeProvider; import org.gcube.common.scope.api.ScopeProvider;
import org.gcube.datatransfer.resolver.ConstantsResolver; import org.gcube.datatransfer.resolver.ConstantsResolver;
import org.gcube.datatransfer.resolver.UriResolverServices; import org.gcube.datatransfer.resolver.UriResolverServices;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
/** /**
* The Class RequestHandler. * The Class RequestHandler.
* *
@ -44,7 +49,8 @@ public class RequestHandler implements ContainerRequestFilter, ContainerResponse
private static final Logger log = LoggerFactory.getLogger(RequestHandler.class); private static final Logger log = LoggerFactory.getLogger(RequestHandler.class);
@Context ServletContext context; @Context
ServletContext context;
@Context @Context
HttpServletRequest webRequest; HttpServletRequest webRequest;
@ -55,17 +61,28 @@ public class RequestHandler implements ContainerRequestFilter, ContainerResponse
@Context @Context
ResourceContext resourceContext; ResourceContext resourceContext;
/* (non-Javadoc) /**
* @see javax.ws.rs.container.ContainerRequestFilter#filter(javax.ws.rs.container.ContainerRequestContext) * Filter.
*
* @param reqContext the req context
* @throws IOException Signals that an I/O exception has occurred.
*/
/*
* (non-Javadoc)
*
* @see
* javax.ws.rs.container.ContainerRequestFilter#filter(javax.ws.rs.container.
* ContainerRequestContext)
*/ */
@Override @Override
public void filter(ContainerRequestContext reqContext) throws IOException { public void filter(ContainerRequestContext reqContext) throws IOException {
log.info(RequestHandler.class.getSimpleName() +" Request called"); log.info(RequestHandler.class.getSimpleName() + " Request called");
setSecretManager(reqContext);
if(SecurityTokenProvider.instance.get()==null) if (SecurityTokenProvider.instance.get() == null)
SecurityTokenProvider.instance.set(context.getInitParameter(ROOT_APP_TOKEN)); SecurityTokenProvider.instance.set(context.getInitParameter(ROOT_APP_TOKEN));
if(ScopeProvider.instance.get()==null) if (ScopeProvider.instance.get() == null)
ScopeProvider.instance.set(context.getInitParameter(ROOT_SCOPE)); ScopeProvider.instance.set(context.getInitParameter(ROOT_SCOPE));
log.info("Token and Scope Provider set called"); log.info("Token and Scope Provider set called");
@ -76,19 +93,17 @@ public class RequestHandler implements ContainerRequestFilter, ContainerResponse
String path = reqContext.getUriInfo().getPath(); String path = reqContext.getUriInfo().getPath();
log.debug("The path is: {}", path); log.debug("The path is: {}", path);
//HOW TO READ THE QUERY STRING // HOW TO READ THE QUERY STRING
/*MultivaluedMap<String, String> queryParameters = reqContext.getUriInfo().getQueryParameters(); /*
String queryString = ""; * MultivaluedMap<String, String> queryParameters =
try { * reqContext.getUriInfo().getQueryParameters(); String queryString = ""; try {
queryString = Util.toQueryString(queryParameters); * queryString = Util.toQueryString(queryParameters); }catch (Exception e) {
}catch (Exception e) { * //silent
//silent * log.warn("Error on reading the query string, trying to continue..."); }
log.warn("Error on reading the query string, trying to continue..."); * log.debug("The query string is: {}", queryString);
}
log.debug("The query string is: {}", queryString);
*/ */
if(path==null || path.isEmpty()) { if (path == null || path.isEmpty()) {
log.debug("The path is null or empty, redirecting to /index"); log.debug("The path is null or empty, redirecting to /index");
URI newRequestURI = reqContext.getUriInfo().getBaseUriBuilder().path("/index").build(); URI newRequestURI = reqContext.getUriInfo().getBaseUriBuilder().path("/index").build();
reqContext.setRequestUri(newRequestURI); reqContext.setRequestUri(newRequestURI);
@ -100,33 +115,36 @@ public class RequestHandler implements ContainerRequestFilter, ContainerResponse
String candidateResource = ""; String candidateResource = "";
try { try {
splittePath = path.split("/"); splittePath = path.split("/");
if(splittePath!=null && splittePath.length>0) { if (splittePath != null && splittePath.length > 0) {
String requestedResourceName = splittePath[0]; String requestedResourceName = splittePath[0];
log.debug("The resource requested is: {}",requestedResourceName); log.debug("The resource requested is: {}", requestedResourceName);
if(requestedResourceName!=null && !requestedResourceName.isEmpty()) { if (requestedResourceName != null && !requestedResourceName.isEmpty()) {
for (String resource : listOfPath) { for (String resource : listOfPath) {
log.trace("Is resource '{}' starting with '{}' ?",resource,requestedResourceName); log.trace("Is resource '{}' starting with '{}' ?", resource, requestedResourceName);
if(resource.startsWith(requestedResourceName)) { if (resource.startsWith(requestedResourceName)) {
log.trace("Yes it starts!"); log.trace("Yes it starts!");
candidateResource = requestedResourceName; candidateResource = requestedResourceName;
log.info("The candidate resource to manage the request is: {}",candidateResource); log.info("The candidate resource to manage the request is: {}", candidateResource);
resourceToRedirectFound = true; resourceToRedirectFound = true;
break; break;
} }
} }
//Try to manage as Catalogue Request ctlg, ctlg-p, etc. // Try to manage as Catalogue Request ctlg, ctlg-p, etc.
if(!resourceToRedirectFound) { if (!resourceToRedirectFound) {
log.info("Trying to manage as hard-coded case among cases: {}", Arrays.asList(ConstantsResolver.resourcesHardCoded).toString()); log.info("Trying to manage as hard-coded case among cases: {}",
Arrays.asList(ConstantsResolver.resourcesHardCoded).toString());
String[] hardCode = ConstantsResolver.resourcesHardCoded; String[] hardCode = ConstantsResolver.resourcesHardCoded;
for (String resource : hardCode) { for (String resource : hardCode) {
log.trace("Is requested resource '{}' starting with hard-coded resource '{}'?",requestedResourceName,resource); log.trace("Is requested resource '{}' starting with hard-coded resource '{}'?",
if(requestedResourceName.startsWith(resource)) { requestedResourceName, resource);
if (requestedResourceName.startsWith(resource)) {
log.trace("Yes it starts!"); log.trace("Yes it starts!");
candidateResource = resource; candidateResource = resource;
log.info("The candidate resource to manage the request is the hard-coded resource: {}",candidateResource); log.info("The candidate resource to manage the request is the hard-coded resource: {}",
candidateResource);
resourceToRedirectFound = true; resourceToRedirectFound = true;
break; break;
} }
@ -134,29 +152,33 @@ public class RequestHandler implements ContainerRequestFilter, ContainerResponse
} }
}else } else
log.warn("It was not possible to get the resource name from the splitted path {}. No action performed", path); log.warn(
}else { "It was not possible to get the resource name from the splitted path {}. No action performed",
path);
} else {
log.warn("It was not possible to split the path {}. No action performed", path); log.warn("It was not possible to split the path {}. No action performed", path);
} }
}catch (Exception e) { } catch (Exception e) {
log.error("Error trying to retrieve the service able to manage the request. No action performed", e); log.error("Error trying to retrieve the service able to manage the request. No action performed", e);
} }
if(resourceToRedirectFound) { if (resourceToRedirectFound) {
log.debug("The input request '{}' can be managed by the service '{}'. No redirect performed", path, candidateResource); log.debug("The input request '{}' can be managed by the service '{}'. No redirect performed", path,
}else { candidateResource);
} else {
log.info("No resource/service found to manage the input request '{}'", path); log.info("No resource/service found to manage the input request '{}'", path);
String newPath = String.format("/%s/%s", ConstantsResolver.defaultServiceToRedirect,path); String newPath = String.format("/%s/%s", ConstantsResolver.defaultServiceToRedirect, path);
//log.debug("The path to redirect is '{}'", newPath); // log.debug("The path to redirect is '{}'", newPath);
//URI newRequestURI = reqContext.getUriInfo().getBaseUriBuilder().path(newPath).build(); // URI newRequestURI =
// reqContext.getUriInfo().getBaseUriBuilder().path(newPath).build();
UriBuilder uriBuilder = reqContext.getUriInfo().getBaseUriBuilder(); UriBuilder uriBuilder = reqContext.getUriInfo().getBaseUriBuilder();
//ADDING THE INPUT QUERY STRING // ADDING THE INPUT QUERY STRING
MultivaluedMap<String, String> queryParameters = reqContext.getUriInfo().getQueryParameters(); MultivaluedMap<String, String> queryParameters = reqContext.getUriInfo().getQueryParameters();
for (String param : queryParameters.keySet()) { for (String param : queryParameters.keySet()) {
List<String> values = queryParameters.get(param); List<String> values = queryParameters.get(param);
if(values!=null && !values.isEmpty()) if (values != null && !values.isEmpty())
uriBuilder.queryParam(param,values.toArray()); uriBuilder.queryParam(param, values.toArray());
} }
URI newRequestURI = uriBuilder.path(newPath).build(); URI newRequestURI = uriBuilder.path(newPath).build();
@ -165,17 +187,69 @@ public class RequestHandler implements ContainerRequestFilter, ContainerResponse
} }
} }
/* (non-Javadoc) /**
* @see javax.ws.rs.container.ContainerResponseFilter#filter(javax.ws.rs.container.ContainerRequestContext, javax.ws.rs.container.ContainerResponseContext) * Filter.
*
* @param requestContext the request context
* @param responseContext the response context
* @throws IOException Signals that an I/O exception has occurred.
*/
/*
* (non-Javadoc)
*
* @see
* javax.ws.rs.container.ContainerResponseFilter#filter(javax.ws.rs.container.
* ContainerRequestContext, javax.ws.rs.container.ContainerResponseContext)
*/ */
@Override @Override
public void filter(ContainerRequestContext requestContext, ContainerResponseContext responseContext) public void filter(ContainerRequestContext requestContext, ContainerResponseContext responseContext)
throws IOException { throws IOException {
log.info(RequestHandler.class.getSimpleName() +" Response called"); log.info(RequestHandler.class.getSimpleName() + " Response called");
SecurityTokenProvider.instance.reset(); SecurityTokenProvider.instance.reset();
ScopeProvider.instance.reset(); ScopeProvider.instance.reset();
log.info("Token and Scope Provider reset called"); log.debug("Token and Scope Provider reset called");
resetScretManager(requestContext, responseContext);
} }
/**
* Reset scret manager.
*
* @param requestContext the request context
* @param responseContext the response context
* @throws IOException Signals that an I/O exception has occurred.
*/
private void resetScretManager(ContainerRequestContext requestContext, ContainerResponseContext responseContext)
throws IOException {
log.debug("SecreteManager instance remove");
SecretManagerProvider.instance.remove();
}
/**
* Sets the secret manager.
*
* @param requestContext the new secret manager
* @throws IOException Signals that an I/O exception has occurred.
*/
private void setSecretManager(ContainerRequestContext requestContext) throws IOException {
log.debug("setSecretManager called");
SecretManagerProvider.instance.remove();
SecretManager secretManager = new SecretManager();
String token = AccessTokenProvider.instance.get();
if (token != null) {
Secret secret = new JWTSecret(token);
secretManager.addSecret(secret);
}
token = SecurityTokenProvider.instance.get();
if (token != null) {
Secret secret = new GCubeSecret(token);
secretManager.addSecret(secret);
}
SecretManagerProvider.instance.set(secretManager);
}
} }

View File

@ -1,5 +1,8 @@
package org.gcube.datatransfer.resolver.services; package org.gcube.datatransfer.resolver.services;
import java.io.InputStream;
import java.net.URL;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import javax.ws.rs.GET; import javax.ws.rs.GET;
import javax.ws.rs.Path; import javax.ws.rs.Path;
@ -9,17 +12,23 @@ import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.Context; import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType; import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response; import javax.ws.rs.core.Response;
import javax.ws.rs.core.Response.ResponseBuilder;
import javax.ws.rs.core.Response.Status; import javax.ws.rs.core.Response.Status;
import javax.ws.rs.core.StreamingOutput;
import org.gcube.application.geoportalcommon.GeoportalCommon;
import org.gcube.application.geoportalcommon.shared.GeoportalItemReferences;
import org.gcube.application.geoportalcommon.shared.GeoportalItemReferences.SHARE_LINK_TO;
import org.gcube.application.geoportaldatamapper.exporter.Geoportal_PDF_Exporter; import org.gcube.application.geoportaldatamapper.exporter.Geoportal_PDF_Exporter;
import org.gcube.application.geoportaldatamapper.shared.ExporterProjectSource; import org.gcube.application.geoportaldatamapper.shared.ExporterProjectSource;
import org.gcube.application.geoportaldatamapper.shared.FileReference;
import org.gcube.common.authorization.utils.manager.SecretManager; import org.gcube.common.authorization.utils.manager.SecretManager;
import org.gcube.common.authorization.utils.manager.SecretManagerProvider; import org.gcube.common.authorization.utils.manager.SecretManagerProvider;
import org.gcube.common.authorization.utils.user.User;
import org.gcube.datatransfer.resolver.ConstantsResolver; import org.gcube.datatransfer.resolver.ConstantsResolver;
import org.gcube.datatransfer.resolver.geoportal.TargetAppGeoportalCodes;
import org.gcube.datatransfer.resolver.services.GeoportalResolver.RESOLVE_AS;
import org.gcube.datatransfer.resolver.services.error.ExceptionManager; import org.gcube.datatransfer.resolver.services.error.ExceptionManager;
import org.gcube.datatransfer.resolver.services.exceptions.BadRequestException; import org.gcube.datatransfer.resolver.services.exceptions.BadRequestException;
import org.gcube.datatransfer.resolver.util.SingleFileStreamingOutput;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -59,11 +68,13 @@ public class GeoportalExporter {
*/ */
@GET @GET
@Path("/export/{type}/{usecase_id}/{project_id}") @Path("/export/{type}/{usecase_id}/{project_id}")
@Produces({ MediaType.TEXT_HTML, MediaType.TEXT_PLAIN }) @Produces({ MediaType.TEXT_HTML, MediaType.TEXT_PLAIN, MediaType.APPLICATION_OCTET_STREAM })
public Response export(@Context HttpServletRequest req, @PathParam(EXPORT_TYPE) String export_type, public Response export(@Context HttpServletRequest req, @PathParam(EXPORT_TYPE) String export_type,
@PathParam(PATH_USECASE_ID) String ucdID, @PathParam(PATH_PROJECT_ID) String projectID) @PathParam(PATH_USECASE_ID) String ucdID, @PathParam(PATH_PROJECT_ID) String projectID)
throws WebApplicationException { throws WebApplicationException {
String userAgentName = req.getHeader("User-Agent");
LOG.info(this.getClass().getSimpleName() + " export - GET starts..."); LOG.info(this.getClass().getSimpleName() + " export - GET starts...");
LOG.debug("params are: exportType: {}, ucdID: {}, projectID: {}", export_type, ucdID, projectID); LOG.debug("params are: exportType: {}, ucdID: {}, projectID: {}", export_type, ucdID, projectID);
@ -71,7 +82,7 @@ public class GeoportalExporter {
checkPathParameterNotNull(req, PATH_USECASE_ID, ucdID); checkPathParameterNotNull(req, PATH_USECASE_ID, ucdID);
checkPathParameterNotNull(req, PATH_PROJECT_ID, projectID); checkPathParameterNotNull(req, PATH_PROJECT_ID, projectID);
ACCEPTED_EXPORT_TYPE exportType = toKnowExportType(req, export_type); checkExportType(req, export_type);
try { try {
@ -87,43 +98,56 @@ public class GeoportalExporter {
Geoportal_PDF_Exporter pdfExporter = new Geoportal_PDF_Exporter(); Geoportal_PDF_Exporter pdfExporter = new Geoportal_PDF_Exporter();
boolean checked = pdfExporter.checkConfig(); boolean checked = pdfExporter.checkConfig();
if (!checked) // ExporterProjectSource exporterSource = new ExporterProjectSource();
return Response.status(Status.NOT_FOUND).build(); // RESOLVE_AS resolveAs = RESOLVE_AS.PUBLIC;
// // #NB SET USERNAME = null to export with PUBLIC ACCESS
ExporterProjectSource exporterSource = new ExporterProjectSource(); // if (!cm.getUser().isApplication()) {
RESOLVE_AS resolveAs = RESOLVE_AS.PUBLIC; // // here the token is of an user
// #NB SET USERNAME = null to export with PUBLIC ACCESS // resolveAs = RESOLVE_AS.PRIVATE;
if (!cm.getUser().isApplication()) { // exporterSource.setAccountname(user.getUsername());
// here the token is of an user // }
resolveAs = RESOLVE_AS.PRIVATE; //
exporterSource.setAccountname(user.getUsername()); // exporterSource.setScope(context);
} // exporterSource.setProjectID(projectID);
// exporterSource.setProfileID(ucdID);
exporterSource.setScope(context); //
exporterSource.setProjectID(projectID); // String vreName = context.substring(context.lastIndexOf("/") + 1, context.length());
exporterSource.setProfileID(ucdID); // LOG.info("Requesting gis link to vre {}", vreName);
// Response theReponseWithLink = new GeoportalResolver().genericResolveLink(req,
String vreName = context.substring(context.lastIndexOf("/") + 1, context.length()); // TargetAppGeoportalCodes.GEO_DV, vreName, ucdID, projectID, resolveAs.name());
LOG.info("Requesting gis link to vre {}", vreName); // String theGisLink = theReponseWithLink.getEntity().toString();
Response theReponseWithLink = new GeoportalResolver().genericResolveLink(req, // LOG.info("Gis link returned {}", theGisLink);
TargetAppGeoportalCodes.GEO_DV, vreName, ucdID, projectID, resolveAs.name()); // exporterSource.setGisLink(theGisLink);
String theGisLink = theReponseWithLink.getEntity().toString();
LOG.info("Gis link returned {}", theGisLink);
exporterSource.setGisLink(theGisLink);
if (checked) { if (checked) {
String pdfURL = null;
if (userAgentName != null) {
LOG.info("Serving request as User-Agent {}", userAgentName);
String entity = entityHTMLMessage("Exporting as PDF...", "The project with " + projectID, true); String entity = entityHTMLMessage("Exporting as PDF...", "The project with " + projectID, true);
return Response.ok(entity).encoding("UTF-8").header(ConstantsResolver.CONTENT_TYPE, "text/html") return Response.ok(entity).encoding("UTF-8").header(ConstantsResolver.CONTENT_TYPE, "text/html")
.build(); .build();
} else { } else {
return Response.status(Status.NOT_FOUND).entity(GeoportalExporter.class.getSimpleName() + " Config KO") LOG.info("Serving request as client...");
FileReference pdfRef = exportAsPDF(req, ucdID, projectID, null, context, user);
InputStream input = new URL(pdfURL).openStream();
StreamingOutput so = new SingleFileStreamingOutput(input);
ResponseBuilder response = Response.ok(so)
.header(ConstantsResolver.CONTENT_DISPOSITION,
"inline; filename=\"" + pdfRef.getFileName() + "\"")
.header("Content-Type", pdfRef.getContentType());
return response.build();
}
} else {
return Response.status(Status.NOT_FOUND)
.entity(GeoportalExporter.class.getSimpleName() + " Config not found in the context " + context)
.type(MediaType.TEXT_PLAIN).build(); .type(MediaType.TEXT_PLAIN).build();
} }
} catch (Exception e) { } catch (Exception e) {
LOG.error("Error on performing healthcheck", e); LOG.error("Error on performing export", e);
throw ExceptionManager.internalErrorException(req, throw ExceptionManager.internalErrorException(req, "Sorry, error occurred when exporting the project",
"Error when performing " + GeoportalExporter.class.getSimpleName() + " healthcheck",
this.getClass(), helpURI); this.getClass(), helpURI);
} }
@ -140,7 +164,7 @@ public class GeoportalExporter {
checkPathParameterNotNull(req, EXPORT_TYPE, export_type); checkPathParameterNotNull(req, EXPORT_TYPE, export_type);
ACCEPTED_EXPORT_TYPE exportType = toKnowExportType(req, export_type); checkExportType(req, export_type);
try { try {
@ -183,8 +207,7 @@ public class GeoportalExporter {
} }
} }
public ACCEPTED_EXPORT_TYPE toKnowExportType(HttpServletRequest req, String export_type) public ACCEPTED_EXPORT_TYPE checkExportType(HttpServletRequest req, String export_type) throws BadRequestException {
throws BadRequestException {
ACCEPTED_EXPORT_TYPE exportType; ACCEPTED_EXPORT_TYPE exportType;
try { try {
exportType = ACCEPTED_EXPORT_TYPE.valueOf(export_type); exportType = ACCEPTED_EXPORT_TYPE.valueOf(export_type);
@ -199,6 +222,67 @@ public class GeoportalExporter {
return exportType; return exportType;
} }
public FileReference exportAsPDF(HttpServletRequest req, String profileID, String projectID, String profileTitle,
String context, User user) throws WebApplicationException {
LOG.info("exportAsPDF for profileID: " + profileID + ", projectID: " + projectID + "called");
LOG.info("exportAsPDF context is {}, user is {}", context, user);
FileReference pdfRef = null;
try {
Geoportal_PDF_Exporter gpdfe = new Geoportal_PDF_Exporter();
ExporterProjectSource exportSource = new ExporterProjectSource();
exportSource.setProfileID(profileID);
exportSource.setProfileTitle(profileTitle);
exportSource.setProjectID(projectID);
exportSource.setScope(context);
GeoportalItemReferences geoportalItemReferences = new GeoportalItemReferences(projectID, profileID,
SHARE_LINK_TO.DATA_VIEWER);
GeoportalItemReferences gir = getPublicLinksFor(geoportalItemReferences, context);
if (user.isApplication()) {
exportSource.setGisLink(gir.getOpenLink().getShortURL());
exportSource.setAccountname(null);
} else {
exportSource.setGisLink(gir.getRestrictedLink().getShortURL());
exportSource.setAccountname(user.getUsername());
}
pdfRef = gpdfe.createPDFFile(exportSource);
} catch (Exception e1) {
LOG.error("Error occurred when exporting the project", e1);
throw ExceptionManager.internalErrorException(req, "Sorry, an error occurred when exporting the project",
this.getClass(), helpURI);
}
return pdfRef;
}
public GeoportalItemReferences getPublicLinksFor(GeoportalItemReferences item, String context) throws Exception {
LOG.info("getPublicLinksFor called for: " + item);
try {
if (item == null)
throw new Exception("Bad request, the item is null");
if (item.getProjectID() == null)
throw new Exception("Bad request, the projectID is null");
if (item.getProfileID() == null)
throw new Exception("Bad request, the profileID is null");
GeoportalCommon gc = new GeoportalCommon();
return gc.getPublicLinksFor(context, item, true);
} catch (Exception e) {
LOG.error("Error on getPublicLinksFor for: " + item, e);
throw new Exception("Share link not available for this item. Try later or contact the support. Error: "
+ e.getMessage());
}
}
/** /**
* Sets the HTML message. * Sets the HTML message.
* *
@ -210,29 +294,13 @@ public class GeoportalExporter {
protected String entityHTMLMessage(String action, String message, boolean waiting) { protected String entityHTMLMessage(String action, String message, boolean waiting) {
String html = "<html>" + "<head>" + "<meta http-equiv=\"content-type\" content=\"text/html; charset=UTF-8\">" String html = "<html>" + "<head>" + "<meta http-equiv=\"content-type\" content=\"text/html; charset=UTF-8\">"
+ "<style>" + "<style>" + "html, body {\n" + " margin: 10px;\n" + " width: 100%;\n" + " height: 100%;\n"
+ "html, body {\n" + " display: table\n" + "}\n" + "#content {\n" + " position: absolute;\n" + " left: 50%;\n"
+ " margin: 10px;\n" + " top: 50%;\n" + " -webkit-transform: translate(-50%, -50%);\n"
+ " width: 100%;\n" + " transform: translate(-50%, -50%);\n" + " text-align: center;\n" + "}" + "#message {\n"
+ " height: 100%;\n" + " color:gray;" + " font-size: 24px;" + "}" + "</style>"
+ " display: table\n"
+ "}\n"
+ "#content {\n"
+ " position: absolute;\n"
+ " left: 50%;\n"
+ " top: 50%;\n"
+ " -webkit-transform: translate(-50%, -50%);\n"
+ " transform: translate(-50%, -50%);\n"
+ " text-align: center;\n"
+ "}"
+ "#message {\n"
+ " color:gray;"
+ " font-size: 24px;"
+ "}"
+ "</style>"
+ "<title>D4Science Geoportal - Action</title>" + "</head>" + "<body>"; + "<title>D4Science Geoportal - Action</title>" + "</head>" + "<body>";
html += "<img alt=\"D4Science Logo\" src=\"https://services.d4science.org/image/layout_set_logo?img_id=32727\"><br />"; html += "<img alt=\"D4Science Logo\" src=\"https://services.d4science.org/image/layout_set_logo?img_id=32727\"><br />";
html += "<div id=\"content\">"; html += "<div id=\"content\">";