Firebase с ProGuard - PullRequest
       7

Firebase с ProGuard

0 голосов
/ 08 сентября 2018

Я делаю приложение с FireBase, которое работает отлично. Пока я не включу ProGuard или даже R8.

Я в основном пробовал каждую комбинацию правил ProGuard, которую нашел в интернете, я даже пытался

-keep class com.firebase.** {*;}
-keep class mypackage.** {*;}

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

-keepattributes *Annotation*
-keepattributes SourceFile,LineNumberTable
-keep public class * extends java.lang.Exception

-keepattributes Signature
-keepclassmembers class com.tritrio.anabi2y.model.** {*;}

-keep public class * implements com.bumptech.glide.module.GlideModule
-keep public class * extends com.bumptech.glide.module.AppGlideModule
-keep public enum com.bumptech.glide.load.ImageHeaderParser$** {
  **[] $VALUES;
  public *;
}

-dontwarn com.firebase.ui.auth.**

Вот StackTrace:

2018-09-08 21:00:03.471 9889-9963/com.tritrio.anabi2y E/io.grpc.a.J: Creating atomic field updaters failed
java.lang.RuntimeException: java.security.PrivilegedActionException: java.lang.NoSuchFieldException: No field streamClosed in class Lio/grpc/a/J$c; (declaration of 'io.grpc.a.J$c' appears in /data/app/com.tritrio.anabi2y-1/base.apk:classes2.dex)
    at java.util.concurrent.atomic.AtomicIntegerFieldUpdater$AtomicIntegerFieldUpdaterImpl.<init>(AtomicIntegerFieldUpdater.java:380)
    at java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater(AtomicIntegerFieldUpdater.java:58)
    at io.grpc.a.J.<clinit>(CensusTracingModule.java:77)
    at io.grpc.a.c.c(AbstractManagedChannelImplBuilder.java:420)
    at io.grpc.a.c.a(AbstractManagedChannelImplBuilder.java:395)
    at com.google.firebase.firestore.f.e.<init>(com.google.firebase:firebase-firestore@@17.0.5:102)
    at com.google.firebase.firestore.b.w.a(com.google.firebase:firebase-firestore@@17.0.5:1217)
    at com.google.firebase.firestore.b.y.run(com.google.firebase:firebase-firestore@@17.0.5)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:428)
    at java.util.concurrent.FutureTask.run(FutureTask.java:237)
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:272)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
    at com.google.firebase.firestore.g.c$a.run(com.google.firebase:firebase-firestore@@17.0.5:190)
    at java.lang.Thread.run(Thread.java:760)
 Caused by: java.security.PrivilegedActionException: java.lang.NoSuchFieldException: No field streamClosed in class Lio/grpc/a/J$c; (declaration of 'io.grpc.a.J$c' appears in /data/app/com.tritrio.anabi2y-1/base.apk:classes2.dex)
    at java.security.AccessController.doPrivileged(AccessController.java:71)
    at java.util.concurrent.atomic.AtomicIntegerFieldUpdater$AtomicIntegerFieldUpdaterImpl.<init>(AtomicIntegerFieldUpdater.java:358)
    at java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater(AtomicIntegerFieldUpdater.java:58) 
    at io.grpc.a.J.<clinit>(CensusTracingModule.java:77) 
    at io.grpc.a.c.c(AbstractManagedChannelImplBuilder.java:420) 
    at io.grpc.a.c.a(AbstractManagedChannelImplBuilder.java:395) 
    at com.google.firebase.firestore.f.e.<init>(com.google.firebase:firebase-firestore@@17.0.5:102) 
    at com.google.firebase.firestore.b.w.a(com.google.firebase:firebase-firestore@@17.0.5:1217) 
    at com.google.firebase.firestore.b.y.run(com.google.firebase:firebase-firestore@@17.0.5) 
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:428) 
    at java.util.concurrent.FutureTask.run(FutureTask.java:237) 
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:272) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607) 
    at com.google.firebase.firestore.g.c$a.run(com.google.firebase:firebase-firestore@@17.0.5:190) 
    at java.lang.Thread.run(Thread.java:760) 
 Caused by: java.lang.NoSuchFieldException: No field streamClosed in class Lio/grpc/a/J$c; (declaration of 'io.grpc.a.J$c' appears in /data/app/com.tritrio.anabi2y-1/base.apk:classes2.dex)
    at java.lang.Class.getDeclaredField(Native Method)
    at java.util.concurrent.atomic.AtomicIntegerFieldUpdater$AtomicIntegerFieldUpdaterImpl$1.run(AtomicIntegerFieldUpdater.java:361)
    at java.util.concurrent.atomic.AtomicIntegerFieldUpdater$AtomicIntegerFieldUpdaterImpl$1.run(AtomicIntegerFieldUpdater.java:360)
    at java.security.AccessController.doPrivileged(AccessController.java:67)
    at java.util.concurrent.atomic.AtomicIntegerFieldUpdater$AtomicIntegerFieldUpdaterImpl.<init>(AtomicIntegerFieldUpdater.java:358) 
    at java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater(AtomicIntegerFieldUpdater.java:58) 
    at io.grpc.a.J.<clinit>(CensusTracingModule.java:77) 
    at io.grpc.a.c.c(AbstractManagedChannelImplBuilder.java:420) 
    at io.grpc.a.c.a(AbstractManagedChannelImplBuilder.java:395) 
    at com.google.firebase.firestore.f.e.<init>(com.google.firebase:firebase-firestore@@17.0.5:102) 
    at com.google.firebase.firestore.b.w.a(com.google.firebase:firebase-firestore@@17.0.5:1217) 
    at com.google.firebase.firestore.b.y.run(com.google.firebase:firebase-firestore@@17.0.5) 
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:428) 
    at java.util.concurrent.FutureTask.run(FutureTask.java:237) 
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:272) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607) 
    at com.google.firebase.firestore.g.c$a.run(com.google.firebase:firebase-firestore@@17.0.5:190) 
    at java.lang.Thread.run(Thread.java:760) 
