influxdata / influxdb-client-java

InfluxDB 2 JVM Based Clients
https://influxdata.github.io/influxdb-client-java/
MIT License
430 stars 129 forks source link

Irritating warning `Already signed out` #645

Open exaSR opened 9 months ago

exaSR commented 9 months ago

Steps to reproduce: List the minimal actions needed to reproduce the behavior.

  1. Open and use multiple connections in a sequence, closing them after use
  2. Perform at least one operation on each connection

(see example code below)

Expected behavior: Each connection is independent, performs as expected and does not trigger any unexpected warnings

Actual behavior: Each connection is independent, performs as expected. However, querying the second connection results in a log-warning:

Nov 16, 2023 1:31:42 PM com.influxdb.client.internal.AuthenticateInterceptor intercept
WARNING: Authorization interception failed. Already signed out.

As far as my debugging attempts got me, the reason is that the same AuthenticateInterceptor object is reused for multiple connections, and its signout flag is set when the first connection is closed, but is never reset for the second connection...

Specifications:

Example Code: The actual code is connecting to different organizations and different users, so any recommendation to just reuse the client is not helpful.

public void produceWarning() {
    InfluxDBClientOptions options = new InfluxDBClientOptions.Builder()
            .url(influxUrl)
            .org(influxOrg)
            .authenticateToken(token)
            .build();

    InfluxDBClient client = InfluxDBClientFactory.create(options);
    client.getBucketsApi().findBuckets();
    client.close();

    InfluxDBClient client2 = InfluxDBClientFactory.create(options);
    // this one produces the warning
    client2.getBucketsApi().findBuckets();
    client2.close();
}
powersj commented 9 months ago

@bednar - looks like we are re-using the AuthenticateInterceptor causing problems with re-use. Can you confirm?

bednar commented 9 months ago

The issue is caused by reusing the OkHttpClient.Builder. The AuthenticateInterceptor is attached to the OkHttpClient.Builder, and when InfluxDBClientOptions is used for creating multiple client instances, they all end up using the same interceptor. We need to devise a method to ensure a unique OkHttpClient.Builder for each client instance in cases where the user has not specified their own.

ycherabai commented 5 months ago

any updates?

bednar commented 5 months ago

@ycherabai, unfortunately not. However, would you be interested in assisting with this? We welcome all PRs and would be glad to review your contribution.