ошибка: невозможно получить доступ к InternalTokenProvider (Firebase / GooglePlayServices) - PullRequest
1 голос
/ 10 мая 2019

В моем приложении, где я использую FireBase, FireBase-UI, Google Maps, среди прочего, это работало отлично. Я хочу обновить до последней версии каждую библиотеку и установить Firebase Performance.

Ошибка Я получаю:

error: cannot access InternalTokenProvider
class file for com.google.firebase.internal.InternalTokenProvider not found

И когда я нажимаю на эту ошибку, она отправляет меня в Activity на эту строку:

auth = FirebaseAuth.getInstance();

Вот мой build.gradle:

apply plugin: 'com.android.application'
apply plugin: 'kotlin-android-extensions'
apply plugin: 'kotlin-android'
apply plugin: 'io.fabric'
apply plugin: 'com.google.firebase.firebase-perf'

android {
    signingConfigs {
        release {
            //signin things
        }
    }
    compileSdkVersion 28
    defaultConfig {

        applicationId "app.example.asd"
        minSdkVersion 21
        targetSdkVersion 28
        versionCode 22
        versionName "2"
        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
        multiDexEnabled true
        signingConfig signingConfigs.release
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
    productFlavors {
    }
}

dependencies {
    implementation fileTree(include: ['*.jar'], dir: 'libs')
    implementation 'androidx.appcompat:appcompat:1.0.0'
    implementation 'androidx.gridlayout:gridlayout:1.0.0'
    implementation 'com.google.android.material:material:1.0.0'

    implementation 'com.google.firebase:firebase-perf:17.0.0'

    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
    implementation 'com.facebook.android:facebook-android-sdk:4.42.0'
    implementation 'com.google.firebase:firebase-core:16.0.9'
    implementation 'com.google.firebase:firebase-messaging:18.0.0'
    implementation "com.google.firebase:firebase-auth:16.0.1"
    implementation 'com.firebaseui:firebase-ui:4.3.2'
    implementation 'com.facebook.android:facebook-login:4.42.0'
    implementation 'androidx.multidex:multidex:2.0.1'
    implementation 'com.google.android.gms:play-services-base:16.1.0'
    implementation 'com.google.android.gms:play-services-location:16.0.0'
    implementation 'com.google.android.gms:play-services-maps:16.1.0'
    implementation 'com.google.android.gms:play-services-auth:16.0.1'
    implementation 'com.google.android.gms:play-services-places:16.1.0'

    implementation 'com.google.firebase:firebase-inappmessaging-display:17.1.1'

    implementation 'com.facebook.android:facebook-share:4.42.0'

    implementation 'com.android.volley:volley:1.1.1'

    implementation 'com.crashlytics.sdk.android:crashlytics:2.10.0'

    annotationProcessor 'com.github.bumptech.glide:compiler:4.9.0'

    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'androidx.test:runner:1.1.1'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'

    //kt y rxjava
    implementation 'androidx.core:core-ktx:1.0.0'
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
    implementation 'com.tbruyelle.rxpermissions2:rxpermissions:0.9.5@aar'
    implementation 'io.reactivex.rxjava2:rxandroid:2.0.1'
    implementation 'io.reactivex.rxjava2:rxjava:2.1.0'
    //lib en kt
}

repositories {
    mavenCentral()
}
apply plugin: 'com.google.gms.google-services'

Может кто-нибудь определить, где проблема в моих зависимостях? Спасибо

UPDATE С помощью Питера я смог исправить ошибку, изменив режим с firebase-auth: 16.0.1 на firebase-auth: 17.0.0.

Теперь я получаю еще одну ошибку при установке и открытии приложения, вот оно:

java.lang.RuntimeException: Uncaught exception in Firebase Database runloop (3.0.0). Please report to firebase-database-client@google.com
        at com.google.firebase.database.android.AndroidPlatform$1$1.run(com.google.firebase:firebase-database@@16.0.5:98)
        at android.os.Handler.handleCallback(Handler.java:790)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:164)
        at android.app.ActivityThread.main(ActivityThread.java:7000)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:441)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1408)
     Caused by: java.lang.NoClassDefFoundError: Failed resolution of: Lcom/google/firebase/FirebaseApp$IdTokenListener;

Ошибка появляется в первый раз, когда я использую эту строку в своем приложении:

myRef = FirebaseDatabase.getInstance().getReference();

Ответы [ 2 ]

5 голосов
/ 17 мая 2019

Похоже, вы вытягиваете com.google.firebase:firebase-database:16.0.5 через зависимость от com.firebaseui:firebase-ui:4.3.2 (https://github.com/firebase/FirebaseUI-Android/releases/tag/4.3.2)

Попробуйте добавить это к вашему build.gradle:

implementation 'com.google.firebase:firebase-database:17.0.0'

Кроме того, обычно проверяйте, используете ли вы последние версии, которые можно найти по адресу https://firebase.google.com/docs/android/setup#available-libraries

ПРИМЕЧАНИЕ: Это основано на новой ошибке в вашем обновлении после перехода с firebase-auth: 16.0.1 на firebase-auth: 17.0.0

1 голос
/ 10 мая 2019

Изменить это:

implementation 'com.google.firebase:firebase-auth:16.0.1'

В это:

implementation 'com.google.firebase:firebase-auth:17.0.0' 
...