2016-03-19 19:48:55 +03:00
|
|
|
package eu.kanade.tachiyomi
|
|
|
|
|
|
|
|
import android.app.Application
|
2016-10-15 12:12:16 +03:00
|
|
|
import android.content.Context
|
|
|
|
import android.support.multidex.MultiDex
|
2016-11-06 20:44:14 +03:00
|
|
|
import com.evernote.android.job.JobManager
|
|
|
|
import eu.kanade.tachiyomi.data.library.LibraryUpdateJob
|
|
|
|
import eu.kanade.tachiyomi.data.updater.UpdateCheckerJob
|
2016-03-19 19:48:55 +03:00
|
|
|
import org.acra.ACRA
|
|
|
|
import org.acra.annotation.ReportsCrashes
|
|
|
|
import timber.log.Timber
|
2016-06-14 16:13:48 +03:00
|
|
|
import uy.kohesive.injekt.Injekt
|
2016-06-15 18:58:28 +03:00
|
|
|
import uy.kohesive.injekt.api.InjektScope
|
|
|
|
import uy.kohesive.injekt.registry.default.DefaultRegistrar
|
2016-03-19 19:48:55 +03:00
|
|
|
|
|
|
|
@ReportsCrashes(
|
|
|
|
formUri = "http://tachiyomi.kanade.eu/crash_report",
|
|
|
|
reportType = org.acra.sender.HttpSender.Type.JSON,
|
|
|
|
httpMethod = org.acra.sender.HttpSender.Method.PUT,
|
|
|
|
buildConfigClass = BuildConfig::class,
|
|
|
|
excludeMatchingSharedPreferencesKeys = arrayOf(".*username.*", ".*password.*")
|
|
|
|
)
|
|
|
|
open class App : Application() {
|
|
|
|
|
|
|
|
override fun onCreate() {
|
|
|
|
super.onCreate()
|
2016-06-15 18:58:28 +03:00
|
|
|
Injekt = InjektScope(DefaultRegistrar())
|
2016-06-14 16:13:48 +03:00
|
|
|
Injekt.importModule(AppModule(this))
|
2016-06-15 18:58:28 +03:00
|
|
|
|
2016-03-19 19:48:55 +03:00
|
|
|
if (BuildConfig.DEBUG) Timber.plant(Timber.DebugTree())
|
|
|
|
|
|
|
|
setupAcra()
|
2016-11-06 20:44:14 +03:00
|
|
|
setupJobManager()
|
2016-03-19 19:48:55 +03:00
|
|
|
}
|
|
|
|
|
2016-10-15 12:12:16 +03:00
|
|
|
override fun attachBaseContext(base: Context) {
|
|
|
|
super.attachBaseContext(base)
|
|
|
|
if (BuildConfig.DEBUG) {
|
|
|
|
MultiDex.install(this)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-03-19 19:48:55 +03:00
|
|
|
protected open fun setupAcra() {
|
|
|
|
ACRA.init(this)
|
|
|
|
}
|
|
|
|
|
2016-11-06 20:44:14 +03:00
|
|
|
protected open fun setupJobManager() {
|
|
|
|
JobManager.create(this).addJobCreator { tag ->
|
|
|
|
when (tag) {
|
|
|
|
LibraryUpdateJob.TAG -> LibraryUpdateJob()
|
|
|
|
UpdateCheckerJob.TAG -> UpdateCheckerJob()
|
|
|
|
else -> null
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-03-19 19:48:55 +03:00
|
|
|
}
|