Merge remote-tracking branch 'origin/do-20241021-tx-auth' into do-20241021-tx-auth

This commit is contained in:
Grahame Grieve 2024-11-08 08:46:59 +10:30
commit d98e575795
8 changed files with 30 additions and 178 deletions

View File

@ -33,12 +33,10 @@ import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStreamWriter;
import java.io.UnsupportedEncodingException;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URI;
import java.net.URLConnection;
import java.nio.charset.StandardCharsets;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;
@ -47,7 +45,6 @@ import java.util.concurrent.TimeUnit;
import lombok.Getter;
import lombok.Setter;
import org.apache.commons.codec.binary.Base64;
import org.apache.commons.io.IOUtils;
import org.apache.commons.lang3.StringUtils;
@ -93,13 +90,7 @@ public class ClientUtils {
@Setter
private int timeout = 5000;
@Getter
@Setter
private String username;
@Getter
@Setter
private String password;
@Setter
@Getter
@ -213,18 +204,6 @@ public class ClientUtils {
return unmarshalReference(response, resourceFormat);
}
private Iterable<HTTPHeader> getAuthHeaders() {
if (password != null) {
try {
byte[] b = Base64.encodeBase64((username + ":" + password).getBytes("ASCII"));
String b64 = new String(b, StandardCharsets.US_ASCII);
return Arrays.asList(new HTTPHeader[]{new HTTPHeader("Authorization", "Basic " + b64)});
} catch (UnsupportedEncodingException e) {
}
}
return Collections.emptyList();
}
public Bundle postBatchRequest(URI resourceUri, byte[] payload, String resourceFormat, int timeoutLoading) {
if (FhirSettings.isProhibitNetworkAccess()) {
throw new FHIRException("Network Access is prohibited in this context");
@ -318,9 +297,6 @@ public class ClientUtils {
Iterable<HTTPHeader> resourceFormatHeaders = getResourceFormatHeaders(httpRequest, format);
resourceFormatHeaders.forEach(configuredHeaders::add);
Iterable<HTTPHeader> authHeaders = getAuthHeaders();
authHeaders.forEach(configuredHeaders::add);
if (headers != null) {
headers.forEach(configuredHeaders::add);
}

View File

@ -110,20 +110,6 @@ public class FHIRToolingClient extends FHIRBaseToolingClient {
initialize(baseServiceUrl);
}
public FHIRToolingClient(String baseServiceUrl, String userAgent, String username, String password)
throws URISyntaxException {
preferredResourceFormat = ResourceFormat.RESOURCE_XML;
utils = getClientUtils();
utils.setUserAgent(userAgent);
utils.setUsername(username);
utils.setPassword(password);
initialize(baseServiceUrl);
}
public void initialize(String baseServiceUrl) throws URISyntaxException {
base = baseServiceUrl;
resourceAddress = new ResourceAddress(baseServiceUrl);
@ -592,22 +578,6 @@ public class FHIRToolingClient extends FHIRBaseToolingClient {
utils.setTimeout(timeout);
}
public String getUsername() {
return utils.getUsername();
}
public void setUsername(String username) {
utils.setUsername(username);
}
public String getPassword() {
return utils.getPassword();
}
public void setPassword(String password) {
utils.setPassword(password);
}
public Parameters getTerminologyCapabilities() {
return (Parameters) utils
.issueGetResourceRequest(resourceAddress.resolveMetadataTxCaps(), withVer(getPreferredResourceFormat(), "1.0"), timeoutNormal)

View File

@ -6,6 +6,7 @@ import java.net.URISyntaxException;
import java.util.*;
import lombok.Getter;
import lombok.Setter;
import org.hl7.fhir.dstu3.model.Bundle;
import org.hl7.fhir.dstu3.model.CapabilityStatement;
import org.hl7.fhir.dstu3.model.CodeSystem;
@ -68,13 +69,16 @@ public class FHIRToolingClient extends FHIRBaseToolingClient {
private CapabilityStatement capabilities;
private Client client = new Client();
private List<HTTPHeader> headers = new ArrayList<>();
private String username;
private String password;
@Setter
@Getter
private String userAgent;
private EnumSet<FhirPublication> allowedVersions;
@Setter
@Getter
private String acceptLanguage;
@Setter
private String contentLanguage;
@Getter
private int useCount;
//Pass endpoint for client - URI
@ -534,21 +538,6 @@ public class FHIRToolingClient extends FHIRBaseToolingClient {
return result == null ? null : (ConceptMap) result.getPayload();
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public long getTimeout() {
return client.getTimeout();
@ -579,15 +568,9 @@ public class FHIRToolingClient extends FHIRBaseToolingClient {
headers.forEach(this.headers::add);
}
//FIXME should be in ManagedWebAccess?
private Iterable<HTTPHeader> generateHeaders(boolean hasBody) {
List<HTTPHeader> headers = new ArrayList<>();
// Add basic auth header if it exists
if (basicAuthHeaderExists()) {
headers.add(getAuthorizationHeader());
}
// Add any other headers
headers.addAll(this.headers);
List<HTTPHeader> headers = new ArrayList<>(this.headers);
if (!Utilities.noString(userAgent)) {
headers.add(new HTTPHeader("User-Agent",userAgent));
}
@ -603,40 +586,11 @@ public class FHIRToolingClient extends FHIRBaseToolingClient {
return headers;
}
public boolean basicAuthHeaderExists() {
return (username != null) && (password != null);
}
public HTTPHeader getAuthorizationHeader() {
String usernamePassword = username + ":" + password;
String base64usernamePassword = Base64.getEncoder().encodeToString(usernamePassword.getBytes());
return new HTTPHeader("Authorization", "Basic " + base64usernamePassword);
}
public String getUserAgent() {
return userAgent;
}
public void setUserAgent(String userAgent) {
this.userAgent = userAgent;
}
public String getServerVersion() {
checkCapabilities();
return capabilities == null ? null : capabilities.getSoftware().getVersion();
}
public void setAcceptLanguage(String lang) {
this.acceptLanguage = lang;
}
public void setContentLanguage(String lang) {
this.contentLanguage = lang;
}
public int getUseCount() {
return useCount;
}
private void recordUse() {
useCount++;
}

View File

@ -76,10 +76,7 @@ public class FHIRToolingClient extends FHIRBaseToolingClient {
@Setter
private Client client = new Client();
private List<HTTPHeader> headers = new ArrayList<>();
@Getter @Setter
private String username;
@Getter @Setter
private String password;
@Getter @Setter
private String userAgent;
@Setter
@ -544,13 +541,8 @@ public class FHIRToolingClient extends FHIRBaseToolingClient {
//FIXME should be in ManagedWebAccess?
private Iterable<HTTPHeader> generateHeaders(boolean hasBody) {
List<HTTPHeader> headers = new ArrayList<>();
// Add basic auth header if it exists
if (basicAuthHeaderExists()) {
headers.add(getAuthorizationHeader());
}
// Add any other headers
headers.addAll(this.headers);
List<HTTPHeader> headers = new ArrayList<>(this.headers);
if (!Utilities.noString(userAgent)) {
headers.add(new HTTPHeader("User-Agent",userAgent));
}
@ -563,21 +555,9 @@ public class FHIRToolingClient extends FHIRBaseToolingClient {
headers.add(new HTTPHeader("Content-Language",contentLanguage));
}
headers.add(new HTTPHeader("Host", "cts.nlm.nih.gov"));
return headers;
}
public boolean basicAuthHeaderExists() {
return (username != null) && (password != null);
}
public HTTPHeader getAuthorizationHeader() {
String usernamePassword = username + ":" + password;
String base64usernamePassword = Base64.getEncoder().encodeToString(usernamePassword.getBytes());
return new HTTPHeader("Authorization", "Basic " + base64usernamePassword);
}
public String getServerVersion() {
checkCapabilities();
return capabilities == null ? null : capabilities.getSoftware().getVersion();

View File

@ -38,7 +38,6 @@ import org.hl7.fhir.r4b.model.*;
import org.hl7.fhir.r4b.model.Parameters.ParametersParameterComponent;
import org.hl7.fhir.r4b.utils.client.network.ByteUtils;
import org.hl7.fhir.r4b.utils.client.network.Client;
import org.hl7.fhir.r4b.utils.client.network.ClientHeaders;
import org.hl7.fhir.r4b.utils.client.network.ResourceRequest;
import org.hl7.fhir.utilities.FHIRBaseToolingClient;
import org.hl7.fhir.utilities.ToolingClientLogger;
@ -46,7 +45,6 @@ import org.hl7.fhir.utilities.Utilities;
import org.hl7.fhir.utilities.http.HTTPHeader;
import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URI;
import java.net.URISyntaxException;
import java.util.*;
@ -96,13 +94,6 @@ public class FHIRToolingClient extends FHIRBaseToolingClient{
@Setter
private Client client = new Client();
private List<HTTPHeader> headers = new ArrayList<>();
@Getter
@Setter
private String username;
@Getter
@Setter
private String password;
@Setter
@Getter
@ -537,13 +528,8 @@ public class FHIRToolingClient extends FHIRBaseToolingClient{
}
private Iterable<HTTPHeader> generateHeaders(boolean hasBody) {
List<HTTPHeader> headers = new ArrayList<>();
// Add basic auth header if it exists
if (basicAuthHeaderExists()) {
headers.add(getAuthorizationHeader());
}
// Add any other headers
headers.addAll(this.headers);
List<HTTPHeader> headers = new ArrayList<>(this.headers);
if (!Utilities.noString(userAgent)) {
headers.add(new HTTPHeader("User-Agent",userAgent));
}
@ -559,16 +545,6 @@ public class FHIRToolingClient extends FHIRBaseToolingClient{
return headers;
}
public boolean basicAuthHeaderExists() {
return (username != null) && (password != null);
}
public HTTPHeader getAuthorizationHeader() {
String usernamePassword = username + ":" + password;
String base64usernamePassword = Base64.getEncoder().encodeToString(usernamePassword.getBytes());
return new HTTPHeader("Authorization", "Basic " + base64usernamePassword);
}
public String getServerVersion() {
return capabilities == null ? null : capabilities.getSoftware().getVersion();
}

View File

@ -100,12 +100,7 @@ public class FHIRToolingClient extends FHIRBaseToolingClient {
@Setter
private Client client = new Client();
private List<HTTPHeader> headers = new ArrayList<>();
@Getter
@Setter
private String username;
@Getter
@Setter
private String password;
@Setter
@Getter
private String userAgent;
@ -602,13 +597,8 @@ public class FHIRToolingClient extends FHIRBaseToolingClient {
//FIXME should be in ManagedWebAccess?
private Iterable<HTTPHeader> generateHeaders(boolean hasBody) {
List<HTTPHeader> headers = new ArrayList<>();
// Add basic auth header if it exists
if (basicAuthHeaderExists()) {
headers.add(getAuthorizationHeader());
}
// Add any other headers
headers.addAll(this.headers);
List<HTTPHeader> headers = new ArrayList<>(this.headers);
if (!Utilities.noString(userAgent)) {
headers.add(new HTTPHeader("User-Agent",userAgent));
}
@ -624,16 +614,6 @@ public class FHIRToolingClient extends FHIRBaseToolingClient {
return headers;
}
public boolean basicAuthHeaderExists() {
return (username != null) && (password != null);
}
public HTTPHeader getAuthorizationHeader() {
String usernamePassword = username + ":" + password;
String base64usernamePassword = Base64.getEncoder().encodeToString(usernamePassword.getBytes());
return new HTTPHeader("Authorization", "Basic " + base64usernamePassword);
}
public String getServerVersion() {
if (capabilities == null) {
try {

View File

@ -76,8 +76,6 @@ public class ManagedWebAccess {
@Getter
private static IFhirWebAccessor fhirWebAccessor;
@Getter
private static String userAgent;
private static List<ServerDetailsPOJO> serverAuthDetails;

View File

@ -51,4 +51,22 @@ public abstract class ManagedWebAccessBuilderBase<B extends ManagedWebAccessBuil
this.token = token;
return self();
}
public B withNoneAuth() {
this.authenticationMode = HTTPAuthenticationMode.NONE;
setAllAuthHeadersToNull();
return self();
}
public B withServerSpecificAuth() {
this.authenticationMode = null;
setAllAuthHeadersToNull();
return self();
}
private void setAllAuthHeadersToNull() {
this.token = null;
this.username = null;
this.password = null;
}
}