X-Git-Url: https://git.argeo.org/?p=gpl%2Fargeo-suite.git;a=blobdiff_plain;f=knowledge%2Forg.argeo.support.odk%2Fsrc%2Forg%2Fargeo%2Fsupport%2Fodk%2Fservlet%2FOdkFormListServlet.java;h=f829c12f92eba407afd9238c6fcceaabb2454a5a;hp=cc892a8b3c195ef0424d0277e11d221d70361f5e;hb=780fe06055c67f30a1a0b55746f3cd4595532756;hpb=702f22eb8cbcb56c927dc21226ee22696426647b diff --git a/knowledge/org.argeo.support.odk/src/org/argeo/support/odk/servlet/OdkFormListServlet.java b/knowledge/org.argeo.support.odk/src/org/argeo/support/odk/servlet/OdkFormListServlet.java index cc892a8..f829c12 100644 --- a/knowledge/org.argeo.support.odk/src/org/argeo/support/odk/servlet/OdkFormListServlet.java +++ b/knowledge/org.argeo.support.odk/src/org/argeo/support/odk/servlet/OdkFormListServlet.java @@ -2,7 +2,6 @@ package org.argeo.support.odk.servlet; import java.io.IOException; import java.io.Writer; -import java.security.AccessControlContext; import java.time.ZoneId; import java.time.ZoneOffset; import java.time.format.DateTimeFormatter; @@ -16,7 +15,8 @@ import javax.jcr.Property; import javax.jcr.Repository; import javax.jcr.RepositoryException; import javax.jcr.Session; -import javax.security.auth.Subject; +import javax.jcr.query.Query; +import javax.jcr.query.QueryResult; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; @@ -25,13 +25,13 @@ 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; import org.argeo.jcr.JcrxApi; import org.argeo.support.odk.OdkForm; +import org.argeo.support.odk.OdkNames; import org.argeo.support.odk.OrxListType; /** Lists available forms. */ @@ -58,49 +58,49 @@ public class OdkFormListServlet extends HttpServlet { String pathInfo = req.getPathInfo(); - Subject subject = Subject - .getSubject((AccessControlContext) req.getAttribute(AccessControlContext.class.getName())); - log.debug("SERVLET CONTEXT: " + subject); - Session session = ServletAuthUtils.doAs(() -> Jcr.login(repository, NodeConstants.SYS_WORKSPACE), req); // session = NodeUtils.openDataAdminSession(repository, NodeConstants.SYS_WORKSPACE); Writer writer = resp.getWriter(); writer.append(""); writer.append(""); - 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 = session.getWorkspace().getQueryManager() -// .createQuery("SELECT * FROM [" + OrxListType.xform.get() + "]", Query.JCR_SQL2); -// } else { + Query query; + if (pathInfo == null) { // 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(""); - sb.append("" + node.getNode("h:html").getIdentifier() + ""); - sb.append("" + node.getProperty(Property.JCR_TITLE).getString() + ""); + sb.append("" + + node.getNode(OdkNames.H_HTML + "/h:head/xforms:model/xforms:instance/xforms:data") + .getProperty("id").getString() + + ""); + sb.append("" + Jcr.getTitle(node) + ""); sb.append("" + versionFormatter.format(JcrUtils.getModified(node)) + ""); +// sb.append("" + versionFormatter.format(JcrUtils.getModified(node)) + ""); sb.append("md5:" + JcrxApi.getChecksum(node, JcrxApi.MD5) + ""); if (node.hasProperty(Property.JCR_DESCRIPTION)) sb.append("" + node.getProperty(Property.JCR_DESCRIPTION).getString() + ""); @@ -128,12 +128,12 @@ public class OdkFormListServlet extends HttpServlet { e.printStackTrace(); // TODO error message // resp.sendError(500); + resp.sendError(503); } finally { Jcr.logout(session); } - boolean oldApproach = true; - if (oldApproach) + } else { for (OdkForm form : odkForms) { StringBuilder sb = new StringBuilder(); sb.append(""); @@ -151,6 +151,7 @@ public class OdkFormListServlet extends HttpServlet { log.debug(str); writer.append(str); } + } writer.append(""); }