В настоящее время создается другой экземпляр OkHttpClient.Builder в методе provideRetrofitInstance, который вы уже предоставили в своем ApiModule. Будьте милы и используйте вместо этого аргумент httpClient.
ичок в Dagger и Retrofit. У меня возникла проблема, когда генерируется несколько экземпляров модифицированного пользовательского перехватчика, несмотря на объявленный синглтон в модуле кинжала. Мне нужен только один экземпляр.
Модуль кинжала
@Module
public class ApiModule
{
private Config config;
public ApiModule(Config config) {
this.config = config;
}
@Provides @Singleton
public OkHttpClient.Builder provideOkHttpClient()
{
return new OkHttpClient.Builder();
}
@Provides @Singleton
public AuthenticationRequestInterceptor provideRequestInterceptor()
{
return new AuthenticationRequestInterceptor();
}
@Provides @Singleton
public Retrofit provideRetrofitInstance()
{
HttpLoggingInterceptor logging = new HttpLoggingInterceptor();
// set your desired log level
logging.setLevel(HttpLoggingInterceptor.Level.BODY);
OkHttpClient.Builder httpClient = new OkHttpClient.Builder();
// add session headers interceptor
httpClient.addInterceptor(provideRequestInterceptor());
// add logging as last interceptor
httpClient.addInterceptor(logging);
return new Retrofit.Builder()
.baseUrl(getConfig().getBaseUrl())
.addConverterFactory(GsonConverterFactory.create())
.addCallAdapterFactory(RxJava2CallAdapterFactory.create())
.client(httpClient.build()) //for logging purpose remove later
.build();
}
}
Модифицированный перехватчик
public class AuthenticationRequestInterceptor implements Interceptor
{
private Map<String, String> defaultHeaders;
public AuthenticationRequestInterceptor()
{
this.defaultHeaders = new HashMap<>();
}
public void setDefaultHeaders(Map<String, String> headers)
{
this.defaultHeaders = headers;
}
@Override
public Response intercept(Chain chain) throws IOException
{
Request request = chain.request();
Request.Builder requestBuilder = request.newBuilder();
for (String key: this.defaultHeaders.keySet())
{
requestBuilder.addHeader(key, this.defaultHeaders.get(key));
}
return chain.proceed(requestBuilder.build());
}
}
соединитель
public class Connect
{
@Inject Retrofit retrofit;
@Inject Config config;
@Inject AuthenticationRequestInterceptor headerInterceptor;
public Connect(PercentApp application)
{
((PercentApp) application).getComponent().inject(this);
/ ** Здесь устанавливаются заголовки перехватчика, но это получает наборы в ином экземплярах, чем тот, который вызывается позже в postUser ** /
headerInterceptor.setDefaultHeaders(generateDefaultAuthHeaders());
}
public void postUser(Observer observer, User user)
{
if(retrofit != null)
{
ApiServices api = retrofit.create(ApiServices.class);
Observable<HashMap> observable = api.postUser("{post something}");
observable.
subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(observer);
}
}
}
И в моем приложении я создаю экземпляр Dagger следующим образом:
DaggerApplicationComponent.builder()
.applicationModule(new ApplicationModule(this))
.apiModule(new ApiModule(new Config(environment)))
.build();
И в моем MainActivity я создаю экземпляр Connect
Connect connect = new Connect((MyApp) getApplication());
User user = new User();
connect.postUser(new UserObserver(this), user);
Теперь проблема в том, что конструктор AuthenticationRequestInterceptor вызывается дважды, и я не понимаю, почему, и из-за этого устанавливаемые мной заголовки устанавливают другой экземпляр Interceptor. Пожалуйста помоги. Спасибо