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.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;
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.OrxListType;
+import org.argeo.support.odk.OrxListName;
+import org.argeo.support.odk.OrxManifestName;
/** Lists available forms. */
public class OdkFormListServlet extends HttpServlet {
private Set<OdkForm> odkForms = Collections.synchronizedSet(new HashSet<>());
- private DateTimeFormatter versionFormatter = DateTimeFormatter.ofPattern("YYYY-MM-dd-HHmm")
- .withZone(ZoneId.from(ZoneOffset.UTC));
+// private DateTimeFormatter versionFormatter = DateTimeFormatter.ofPattern("YYYY-MM-dd-HHmm")
+// .withZone(ZoneId.from(ZoneOffset.UTC));
private Repository repository;
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("<?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 = 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 [" + 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(OrxListType.xform.get())) {
+ if (node.isNodeType(OrxListName.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("<version>" + versionFormatter.format(JcrUtils.getModified(node)) + "</version>");
+ sb.append("<formID>" + node.getProperty(OrxListName.formID.get()).getString() + "</formID>");
+ sb.append("<name>" + Jcr.getTitle(node) + "</name>");
+ sb.append("<version>" + node.getProperty(OrxListName.version.get()).getString() + "</version>");
sb.append("<hash>md5:" + JcrxApi.getChecksum(node, JcrxApi.MD5) + "</hash>");
if (node.hasProperty(Property.JCR_DESCRIPTION))
sb.append("<name>" + node.getProperty(Property.JCR_DESCRIPTION).getString() + "</name>");
sb.append("<downloadUrl>" + protocol + "://" + serverName
+ (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort) + "/api/odk/form/"
+ node.getPath() + "</downloadUrl>");
+ if (node.hasNode(OrxManifestName.manifest.name())) {
+ sb.append("<manifestUrl>" + protocol + "://" + serverName
+ + (serverPort == 80 || serverPort == 443 ? "" : ":" + serverPort)
+ + "/api/odk/formManifest" + node.getNode(OrxManifestName.manifest.name()).getPath()
+ + "</manifestUrl>");
+ }
sb.append("</xform>");
} else if (node.isNodeType(EntityType.formSet.get())) {
sb.append("<xforms-group>");
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("<xform>");
log.debug(str);
writer.append(str);
}
+ }
writer.append("</xforms>");
}