[
https://issues.apache.org/jira/browse/CAMEL-21363?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Claus Ibsen resolved CAMEL-21363.
---------------------------------
Resolution: Fixed
> camel-whatsapp - Serialization error in MessageResponse when the Message
> object returns "message_status" from the endpoint.
> ---------------------------------------------------------------------------------------------------------------------------
>
> Key: CAMEL-21363
> URL: https://issues.apache.org/jira/browse/CAMEL-21363
> Project: Camel
> Issue Type: Bug
> Reporter: Roberto Viani Junior
> Priority: Minor
> Fix For: 4.8.1, 4.9.0
>
>
> There was no registered Camel WhatsApp component in the list of components
> for this Jira, so I went ahead and created it in the {{camel-core}} module
>
> According to the [WhatsApp Cloud API
> documentation|https://developers.facebook.com/docs/whatsapp/cloud-api/reference/messages#resposta-bem-sucedida],
> the {{message_status}} field is expected in the successful response.
> However, the {{MessageResponse}} object fails to deserialize this field
> because it is not currently mapped in the {{Message}} class. This results in
> an {{{}UnrecognizedPropertyException{}}}. The {{Message}} class needs to be
> updated to include this field to ensure proper deserialization. This error
> occurs while sending a template message
>
> Error description:
>
> {code:java}
> Caused by: com.fasterxml.jackson.databind.exc.UnrecognizedPropertyException:
> Unrecognized field "message_status" (class
> org.apache.camel.component.whatsapp.model.Message), not marked as ignorable
> (one known property: "id"])
> at [Source: REDACTED (`StreamReadFeature.INCLUDE_SOURCE_IN_LOCATION`
> disabled); line: 12, column: 23] (through reference chain:
> org.apache.camel.component.whatsapp.model.MessageResponse["messages"]->java.util.ArrayList[0]->org.apache.camel.component.whatsapp.model.Message["message_status"])
> at
> com.fasterxml.jackson.databind.exc.UnrecognizedPropertyException.from(UnrecognizedPropertyException.java:61)
> at
> com.fasterxml.jackson.databind.DeserializationContext.handleUnknownProperty(DeserializationContext.java:1153)
> at
> com.fasterxml.jackson.databind.deser.std.StdDeserializer.handleUnknownProperty(StdDeserializer.java:2224)
> at
> com.fasterxml.jackson.databind.deser.BeanDeserializerBase.handleUnknownProperty(BeanDeserializerBase.java:1793)
> at
> com.fasterxml.jackson.databind.deser.BeanDeserializerBase.handleUnknownVanilla(BeanDeserializerBase.java:1771)
> at
> com.fasterxml.jackson.databind.deser.BeanDeserializer.vanillaDeserialize(BeanDeserializer.java:316)
> at
> com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:177)
> at
> com.fasterxml.jackson.databind.deser.std.CollectionDeserializer._deserializeFromArray(CollectionDeserializer.java:359)
> at
> com.fasterxml.jackson.databind.deser.std.CollectionDeserializer.deserialize(CollectionDeserializer.java:244)
> at
> com.fasterxml.jackson.databind.deser.std.CollectionDeserializer.deserialize(CollectionDeserializer.java:28)
> at
> com.fasterxml.jackson.databind.deser.impl.MethodProperty.deserializeAndSet(MethodProperty.java:129)
> at
> com.fasterxml.jackson.databind.deser.BeanDeserializer.vanillaDeserialize(BeanDeserializer.java:310)
> at
> com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:177)
> at
> com.fasterxml.jackson.databind.deser.DefaultDeserializationContext.readRootValue(DefaultDeserializationContext.java:342)
> at
> com.fasterxml.jackson.databind.ObjectMapper._readMapAndClose(ObjectMapper.java:4899)
> at
> com.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:3846)
> at
> com.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:3814)
> at
> org.apache.camel.component.whatsapp.service.WhatsAppServiceRestAPIAdapter$OutgoingMessageHandler.lambda$sendMessage$0(WhatsAppServiceRestAPIAdapter.java:206)
> at
> java.base/java.util.concurrent.CompletableFuture$UniAccept.tryFire(CompletableFuture.java:718)
> at
> java.base/java.util.concurrent.CompletableFuture.postComplete(CompletableFuture.java:510)
> at
> java.base/java.util.concurrent.CompletableFuture.postFire(CompletableFuture.java:614)
> at
> java.base/java.util.concurrent.CompletableFuture$UniWhenComplete.tryFire(CompletableFuture.java:844)
> at
> java.base/java.util.concurrent.CompletableFuture$Completion.exec(CompletableFuture.java:483)
> at
> java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:387)
> at
> java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1312)
> at
> java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1843)
> at
> java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1808)
> at
> java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:188)
> {code}
--
This message was sent by Atlassian Jira
(v8.20.10#820010)