X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=org.argeo.app.servlet.odk%2Fsrc%2Forg%2Fargeo%2Fapp%2Fservlet%2Fodk%2FOdkManifestServlet.java;h=6e145c2b951fb0f87013e3887b29258a181973e9;hb=c27369172d8f9724f73b0e6be692238931851211;hp=2c62ba10cfa647321a6eae52581db4e84a023561;hpb=597c7013edda6cd7d846761233bc57e08ef5f99c;p=gpl%2Fargeo-suite.git diff --git a/org.argeo.app.servlet.odk/src/org/argeo/app/servlet/odk/OdkManifestServlet.java b/org.argeo.app.servlet.odk/src/org/argeo/app/servlet/odk/OdkManifestServlet.java index 2c62ba1..6e145c2 100644 --- a/org.argeo.app.servlet.odk/src/org/argeo/app/servlet/odk/OdkManifestServlet.java +++ b/org.argeo.app.servlet.odk/src/org/argeo/app/servlet/odk/OdkManifestServlet.java @@ -54,12 +54,9 @@ public class OdkManifestServlet extends HttpServlet { if (pathInfo.startsWith("//")) pathInfo = pathInfo.substring(1); -// 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); - StringBuilder baseServer = ServletUtils.getRequestUrlBase(req); + // 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); Session session = RemoteAuthUtils.doAs(() -> Jcr.login(repository, null), new ServletHttpRequest(req)); @@ -139,7 +136,13 @@ public class OdkManifestServlet extends HttpServlet { if (target.isNodeType(NodeType.NT_QUERY)) { Query query = target.getSession().getWorkspace().getQueryManager().getQuery(target); QueryResult queryResult = query.execute(); - String[] columnNames = queryResult.getColumnNames(); + List columnNames = new ArrayList<>(); + for (String c : queryResult.getColumnNames()) { + columnNames.add(c); + } + // TODO make it more configurable + columnNames.add("display"); + if (EntityMimeType.XML.equals(mimeType)) { } else if (EntityMimeType.CSV.equals(mimeType)) { CsvWriter csvWriter = new CsvWriter(out, charset); @@ -153,12 +156,14 @@ public class OdkManifestServlet extends HttpServlet { for (Value value : values) { lst.add(value.getString()); } + // display + lst.add(row.getValue("name").getString() + " (" + row.getValue("label").getString() + ")"); csvWriter.writeLine(lst); } } else { // corner case of an empty initial database List lst = new ArrayList<>(); - for (int i = 0; i < columnNames.length; i++) + for (int i = 0; i < columnNames.size(); i++) lst.add("-"); csvWriter.writeLine(lst); }