J'ai récemment fait face à un problème similaire et j'ai trouvé une solution pas très belle, mais fonctionnante. Vous pouvez utiliser une variable statique.
public class SessionData {
private static String sessionId;
public static String getSessionId() {
return sessionId;
}
public static void setSessionId(String sessionId) {
SessionData.sessionId = sessionId;
}
}
Ensuite, vous pouvez régler le IdToken, après que vous l'obtenez à partir du SDK Google (par exemple après que l'utilisateur connecté).
SessionData.setSessionId(yourCurrentToken);
Dans la classe où vous déclarez la Retrofit.Builder, vous devez utiliser les importations suivantes (comme vous le dites, l'intercepteur okhttp).
import com.squareup.okhttp.Interceptor;
import com.squareup.okhttp.OkHttpClient;
import com.squareup.okhttp.Request;
import com.squareup.okhttp.Response;
Et le contenu de la classe devrait ressembler à ceci.
public class RestClient implements Interceptor {
public RestClient() {
OkHttpClient httpClient = new OkHttpClient();
// add your other interceptors …
// add logging as last interceptor
httpClient.interceptors().add(this); // <-- this adds the header with the sessionId to every request
Retrofit restAdapter = new Retrofit.Builder()
.baseUrl(RestConstants.BASE_URL)
.addCallAdapterFactory(RxJavaCallAdapterFactory.create())
.addConverterFactory(GsonConverterFactory.create())
.client(httpClient)
.build();
}
@Override
public Response intercept(Chain chain) throws IOException {
Request originalRequest = chain.request();
if (SessionData.getSessionId() != null) {
Request newRequest = originalRequest.newBuilder()
.header("sessionId", SessionData.getSessionId())
.build();
return chain.proceed(newRequest);
}
return chain.proceed(originalRequest);
}
}