Added code to render docs

This commit is contained in:
Luca Frosini 2022-09-26 10:50:10 +02:00
parent 6ef47a947e
commit 6b5c3fb267
3 changed files with 59 additions and 5 deletions

View File

@ -6,6 +6,7 @@
<include pattern="org.gcube.gcat.rest.*" /> <include pattern="org.gcube.gcat.rest.*" />
<exclude pattern="org.gcube.gcat.*" /> <exclude pattern="org.gcube.gcat.*" />
<exclude pattern="org.gcube.gcat.rest.Docs" /> <exclude pattern="org.gcube.gcat.rest.Docs" />
<exclude pattern="org.gcube.gcat.rest.ApiDocs" />
</api-classes> </api-classes>
<modules> <modules>
<gwt-json-overlay disabled="true " /> <gwt-json-overlay disabled="true " />

View File

@ -0,0 +1,52 @@
package org.gcube.gcat.rest;
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.InternalServerErrorException;
import javax.ws.rs.Path;
import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.Context;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* @author Luca Frosini (ISTI-CNR)
*/
@Path("api-docs")
public class ApiDocs {
private static Logger logger = LoggerFactory.getLogger(ApiDocs.class);
@GET
@Path("{any: .*}")
public InputStream toDoc(@Context HttpServletRequest req) throws WebApplicationException {
logger.trace("Called method to redirect to api-docs/index.html");
String pathInfo = req.getPathInfo();
try {
if (pathInfo.endsWith("/api-docs")) {
pathInfo += "/index.html";
}
if (pathInfo.endsWith("/api-docs/")) {
pathInfo += "index.html";
}
logger.info("redirecting to {}", pathInfo);
String realPath = req.getServletContext().getRealPath(pathInfo);
return new FileInputStream(new File(realPath));
} catch (Exception e) {
throw new InternalServerErrorException(e);
}
}
}

View File

@ -15,27 +15,28 @@ import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
/** /**
* @author Francesco Mangiacrapa (ISTI-CNR)
* @author Luca Frosini (ISTI-CNR) * @author Luca Frosini (ISTI-CNR)
*/ */
@Path("api-docs") @Path("docs")
public class Docs { public class Docs {
private static Logger logger = LoggerFactory.getLogger(Docs.class); private static Logger logger = LoggerFactory.getLogger(Docs.class);
@GET @GET
@Path("{any: .*}") @Path("{any: .*}")
public InputStream toDoc(@Context HttpServletRequest req) throws WebApplicationException { public InputStream toDoc(@Context HttpServletRequest req) throws WebApplicationException {
logger.trace("Called method to redirect to api-docs/index.html"); logger.trace("Called method to redirect to docs/index.html");
String pathInfo = req.getPathInfo(); String pathInfo = req.getPathInfo();
try { try {
if (pathInfo.endsWith("/api-docs")) { if (pathInfo.endsWith("/docs")) {
pathInfo += "/index.html"; pathInfo += "/index.html";
} }
if (pathInfo.endsWith("/api-docs/")) { if (pathInfo.endsWith("/docs/")) {
pathInfo += "index.html"; pathInfo += "index.html";
} }