X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=org.argeo.cms.jcr%2Fsrc%2Forg%2Fargeo%2Fcms%2Fjcr%2Facr%2FBasicSearchToQom.java;h=ab01d7fd33d2e999b2d0f078142a5acdff595292;hb=9740c5b4c510001454c14750df4ef5cc1d782be9;hp=72940705a0f07aa2f1ce0bcb828cfa025375a50d;hpb=d58ef68ac546bc3d9874834f5345e67dbe9b6835;p=gpl%2Fargeo-jcr.git diff --git a/org.argeo.cms.jcr/src/org/argeo/cms/jcr/acr/BasicSearchToQom.java b/org.argeo.cms.jcr/src/org/argeo/cms/jcr/acr/BasicSearchToQom.java index 7294070..ab01d7f 100644 --- a/org.argeo.cms.jcr/src/org/argeo/cms/jcr/acr/BasicSearchToQom.java +++ b/org.argeo.cms.jcr/src/org/argeo/cms/jcr/acr/BasicSearchToQom.java @@ -1,8 +1,11 @@ package org.argeo.cms.jcr.acr; +import static javax.jcr.query.qom.QueryObjectModelConstants.JCR_OPERATOR_EQUAL_TO; + import java.util.ArrayList; import java.util.List; +import javax.jcr.Property; import javax.jcr.RepositoryException; import javax.jcr.Session; import javax.jcr.query.QueryManager; @@ -15,13 +18,21 @@ import javax.jcr.query.qom.StaticOperand; import javax.xml.namespace.QName; import org.apache.jackrabbit.commons.query.sql2.QOMFormatter; +import org.argeo.api.acr.DName; import org.argeo.api.acr.NamespaceUtils; import org.argeo.api.acr.search.BasicSearch; import org.argeo.api.acr.search.Constraint; import org.argeo.api.acr.search.ContentFilter; -import org.argeo.api.acr.search.ContentFilter.Eq; -import org.argeo.api.acr.search.ContentFilter.IsContentClass; -import org.argeo.api.acr.search.ContentFilter.Not; +import org.argeo.api.acr.search.Eq; +import org.argeo.api.acr.search.Gt; +import org.argeo.api.acr.search.Gte; +import org.argeo.api.acr.search.IsContentClass; +import org.argeo.api.acr.search.IsDefined; +import org.argeo.api.acr.search.Like; +import org.argeo.api.acr.search.Lt; +import org.argeo.api.acr.search.Lte; +import org.argeo.api.acr.search.Not; +import org.argeo.api.acr.search.PropertyValueContraint; import org.argeo.api.cms.CmsLog; /** Convert an ACR basic search to a JCR query. */ @@ -113,15 +124,50 @@ class BasicSearchToQom { return currQomConstraint; } - } else if (constraint instanceof Eq comp) { - DynamicOperand dynamicOperand = factory.propertyValue(selectorName, - NamespaceUtils.toPrefixedName(comp.getProp())); + } else if (constraint instanceof PropertyValueContraint comp) { + QName prop = comp.getProp(); + if (DName.creationdate.equals(prop)) + prop = JcrName.created.qName(); + else if (DName.getlastmodified.equals(prop)) + prop = JcrName.lastModified.qName(); + + DynamicOperand dynamicOperand = factory.propertyValue(selectorName, NamespaceUtils.toPrefixedName(prop)); // TODO better convert attribute value StaticOperand staticOperand = factory - .literal(session.getValueFactory().createValue(comp.getValue().toString())); - return factory.comparison(dynamicOperand, QueryObjectModelConstants.JCR_OPERATOR_EQUAL_TO, staticOperand); + .literal(JcrContent.convertSingleObject(session.getValueFactory(), comp.getValue())); + javax.jcr.query.qom.Constraint res; + if (comp instanceof Eq) + res = factory.comparison(dynamicOperand, QueryObjectModelConstants.JCR_OPERATOR_EQUAL_TO, + staticOperand); + else if (comp instanceof Lt) + res = factory.comparison(dynamicOperand, QueryObjectModelConstants.JCR_OPERATOR_LESS_THAN, + staticOperand); + else if (comp instanceof Lte) + res = factory.comparison(dynamicOperand, QueryObjectModelConstants.JCR_OPERATOR_LESS_THAN_OR_EQUAL_TO, + staticOperand); + else if (comp instanceof Gt) + res = factory.comparison(dynamicOperand, QueryObjectModelConstants.JCR_OPERATOR_GREATER_THAN, + staticOperand); + else if (comp instanceof Gte) + res = factory.comparison(dynamicOperand, + QueryObjectModelConstants.JCR_OPERATOR_GREATER_THAN_OR_EQUAL_TO, staticOperand); + else if (comp instanceof Like) + res = factory.comparison(dynamicOperand, QueryObjectModelConstants.JCR_OPERATOR_LIKE, staticOperand); + else + throw new UnsupportedOperationException("Constraint of type " + comp.getClass() + " is not supported"); + return res; } else if (constraint instanceof Not not) { return factory.not(toQomConstraint(not.getNegated())); + } else if (constraint instanceof IsDefined comp) { + QName prop = comp.getProp(); + if (DName.checkedIn.equals(prop) || DName.checkedOut.equals(prop)) { + DynamicOperand dynamicOperand = factory.propertyValue(selectorName, Property.JCR_IS_CHECKED_OUT); + StaticOperand staticOperand = factory + .literal(session.getValueFactory().createValue(DName.checkedOut.equals(prop))); + return factory.comparison(dynamicOperand, JCR_OPERATOR_EQUAL_TO, staticOperand); + } else { + return factory.propertyExistence(selectorName, NamespaceUtils.toPrefixedName(prop)); + } } else { throw new IllegalArgumentException("Constraint " + constraint.getClass() + " is not supported"); }