X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=org.argeo.app.servlet.odk%2Fsrc%2Forg%2Fargeo%2Fapp%2Fservlet%2Fodk%2FOdkFormListServlet.java;h=41a3039a3df72909bba6ee1dbd5ce1f7ae6b4395;hb=597c7013edda6cd7d846761233bc57e08ef5f99c;hp=c88bf4ae9fc5c81545abdd1c02d90bde34517520;hpb=942fd932e1f6ed3319575c4c1d944912dfca9fa5;p=gpl%2Fargeo-suite.git diff --git a/org.argeo.app.servlet.odk/src/org/argeo/app/servlet/odk/OdkFormListServlet.java b/org.argeo.app.servlet.odk/src/org/argeo/app/servlet/odk/OdkFormListServlet.java index c88bf4a..41a3039 100644 --- a/org.argeo.app.servlet.odk/src/org/argeo/app/servlet/odk/OdkFormListServlet.java +++ b/org.argeo.app.servlet.odk/src/org/argeo/app/servlet/odk/OdkFormListServlet.java @@ -2,9 +2,6 @@ package org.argeo.app.servlet.odk; import java.io.IOException; import java.io.Writer; -import java.util.Collections; -import java.util.HashSet; -import java.util.Set; import javax.jcr.Node; import javax.jcr.NodeIterator; @@ -22,11 +19,11 @@ import javax.servlet.http.HttpServletResponse; import org.argeo.api.cms.CmsConstants; import org.argeo.api.cms.CmsLog; import org.argeo.app.api.EntityType; -import org.argeo.app.odk.OdkForm; import org.argeo.app.odk.OrxListName; 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; @@ -35,11 +32,6 @@ public class OdkFormListServlet extends HttpServlet { private static final long serialVersionUID = 2706191315048423321L; private final static CmsLog log = CmsLog.getLog(OdkFormListServlet.class); - 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 @@ -48,120 +40,83 @@ public class OdkFormListServlet extends HttpServlet { 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"; +//// 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); +// String requestUri=req.getRequestURI(); +// String forwardedHost = req.getHeader("X-Forwarded-Host"); +// URL requestUrl = new URL(req.getRequestURL().toString()); +// String baseServer = requestUrl.getProtocol() + "://" + requestUrl.getHost() +// + (requestUrl.getPort() > 0 ? ":" + requestUrl.getPort() : ""); + StringBuilder baseServer = ServletUtils.getRequestUrlBase(req); 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(""); writer.append(""); - 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 { - query = session.getWorkspace().getQueryManager() - .createQuery( - "SELECT node FROM [" + OrxListName.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(OrxListName.xform.get())) { - sb.append(""); - sb.append("" + node.getProperty(OrxListName.formID.get()).getString() + ""); - sb.append("" + Jcr.getTitle(node) + ""); - sb.append("" + node.getProperty(OrxListName.version.get()).getString() + ""); - 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() + ""); - if (node.hasNode(OrxManifestName.manifest.name())) { - sb.append("" + protocol + "://" + serverName - + (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort) - + "/api/odk/formManifest" + node.getNode(OrxManifestName.manifest.name()).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); - resp.sendError(503); - } finally { - Jcr.logout(session); + try { + + Query query; + if (pathInfo == null) { + query = session.getWorkspace().getQueryManager() + .createQuery("SELECT * FROM [" + OrxListName.xform.get() + "]", Query.JCR_SQL2); + } else { + query = session.getWorkspace().getQueryManager() + .createQuery( + "SELECT node FROM [" + OrxListName.xform.get() + + "] AS node WHERE ISDESCENDANTNODE (node, '" + pathInfo + "')", + Query.JCR_SQL2); } + QueryResult queryResult = query.execute(); - } else { - for (OdkForm form : odkForms) { + NodeIterator nit = queryResult.getNodes(); + while (nit.hasNext()) { 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(""); + Node node = nit.nextNode(); + if (node.isNodeType(OrxListName.xform.get())) { + sb.append(""); + sb.append("" + node.getProperty(OrxListName.formID.get()).getString() + ""); + sb.append("" + Jcr.getTitle(node) + ""); + sb.append("" + node.getProperty(OrxListName.version.get()).getString() + ""); + sb.append("md5:" + JcrxApi.getChecksum(node, JcrxApi.MD5) + ""); + if (node.hasProperty(Property.JCR_DESCRIPTION)) + sb.append("" + node.getProperty(Property.JCR_DESCRIPTION).getString() + ""); + sb.append("" + baseServer + "/api/odk/form" + node.getPath() + ""); + if (node.hasNode(OrxManifestName.manifest.name())) { + sb.append("" + baseServer + "/api/odk/formManifest" + + node.getNode(OrxManifestName.manifest.name()).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("" + baseServer + "/api/odk/formList" + node.getPath() + ""); + sb.append(""); + } String str = sb.toString(); - if (log.isDebugEnabled()) - log.debug(str); - writer.append(str); + if (!str.equals("")) { + if (log.isDebugEnabled()) + log.debug(str); + writer.append(str); + } } + } catch (RepositoryException e) { + e.printStackTrace(); + // TODO error message + // resp.sendError(500); + resp.sendError(503); + } finally { + Jcr.logout(session); } writer.append(""); } - public void addForm(OdkForm odkForm) { - odkForms.add(odkForm); - } - - public void removeForm(OdkForm odkForm) { - odkForms.remove(odkForm); - } - public void setRepository(Repository repository) { this.repository = repository; }