【发布时间】:2018-01-04 10:59:10
【问题描述】:
您好,我这里有一个情况,我有一个自定义 FirebaseAuthLiveData 类扩展 Livedata 并实现 OnCompleteListener。这个类基本上使用firebase完成所有与身份验证相关的工作。我正在关注应用程序的 mvvm 架构。所以我将观察活动中的实时数据。现在的问题是,当我尝试将 livedata 的值保存在oncomplete 中时,我遇到了Task Not Complete yet 异常,但是当我再次重新打开应用程序时,它已经登录了......我已经附上了课程,如果有人能指出什么我做错了
我使用的 firebase 版本是 11.8.0
class FirebaseAuthLiveData (private val firebaseAuth: FirebaseAuth) : LiveData<Resource<FirebaseUser>>(), OnCompleteListener<AuthResult>, OnFailureListener{
override fun onFailure(p0: Exception) {
value = Resource.error(p0.localizedMessage,null)
}
override fun onComplete(p0: Task<AuthResult>) {
Log.d("firebase auth", "is task successful : "+p0.isSuccessful);
if (p0.isSuccessful) {
value = Resource.success(p0.result.user)
}
}
//this is called from a viewmodel
fun signInAnonymously( ){
firebaseAuth.signInAnonymously()
.addOnFailureListener(this)
.addOnCompleteListener(this)
}
}
这是logcat
FATAL EXCEPTION: main
Process: com.creoit.android.withdrawalwarrior, PID: 10246
java.lang.IllegalStateException: Task is not yet complete
at com.google.android.gms.common.internal.zzbq.zza(Unknown Source)
at com.google.android.gms.tasks.zzn.zzbjk(Unknown Source)
at com.google.android.gms.tasks.zzn.getResult(Unknown Source)
at com.creoit.android.withdrawalwarrior.prior_info.PriorInfoContentActivity$signInAnonymouslyWithFirebase$1.onChanged(PriorInfoContentActivity.kt:124)
at com.creoit.android.withdrawalwarrior.prior_info.PriorInfoContentActivity$signInAnonymouslyWithFirebase$1.onChanged(PriorInfoContentActivity.kt:33)
at android.arch.lifecycle.LiveData.considerNotify(LiveData.java:131)
at android.arch.lifecycle.LiveData.dispatchingValue(LiveData.java:148)
at android.arch.lifecycle.LiveData.setValue(LiveData.java:294)
at com.creoit.android.withdrawalwarrior.firebase.livedata.FirebaseAuthLiveData.onComplete(FirebaseAuthLiveData.kt:28)
at com.google.android.gms.tasks.zzf.run(Unknown Source)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5451)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
【问题讨论】:
标签: android firebase firebase-authentication android-livedata