X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=org.argeo.app.servlet.odk%2Fsrc%2Forg%2Fargeo%2Fapp%2Fservlet%2Fodk%2FOdkFormListServlet.java;h=41a3039a3df72909bba6ee1dbd5ce1f7ae6b4395;hb=615c2201dc78d0c103b25f0f273ff2e023eb87a1;hp=21b342112df1423a5b1524543a55082862990d35;hpb=6e56ffa34cb02ab04d028423aea342e3dfed4358;p=gpl%2Fargeo-suite.git
diff --git a/org.argeo.app.servlet.odk/src/org/argeo/app/servlet/odk/OdkFormListServlet.java b/org.argeo.app.servlet.odk/src/org/argeo/app/servlet/odk/OdkFormListServlet.java
index 21b3421..41a3039 100644
--- a/org.argeo.app.servlet.odk/src/org/argeo/app/servlet/odk/OdkFormListServlet.java
+++ b/org.argeo.app.servlet.odk/src/org/argeo/app/servlet/odk/OdkFormListServlet.java
@@ -23,6 +23,7 @@ import org.argeo.app.odk.OrxListName;
import org.argeo.app.odk.OrxManifestName;
import org.argeo.cms.auth.RemoteAuthUtils;
import org.argeo.cms.servlet.ServletHttpRequest;
+import org.argeo.cms.servlet.ServletUtils;
import org.argeo.jcr.Jcr;
import org.argeo.jcr.JcrxApi;
@@ -39,9 +40,17 @@ public class OdkFormListServlet extends HttpServlet {
resp.setHeader("X-OpenRosa-Version", "1.0");
resp.setDateHeader("Date", System.currentTimeMillis());
- String serverName = req.getServerName();
- int serverPort = req.getServerPort();
- String protocol = serverPort == 443 || req.isSecure() ? "https" : "http";
+//// String serverName = req.getServerName();
+//// int serverPort = req.getServerPort();
+//// String protocol = serverPort == 443 || req.isSecure() ? "https" : "http";
+//// String baseServer = protocol + "://" + serverName
+//// + (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort);
+// String requestUri=req.getRequestURI();
+// String forwardedHost = req.getHeader("X-Forwarded-Host");
+// URL requestUrl = new URL(req.getRequestURL().toString());
+// String baseServer = requestUrl.getProtocol() + "://" + requestUrl.getHost()
+// + (requestUrl.getPort() > 0 ? ":" + requestUrl.getPort() : "");
+ StringBuilder baseServer = ServletUtils.getRequestUrlBase(req);
String pathInfo = req.getPathInfo();
@@ -77,23 +86,17 @@ public class OdkFormListServlet extends HttpServlet {
sb.append("md5:" + JcrxApi.getChecksum(node, JcrxApi.MD5) + "");
if (node.hasProperty(Property.JCR_DESCRIPTION))
sb.append("" + node.getProperty(Property.JCR_DESCRIPTION).getString() + "");
- sb.append("" + protocol + "://" + serverName
- + (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort) + "/api/odk/form"
- + node.getPath() + "");
+ sb.append("" + baseServer + "/api/odk/form" + node.getPath() + "");
if (node.hasNode(OrxManifestName.manifest.name())) {
- sb.append("" + protocol + "://" + serverName
- + (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort)
- + "/api/odk/formManifest" + node.getNode(OrxManifestName.manifest.name()).getPath()
- + "");
+ sb.append("" + baseServer + "/api/odk/formManifest"
+ + node.getNode(OrxManifestName.manifest.name()).getPath() + "");
}
sb.append("");
} else if (node.isNodeType(EntityType.formSet.get())) {
sb.append("");
sb.append("" + node.getPath() + "");
sb.append("" + node.getProperty(Property.JCR_TITLE).getString() + "");
- sb.append("" + protocol + "://" + serverName
- + (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort) + "/api/odk/formList"
- + node.getPath() + "");
+ sb.append("" + baseServer + "/api/odk/formList" + node.getPath() + "");
sb.append("");
}
String str = sb.toString();