2018-09-08 21:00:03.743 9889-9922/com.tritrio.anabi2y E/Fabric: Failed to retrieve settings from https://settings.crashlytics.com/spi/v2/platforms/android/apps/com.tritrio.anabi2y/settings
2018-09-08 21:00:03.745 9889-9930/com.tritrio.anabi2y E/Answers: Failed to retrieve settings
2018-09-08 21:00:03.766 9889-9889/com.tritrio.anabi2y E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.tritrio.anabi2y, PID: 9889
java.lang.RuntimeException: Internal error in Firestore (0.6.6-dev).
    at com.google.firebase.firestore.g.c.a(com.google.firebase:firebase-firestore@@17.0.5:324)
    at com.google.firebase.firestore.g.f.run(com.google.firebase:firebase-firestore@@17.0.5)
    at android.os.Handler.handleCallback(Handler.java:754)
    at android.os.Handler.dispatchMessage(Handler.java:95)
    at android.os.Looper.loop(Looper.java:165)
    at android.app.ActivityThread.main(ActivityThread.java:6375)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:883)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773)
 Caused by: java.lang.AbstractMethodError: abstract method "com.google.protobuf.y$d com.google.protobuf.y$d.a(int)"
    at com.google.protobuf.t.a(GeneratedMessageLite.java:1319)
    at b.a.c.a.F$b.a(com.google.firebase:firebase-firestore@@17.0.5:2145)
    at b.a.c.a.F$b$a.a(com.google.firebase:firebase-firestore@@17.0.5:428)
    at com.google.firebase.firestore.f.p.a(com.google.firebase:firebase-firestore@@17.0.5:665)
    at com.google.firebase.firestore.c.N.a(com.google.firebase:firebase-firestore@@17.0.5:150)
    at com.google.firebase.firestore.c.w.b(com.google.firebase:firebase-firestore@@17.0.5:82)
    at com.google.firebase.firestore.c.O.a(com.google.firebase:firebase-firestore@@17.0.5:479)
    at com.google.firebase.firestore.c.V.run(com.google.firebase:firebase-firestore@@17.0.5)
    at com.google.firebase.firestore.c.u.a(com.google.firebase:firebase-firestore@@17.0.5:117)
    at com.google.firebase.firestore.c.O.a(com.google.firebase:firebase-firestore@@17.0.5:474)
    at com.google.firebase.firestore.b.f.a(com.google.firebase:firebase-firestore@@17.0.5:165)
    at com.google.firebase.firestore.b.t.a(com.google.firebase:firebase-firestore@@17.0.5:79)
    at com.google.firebase.firestore.b.w.c(com.google.firebase:firebase-firestore@@17.0.5:132)
    at com.google.firebase.firestore.b.C.run(com.google.firebase:firebase-firestore@@17.0.5)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:428)
    at java.util.concurrent.FutureTask.run(FutureTask.java:237)
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:272)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
    at com.google.firebase.firestore.g.c$a.run(com.google.firebase:firebase-firestore@@17.0.5:190)
    at java.lang.Thread.run(Thread.java:760)

Вот build.gradle моего проекта:

buildscript {
    ext.kotlin_version = '1.2.61'
    repositories {
        google()
        jcenter()
        maven { url 'https://maven.fabric.io/public' }
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.3.0-alpha08'
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
        classpath 'com.google.gms:google-services:4.0.1'
        classpath 'io.fabric.tools:gradle:1.25.4'
    }
}

allprojects {
    repositories {
        google()
        jcenter()
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

А вот мой build.gradle моих модулей:

apply plugin: 'com.android.application'

apply plugin: 'kotlin-android'

apply plugin: 'kotlin-android-extensions'

apply plugin: 'kotlin-kapt'

apply plugin: 'io.fabric'

android {
    compileSdkVersion 28
    defaultConfig {
        applicationId "com.tritrio.anabi2y"
        minSdkVersion 16
        targetSdkVersion 28
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
//        multiDexEnabled true
        resConfigs "en", "ar"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
        debug {
            minifyEnabled true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
    implementation "com.android.support:appcompat-v7:28.0.0-alpha3"
    implementation "com.android.support:support-v4:28.0.0-alpha3"
    implementation "com.android.support:recyclerview-v7:28.0.0-alpha3"
    implementation "com.android.support:cardview-v7:28.0.0-alpha3"
    implementation "com.android.support:design:28.0.0-alpha3"
    implementation "com.android.support:customtabs:28.0.0-alpha3"
    implementation "com.android.support.constraint:constraint-layout:1.1.3"
    implementation "com.google.firebase:firebase-core:16.0.3"
    implementation "com.google.firebase:firebase-auth:16.0.3"
    implementation "com.firebaseui:firebase-ui-auth:4.1.0"
//    implementation "com.facebook.android:facebook-login:4.35.0"
    implementation "com.google.android.gms:play-services-auth:16.0.0"
    implementation "com.google.firebase:firebase-firestore:17.1.0"
    implementation "com.firebaseui:firebase-ui-firestore:4.1.0"
    implementation "android.arch.paging:runtime:1.0.1"
    implementation "com.github.bumptech.glide:glide:4.8.0"
//    implementation 'com.android.support:multidex:1.0.3'
    implementation "com.google.firebase:firebase-storage:16.0.2"
    implementation "com.crashlytics.sdk.android:crashlytics:2.9.5"
    implementation "org.jsoup:jsoup:1.11.3"
    implementation 'com.google.android.gms:play-services-maps:15.0.1'
    implementation 'com.google.android.gms:play-services-places:15.0.1'
    implementation 'com.google.android.gms:play-services-location:15.0.1'
    implementation 'com.google.maps.android:android-maps-utils:0.5'
    kapt "android.arch.lifecycle:compiler:1.1.1"
    kapt "com.github.bumptech.glide:compiler:4.8.0"
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
}

apply plugin: 'com.google.gms.google-services'

Ответы [ 2 ]

0 голосов
/ 10 сентября 2018

Вы должны использовать официальные правила Примеры быстрого старта

Часто это правила для библиотек андроидов Firebase

-keepattributes EnclosingMethod
-keepattributes InnerClasses

-dontwarn org.xmlpull.v1.**
-dontnote org.xmlpull.v1.**
-keep class org.xmlpull.** { *; }
-keepclassmembers class org.xmlpull.** { *; }
0 голосов
/ 10 сентября 2018

R8 был виновником.

После его отключения все заработало как положено.

Я сообщил о проблеме google и firebase.

...