如何在不使用任务监听器的情况下获取Firebase验证令牌?

时间:2016-11-01 17:31:06

标签: java android firebase firebase-authentication

我正在使用Retrofit 2,在使用Firebase Auth之前我曾在SharedPreferencesHttpInterceptor

中存储我的令牌
@Named("rest_api")
@Singleton
@Provides
Interceptor provideRESTInterceptor(final UserManager userManager) {
    return new Interceptor() {
        @Override
        public Response intercept(final Chain chain) throws IOException {
            final Request original = chain.request();

            Request request = original.newBuilder()
                    .header("Accept", "application/json")
                    .header("Authorization", "XXXX " + sharedPreference.getToken())
                    .method(original.method(), original.body())
                    .build();

            Response response = chain.proceed(request);
            return response;
        }
    };
}

我怎样才能实现这样的目标 FirebaseUser.getToken(false/true)?我不知道如何等待侦听器回调,而不是使用firebase令牌处理请求。

我也在考虑在这里检查令牌有效性以及它是否即将到期getToken(true)

1 个答案:

答案 0 :(得分:9)

我不确定理解整个问题,但是等待侦听器回调(换句话说,从异步调用中创建同步方法)可以像这样实现:

private String getToken() {
    final StringBuilder token = new StringBuilder() ;
    final CountDownLatch countDownLatch = new CountDownLatch(1) ;
    FirebaseAuth.getInstance().getCurrentUser().getToken(true).addOnCompleteListener(new OnCompleteListener<GetTokenResult>() {
        @Override
        public void onComplete(@NonNull Task<GetTokenResult> task) {
            token.append(task.getResult().getToken());
            countDownLatch.countDown();
        }
    });
    try {
        countDownLatch.await(30L, TimeUnit.SECONDS);
        return token.toString() ;
    } catch (InterruptedException ie) {
        return null;            
    }
}

注意:

  • StringBuilder在这里仅用作String holder。
  • 防弹实现当然应该检查task.isSuccessful()
  • 超时(此处为30秒)应根据您的情况进行调整

希望这有帮助。