uri-resolver/src/main/java/org/gcube/datatransfer/resolver/services/DocsGenerator.java

70 lines
1.8 KiB
Java
Raw Normal View History

/**
*
*/
package org.gcube.datatransfer.resolver.services;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import javax.servlet.http.HttpServletRequest;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.Context;
import org.gcube.datatransfer.resolver.services.error.ExceptionManager;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
2022-04-01 10:25:30 +02:00
* The Class DocsGenerator.
*
2022-03-24 17:33:54 +01:00
* @author Francesco Mangiacrapa at ISTI-CNR francesco.mangiacrapa@isti.cnr.it
*
2022-04-01 10:25:30 +02:00
* Apr 1, 2022
*/
2022-03-24 15:59:07 +01:00
@Path("docs")
2022-04-01 10:25:30 +02:00
public class DocsGenerator {
2022-04-01 10:25:30 +02:00
private static Logger logger = LoggerFactory.getLogger(DocsGenerator.class);
2022-03-24 17:33:54 +01:00
/**
* To doc.
*
* @param req the req
* @return the input stream
* @throws WebApplicationException the web application exception
*/
@GET
2022-03-24 16:20:26 +01:00
@Path("/{any: .*}")
2022-03-28 15:18:17 +02:00
public InputStream toDoc(@Context HttpServletRequest req) throws WebApplicationException {
2022-04-01 10:25:30 +02:00
logger.info(DocsGenerator.class.getSimpleName() + " toDoc called");
2022-03-24 15:59:07 +01:00
2022-03-28 15:18:17 +02:00
String pathInfo = req.getPathInfo();
logger.info("pathInfo {}", pathInfo);
2022-03-24 15:59:07 +01:00
try {
2022-04-01 10:25:30 +02:00
if (pathInfo.endsWith("/docs/")) {
2022-03-24 16:38:16 +01:00
pathInfo += "index.html";
2022-04-01 10:25:30 +02:00
}
2022-03-28 15:18:17 +02:00
logger.info("redirecting to {}", pathInfo);
String realPath = req.getServletContext().getRealPath(pathInfo);
return new FileInputStream(new File(realPath));
2022-03-24 15:59:07 +01:00
} catch (Exception e) {
if (!(e instanceof WebApplicationException)) {
// UNEXPECTED EXCEPTION managing it as WebApplicationException
2022-03-28 15:18:17 +02:00
String error = pathInfo + " not found. Please, contact the support!";
throw ExceptionManager.internalErrorException(req, error, this.getClass(), null);
}
2022-03-24 15:59:07 +01:00
// ALREADY MANAGED AS WebApplicationException
logger.error("Exception:", e);
throw (WebApplicationException) e;
}
}
2022-03-24 15:59:07 +01:00
}