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;
private static final long serialVersionUID = 2706191315048423321L;
private final static CmsLog log = CmsLog.getLog(OdkFormListServlet.class);
-// private Set<OdkForm> odkForms = Collections.synchronizedSet(new HashSet<>());
-
-// private DateTimeFormatter versionFormatter = DateTimeFormatter.ofPattern("YYYY-MM-dd-HHmm")
-// .withZone(ZoneId.from(ZoneOffset.UTC));
-
private Repository repository;
@Override
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";
+ // we force HTTPS since ODK Collect will fail anyhow when sending http
+ // cf. https://forum.getodk.org/t/authentication-for-non-https-schems/32967/4
+ StringBuilder baseServer = ServletUtils.getRequestUrlBase(req, true);
String pathInfo = req.getPathInfo();
Session session = RemoteAuthUtils.doAs(() -> Jcr.login(repository, CmsConstants.SYS_WORKSPACE),
new ServletHttpRequest(req));
-// session = NodeUtils.openDataAdminSession(repository, NodeConstants.SYS_WORKSPACE);
Writer writer = resp.getWriter();
writer.append("<?xml version='1.0' encoding='UTF-8' ?>");
writer.append("<xforms xmlns=\"http://openrosa.org/xforms/xformsList\">");
-// boolean oldApproach = false;
-// if (!oldApproach) {
try {
Query query;
if (pathInfo == null) {
-// query = session.getWorkspace().getQueryManager()
-// .createQuery("SELECT * FROM [nt:unstructured]", Query.JCR_SQL2);
query = session.getWorkspace().getQueryManager()
.createQuery("SELECT * FROM [" + OrxListName.xform.get() + "]", Query.JCR_SQL2);
} else {
QueryResult queryResult = query.execute();
NodeIterator nit = queryResult.getNodes();
-// log.debug(session.getUserID());
-// log.debug(session.getWorkspace().getName());
-// NodeIterator nit = session.getRootNode().getNodes();
-// while (nit.hasNext()) {
-// log.debug(nit.nextNode());
-// }
while (nit.hasNext()) {
StringBuilder sb = new StringBuilder();
Node node = nit.nextNode();
sb.append("<hash>md5:" + JcrxApi.getChecksum(node, JcrxApi.MD5) + "</hash>");
if (node.hasProperty(Property.JCR_DESCRIPTION))
sb.append("<name>" + node.getProperty(Property.JCR_DESCRIPTION).getString() + "</name>");
- sb.append("<downloadUrl>" + protocol + "://" + serverName
- + (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort) + "/api/odk/form"
- + node.getPath() + "</downloadUrl>");
+ sb.append("<downloadUrl>" + baseServer + "/api/odk/form" + node.getPath() + "</downloadUrl>");
if (node.hasNode(OrxManifestName.manifest.name())) {
- sb.append("<manifestUrl>" + protocol + "://" + serverName
- + (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort)
- + "/api/odk/formManifest" + node.getNode(OrxManifestName.manifest.name()).getPath()
- + "</manifestUrl>");
+ sb.append("<manifestUrl>" + baseServer + "/api/odk/formManifest"
+ + node.getNode(OrxManifestName.manifest.name()).getPath() + "</manifestUrl>");
}
sb.append("</xform>");
} else if (node.isNodeType(EntityType.formSet.get())) {
sb.append("<xforms-group>");
sb.append("<groupId>" + node.getPath() + "</groupId>");
sb.append("<name>" + node.getProperty(Property.JCR_TITLE).getString() + "</name>");
- sb.append("<listUrl>" + protocol + "://" + serverName
- + (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort) + "/api/odk/formList"
- + node.getPath() + "</listUrl>");
+ sb.append("<listUrl>" + baseServer + "/api/odk/formList" + node.getPath() + "</listUrl>");
sb.append("</xforms-group>");
}
String str = sb.toString();
if (!str.equals("")) {
- if (log.isDebugEnabled())
- log.debug(str);
+ if (log.isTraceEnabled())
+ log.trace(str);
writer.append(str);
}
}
} finally {
Jcr.logout(session);
}
-
-// } else {
-// for (OdkForm form : odkForms) {
-// StringBuilder sb = new StringBuilder();
-// sb.append("<xform>");
-// sb.append("<formID>" + form.getFormId() + "</formID>");
-// sb.append("<name>" + form.getName() + "</name>");
-// sb.append("<version>" + form.getVersion() + "</version>");
-// sb.append("<hash>" + form.getHash(null) + "</hash>");
-// sb.append("<descriptionText>" + form.getDescription() + "</descriptionText>");
-// sb.append("<downloadUrl>" + protocol + "://" + serverName
-// + (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort) + "/api/odk/form/"
-// + form.getFileName() + "</downloadUrl>");
-// sb.append("</xform>");
-// String str = sb.toString();
-// if (log.isDebugEnabled())
-// log.debug(str);
-// writer.append(str);
-// }
-// }
writer.append("</xforms>");
}
-// public void addForm(OdkForm odkForm) {
-// odkForms.add(odkForm);
-// }
-//
-// public void removeForm(OdkForm odkForm) {
-// odkForms.remove(odkForm);
-// }
-
public void setRepository(Repository repository) {
this.repository = repository;
}