Uploaded image for project: 'CXF'
  1. CXF
  2. CXF-6037

in JAX-RS search there is no support for java.sql.Time in fiql

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Closed
    • Critical
    • Resolution: Fixed
    • 3.0.1
    • 3.0.2, 3.1
    • JAX-RS
    • None
    • Unknown

    Description

      When JPA annotated class is using java.sql.Time :

      ...
      @Temporal(TemporalType.TIME)
      private Time arrivalTime;
      ...

      I have set the property on the parser format of the date :
      Map<String, String> parserProperties = ImmutableMap.of(
      "search.date-format", "yyyy-MM-dd HH:mm:ss"
      );

      searchContext.getCondition(genericType, beanProperties, parserProperties);
      ...

      and I want to use that property in url :
      curl -i -X GET "http://localhost:8181/cxf/.../page?_search=arrivalTime==0000-00-00%2017:00:00"

      I have an exception :
      <h3>Caused by:</h3><pre>java.lang.IllegalArgumentException: argument type mismatch; setter parameter type: java.sql.Time
      , set value type: java.util.Date
      at org.apache.cxf.jaxrs.ext.search.Beanspector.setValue(Beanspector.java:155)
      at org.apache.cxf.jaxrs.ext.search.Beanspector.setValue(Beanspector.java:134)
      at org.apache.cxf.jaxrs.ext.search.fiql.FiqlParser$Comparison.createTemplate(FiqlParser.java:387)
      at org.apache.cxf.jaxrs.ext.search.fiql.FiqlParser$Comparison.build(FiqlParser.java:365)
      at org.apache.cxf.jaxrs.ext.search.fiql.FiqlParser.parse(FiqlParser.java:166)
      at org.apache.cxf.jaxrs.ext.search.SearchContextImpl.getCondition(SearchContextImpl.java:98)
      at org.apache.cxf.jaxrs.ext.search.SearchContextImpl.getCondition(SearchContextImpl.java:69)
      at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
      at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
      at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
      at java.lang.reflect.Method.invoke(Method.java:606)
      at org.apache.cxf.jaxrs.impl.tl.ThreadLocalInvocationHandler.invoke(ThreadLocalInvocationHandler.java:46)
      at com.sun.proxy.$Proxy137.getCondition(Unknown Source)

      This is because during Condition creation the java.util.Date object is created as value instead of java.sql.Time.

      I have debugged the sources from :
      http://search.maven.org/remotecontent?filepath=org/apache/cxf/cxf-rt-rs-extension-search/3.0.1/cxf-rt-rs-extension-search-3.0.1-sources.jar

      The problem is in the class :
      org.apache.cxf.jaxrs.ext.search.AbstractSearchConditionParser#protected Object parseType(... starts in line 103

      When value from fiql expression is determined there is if date can be constructed from string (line number 116):
      if (Date.class.isAssignableFrom(valueType))

      { castedValue = convertToDate(valueType, value); }

      private Object convertToDate(... line number 261
      ...
      try

      { if (Timestamp.class.isAssignableFrom(valueType)) { return convertToTimestamp(value); }

      else

      { return convertToDefaultDate(value); }

      ...
      The code goes to default date(value), however there should be if for java.sql.Time also and last option should be default date :
      java.sql.Time.class.isAssignableFrom(valueType)

      Attachments

        Activity

          People

            sergey_beryozkin Sergey Beryozkin
            kluszynski Krzysztof Luszynski
            Votes:
            0 Vote for this issue
            Watchers:
            1 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: