вот при регистрации приходится добавлять AuthInterceptor для http клиента, соответственно логин и пароль. А я хотел заинжектить свой retrofitApi один раз из AppModule. Это можно как то красиво провернуть? Или прийдется каждый раз в репозиторий прокидвыать метод по созданию того или иного клиента (зарегистрированный/аноним)?
Что то пока на ум не приходит красивого решения, может кто сталкивался с подобным?
https://github.com/AndroidArchitecture/AndroidArchitectureBook/blob/master/cases/auth/Auth_article.md
Провайдите такой интерсептор, используете его при создании OkHttpClient: @Provides @Singleton @Named("authInterceptor") Interceptor provideAuthInterceptor(PrefsManager prefsManager) { return chain -> { Request request = chain.request(); Request.Builder newRequest = request.newBuilder(); List<String> customAnnotations = request.headers().values("@"); for (String annotation : customAnnotations) { if (annotation.equals(ANNOTATION_AUTHORIZED)) { newRequest.addHeader(HEADER_AUTH, prefsManager.getApiToken()); } } newRequest.removeHeader("@"); return chain.proceed(newRequest.build()); }; }В запросе, который необходимо выполнять авторизированным, добавляете Headers: @GET("api/v2/nodes/{nodeId}/values") @Headers("@: " + ANNOTATION_AUTHORIZED) Observable<Response<QrCodeResponse>> getAddress(@Path("nodeId") String nodeId);
Обсуждают сегодня