[ 
https://issues.apache.org/jira/browse/OLINGO-1459?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Mahdi Ansari closed OLINGO-1459.
--------------------------------

> Apache Olinge OData service throws EdmSimpleTypeException when the column in 
> database is of type TEXT or BLOB
> -------------------------------------------------------------------------------------------------------------
>
>                 Key: OLINGO-1459
>                 URL: https://issues.apache.org/jira/browse/OLINGO-1459
>             Project: Olingo
>          Issue Type: Bug
>          Components: odata2-jpa
>    Affects Versions: V2 2.0.11
>         Environment: spring-boot 2.3.0, MariaDB, 
>            Reporter: Mahdi Ansari
>            Priority: Major
>
> I have made an entity by using JPA in eclipse. The definition of the table in 
> my MySQL is like this:
> {code:java}
> CREATE TABLE `users` (`id` int(255) NOT NULL,`name` varchar(255) NOT 
> NULL,`photo_content` text CHARACTER SET ascii DEFAULT NULL) ENGINE=InnoDB 
> DEFAULT CHARSET=utf8;{code}
> and the equivalent entity that I generated by JPA is like this:
> {code:java}
> import java.io.Serializable;import java.io.Serializable;import 
> javax.persistence.*;import java.util.Set;/** * The persistent class for the 
> users database table. *  
> */@Entity@Table(name="users")@NamedQuery(name="User.findAll", query="SELECT u 
> FROM User u")public class User implements Serializable { private static final 
> long serialVersionUID = 1L;
>  @Id @GeneratedValue(strategy=GenerationType.IDENTITY) @Column(unique=true, 
> nullable=false) private int id;
>  @Column(nullable=false, length=255) private String name;
>  @Lob @Column(name="photo_content") private String photoContent;
>  //bi-directional many-to-one association to Answer 
> @OneToMany(mappedBy="user") private Set<Answer> answers;
>  //bi-directional many-to-one association to Survey 
> @OneToMany(mappedBy="user") private Set<Survey> surveys;
>  public User() { }
>  public int getId() { return this.id; }
>  public void setId(int id) { this.id = id; }
>  public String getName() { return this.name; }
>  public void setName(String name) { this.name = name; }
>  public String getPhotoContent() { return this.photoContent; }
>  public void setPhotoContent(String photoContent) { this.photoContent = 
> photoContent; }
>  public Set<Answer> getAnswers() { return this.answers; }
>  public void setAnswers(Set<Answer> answers) { this.answers = answers; }
>  public Answer addAnswer(Answer answer) { getAnswers().add(answer); 
> answer.setUser(this);
>  return answer; }
>  public Answer removeAnswer(Answer answer) { getAnswers().remove(answer); 
> answer.setUser(null);
>  return answer; }
>  public Set<Survey> getSurveys() { return this.surveys; }
>  public void setSurveys(Set<Survey> surveys) { this.surveys = surveys; }
>  public Survey addSurvey(Survey survey) { getSurveys().add(survey); 
> survey.setUser(this);
>  return survey; }
>  public Survey removeSurvey(Survey survey) { getSurveys().remove(survey); 
> survey.setUser(null);
>  return survey; }
> }
> {code}
> As soon as the column {{photo_content}} has some value like this:
> {code:java}
> {code}
> and I try to read the {{Users}} by OData service I will see the following 
> exception:
> {code:java}
> <error xmlns="http://schemas.microsoft.com/ado/2007/08/dataservices/metadata";>
> <code/>
> <message xml:lang="en">
> Missing message for key 
> 'org.apache.olingo.odata2.api.edm.EdmSimpleTypeException.PROPERTY_VALUE_FACETS_NOT_MATCHED'!
> </message>
> </error>{code}
> How can I solve it? I found another post 
> [here|https://stackoverflow.com/questions/26544210/apache-olinge-odata-service-edmsimpletypeexception]
>  that in the answer, it has been claimed that this error is because of data 
> type conversion but when it is long string we don't have any type casting!
>  
> Here is the stack trace:
> {quote} 
> 12:01:55.528 [http-nio-9090-exec-7] ERROR 
> me.cimply.ask.odata.utils.ODataJPAProcessorUtil - "OData - JPA Runtime: 
> Internal error [Missing message for key 'org.a
> pache.olingo.odata2.api.edm.EdmSimpleTypeException.PROPERTY_VALUE_FACETS_NOT_MATCHED'!]"
> org.apache.olingo.odata2.jpa.processor.api.exception.ODataJPARuntimeException:
>  "OData - JPA Runtime: Internal error [Missing message for key 
> 'org.apache.olingo.
> odata2.api.edm.EdmSimpleTypeException.PROPERTY_VALUE_FACETS_NOT_MATCHED'!]"
>  at 
> org.apache.olingo.odata2.jpa.processor.api.exception.ODataJPARuntimeException.throwException(ODataJPARuntimeException.java:100)
>  at 
> org.apache.olingo.odata2.jpa.processor.core.ODataJPAResponseBuilderDefault.build(ODataJPAResponseBuilderDefault.java:125)
>  at 
> me.cimply.ask.odata.utils.ODataJPAProcessorUtil.readEntitySet(ODataJPAProcessorUtil.java:84)
>  at org.apache.olingo.odata2.core.Dispatcher.dispatch(Dispatcher.java:77)
>  at 
> org.apache.olingo.odata2.core.ODataRequestHandler.handle(ODataRequestHandler.java:131)
>  at 
> org.apache.olingo.odata2.core.rest.ODataSubLocator.handle(ODataSubLocator.java:164)
>  at 
> org.apache.olingo.odata2.core.rest.ODataSubLocator.handleGet(ODataSubLocator.java:58)
>  at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>  at 
> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
>  at 
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
>  at java.lang.reflect.Method.invoke(Method.java:498)
>  at 
> org.apache.cxf.service.invoker.AbstractInvoker.performInvocation(AbstractInvoker.java:179)
>  at 
> org.apache.cxf.service.invoker.AbstractInvoker.invoke(AbstractInvoker.java:96)
>  at org.apache.cxf.jaxrs.JAXRSInvoker.invoke(JAXRSInvoker.java:201)
>  at org.apache.cxf.jaxrs.JAXRSInvoker.invoke(JAXRSInvoker.java:285)
>  at org.apache.cxf.jaxrs.JAXRSInvoker.invoke(JAXRSInvoker.java:104)
>  at 
> org.apache.cxf.interceptor.ServiceInvokerInterceptor$1.run(ServiceInvokerInterceptor.java:59)
>  at 
> org.apache.cxf.interceptor.ServiceInvokerInterceptor.handleMessage(ServiceInvokerInterceptor.java:96)
>  at 
> org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:308)
>  at 
> org.apache.cxf.transport.ChainInitiationObserver.onMessage(ChainInitiationObserver.java:121)
>  at 
> org.apache.cxf.transport.http.AbstractHTTPDestination.invoke(AbstractHTTPDestination.java:267)
>  at 
> org.apache.cxf.transport.servlet.ServletController.invokeDestination(ServletController.java:234)
>  at 
> org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:208)
>  at 
> org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:160)
>  at 
> org.apache.cxf.transport.servlet.CXFNonSpringServlet.invoke(CXFNonSpringServlet.java:225)
>  at 
> org.apache.cxf.transport.servlet.AbstractHTTPServlet.handleRequest(AbstractHTTPServlet.java:301)
>  at 
> org.apache.cxf.transport.servlet.AbstractHTTPServlet.doGet(AbstractHTTPServlet.java:225)
>  at javax.servlet.http.HttpServlet.service(HttpServlet.java:634)
>  at 
> org.apache.cxf.transport.servlet.AbstractHTTPServlet.service(AbstractHTTPServlet.java:276)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
>  at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
>  at 
> org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:113)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:320)
>  at 
> org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:126)
>  at 
> org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:90)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
>  at 
> org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:118)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
>  at 
> org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:137)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
>  at 
> org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:111)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
>  at 
> org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:158)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
>  at 
> org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
>  at 
> me.cimply.ask.odata.security.JwtAuthenticationFilter.doFilterInternal(JwtAuthenticationFilter.java:75)
>  at 
> org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
>  at 
> org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:116)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
>  at 
> org.springframework.web.filter.CorsFilter.doFilterInternal(CorsFilter.java:92)
>  at 
> org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
>  at 
> org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:92)
>  at 
> org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:77)
>  at 
> org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
>  at 
> org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:105)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
>  at 
> org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:56)
>  at 
> org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
>  at 
> org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
>  at 
> org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:215)
>  at 
> org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:178)
>  at 
> org.springframework.security.web.debug.DebugFilter.invokeWithWrappedRequest(DebugFilter.java:90)
>  at 
> org.springframework.security.web.debug.DebugFilter.doFilter(DebugFilter.java:77)
>  at 
> org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:358)
>  at 
> org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:271)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
>  at 
> org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100)
>  at 
> org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
>  at 
> org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93)
>  at 
> org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
>  at 
> org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201)
>  at 
> org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
>  at 
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
>  at 
> org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:202)
>  at 
> org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
>  at 
> org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541)
>  at 
> org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
>  at 
> org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
>  at 
> org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
>  at 
> org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
>  at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:373)
>  at 
> org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
>  at 
> org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868)
>  at 
> org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1590)
>  at 
> org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
>  at 
> java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
>  at 
> java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
>  at 
> org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
>  at java.lang.Thread.run(Thread.java:748)
> Caused by: org.apache.olingo.odata2.core.ep.EntityProviderProducerException: 
> Missing message for key 
> 'org.apache.olingo.odata2.api.edm.EdmSimpleTypeException.PR
> OPERTY_VALUE_FACETS_NOT_MATCHED'!
>  at 
> org.apache.olingo.odata2.core.ep.producer.XmlPropertyEntityProducer.appendProperty(XmlPropertyEntityProducer.java:223)
>  at 
> org.apache.olingo.odata2.core.ep.producer.XmlPropertyEntityProducer.append(XmlPropertyEntityProducer.java:79)
>  at 
> org.apache.olingo.odata2.core.ep.producer.AtomEntryEntityProducer.appendPropertyNameValue(AtomEntryEntityProducer.java:659)
>  at 
> org.apache.olingo.odata2.core.ep.producer.AtomEntryEntityProducer.appendProperties(AtomEntryEntityProducer.java:636)
>  at 
> org.apache.olingo.odata2.core.ep.producer.AtomEntryEntityProducer.append(AtomEntryEntityProducer.java:135)
>  at 
> org.apache.olingo.odata2.core.ep.producer.AtomFeedProducer.appendEntries(AtomFeedProducer.java:144)
>  at 
> org.apache.olingo.odata2.core.ep.producer.AtomFeedProducer.append(AtomFeedProducer.java:80)
>  at 
> org.apache.olingo.odata2.core.ep.AtomEntityProvider.writeFeed(AtomEntityProvider.java:233)
>  at 
> org.apache.olingo.odata2.core.ep.ProviderFacadeImpl.writeFeed(ProviderFacadeImpl.java:123)
>  at 
> org.apache.olingo.odata2.api.ep.EntityProvider.writeFeed(EntityProvider.java:588)
>  at 
> org.apache.olingo.odata2.jpa.processor.core.ODataJPAResponseBuilderDefault.build(ODataJPAResponseBuilderDefault.java:121)
>  ... 102 more
> Caused by: org.apache.olingo.odata2.api.edm.EdmSimpleTypeException: The 
> metadata constraints '[Nullable=true, MaxLength=255]' do not allow to format 
> the value '
>  ....CC'.
>  at 
> org.apache.olingo.odata2.core.edm.EdmString.internalValueToString(EdmString.java:80)
>  at 
> org.apache.olingo.odata2.core.edm.AbstractSimpleType.valueToString(AbstractSimpleType.java:112)
>  at 
> org.apache.olingo.odata2.core.ep.producer.XmlPropertyEntityProducer.appendProperty(XmlPropertyEntityProducer.java:220)
>  ... 112 more
> {quote}
>  



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

Reply via email to