google-auth-library-java icon indicating copy to clipboard operation
google-auth-library-java copied to clipboard

Method implementation and logic isOnGAEStandard7() is incorrect for java21 jetty which does not define the old jetty logging class.

Open ludoch opened this issue 1 year ago • 3 comments
trafficstars

An Appengine customer recently filed this bug:

We recently upgraded to Java 21 and noticed a change in behavior when calling GoogleCredentials.getApplicationDefault()

Before Java 21, it was returning us a ComputeEngineCredentials, which was expected.But now it is returning us an AppEngineCredentials so we have to set a environment to revert to the old behavior.

We suspect maybe one of the conditions changed in isOnGaeStandard7() on Java 21 runtime.

See https://github.com/googleapis/google-auth-library-java/blob/3a546fb21a747a2d596b24a530391b7aedd1ebc7/oauth2_http/java/com/google/auth/oauth2/DefaultCredentialsProvider.java#L319

return GAE_RUNTIME_VERSION != null
&& (SPECIFICATION_VERSION.equals("1.7") || RUNTIME_JETTY_LOGGER == null);

While it might have been true for GAE Java7 (now completely removed), for the GAE runtimes java8,11 and 17, RUNTIME_JETTY_LOGGER was never null, and customers expect anyway ComputeEngineCredentials, not AppEngineCredentials by default!

But the new GAE environment supporting Java21 GAE, RUNTIME_JETTY_LOGGER is now null, as Jetty12 entirely rewrote their logging logic and doe not define this Jetty internal property.

Currently, App Engine Java21 code had to defined again this property to avoid app regression, but we need to fix this auth-library bug for newer releases so we can avoid doing this ugly workaround for GAE customers. Maybe remove entirely the special case for GAE to avoid regression for existing GAE customers.

ludoch avatar Mar 13 '24 17:03 ludoch

Google internal bug is b/328772995

Related temp PR https://github.com/GoogleCloudPlatform/appengine-java-standard/pull/100

ludoch avatar Mar 13 '24 17:03 ludoch

thanks for the detailed explnation, looking :)

TimurSadykov avatar Mar 21 '24 05:03 TimurSadykov