ODK servlets based on JCR.
authorMathieu Baudier <mbaudier@argeo.org>
Wed, 4 Nov 2020 07:37:08 +0000 (08:37 +0100)
committerMathieu Baudier <mbaudier@argeo.org>
Wed, 4 Nov 2020 07:37:08 +0000 (08:37 +0100)
knowledge/org.argeo.support.odk/src/org/argeo/support/odk/OdkNames.java [new file with mode: 0644]
knowledge/org.argeo.support.odk/src/org/argeo/support/odk/servlet/OdkFormListServlet.java
knowledge/org.argeo.support.odk/src/org/argeo/support/odk/servlet/OdkFormServlet.java

diff --git a/knowledge/org.argeo.support.odk/src/org/argeo/support/odk/OdkNames.java b/knowledge/org.argeo.support.odk/src/org/argeo/support/odk/OdkNames.java
new file mode 100644 (file)
index 0000000..fbb2087
--- /dev/null
@@ -0,0 +1,7 @@
+package org.argeo.support.odk;
+
+/** Names related to ODK. */
+public interface OdkNames {
+
+       public final static String H_HTML = "h:html";
+}
index cc892a8b3c195ef0424d0277e11d221d70361f5e..c8a66bf14a806a2c20899a5e9c4f9735fcd8686c 100644 (file)
@@ -16,6 +16,8 @@ import javax.jcr.Property;
 import javax.jcr.Repository;
 import javax.jcr.RepositoryException;
 import javax.jcr.Session;
+import javax.jcr.query.Query;
+import javax.jcr.query.QueryResult;
 import javax.security.auth.Subject;
 import javax.servlet.ServletException;
 import javax.servlet.http.HttpServlet;
@@ -25,8 +27,7 @@ import javax.servlet.http.HttpServletResponse;
 import org.apache.commons.logging.Log;
 import org.apache.commons.logging.LogFactory;
 import org.argeo.api.NodeConstants;
-import org.argeo.api.NodeUtils;
-import org.argeo.cms.auth.ServletAuthUtils;
+import org.argeo.cms.servlet.ServletAuthUtils;
 import org.argeo.entity.EntityType;
 import org.argeo.jcr.Jcr;
 import org.argeo.jcr.JcrUtils;
@@ -67,39 +68,39 @@ public class OdkFormListServlet extends HttpServlet {
                Writer writer = resp.getWriter();
                writer.append("<?xml version='1.0' encoding='UTF-8' ?>");
                writer.append("<xforms xmlns=\"http://openrosa.org/xforms/xformsList\">");
-               boolean newApproach = true;
-               if (newApproach)
+               boolean oldApproach = false;
+               if (oldApproach) {
                        try {
 
-//                     Query query;
-//                     if (pathInfo == null) {
-////                           query = session.getWorkspace().getQueryManager()
-////                                           .createQuery("SELECT * FROM [nt:unstructured]", Query.JCR_SQL2);
+                               Query query;
+                               if (pathInfo == null) {
 //                             query = session.getWorkspace().getQueryManager()
-//                                             .createQuery("SELECT * FROM [" + OrxListType.xform.get() + "]", Query.JCR_SQL2);
-//                     } else {
-//                             query = session.getWorkspace().getQueryManager()
-//                                             .createQuery(
-//                                                             "SELECT node FROM [" + OrxListType.xform.get()
-//                                                                             + "] AS node WHERE ISDESCENDANTNODE (node, '" + pathInfo + "')",
-//                                                             Query.JCR_SQL2);
-//                     }
-//                     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());
+//                                             .createQuery("SELECT * FROM [nt:unstructured]", Query.JCR_SQL2);
+                                       query = session.getWorkspace().getQueryManager()
+                                                       .createQuery("SELECT * FROM [" + OrxListType.xform.get() + "]", Query.JCR_SQL2);
+                               } else {
+                                       query = session.getWorkspace().getQueryManager()
+                                                       .createQuery(
+                                                                       "SELECT node FROM [" + OrxListType.xform.get()
+                                                                                       + "] AS node WHERE ISDESCENDANTNODE (node, '" + pathInfo + "')",
+                                                                       Query.JCR_SQL2);
                                }
+                               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();
                                        if (node.isNodeType(OrxListType.xform.get())) {
                                                sb.append("<xform>");
                                                sb.append("<formID>" + node.getNode("h:html").getIdentifier() + "</formID>");
-                                               sb.append("<name>" + node.getProperty(Property.JCR_TITLE).getString() + "</name>");
+                                               sb.append("<name>" + Jcr.getTitle(node) + "</name>");
                                                sb.append("<version>" + versionFormatter.format(JcrUtils.getModified(node)) + "</version>");
                                                sb.append("<hash>md5:" + JcrxApi.getChecksum(node, JcrxApi.MD5) + "</hash>");
                                                if (node.hasProperty(Property.JCR_DESCRIPTION))
@@ -132,8 +133,7 @@ public class OdkFormListServlet extends HttpServlet {
                                Jcr.logout(session);
                        }
 
-               boolean oldApproach = true;
-               if (oldApproach)
+               } else {
                        for (OdkForm form : odkForms) {
                                StringBuilder sb = new StringBuilder();
                                sb.append("<xform>");
@@ -151,6 +151,7 @@ public class OdkFormListServlet extends HttpServlet {
                                        log.debug(str);
                                writer.append(str);
                        }
+               }
                writer.append("</xforms>");
        }
 
index 93f41479ded820342874e326a9ced9631af4db66..301e1bb433d9bcc52c8768829378677d6416e831 100644 (file)
@@ -16,9 +16,10 @@ import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 
 import org.apache.commons.io.FilenameUtils;
-import org.argeo.cms.auth.ServletAuthUtils;
+import org.argeo.cms.servlet.ServletAuthUtils;
 import org.argeo.jcr.Jcr;
 import org.argeo.support.odk.OdkForm;
+import org.argeo.support.odk.OdkNames;
 
 /** Retrieves a single form. */
 public class OdkFormServlet extends HttpServlet {
@@ -35,9 +36,10 @@ public class OdkFormServlet extends HttpServlet {
 
                String pathInfo = req.getPathInfo();
 
+               boolean oldApproach = false;
                try {
-                       if (session.nodeExists(pathInfo)) {
-                               session.exportDocumentView(pathInfo + "/h:html", resp.getOutputStream(), true, false);
+                       if (!oldApproach) {
+                               session.exportDocumentView(pathInfo + "/" + OdkNames.H_HTML, resp.getOutputStream(), true, false);
                        } else {
 
                                String fileName = FilenameUtils.getName(pathInfo);