From 06919f9a2087661b0f09a5ea36add09ab41d79d1 Mon Sep 17 00:00:00 2001 From: maclema Date: Tue, 16 May 2017 15:15:54 -0600 Subject: [PATCH] Update BaseClient.java Fix for null access on httpRequest in DataFormatException and IOException handlers. --- .../ca/uhn/fhir/rest/client/BaseClient.java | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/hapi-fhir-base/src/main/java/ca/uhn/fhir/rest/client/BaseClient.java b/hapi-fhir-base/src/main/java/ca/uhn/fhir/rest/client/BaseClient.java index a0b049b5e95..7ed8bc1df38 100644 --- a/hapi-fhir-base/src/main/java/ca/uhn/fhir/rest/client/BaseClient.java +++ b/hapi-fhir-base/src/main/java/ca/uhn/fhir/rest/client/BaseClient.java @@ -323,13 +323,24 @@ public abstract class BaseClient implements IRestfulClient { } } catch (DataFormatException e) { - //FIXME potential null access on httpResquest - String msg = getFhirContext().getLocalizer().getMessage(BaseClient.class, "failedToParseResponse", httpRequest.getHttpVerbName(), httpRequest.getUri(), e.toString()); + String msg; + if ( httpRequest != null ) { + msg = getFhirContext().getLocalizer().getMessage(BaseClient.class, "failedToParseResponse", httpRequest.getHttpVerbName(), httpRequest.getUri(), e.toString()); + } + else { + msg = getFhirContext().getLocalizer().getMessage(BaseClient.class, "failedToParseResponse", "UNKNOWN", "UNKNOWN", e.toString()); + } throw new FhirClientConnectionException(msg, e); } catch (IllegalStateException e) { throw new FhirClientConnectionException(e); } catch (IOException e) { - String msg = getFhirContext().getLocalizer().getMessage(BaseClient.class, "ioExceptionDuringOperation", httpRequest.getHttpVerbName(), httpRequest.getUri(), e.toString()); + String msg; + if ( httpRequest != null ) { + msg = getFhirContext().getLocalizer().getMessage(BaseClient.class, "failedToParseResponse", httpRequest.getHttpVerbName(), httpRequest.getUri(), e.toString()); + } + else { + msg = getFhirContext().getLocalizer().getMessage(BaseClient.class, "failedToParseResponse", "UNKNOWN", "UNKNOWN", e.toString()); + } throw new FhirClientConnectionException(msg, e); } catch (RuntimeException e) { throw e;