[
https://issues.apache.org/jira/browse/CXF-6037?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Sergey Beryozkin resolved CXF-6037.
-----------------------------------
Resolution: Fixed
Fix Version/s: (was: 3.0.1)
3.1.0
Assignee: Sergey Beryozkin
> in JAX-RS search there is no support for java.sql.Time in fiql
> --------------------------------------------------------------
>
> Key: CXF-6037
> URL: https://issues.apache.org/jira/browse/CXF-6037
> Project: CXF
> Issue Type: Bug
> Components: JAX-RS
> Affects Versions: 3.0.1
> Reporter: Krzysztof Luszynski
> Assignee: Sergey Beryozkin
> Priority: Critical
> Fix For: 3.0.2, 3.1.0
>
>
> 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)
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)