From 7a17001aeb4347eac7305aee165d0d3e6b846949 Mon Sep 17 00:00:00 2001 From: samuelmale Date: Wed, 20 Mar 2024 01:57:49 +0300 Subject: [PATCH] Error handling --- .../api/event/PatientCreateUpdateListener.java | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/api/src/main/java/org/openmrs/module/clientregistry/api/event/PatientCreateUpdateListener.java b/api/src/main/java/org/openmrs/module/clientregistry/api/event/PatientCreateUpdateListener.java index 27973fd..bab5bce 100644 --- a/api/src/main/java/org/openmrs/module/clientregistry/api/event/PatientCreateUpdateListener.java +++ b/api/src/main/java/org/openmrs/module/clientregistry/api/event/PatientCreateUpdateListener.java @@ -5,6 +5,7 @@ import javax.jms.Message; import ca.uhn.fhir.rest.client.api.IGenericClient; +import ca.uhn.fhir.rest.client.exceptions.FhirClientConnectionException; import org.apache.commons.lang3.StringUtils; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; @@ -20,6 +21,7 @@ import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Component; +import ca.uhn.fhir.parser.DataFormatException; @Component public class PatientCreateUpdateListener implements EventListener { @@ -98,7 +100,18 @@ private void processMessage(Message message) throws JMSException { if (mapMessage.getJMSDestination().toString().equals(ClientRegistryConstants.UPDATE_MESSAGE_DESTINATION)) { client.update().resource(patient).execute(); } else { - client.create().resource(patient).execute(); + try { + client.create().resource(patient).execute(); + } + catch (FhirClientConnectionException e) { + Throwable cause = e.getCause(); + if (cause instanceof DataFormatException) { + // just warn if the CR responds with unsupported data format + log.warn(e.getMessage()); + } else { + throw e; + } + } } } }