Added code to render docs
This commit is contained in:
parent
6ef47a947e
commit
6b5c3fb267
|
@ -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 " />
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -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";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue