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=cc892a8b3c195ef0424d0277e11d221d70361f5e;hp=8398c7fa54769a3110aa6eaac54a7dbb7554b8a2;hb=702f22eb8cbcb56c927dc21226ee22696426647b;hpb=5aeef7f6fe70d741b66a58eb51cdd2f1bcfdfcf1 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 8398c7f..cc892a8 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,10 +2,21 @@ 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; import java.util.Collections; import java.util.HashSet; import java.util.Set; +import javax.jcr.Node; +import javax.jcr.NodeIterator; +import javax.jcr.Property; +import javax.jcr.Repository; +import javax.jcr.RepositoryException; +import javax.jcr.Session; +import javax.security.auth.Subject; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; @@ -13,7 +24,15 @@ 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.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.OrxListType; /** Lists available forms. */ public class OdkFormListServlet extends HttpServlet { @@ -22,6 +41,11 @@ public class OdkFormListServlet extends HttpServlet { private Set odkForms = Collections.synchronizedSet(new HashSet<>()); + private DateTimeFormatter versionFormatter = DateTimeFormatter.ofPattern("YYYY-MM-dd-HHmm") + .withZone(ZoneId.from(ZoneOffset.UTC)); + + private Repository repository; + @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { resp.setContentType("text/xml; charset=utf-8"); @@ -32,27 +56,101 @@ public class OdkFormListServlet extends HttpServlet { int serverPort = req.getServerPort(); String protocol = serverPort == 443 || req.isSecure() ? "https" : "http"; + 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(""); - for (OdkForm form : odkForms) { - StringBuilder sb = new StringBuilder(); - sb.append(""); - sb.append("" + form.getFormId() + ""); - sb.append("" + form.getName() + ""); - sb.append("" + form.getVersion() + ""); - sb.append("" + form.getHash(null) + ""); - sb.append("" + form.getDescription() + ""); - sb.append("" + protocol + "://" + serverName - + (serverPort == 80 - || serverPort == 443 ? "" : ":" + serverPort) + "/api/odk/" + form.getFileName() - + ""); - sb.append(""); - String str = sb.toString(); - if (log.isDebugEnabled()) - log.debug(str); - writer.append(str); - } + boolean newApproach = true; + if (newApproach) + 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 = 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("" + 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() + ""); + sb.append("" + protocol + "://" + serverName + + (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort) + "/api/odk/form/" + + node.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(""); + } + String str = sb.toString(); + if (!str.equals("")) { + if (log.isDebugEnabled()) + log.debug(str); + writer.append(str); + } + } + } catch (RepositoryException e) { + e.printStackTrace(); + // TODO error message + // resp.sendError(500); + } finally { + Jcr.logout(session); + } + + boolean oldApproach = true; + if (oldApproach) + for (OdkForm form : odkForms) { + StringBuilder sb = new StringBuilder(); + sb.append(""); + sb.append("" + form.getFormId() + ""); + sb.append("" + form.getName() + ""); + sb.append("" + form.getVersion() + ""); + sb.append("" + form.getHash(null) + ""); + sb.append("" + form.getDescription() + ""); + sb.append("" + protocol + "://" + serverName + + (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort) + "/api/odk/form/" + + form.getFileName() + ""); + sb.append(""); + String str = sb.toString(); + if (log.isDebugEnabled()) + log.debug(str); + writer.append(str); + } writer.append(""); } @@ -63,4 +161,9 @@ public class OdkFormListServlet extends HttpServlet { public void removeForm(OdkForm odkForm) { odkForms.remove(odkForm); } + + public void setRepository(Repository repository) { + this.repository = repository; + } + }