diff --git a/README.md b/README.md index 1f172aa9..f19f66c4 100644 --- a/README.md +++ b/README.md @@ -1,3 +1,6 @@ # java-sdk OpenTDF Java SDK + +### Logging +We use [slf4j](https://www.slf4j.org/), without providing a backend. We use log4j2 in our tests. diff --git a/pom.xml b/pom.xml index 9c380979..cec30b22 100644 --- a/pom.xml +++ b/pom.xml @@ -37,21 +37,13 @@ 5.10.1 pom import - - - org.apache.logging.log4j - log4j-api - ${log4j.version} org.apache.logging.log4j - log4j-core - ${log4j.version} - - - org.apache.logging.log4j - log4j-slf4j2-impl - ${log4j.version} + log4j-bom + 2.23.1 + pom + import org.projectlombok diff --git a/protocol/pom.xml b/protocol/pom.xml index ae7729d9..ec9118e6 100644 --- a/protocol/pom.xml +++ b/protocol/pom.xml @@ -57,8 +57,6 @@ - - diff --git a/sdk/pom.xml b/sdk/pom.xml index 31903888..ac179299 100644 --- a/sdk/pom.xml +++ b/sdk/pom.xml @@ -17,6 +17,26 @@ protocol 0.1.0-SNAPSHOT + + org.slf4j + slf4j-api + 2.0.13 + + + org.apache.logging.log4j + log4j-slf4j2-impl + test + + + org.apache.logging.log4j + log4j-core + test + + + org.apache.logging.log4j + log4j-api + test + org.junit.jupiter junit-jupiter diff --git a/sdk/src/main/java/io/opentdf/platform/sdk/GRPCAuthInterceptor.java b/sdk/src/main/java/io/opentdf/platform/sdk/GRPCAuthInterceptor.java index 24fc186e..bfb04d4c 100644 --- a/sdk/src/main/java/io/opentdf/platform/sdk/GRPCAuthInterceptor.java +++ b/sdk/src/main/java/io/opentdf/platform/sdk/GRPCAuthInterceptor.java @@ -15,7 +15,6 @@ import com.nimbusds.oauth2.sdk.http.HTTPRequest; import com.nimbusds.oauth2.sdk.http.HTTPResponse; import com.nimbusds.oauth2.sdk.token.AccessToken; -import com.nimbusds.oauth2.sdk.tokenexchange.TokenExchangeGrant; import io.grpc.CallOptions; import io.grpc.Channel; import io.grpc.ClientCall; @@ -23,6 +22,8 @@ import io.grpc.ForwardingClientCall; import io.grpc.Metadata; import io.grpc.MethodDescriptor; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import java.net.URI; import java.net.URISyntaxException; @@ -40,6 +41,9 @@ class GRPCAuthInterceptor implements ClientInterceptor { private final RSAKey rsaKey; private final URI tokenEndpointURI; + private static final Logger logger = LoggerFactory.getLogger(GRPCAuthInterceptor.class); + + /** * Constructs a new GRPCAuthInterceptor with the specified client authentication and RSA key. * @@ -101,6 +105,8 @@ private synchronized AccessToken getToken() { // If the token is expired or initially null, get a new token if (token == null || isTokenExpired()) { + logger.trace("The current access token is expired or empty, getting a new one"); + // Construct the client credentials grant AuthorizationGrant clientGrant = new ClientCredentialsGrant(); @@ -124,9 +130,17 @@ private synchronized AccessToken getToken() { throw new RuntimeException("Token request failed: " + error); } - this.token = tokenResponse.toSuccessResponse().getTokens().getAccessToken(); - // DPoPAccessToken dPoPAccessToken = tokens.getDPoPAccessToken(); + var tokens = tokenResponse.toSuccessResponse().getTokens(); + if (tokens.getDPoPAccessToken() != null) { + logger.trace("retrieved a new DPoP access token"); + } else if (tokens.getAccessToken() != null) { + logger.trace("retrieved a new access token"); + } else { + logger.trace("got an access token of unknown type"); + } + + this.token = tokens.getAccessToken(); if (token.getLifetime() != 0) { // Need some type of leeway but not sure whats best diff --git a/sdk/src/main/java/io/opentdf/platform/sdk/SDKBuilder.java b/sdk/src/main/java/io/opentdf/platform/sdk/SDKBuilder.java index 20f10dd4..5cf830b9 100644 --- a/sdk/src/main/java/io/opentdf/platform/sdk/SDKBuilder.java +++ b/sdk/src/main/java/io/opentdf/platform/sdk/SDKBuilder.java @@ -14,9 +14,12 @@ import io.grpc.ManagedChannel; import io.grpc.ManagedChannelBuilder; import io.grpc.Status; +import io.grpc.StatusRuntimeException; import io.opentdf.platform.wellknownconfiguration.GetWellKnownConfigurationRequest; import io.opentdf.platform.wellknownconfiguration.GetWellKnownConfigurationResponse; import io.opentdf.platform.wellknownconfiguration.WellKnownServiceGrpc; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import java.io.IOException; import java.util.UUID; @@ -65,7 +68,7 @@ ManagedChannel buildChannel() { var stub = WellKnownServiceGrpc.newBlockingStub(bootstrapChannel); try { config = stub.getWellKnownConfiguration(GetWellKnownConfigurationRequest.getDefaultInstance()); - } catch (Exception e) { + } catch (StatusRuntimeException e) { Status status = Status.fromThrowable(e); throw new SDKException(String.format("Got grpc status [%s] when getting configuration", status), e); } @@ -82,7 +85,7 @@ ManagedChannel buildChannel() { .getFieldsOrThrow(PLATFORM_ISSUER) .getStringValue(); - } catch (Exception e) { + } catch (StatusRuntimeException e) { throw new SDKException("Error getting the issuer from the platform", e); } diff --git a/sdk/src/test/resources/log4j2.xml b/sdk/src/test/resources/log4j2.xml new file mode 100644 index 00000000..fc4a9ca8 --- /dev/null +++ b/sdk/src/test/resources/log4j2.xml @@ -0,0 +1,13 @@ + + + + + + + + + + + + +