Added query parameter as_url
This commit is contained in:
parent
a2216d237d
commit
dc3ea29ff3
|
@ -75,7 +75,7 @@ public class HTML_Page {
|
||||||
+ " }\n"
|
+ " }\n"
|
||||||
+ " } catch (error) {\n"
|
+ " } catch (error) {\n"
|
||||||
+ " console.log(\"no json response \" + response_object);\n"
|
+ " console.log(\"no json response \" + response_object);\n"
|
||||||
+ " console.log(\"error \" + error);\n"
|
+ " //console.log(\"error \" + error);\n"
|
||||||
+ " showError(\"Error when exporting PDF :-(\");\n"
|
+ " showError(\"Error when exporting PDF :-(\");\n"
|
||||||
+ " }\n"
|
+ " }\n"
|
||||||
+ "\n"
|
+ "\n"
|
||||||
|
|
|
@ -3,11 +3,13 @@ package org.gcube.datatransfer.resolver.services;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
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;
|
||||||
import javax.ws.rs.PathParam;
|
import javax.ws.rs.PathParam;
|
||||||
import javax.ws.rs.Produces;
|
import javax.ws.rs.Produces;
|
||||||
|
import javax.ws.rs.QueryParam;
|
||||||
import javax.ws.rs.WebApplicationException;
|
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;
|
||||||
|
@ -56,23 +58,31 @@ public class GeoportalExporter {
|
||||||
public static final String PATH_USECASE_ID = GeoportalResolver.PATH_USECASE_ID;
|
public static final String PATH_USECASE_ID = GeoportalResolver.PATH_USECASE_ID;
|
||||||
public static final String PATH_VRE_NAME = GeoportalResolver.PATH_VRE_NAME;
|
public static final String PATH_VRE_NAME = GeoportalResolver.PATH_VRE_NAME;
|
||||||
|
|
||||||
|
public static final String QUERY_PARAMETER_AS_URL = "as_url";
|
||||||
|
|
||||||
private static final Logger LOG = LoggerFactory.getLogger(GeoportalExporter.class);
|
private static final Logger LOG = LoggerFactory.getLogger(GeoportalExporter.class);
|
||||||
private static String helpURI = "https://wiki.gcube-system.org/gcube/URI_Resolver#Geoportal_Resolver";
|
private static String helpURI = "https://wiki.gcube-system.org/gcube/URI_Resolver#Geoportal_Resolver";
|
||||||
|
|
||||||
private static LinkedHashMap<String, FetchPDF> map = new LinkedHashMap<String, FetchPDF>();
|
private static LinkedHashMap<String, FetchPDF> map = new LinkedHashMap<String, FetchPDF>();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Enum ACCEPTED_EXPORT_TYPE.
|
||||||
|
*
|
||||||
|
* @author Francesco Mangiacrapa at ISTI-CNR francesco.mangiacrapa@isti.cnr.it
|
||||||
|
*
|
||||||
|
* Apr 22, 2024
|
||||||
|
*/
|
||||||
public enum ACCEPTED_EXPORT_TYPE {
|
public enum ACCEPTED_EXPORT_TYPE {
|
||||||
pdf
|
pdf
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Resolve geoportal no app def.
|
* Export.
|
||||||
*
|
*
|
||||||
* @param req the req
|
* @param req the req
|
||||||
* @param vreName the vre name
|
* @param export_type the export type
|
||||||
* @param exportType the export type
|
* @param ucdID the ucd ID
|
||||||
* @param ucdID the ucd ID
|
* @param projectID the project ID
|
||||||
* @param projectID the project ID
|
|
||||||
* @return the response
|
* @return the response
|
||||||
* @throws WebApplicationException the web application exception
|
* @throws WebApplicationException the web application exception
|
||||||
*/
|
*/
|
||||||
|
@ -80,8 +90,8 @@ public class GeoportalExporter {
|
||||||
@Path("/export/{type}/{usecase_id}/{project_id}")
|
@Path("/export/{type}/{usecase_id}/{project_id}")
|
||||||
@Produces({ MediaType.TEXT_HTML, MediaType.TEXT_PLAIN, MediaType.APPLICATION_OCTET_STREAM })
|
@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 {
|
@QueryParam(QUERY_PARAMETER_AS_URL) @Nullable String asURL) throws WebApplicationException {
|
||||||
|
|
||||||
String userAgentName = req.getHeader("User-Agent");
|
String userAgentName = req.getHeader("User-Agent");
|
||||||
|
|
||||||
|
@ -92,6 +102,13 @@ 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);
|
||||||
|
|
||||||
|
boolean getAsURL = false;
|
||||||
|
try {
|
||||||
|
getAsURL = Boolean.parseBoolean(asURL);
|
||||||
|
} catch (Exception e) {
|
||||||
|
// TODO: handle exception
|
||||||
|
}
|
||||||
|
|
||||||
checkExportType(req, export_type);
|
checkExportType(req, export_type);
|
||||||
|
|
||||||
boolean checked = false;
|
boolean checked = false;
|
||||||
|
@ -159,14 +176,20 @@ public class GeoportalExporter {
|
||||||
LOG.info("Serving request as client...");
|
LOG.info("Serving request as client...");
|
||||||
FileReference pdfRef = exportAsPDF(req, ucdID, projectID, null, context, user);
|
FileReference pdfRef = exportAsPDF(req, ucdID, projectID, null, context, user);
|
||||||
|
|
||||||
InputStream input = pdfRef.getStorageVolatileURL().openStream();
|
if (!getAsURL) {
|
||||||
StreamingOutput so = new SingleFileStreamingOutput(input);
|
//returning as stream
|
||||||
|
InputStream input = pdfRef.getStorageVolatileURL().openStream();
|
||||||
|
StreamingOutput so = new SingleFileStreamingOutput(input);
|
||||||
|
|
||||||
ResponseBuilder response = Response.ok(so)
|
ResponseBuilder response = Response.ok(so)
|
||||||
.header(ConstantsResolver.CONTENT_DISPOSITION,
|
.header(ConstantsResolver.CONTENT_DISPOSITION,
|
||||||
"inline; filename=\"" + pdfRef.getFileName() + "\"")
|
"inline; filename=\"" + pdfRef.getFileName() + "\"")
|
||||||
.header("Content-Type", pdfRef.getContentType());
|
.header("Content-Type", pdfRef.getContentType());
|
||||||
return response.build();
|
return response.build();
|
||||||
|
}else {
|
||||||
|
//returning as URI;
|
||||||
|
return Response.seeOther(pdfRef.getStorageVolatileURL().toURI()).build();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error("Error on performing export", e);
|
LOG.error("Error on performing export", e);
|
||||||
|
@ -182,6 +205,14 @@ public class GeoportalExporter {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Healthcheck.
|
||||||
|
*
|
||||||
|
* @param req the req
|
||||||
|
* @param export_type the export type
|
||||||
|
* @return the response
|
||||||
|
* @throws WebApplicationException the web application exception
|
||||||
|
*/
|
||||||
@GET
|
@GET
|
||||||
@Path("/export/{type}/healthcheck")
|
@Path("/export/{type}/healthcheck")
|
||||||
@Produces({ MediaType.TEXT_HTML, MediaType.TEXT_PLAIN })
|
@Produces({ MediaType.TEXT_HTML, MediaType.TEXT_PLAIN })
|
||||||
|
@ -224,6 +255,14 @@ public class GeoportalExporter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* View PDF.
|
||||||
|
*
|
||||||
|
* @param req the req
|
||||||
|
* @param pdfCode the pdf code
|
||||||
|
* @return the response
|
||||||
|
* @throws WebApplicationException the web application exception
|
||||||
|
*/
|
||||||
@GET
|
@GET
|
||||||
@Path("/view/{pdfCode}")
|
@Path("/view/{pdfCode}")
|
||||||
@Produces({ MediaType.TEXT_PLAIN, MediaType.TEXT_HTML })
|
@Produces({ MediaType.TEXT_PLAIN, MediaType.TEXT_HTML })
|
||||||
|
@ -309,6 +348,14 @@ public class GeoportalExporter {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check path parameter not null.
|
||||||
|
*
|
||||||
|
* @param req the req
|
||||||
|
* @param parameter the parameter
|
||||||
|
* @param value the value
|
||||||
|
* @throws BadRequestException the bad request exception
|
||||||
|
*/
|
||||||
public void checkPathParameterNotNull(HttpServletRequest req, String parameter, String value)
|
public void checkPathParameterNotNull(HttpServletRequest req, String parameter, String value)
|
||||||
throws BadRequestException {
|
throws BadRequestException {
|
||||||
if (value == null || value.isEmpty()) {
|
if (value == null || value.isEmpty()) {
|
||||||
|
@ -318,6 +365,14 @@ public class GeoportalExporter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check export type.
|
||||||
|
*
|
||||||
|
* @param req the req
|
||||||
|
* @param export_type the export type
|
||||||
|
* @return the accepted export type
|
||||||
|
* @throws BadRequestException the bad request exception
|
||||||
|
*/
|
||||||
public ACCEPTED_EXPORT_TYPE checkExportType(HttpServletRequest req, String export_type) throws BadRequestException {
|
public ACCEPTED_EXPORT_TYPE checkExportType(HttpServletRequest req, String export_type) throws BadRequestException {
|
||||||
ACCEPTED_EXPORT_TYPE exportType;
|
ACCEPTED_EXPORT_TYPE exportType;
|
||||||
try {
|
try {
|
||||||
|
@ -333,6 +388,18 @@ public class GeoportalExporter {
|
||||||
return exportType;
|
return exportType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Export as PDF.
|
||||||
|
*
|
||||||
|
* @param req the req
|
||||||
|
* @param profileID the profile ID
|
||||||
|
* @param projectID the project ID
|
||||||
|
* @param profileTitle the profile title
|
||||||
|
* @param context the context
|
||||||
|
* @param user the user
|
||||||
|
* @return the file reference
|
||||||
|
* @throws WebApplicationException the web application exception
|
||||||
|
*/
|
||||||
public FileReference exportAsPDF(HttpServletRequest req, String profileID, String projectID, String profileTitle,
|
public FileReference exportAsPDF(HttpServletRequest req, String profileID, String projectID, String profileTitle,
|
||||||
String context, User user) throws WebApplicationException {
|
String context, User user) throws WebApplicationException {
|
||||||
LOG.info("exportAsPDF for profileID: " + profileID + ", projectID: " + projectID + "called");
|
LOG.info("exportAsPDF for profileID: " + profileID + ", projectID: " + projectID + "called");
|
||||||
|
@ -370,6 +437,14 @@ public class GeoportalExporter {
|
||||||
return pdfRef;
|
return pdfRef;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the public links for.
|
||||||
|
*
|
||||||
|
* @param item the item
|
||||||
|
* @param context the context
|
||||||
|
* @return the public links for
|
||||||
|
* @throws Exception the exception
|
||||||
|
*/
|
||||||
public GeoportalItemReferences getPublicLinksFor(GeoportalItemReferences item, String context) throws Exception {
|
public GeoportalItemReferences getPublicLinksFor(GeoportalItemReferences item, String context) throws Exception {
|
||||||
LOG.info("getPublicLinksFor called for: " + item);
|
LOG.info("getPublicLinksFor called for: " + item);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue