2018-07-18 14:13:57 -05:00
|
|
|
package io.github.wulkanowy
|
|
|
|
|
2018-08-22 15:31:17 -05:00
|
|
|
import android.content.Context
|
2019-06-06 15:32:43 -05:00
|
|
|
import android.util.Log.INFO
|
|
|
|
import android.util.Log.VERBOSE
|
2018-10-20 13:59:46 -05:00
|
|
|
import androidx.multidex.MultiDex
|
2019-03-09 03:13:36 -06:00
|
|
|
import androidx.work.Configuration
|
|
|
|
import androidx.work.WorkManager
|
2018-07-18 14:13:57 -05:00
|
|
|
import com.jakewharton.threetenabp.AndroidThreeTen
|
|
|
|
import dagger.android.AndroidInjector
|
|
|
|
import dagger.android.support.DaggerApplication
|
|
|
|
import eu.davidea.flexibleadapter.FlexibleAdapter
|
2018-10-03 14:28:23 -05:00
|
|
|
import eu.davidea.flexibleadapter.utils.Log
|
2018-07-18 14:13:57 -05:00
|
|
|
import io.github.wulkanowy.di.DaggerAppComponent
|
2019-03-09 03:13:36 -06:00
|
|
|
import io.github.wulkanowy.services.sync.SyncWorkerFactory
|
2019-04-26 16:53:02 -05:00
|
|
|
import io.github.wulkanowy.utils.ActivityLifecycleLogger
|
2019-06-06 15:32:43 -05:00
|
|
|
import io.github.wulkanowy.utils.AppInfo
|
2018-10-03 14:28:23 -05:00
|
|
|
import io.github.wulkanowy.utils.CrashlyticsTree
|
|
|
|
import io.github.wulkanowy.utils.DebugLogTree
|
2019-06-03 07:12:48 -05:00
|
|
|
import io.github.wulkanowy.utils.initCrashlytics
|
2019-03-26 08:32:23 -05:00
|
|
|
import io.reactivex.exceptions.UndeliverableException
|
|
|
|
import io.reactivex.plugins.RxJavaPlugins
|
2018-07-18 14:13:57 -05:00
|
|
|
import timber.log.Timber
|
2019-03-26 08:32:23 -05:00
|
|
|
import java.io.IOException
|
2018-11-10 16:24:33 -06:00
|
|
|
import javax.inject.Inject
|
2018-07-18 14:13:57 -05:00
|
|
|
|
|
|
|
class WulkanowyApp : DaggerApplication() {
|
|
|
|
|
2019-03-09 03:13:36 -06:00
|
|
|
@Inject
|
|
|
|
lateinit var workerFactory: SyncWorkerFactory
|
|
|
|
|
2019-06-06 15:32:43 -05:00
|
|
|
@Inject
|
|
|
|
lateinit var appInfo: AppInfo
|
|
|
|
|
2018-08-22 15:31:17 -05:00
|
|
|
override fun attachBaseContext(base: Context?) {
|
|
|
|
super.attachBaseContext(base)
|
|
|
|
MultiDex.install(this)
|
|
|
|
}
|
2018-07-18 14:13:57 -05:00
|
|
|
|
|
|
|
override fun onCreate() {
|
|
|
|
super.onCreate()
|
|
|
|
AndroidThreeTen.init(this)
|
2019-03-26 08:32:23 -05:00
|
|
|
RxJavaPlugins.setErrorHandler(::onError)
|
2019-04-19 16:52:34 -05:00
|
|
|
|
2019-06-06 15:32:43 -05:00
|
|
|
initWorkManager()
|
2019-04-19 16:52:34 -05:00
|
|
|
initLogging()
|
2019-06-06 15:32:43 -05:00
|
|
|
initCrashlytics(this, appInfo)
|
|
|
|
}
|
|
|
|
|
|
|
|
private fun initWorkManager() {
|
|
|
|
WorkManager.initialize(this,
|
|
|
|
Configuration.Builder()
|
|
|
|
.setWorkerFactory(workerFactory)
|
|
|
|
.setMinimumLoggingLevel(if (appInfo.isDebug) VERBOSE else INFO)
|
|
|
|
.build())
|
2018-07-18 14:13:57 -05:00
|
|
|
}
|
|
|
|
|
2019-04-19 16:52:34 -05:00
|
|
|
private fun initLogging() {
|
2019-06-06 15:32:43 -05:00
|
|
|
if (appInfo.isDebug) {
|
2019-04-19 16:52:34 -05:00
|
|
|
Timber.plant(DebugLogTree())
|
|
|
|
FlexibleAdapter.enableLogs(Log.Level.DEBUG)
|
|
|
|
} else {
|
|
|
|
Timber.plant(CrashlyticsTree())
|
|
|
|
}
|
2019-04-26 16:53:02 -05:00
|
|
|
registerActivityLifecycleCallbacks(ActivityLifecycleLogger())
|
2018-07-18 14:13:57 -05:00
|
|
|
}
|
|
|
|
|
2019-04-19 16:52:34 -05:00
|
|
|
private fun onError(error: Throwable) {
|
|
|
|
if (error is UndeliverableException && error.cause is IOException || error.cause is InterruptedException) {
|
|
|
|
Timber.e(error.cause, "An undeliverable error occurred")
|
|
|
|
} else throw error
|
2019-03-26 08:32:23 -05:00
|
|
|
}
|
|
|
|
|
2018-10-03 14:28:23 -05:00
|
|
|
override fun applicationInjector(): AndroidInjector<out DaggerApplication> {
|
2019-04-18 09:38:49 -05:00
|
|
|
return DaggerAppComponent.factory().create(this)
|
2018-10-03 14:28:23 -05:00
|
|
|
}
|
2018-07-18 14:13:57 -05:00
|
|
|
}
|