better handling of errors from server for batches

This commit is contained in:
Grahame Grieve 2023-09-21 12:37:52 +10:00
parent b7f3978889
commit b11489f6ad
1 changed files with 8 additions and 1 deletions

View File

@ -18,6 +18,7 @@ import org.hl7.fhir.r4.model.Resource;
import org.hl7.fhir.r4.utils.ResourceUtilities; import org.hl7.fhir.r4.utils.ResourceUtilities;
import org.hl7.fhir.r4.utils.client.EFhirClientException; import org.hl7.fhir.r4.utils.client.EFhirClientException;
import org.hl7.fhir.r4.utils.client.ResourceFormat; import org.hl7.fhir.r4.utils.client.ResourceFormat;
import org.hl7.fhir.utilities.TextFile;
import org.hl7.fhir.utilities.settings.FhirSettings; import org.hl7.fhir.utilities.settings.FhirSettings;
import okhttp3.Authenticator; import okhttp3.Authenticator;
@ -247,7 +248,7 @@ public class FhirRequestBuilder {
public Bundle executeAsBatch() throws IOException { public Bundle executeAsBatch() throws IOException {
formatHeaders(httpRequest, resourceFormat, null); formatHeaders(httpRequest, resourceFormat, null);
Response response = getHttpClient().newCall(httpRequest.build()).execute(); Response response = getHttpClient().newCall(httpRequest.build()).execute();
return unmarshalFeed(response, resourceFormat); return unmarshalFeed(response, resourceFormat);
} }
/** /**
@ -307,6 +308,12 @@ public class FhirRequestBuilder {
} }
} }
} }
if (!response.isSuccessful() && feed == null && error == null) {
String text = TextFile.bytesToString(body);
throw new EFhirClientException("Error from "+source+": " + text);
}
} catch (EFhirClientException e) {
throw e;
} catch (IOException ioe) { } catch (IOException ioe) {
throw new EFhirClientException("Error reading Http Response from "+source+":"+ioe.getMessage(), ioe); throw new EFhirClientException("Error reading Http Response from "+source+":"+ioe.getMessage(), ioe);
} catch (Exception e) { } catch (Exception e) {